Fridolin Somers
d421cfaed5
On OPAC, a user can requested a discharge even if one is already pending. This generates several pending discharges in staff interface that can not be deleted. This is because request operation leads to page 'opac-discharge.pl?op=request' and user can refresh this page performing a new request. Perl code must check that operation is allowed. Patch reoganised the code so that the following FIXME is obsolete : 'FIXME looks like $available is not needed' Patch also replaces 'op' arg test to also check undef : input->param("op") // '' Test plan : 1) Set system preference 'useDischarge' to 'Allow' 2) Choose a patron without checkouts nor fines nor restrictions 3) Log at OPAC and go to patron page /cgi-bin/koha/opac-user.pl 4) Click on 'ask for a discharge' tab => You see /cgi-bin/koha/opac-discharge.pl with text 'What is a discharge? ...' 5) Click on 'Ask for a discharge' link => You see /cgi-bin/koha/opac-discharge.pl?op=request with text 'Your discharge request has been sent ...' 6) In a new browser tab/page, go to intranet on /cgi-bin/koha/members/discharges.pl => You see one discharge requets for the patron 7) Come back to OPAC and refresh page => You see /cgi-bin/koha/opac-discharge.pl with text 'Your discharge will be available on this page within a few days.' 8) Come back to intranet and refresh /cgi-bin/koha/opac-discharge.pl => There is still one requets for the patron 9) Come back to OPAC and enter URL /cgi-bin/koha/opac-discharge.pl?op=get => You see /cgi-bin/koha/opac-discharge.pl with text 'Your discharge will be available on this page within a few days.' 10) Come back to intranet and refresh /cgi-bin/koha/opac-discharge.pl => There is still one requets for the patron 11) Click on 'allow' on patron discharge request 12) Come back to OPAC and refresh /cgi-bin/koha/opac-discharge.pl => You see link 'Get your discharge' 13) enter URL /cgi-bin/koha/opac-discharge.pl?op=request => You see same page and no new discharge requets is created 14) Come back to intranet on patron details page 15) Remove the discharge restriction 16) Come back to OPAC and refresh /cgi-bin/koha/opac-discharge.pl => You see text 'What is a discharge?...' 17) enter URL /cgi-bin/koha/opac-discharge.pl?op=get => You see same page and no new discharge requets is created Signed-off-by: Charles Farmer <charles.farmer@inLibro.com> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
118 lines
3.2 KiB
Perl
Executable file
118 lines
3.2 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# This file is part of Koha.
|
|
#
|
|
# Copyright 2013 BibLibre
|
|
#
|
|
# 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>.
|
|
|
|
use Modern::Perl;
|
|
use Carp;
|
|
|
|
use C4::Auth qw(:DEFAULT get_session);
|
|
use CGI qw( -utf8 );
|
|
use C4::Context;
|
|
use C4::Output;
|
|
use C4::Log;
|
|
use C4::Debug;
|
|
use Koha::Patrons;
|
|
use Koha::Patron::Discharge;
|
|
use Koha::DateUtils;
|
|
|
|
my $input = new CGI;
|
|
|
|
unless ( C4::Context->preference('useDischarge') ) {
|
|
print $input->redirect("/cgi-bin/koha/errors/404.pl");
|
|
exit;
|
|
}
|
|
|
|
my $op = $input->param("op") // '';
|
|
|
|
# Getting the template and auth
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user({
|
|
template_name => "opac-discharge.tt",
|
|
query => $input,
|
|
type => "opac",
|
|
debug => 1,
|
|
});
|
|
|
|
my $can_be_discharged = Koha::Patron::Discharge::can_be_discharged({ borrowernumber => $loggedinuser });
|
|
if ($can_be_discharged == 0) {
|
|
$template->param( has_checkouts => 1 );
|
|
}
|
|
|
|
my $pending = Koha::Patron::Discharge::count({
|
|
borrowernumber => $loggedinuser,
|
|
pending => 1,
|
|
});
|
|
my $available = Koha::Patron::Discharge::is_discharged({borrowernumber => $loggedinuser});
|
|
|
|
if ( $op eq 'request' ) {
|
|
if ($pending || $available) {
|
|
# Request already done
|
|
print $input->redirect("/cgi-bin/koha/opac-discharge.pl");
|
|
exit;
|
|
}
|
|
my $success = Koha::Patron::Discharge::request({
|
|
borrowernumber => $loggedinuser,
|
|
});
|
|
if ($success) {
|
|
$template->param( success => 1 );
|
|
}
|
|
else {
|
|
$template->param( has_issues => 1 );
|
|
}
|
|
}
|
|
elsif ( $op eq 'get' ) {
|
|
unless ($available) {
|
|
# No valid discharge to get
|
|
print $input->redirect("/cgi-bin/koha/opac-discharge.pl");
|
|
exit;
|
|
}
|
|
eval {
|
|
|
|
# Getting member data
|
|
my $patron = Koha::Patrons->find( $loggedinuser );
|
|
my $pdf_path = Koha::Patron::Discharge::generate_as_pdf({
|
|
borrowernumber => $loggedinuser,
|
|
branchcode => $patron->branchcode,
|
|
});
|
|
|
|
binmode(STDOUT);
|
|
print $input->header(
|
|
-type => 'application/pdf',
|
|
-charset => 'utf-8',
|
|
-attachment => "discharge_$loggedinuser.pdf",
|
|
);
|
|
open my $fh, '<', $pdf_path;
|
|
my @lines = <$fh>;
|
|
close $fh;
|
|
print @lines;
|
|
exit;
|
|
};
|
|
if ( $@ ) {
|
|
carp $@;
|
|
$template->param( messages => [ {type => 'error', code => 'unable_to_generate_pdf'} ] );
|
|
}
|
|
}
|
|
else {
|
|
$template->param(
|
|
available => $available,
|
|
pending => $pending,
|
|
);
|
|
}
|
|
|
|
$template->param( dischargeview => 1 );
|
|
|
|
output_html_with_http_headers $input, $cookie, $template->output, undef, { force_no_caching => 1 };
|