Bug 36507: Allow non-superlibrarians to set desk and register
[koha.git] / circ / set-library.pl
1 #!/usr/bin/perl
2
3 # Copyright 2000-2002 Katipo Communications
4 #
5 # This file is part of Koha.
6 #
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.
11 #
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.
16 #
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>.
19
20 use Modern::Perl;
21 use CGI qw ( -utf8 );
22
23 use C4::Context;
24 use C4::Output qw( output_html_with_http_headers );
25 use C4::Auth qw( get_template_and_user get_session haspermission );
26 use Koha::BiblioFrameworks;
27 use Koha::Cash::Registers;
28 use Koha::Libraries;
29 use Koha::Desks;
30
31 my $query = CGI->new();
32
33 my ( $template, $borrowernumber, $cookie, $flags ) = get_template_and_user({
34     template_name   => "circ/set-library.tt",
35     query           => $query,
36     type            => "intranet",
37     flagsrequired   => { catalogue => 1, },
38 });
39
40 my $sessionID = $query->cookie("CGISESSID");
41 my $session = get_session($sessionID);
42
43 my $op                  = $query->param('op') || q{};
44 my $branch              = $query->param('branch');
45 my $desk_id             = $query->param('desk_id');
46 my $register_id         = $query->param('register_id');
47 my $userenv_branch      = C4::Context->userenv->{'branch'} || '';
48 my $userenv_desk        = C4::Context->userenv->{'desk_id'} || '';
49 my $userenv_register_id = C4::Context->userenv->{'register_id'} || '';
50 my @updated;
51
52 my $library = Koha::Libraries->find($branch);
53 # $session lines here are doing the updating
54 ## Please see file perltidy.ERR
55 if (
56        $op eq 'cud-set-library'
57     && $library
58     && (   C4::Auth::haspermission( C4::Context->userenv->{'id'}, { 'loggedinlibrary' => 1 } )
59         or C4::Context::IsSuperLibrarian() )
60     )
61 {
62     if ( !$userenv_branch or $userenv_branch ne $branch ) {
63         my $branchname = $library->branchname;
64         $session->param( 'branchname', $branchname );    # update sesssion in DB
65         $session->param( 'branch',     $branch );        # update sesssion in DB
66         push @updated, {
67             updated_branch => 1,
68             old_branch     => $userenv_branch,
69             new_branch     => $branch,
70         };
71     }    # else branch the same, no update
72 } elsif ( $op eq 'cud-set-library' && $library ) {
73     if ( $desk_id && ( !$userenv_desk or $userenv_desk ne $desk_id ) ) {
74         my $desk          = Koha::Desks->find( { desk_id => $desk_id } );
75         my $old_desk_name = '';
76         if ($userenv_desk) {
77             $old_desk_name = Koha::Desks->find( { desk_id => $userenv_desk } )->desk_name;
78         }
79         $template->param( LoginDeskname => $desk->desk_name );
80         $template->param( LoginDeskid   => $desk->desk_id );
81         $session->param( desk_name => $desk->desk_name );
82         $session->param( desk_id   => $desk->desk_id );
83         $session->flush();
84         push @updated, {
85             updated_desk => 1,
86             old_desk     => $old_desk_name,
87         };
88     }
89     if ( defined($register_id)
90         && ( $userenv_register_id ne $register_id ) )
91     {
92         my $old_register_name = C4::Context->userenv->{'register_name'} || '';
93         my $register          = Koha::Cash::Registers->find($register_id);
94         $session->param( 'register_id',   $register_id );
95         $session->param( 'register_name', $register ? $register->name : '' );
96         push @updated,
97             {
98             updated_register => 1,
99             old_register     => $old_register_name
100             };
101     }
102     $session->flush();
103 } else {
104     $branch  = $userenv_branch;    # fallback value
105     $desk_id = $userenv_desk;
106 }
107
108 $template->param(updated => \@updated) if (scalar @updated);
109
110 my @recycle_loop;
111 foreach my $param ($query->param()) {
112     $param or next;                   # disclude blanks
113     $param eq "branch"     and next;  # disclude branch
114     $param eq "desk_id"    and next;  # disclude desk_id
115     $param eq "register_id" and next;    # disclude register
116     $param eq "oldreferer" and next;  # disclude oldreferer
117     push @recycle_loop, {
118         param => $param,
119         value => scalar $query->param($param),
120       };
121 }
122
123 my $referer =  $query->param('oldreferer') || $ENV{HTTP_REFERER} || '';
124 $referer =~ /set-library\.pl/ and undef $referer;   # avoid sending them back to this same page.
125
126 if (scalar @updated and not scalar @recycle_loop) {
127     # we updated something, and there were no extra params to POST: quick redirect
128     print $query->redirect($referer || '/cgi-bin/koha/circ/circulation.pl');
129 }
130
131 $template->param(
132     referer     => $referer,
133     branch      => $branch,
134     desk_id     => $desk_id,
135     recycle_loop=> \@recycle_loop,
136 );
137
138 # Checking if there is a Fast Cataloging Framework
139 $template->param( fast_cataloging => 1 ) if Koha::BiblioFrameworks->find( 'FA' );
140
141 output_html_with_http_headers $query, $cookie, $template->output;