Bug 26922: Regression tests
[koha.git] / installer / onboarding.pl
blob6680cd94d90a3ae2781be78125e8834542c6edf6
1 #!/usr/bin/perl
3 # This file is part of Koha.
5 # Copyright (C) 2017 Catalyst IT
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 use Modern::Perl;
21 use C4::Context;
22 use C4::InstallAuth;
23 use CGI qw ( -utf8 );
24 use C4::Output;
25 use C4::Members qw(checkcardnumber);
26 use Koha::Patrons;
27 use Koha::Libraries;
28 use Koha::Database;
29 use Koha::DateUtils;
30 use Koha::Patrons;
31 use Koha::Patron::Categories;
32 use Koha::ItemTypes;
33 use Koha::CirculationRules;
35 #Setting variables
36 my $input = CGI->new;
38 unless ( C4::Context->preference('Version') ) {
39 print $input->redirect("/cgi-bin/koha/installer/install.pl");
40 exit;
43 my ( $user, $cookie, $sessionID, $flags ) =
44 C4::InstallAuth::checkauth( $input, 0, undef, 'intranet' );
45 die "Not logged in"
46 unless $user
47 ; # Should not happen, we should be redirect if the user is not logged in. But do not trust authentication...
49 my $step = $input->param('step') || 1;
50 my $op = $input->param('op') || '';
52 my $template_params = {};
53 $template_params->{op} = $op;
55 my $schema = Koha::Database->new()->schema();
57 my @messages;
59 if ( $step == 1 ) {
61 if ( $op eq 'add_validate_library' ) {
63 my $branchcode = $input->param('branchcode');
64 $branchcode = uc($branchcode);
66 $branchcode =~ s|\s||g
67 ; # Use a regular expression to check the value of the inputted branchcode
69 my $library = Koha::Library->new(
71 branchcode => $branchcode,
72 branchname => scalar $input->param('branchname'),
76 eval { $library->store; };
77 unless ($@) {
78 push @messages, { code => 'success_on_insert_library' };
80 else {
81 push @messages, { code => 'error_on_insert_library' };
85 $step++ if Koha::Libraries->count;
87 if ( $step == 2 ) {
88 if ( $op eq "add_validate_category" ) {
90 my $searchfield = $input->param('description') // q||;
91 my $categorycode = $input->param('categorycode');
92 my $category;
93 $template_params->{categorycode} = $categorycode;
95 $categorycode = $input->param('categorycode');
96 my $description = $input->param('description');
97 my $overduenoticerequired = $input->param('overduenoticerequired');
98 my $category_type = $input->param('category_type');
99 my $default_privacy = $input->param('default_privacy');
100 my $enrolmentperiod = $input->param('enrolmentperiod');
101 my $enrolmentperioddate = $input->param('enrolmentperioddate') || undef;
103 #Converts the string into a date format
104 if ($enrolmentperioddate) {
105 $enrolmentperioddate = output_pref(
107 dt => dt_from_string($enrolmentperioddate),
108 dateformat => 'DateTime',
109 dateonly => 1,
114 #Adds a new patron category to the database
115 $category = Koha::Patron::Category->new(
117 categorycode => $categorycode,
118 description => $description,
119 overduenoticerequired => $overduenoticerequired,
120 category_type => $category_type,
121 default_privacy => $default_privacy,
122 enrolmentperiod => $enrolmentperiod,
123 enrolmentperioddate => $enrolmentperioddate
127 eval { $category->store; };
129 unless ($@) {
130 push @messages, { code => 'success_on_insert_category' };
132 else {
133 push @messages, { code => 'error_on_insert_category' };
137 $step++ if Koha::Patron::Categories->count;
139 if ( $step == 3 ) {
140 if ( $op eq 'add_validate_patron' ) {
142 #Create a patron
143 my $firstpassword = $input->param('password') || '';
144 my $secondpassword = $input->param('password2') || '';
145 my $cardnumber = $input->param('cardnumber');
146 my $userid = $input->param('userid');
147 my $categorycode = $input->param('categorycode_entry');
148 my $patron_category =
149 Koha::Patron::Categories->find( $categorycode );
151 my ( $is_valid, $passworderror ) =
152 Koha::AuthUtils::is_password_valid( $firstpassword,
153 $patron_category );
156 if ( my $error_code = checkcardnumber($cardnumber) ) {
157 if ( $error_code == 1 ) {
158 push @messages, { code => 'ERROR_cardnumber_already_exists' };
160 elsif ( $error_code == 2 ) {
161 push @messages, { code => 'ERROR_cardnumber_length' };
164 elsif ( $firstpassword ne $secondpassword ) {
166 push @messages, { code => 'ERROR_password_mismatch' };
168 elsif ( $passworderror) {
169 push @messages, { code => 'ERROR_password_too_short'} if $passworderror eq 'too_short';
170 push @messages, { code => 'ERROR_password_too_weak'} if $passworderror eq 'too_weak';
171 push @messages, { code => 'ERROR_password_has_whitespaces'} if $passworderror eq 'has_whitespaces';
174 else {
175 my $patron_data = {
176 surname => scalar $input->param('surname'),
177 firstname => scalar $input->param('firstname'),
178 cardnumber => scalar $input->param('cardnumber'),
179 branchcode => scalar $input->param('libraries'),
180 categorycode => $categorycode,
181 userid => scalar $input->param('userid'),
182 privacy => "default",
183 address => "",
184 city => "",
185 flags => 1, # Will be superlibrarian
188 $patron_data->{dateexpiry} =
189 $patron_category->get_expiry_date( $patron_data->{dateenrolled} );
191 eval {
192 my $patron = Koha::Patron->new($patron_data)->store;
193 $patron->set_password({ password => $firstpassword });
196 #Error handling checking if the patron was created successfully
197 unless ($@) {
198 push @messages, { code => 'success_on_insert_patron' };
200 else {
201 warn $@;
202 push @messages, { code => 'error_on_insert_patron' };
207 $step++ if Koha::Patrons->search( { flags => 1 } )->count;
209 if ( $step == 4 ) {
210 if ( $op eq 'add_validate_itemtype' ) {
211 my $description = $input->param('description');
212 my $itemtype_code = $input->param('itemtype');
213 $itemtype_code = uc($itemtype_code);
215 my $itemtype = Koha::ItemType->new(
217 itemtype => $itemtype_code,
218 description => $description,
221 eval { $itemtype->store; };
223 unless ($@) {
224 push @messages, { code => 'success_on_insert_itemtype' };
226 else {
227 push @messages, { code => 'error_on_insert_itemtype' };
231 $step++ if Koha::ItemTypes->count;
233 if ( $step == 5 ) {
235 if ( $op eq 'add_validate_circ_rule' ) {
237 #If no libraries exist then set the $branch value to *
238 my $branch = $input->param('branch') || '*';
240 my $type = $input->param('type');
241 my $branchcode = $input->param('branch');
242 my $categorycode = $input->param('categorycode');
243 my $itemtype = $input->param('itemtype');
244 my $maxissueqty = $input->param('maxissueqty');
245 my $issuelength = $input->param('issuelength');
246 my $lengthunit = $input->param('lengthunit');
247 my $renewalsallowed = $input->param('renewalsallowed');
248 my $renewalperiod = $input->param('renewalperiod');
249 my $reservesallowed = $input->param('reservesallowed');
250 my $holds_per_day = $input->param('holds_per_day');
251 my $holds_per_record = $input->param('holds_per_record');
252 my $onshelfholds = $input->param('onshelfholds') || 0;
253 $maxissueqty =~ s/\s//g;
254 $maxissueqty = undef if $maxissueqty !~ /^\d+/;
255 $issuelength = $issuelength eq q{} ? undef : $issuelength;
257 my $params = {
258 branchcode => $branchcode,
259 categorycode => $categorycode,
260 itemtype => $itemtype,
261 rules => {
262 renewalsallowed => $renewalsallowed,
263 renewalperiod => $renewalperiod,
264 issuelength => $issuelength,
265 lengthunit => $lengthunit,
266 onshelfholds => $onshelfholds,
267 article_requests => "no",
268 auto_renew => 0,
269 cap_fine_to_replacement_price => 0,
270 chargeperiod => 0,
271 chargeperiod_charge_at => 0,
272 fine => 0,
273 finedays => 0,
274 firstremind => 0,
275 hardduedate => "",
276 hardduedatecompare => -1,
277 holds_per_day => $holds_per_day,
278 holds_per_record => $holds_per_record,
279 maxissueqty => $maxissueqty,
280 maxonsiteissueqty => "",
281 maxsuspensiondays => "",
282 no_auto_renewal_after => "",
283 no_auto_renewal_after_hard_limit => "",
284 norenewalbefore => "",
285 opacitemholds => "N",
286 overduefinescap => "",
287 rentaldiscount => 0,
288 reservesallowed => $reservesallowed,
289 suspension_chargeperiod => undef,
290 decreaseloanholds => undef,
294 eval {
295 Koha::CirculationRules->set_rules($params);
298 if ($@) {
299 warn $@;
300 push @messages, { code => 'error_on_insert_circ_rule' };
301 } else {
302 push @messages, { code => 'success_on_insert_circ_rule' };
306 $step++ if Koha::CirculationRules->count;
309 my $libraries = Koha::Libraries->search( {}, { order_by => ['branchcode'] }, );
310 $template_params->{libraries} = $libraries;
312 if ( $step > 5 ) {
313 $template_params->{all_done} = 1; # If step 5 is complete, we are done!
314 $step = 5;
317 #Getting the appropriate template to display to the user
318 my ( $template, $loggedinuser );
319 ( $template, $loggedinuser, $cookie ) = C4::InstallAuth::get_template_and_user(
321 template_name => "onboarding/onboardingstep${step}.tt",
322 query => $input,
323 type => "intranet",
324 debug => 1,
328 $template_params->{messages} = \@messages;
329 my $categories = Koha::Patron::Categories->search();
330 $template_params->{categories} = $categories;
332 my $itemtypes = Koha::ItemTypes->search();
333 $template_params->{itemtypes} = $itemtypes;
335 $template->param(%$template_params);
337 output_html_with_http_headers $input, $cookie, $template->output;