Jonathan Druart
62285d2de4
The idea of output_and_exit_if_error (added by bug 18403) is to make sure parameters are valid before executing the script. If not (old or broken URLs), we shortcut everything coming next to display a generic error ("object does not exist", "you do not have permission to do that", etc.) This bug report fixes the scripts under serials/*. Test plan: Hit the script under the serials directory with an invalid subscriptionid parameter and confirm you get an error instead of the normal view with empty values. The goal is not to be exhaustive during the first iteration, but at least to fix the most common views. For instance: /cgi-bin/koha/serials/subscription-detail.pl?subscriptionid=XXX /cgi-bin/koha/serials/serials-collection.pl?subscriptionid=XXX /cgi-bin/koha/serials/routing.pl?subscriptionid=XXX&op=new /cgi-bin/koha/serials/subscription-add.pl?op=modify&subscriptionid=XXx /cgi-bin/koha/serials/subscription-add.pl?op=dup&subscriptionid=XXX Signed-off-by: Séverine QUEUNE <severine.queune@bulac.fr> Signed-off-by: Séverine QUEUNE <severine.queune@bulac.fr> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
120 lines
3.7 KiB
Perl
Executable file
120 lines
3.7 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Copyright 2000-2002 Katipo Communications
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but
|
|
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with Koha; if not, see <http://www.gnu.org/licenses>.
|
|
|
|
|
|
=head1 NAME
|
|
|
|
subscription-renew.pl
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
this script renew an existing subscription.
|
|
|
|
=head1 Parameters
|
|
|
|
=over 4
|
|
|
|
=item op
|
|
op use to know the operation to do on this template.
|
|
* renew : to renew the subscription.
|
|
|
|
Note that if op = modsubscription there are a lot of other parameters.
|
|
|
|
=item subscriptionid
|
|
Id of the subscription this script has to renew
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
use Modern::Perl;
|
|
|
|
use CGI qw ( -utf8 );
|
|
use Carp;
|
|
use C4::Koha;
|
|
use C4::Auth;
|
|
use C4::Context;
|
|
use C4::Auth;
|
|
use C4::Output;
|
|
use C4::Serials;
|
|
use Koha::DateUtils;
|
|
|
|
my $query = new CGI;
|
|
my $dbh = C4::Context->dbh;
|
|
|
|
my $mode = $query->param('mode') || q{};
|
|
my $op = $query->param('op') || 'display';
|
|
my @subscriptionids = $query->multi_param('subscriptionid');
|
|
my $done = 0; # for after form has been submitted
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "serials/subscription-renew.tt",
|
|
query => $query,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { serials => 'renew_subscription' },
|
|
debug => 1,
|
|
}
|
|
);
|
|
if ( $op eq "renew" ) {
|
|
# Do not use this script with op=renew and @subscriptionids > 1!
|
|
my $subscriptionid = $subscriptionids[0];
|
|
# Make sure the subscription exists
|
|
my $subscription = GetSubscription( $subscriptionid );
|
|
output_and_exit( $query, $cookie, $template, 'unknown_subscription') unless $subscription;
|
|
my $startdate = output_pref( { str => scalar $query->param('startdate'), dateonly => 1, dateformat => 'iso' } );
|
|
ReNewSubscription(
|
|
$subscriptionid, $loggedinuser,
|
|
$startdate, scalar $query->param('numberlength'),
|
|
scalar $query->param('weeklength'), scalar $query->param('monthlength'),
|
|
scalar $query->param('note')
|
|
);
|
|
} elsif ( $op eq 'multi_renew' ) {
|
|
for my $subscriptionid ( @subscriptionids ) {
|
|
my $subscription = GetSubscription( $subscriptionid );
|
|
next unless $subscription;
|
|
ReNewSubscription(
|
|
$subscriptionid, $loggedinuser,
|
|
$subscription->{enddate}, $subscription->{numberlength},
|
|
$subscription->{weeklength}, $subscription->{monthlength},
|
|
);
|
|
}
|
|
} else {
|
|
my $subscriptionid = $subscriptionids[0];
|
|
my $subscription = GetSubscription($subscriptionid);
|
|
output_and_exit( $query, $cookie, $template, 'unknown_subscription') unless $subscription;
|
|
if ($subscription->{'cannotedit'}){
|
|
carp "Attempt to renew subscription $subscriptionid by ".C4::Context->userenv->{'id'}." not allowed";
|
|
print $query->redirect("/cgi-bin/koha/serials/subscription-detail.pl?subscriptionid=$subscriptionid");
|
|
}
|
|
|
|
my $newstartdate = output_pref( { str => $subscription->{enddate}, dateonly => 1 } )
|
|
or output_pref( { dt => dt_from_string, dateonly => 1 } );
|
|
|
|
$template->param(
|
|
startdate => $newstartdate,
|
|
subscription => $subscription,
|
|
);
|
|
}
|
|
|
|
$template->param(
|
|
op => $op,
|
|
);
|
|
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|