Frédéric Demians
ff1579de6d
Signed-off-by: Hector Castro <hector.hecaxmmx@gmail.com> Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org> All affected files tested with `perl -c`. Signed-off-by: Jesse Weaver <jweaver@bywatersolutions.com>
130 lines
3.6 KiB
Perl
Executable file
130 lines
3.6 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
#
|
|
# 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
|
|
|
|
checkexpiration.pl
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
This script check what subscription will expire before C<$datenumber $datelimit>
|
|
|
|
=head1 PARAMETERS
|
|
|
|
=over 4
|
|
|
|
=item title
|
|
To filter subscription on title
|
|
|
|
=item issn
|
|
To filter subscription on issn
|
|
|
|
=item date
|
|
The date to filter on.
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
use strict;
|
|
use warnings;
|
|
use CGI qw ( -utf8 );
|
|
use C4::Auth;
|
|
use C4::Serials; # GetExpirationDate
|
|
use C4::Branch;
|
|
use C4::Output;
|
|
use C4::Context;
|
|
use Koha::DateUtils;
|
|
|
|
use DateTime;
|
|
|
|
my $query = new CGI;
|
|
|
|
my ( $template, $loggedinuser, $cookie, $flags ) = get_template_and_user (
|
|
{
|
|
template_name => "serials/checkexpiration.tt",
|
|
query => $query,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { serials => 'check_expiration' },
|
|
debug => 1,
|
|
}
|
|
);
|
|
|
|
my $title = $query->param('title');
|
|
my $issn = $query->param('issn');
|
|
my $branch = $query->param('branch');
|
|
my $date = $query->param('date');
|
|
$date = eval { dt_from_string( $query->param('date') ) } if $date;
|
|
|
|
if ($date) {
|
|
my @subscriptions = SearchSubscriptions({ title => $title, issn => $issn, orderby => 'title' });
|
|
my @subscriptions_loop;
|
|
|
|
foreach my $subscription ( @subscriptions ) {
|
|
my $subscriptionid = $subscription->{'subscriptionid'};
|
|
my $expirationdate = GetExpirationDate($subscriptionid);
|
|
|
|
$subscription->{expirationdate} = $expirationdate;
|
|
|
|
next if $expirationdate !~ /\d{4}-\d{2}-\d{2}/; # next if not in ISO format.
|
|
|
|
next if $subscription->{closed};
|
|
if ( !C4::Context->preference("IndependentBranches")
|
|
or C4::Context->IsSuperLibrarian()
|
|
or ( ref $flags->{serials} and $flags->{serials}->{superserials} )
|
|
or ( !ref $flags->{serials} and $flags->{serials} == 1 ) )
|
|
{
|
|
$subscription->{cannotedit} = 0;
|
|
}
|
|
next if $subscription->{cannotedit};
|
|
|
|
my $expirationdate_dt = dt_from_string( $expirationdate, 'iso' );
|
|
if ( DateTime->compare( $date, $expirationdate_dt ) == 1
|
|
&& ( !$branch || ( $subscription->{'branchcode'} eq $branch ) ) ) {
|
|
push @subscriptions_loop, $subscription;
|
|
}
|
|
}
|
|
|
|
$template->param (
|
|
title => $title,
|
|
issn => $issn,
|
|
numsubscription => scalar @subscriptions_loop,
|
|
date => $date,
|
|
subscriptions_loop => \@subscriptions_loop,
|
|
"BiblioDefaultView".C4::Context->preference("BiblioDefaultView") => 1,
|
|
searched => 1,
|
|
);
|
|
}
|
|
|
|
my $branches_loop;
|
|
if ( !C4::Context->preference("IndependentBranches")
|
|
or C4::Context->IsSuperLibrarian()
|
|
or ( ref $flags->{serials} and $flags->{serials}->{superserials} )
|
|
or ( !ref $flags->{serials} and $flags->{serials} == 1 ) )
|
|
{
|
|
$branches_loop = C4::Branch::GetBranchesLoop( $branch );
|
|
}
|
|
|
|
$template->param (
|
|
(uc(C4::Context->preference("marcflavour"))) => 1,
|
|
branches_loop => $branches_loop,
|
|
);
|
|
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|