Bug 21474: Add the Koha::Subscription->frequency method
[koha.git] / Koha / Subscription.pm
blob27d926dcb8abc42ecb6ae0434b3eb3927e4714be
1 package Koha::Subscription;
3 # Copyright ByWater Solutions 2015
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 3 of the License, or (at your option) any later
10 # version.
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License along
17 # with Koha; if not, write to the Free Software Foundation, Inc.,
18 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 use Modern::Perl;
22 use Carp;
24 use Koha::Database;
25 use Koha::Biblios;
26 use Koha::Acquisition::Booksellers;
27 use Koha::Subscription::Frequencies;
29 use base qw(Koha::Object);
31 =head1 NAME
33 Koha::Subscription - Koha Subscription Object class
35 =head1 API
37 =head2 Class Methods
39 =cut
41 =head3 biblio
43 Returns the biblio linked to this subscription as a Koha::Biblio object
45 =cut
47 sub biblio {
48 my ($self) = @_;
50 return scalar Koha::Biblios->find($self->biblionumber);
53 =head3 vendor
55 Returns the vendor/supplier linked to this subscription as a Koha::Acquisition::Bookseller object
57 =cut
59 sub vendor {
60 my ($self) = @_;
61 return scalar Koha::Acquisition::Booksellers->find($self->aqbooksellerid);
64 =head3 subscribers
66 my $subscribers = $subscription->subscribers;
68 return a Koha::Patrons object
70 =cut
72 sub subscribers {
73 my ($self) = @_;
74 my $schema = Koha::Database->new->schema;
75 my @borrowernumbers = $schema->resultset('Alert')->search({ externalid => $self->subscriptionid })->get_column( 'borrowernumber' )->all;
76 return Koha::Patrons->search({ borrowernumber => {-in => \@borrowernumbers } });
79 =head3 add_subscriber
81 $subscription->add_subscriber( $patron );
83 Add a new subscriber (Koha::Patron) to this subscription
85 =cut
87 sub add_subscriber {
88 my ( $self, $patron ) = @_;
89 my $schema = Koha::Database->new->schema;
90 my $rs = $schema->resultset('Alert');
91 $rs->create({ externalid => $self->subscriptionid, borrowernumber => $patron->borrowernumber });
94 =head3 remove_subscriber
96 $subscription->remove_subscriber( $subscriber );
98 Remove a subscriber (Koha::Patron) from this subscription
100 =cut
102 sub remove_subscriber {
103 my ($self, $patron) = @_;
104 my $schema = Koha::Database->new->schema;
105 my $rs = $schema->resultset('Alert');
106 my $subscriber = $rs->find({ externalid => $self->subscriptionid, borrowernumber => $patron->borrowernumber });
107 $subscriber->delete if $subscriber;
110 =head3 frequency
112 my $frequency = $subscription->frequency
114 Return the subscription frequency
116 =cut
118 sub frequency {
119 my($self)=@_;
120 my $frequency_rs= $self->_result->periodicity;
121 return Koha::Subscription::Frequency->_new_from_dbic($frequency_rs);
124 =head3 type
126 =cut
128 sub _type {
129 return 'Subscription';
132 =head1 AUTHOR
134 Kyle M Hall <kyle@bywatersolutions.com>
136 =cut