Main Koha release repository
https://koha-community.org
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
214 lines
6.0 KiB
214 lines
6.0 KiB
package Koha::Subscription;
|
|
|
|
# Copyright ByWater Solutions 2015
|
|
#
|
|
# 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, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
use Modern::Perl;
|
|
|
|
use Carp;
|
|
|
|
use Koha::Database;
|
|
use Koha::Biblios;
|
|
use Koha::Acquisition::Booksellers;
|
|
use Koha::Biblioitems;
|
|
use Koha::Subscriptions;
|
|
use Koha::Subscription::Frequencies;
|
|
use Koha::Subscription::Numberpatterns;
|
|
use JSON;
|
|
|
|
use base qw(Koha::Object Koha::Object::Mixin::AdditionalFields);
|
|
|
|
=head1 NAME
|
|
|
|
Koha::Subscription - Koha Subscription Object class
|
|
|
|
=head1 API
|
|
|
|
=head2 Class Methods
|
|
|
|
=cut
|
|
|
|
=head3 biblio
|
|
|
|
Returns the biblio linked to this subscription as a Koha::Biblio object
|
|
|
|
=cut
|
|
|
|
sub biblio {
|
|
my ($self) = @_;
|
|
|
|
return Koha::Biblios->find($self->biblionumber);
|
|
}
|
|
|
|
=head3 vendor
|
|
|
|
Returns the vendor/supplier linked to this subscription as a Koha::Acquisition::Bookseller object
|
|
|
|
=cut
|
|
|
|
sub vendor {
|
|
my ($self) = @_;
|
|
return Koha::Acquisition::Booksellers->find($self->aqbooksellerid);
|
|
}
|
|
|
|
=head3 subscribers
|
|
|
|
my $subscribers = $subscription->subscribers;
|
|
|
|
return a Koha::Patrons object
|
|
|
|
=cut
|
|
|
|
sub subscribers {
|
|
my ($self) = @_;
|
|
my $schema = Koha::Database->new->schema;
|
|
my @borrowernumbers = $schema->resultset('Alert')->search({ externalid => $self->subscriptionid })->get_column( 'borrowernumber' )->all;
|
|
return Koha::Patrons->search({ borrowernumber => {-in => \@borrowernumbers } });
|
|
}
|
|
|
|
=head3 add_subscriber
|
|
|
|
$subscription->add_subscriber( $patron );
|
|
|
|
Add a new subscriber (Koha::Patron) to this subscription
|
|
|
|
=cut
|
|
|
|
sub add_subscriber {
|
|
my ( $self, $patron ) = @_;
|
|
my $schema = Koha::Database->new->schema;
|
|
my $rs = $schema->resultset('Alert');
|
|
$rs->create({ externalid => $self->subscriptionid, borrowernumber => $patron->borrowernumber });
|
|
}
|
|
|
|
=head3 remove_subscriber
|
|
|
|
$subscription->remove_subscriber( $subscriber );
|
|
|
|
Remove a subscriber (Koha::Patron) from this subscription
|
|
|
|
=cut
|
|
|
|
sub remove_subscriber {
|
|
my ($self, $patron) = @_;
|
|
my $schema = Koha::Database->new->schema;
|
|
my $rs = $schema->resultset('Alert');
|
|
my $subscriber = $rs->find({ externalid => $self->subscriptionid, borrowernumber => $patron->borrowernumber });
|
|
$subscriber->delete if $subscriber;
|
|
}
|
|
|
|
=head3 frequency
|
|
|
|
my $frequency = $subscription->frequency
|
|
|
|
Return the subscription frequency
|
|
|
|
=cut
|
|
|
|
sub frequency {
|
|
my($self)=@_;
|
|
my $frequency_rs= $self->_result->periodicity;
|
|
return Koha::Subscription::Frequency->_new_from_dbic($frequency_rs);
|
|
}
|
|
|
|
=head3 get_search_info
|
|
|
|
=cut
|
|
|
|
sub get_search_info {
|
|
my $self=shift;
|
|
my $searched_sub_id = shift;
|
|
my $biblio = Koha::Biblios->find( { 'biblionumber' => $searched_sub_id } );
|
|
return unless $biblio;
|
|
my $biblioitem =
|
|
Koha::Biblioitems->find( { 'biblionumber' => $searched_sub_id } );
|
|
|
|
my $sub_mana_info = {
|
|
'title' => $biblio->title,
|
|
'issn' => $biblioitem->issn,
|
|
'ean' => $biblioitem->ean,
|
|
'publishercode' => $biblioitem->publishercode
|
|
};
|
|
return $sub_mana_info;
|
|
}
|
|
|
|
=head3 get_sharable_info
|
|
|
|
=cut
|
|
|
|
sub get_sharable_info {
|
|
my $self = shift;
|
|
my $shared_sub_id = shift;
|
|
my $subscription = Koha::Subscriptions->find($shared_sub_id);
|
|
my $biblio = Koha::Biblios->find( $subscription->biblionumber );
|
|
my $biblioitem = Koha::Biblioitems->find(
|
|
{ 'biblionumber' => $subscription->biblionumber } );
|
|
my $sub_frequency =
|
|
Koha::Subscription::Frequencies->find( $subscription->periodicity );
|
|
my $sub_numberpatteern =
|
|
Koha::Subscription::Numberpatterns->find( $subscription->numberpattern );
|
|
|
|
my $sub_mana_info = {
|
|
'title' => $biblio->title,
|
|
'sfdescription' => $sub_frequency->description,
|
|
'unit' => $sub_frequency->unit,
|
|
'unitsperissue' => $sub_frequency->unitsperissue,
|
|
'issuesperunit' => $sub_frequency->issuesperunit,
|
|
'label' => $sub_numberpatteern->label,
|
|
'sndescription' => $sub_numberpatteern->description,
|
|
'numberingmethod' => $sub_numberpatteern->numberingmethod,
|
|
'label1' => $sub_numberpatteern->label1,
|
|
'add1' => $sub_numberpatteern->add1,
|
|
'every1' => $sub_numberpatteern->every1,
|
|
'whenmorethan1' => $sub_numberpatteern->whenmorethan1,
|
|
'setto1' => $sub_numberpatteern->setto1,
|
|
'numbering1' => $sub_numberpatteern->numbering1,
|
|
'label2' => $sub_numberpatteern->label2,
|
|
'add2' => $sub_numberpatteern->add2,
|
|
'every2' => $sub_numberpatteern->every2,
|
|
'whenmorethan2' => $sub_numberpatteern->whenmorethan2,
|
|
'setto2' => $sub_numberpatteern->setto2,
|
|
'numbering2' => $sub_numberpatteern->numbering2,
|
|
'label3' => $sub_numberpatteern->label3,
|
|
'add3' => $sub_numberpatteern->add3,
|
|
'every3' => $sub_numberpatteern->every3,
|
|
'whenmorethan3' => $sub_numberpatteern->whenmorethan3,
|
|
'setto3' => $sub_numberpatteern->setto3,
|
|
'numbering3' => $sub_numberpatteern->numbering3,
|
|
'issn' => $biblioitem->issn,
|
|
'ean' => $biblioitem->ean,
|
|
'publishercode' => $biblioitem->publishercode
|
|
};
|
|
return $sub_mana_info;
|
|
}
|
|
|
|
|
|
=head3 _type
|
|
|
|
=cut
|
|
|
|
sub _type {
|
|
return 'Subscription';
|
|
}
|
|
|
|
=head1 AUTHOR
|
|
|
|
Kyle M Hall <kyle@bywatersolutions.com>
|
|
|
|
=cut
|
|
|
|
1;
|
|
|