# 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 strict;
#use warnings; FIXME - Bug 2505
-use C4::SQLHelper qw(:all);
+use C4::Context;
+use Koha::Database;
use vars qw($VERSION @ISA @EXPORT);
require Exporter;
@ISA = qw(Exporter);
@EXPORT = qw(
- &GetContract
- &AddContract
- &ModContract
- &DelContract
+ &GetContracts
+ &GetContract
+ &AddContract
+ &ModContract
+ &DelContract
);
}
add a new contract, to modify it or to get some informations around
a contract.
-This module is just a wrapper for C4::SQLHelper functions, so take a look at
-SQLHelper centralised documentation to know how to use the following subs.
+=cut
+
+
+=head2 GetContracts
+
+$contractlist = GetContracts({
+ booksellerid => $booksellerid,
+ activeonly => $activeonly
+});
+
+Looks up the contracts that belong to a bookseller
+
+Returns a list of contracts
+
+=over
+
+=item C<$booksellerid> is the "id" field in the "aqbooksellers" table.
+
+=item C<$activeonly> if exists get only contracts that are still active.
+
+=back
+
+=cut
+
+sub GetContracts {
+ my ($filters) = @_;
+ if( $filters->{activeonly} ) {
+ $filters->{contractenddate} = {'>=' => \'now()'};
+ delete $filters->{activeonly};
+ }
+
+ my $rs = Koha::Database->new()->schema->resultset('Aqcontract');
+ $rs = $rs->search($filters);
+ $rs->result_class('DBIx::Class::ResultClass::HashRefInflator');
+ return [ $rs->all ];
+}
+
+=head2 GetContract
+
+$contract = GetContract( { contractnumber => $contractnumber } );
+
+Looks up the contract that has PRIMKEY (contractnumber) value $contractID
+
+Returns a contract
=cut
-sub GetContract { SearchInTable("aqcontract", shift); }
+sub GetContract {
+ my ($params) = @_;
+ my $contractnumber = $params->{contractnumber};
+
+ return unless $contractnumber;
+
+ my $contracts = GetContracts({
+ contractnumber => $contractnumber,
+ });
+ return $contracts->[0];
+}
+
+sub AddContract {
+ my ($contract) = @_;
+ return unless($contract->{booksellerid});
+
+ my $rs = Koha::Database->new()->schema->resultset('Aqcontract');
+ return $rs->create($contract)->id;
+}
-sub AddContract { InsertInTable("aqcontract", shift); }
+sub ModContract {
+ my ($contract) = @_;
+ my $result = Koha::Database->new()->schema->resultset('Aqcontract')->find($contract);
+ return unless($result);
-sub ModContract { UpdateInTable("aqcontract", shift); }
+ $result = $result->update($contract);
+ return $result->in_storage;
+}
-sub DelContract { DeleteInTable("aqcontract", shift); }
+sub DelContract {
+ my ($contract) = @_;
+ return unless($contract->{contractnumber});
+
+ my $result = Koha::Database->new()->schema->resultset('Aqcontract')->find($contract);
+ return unless($result);
+
+ eval { $result->delete };
+ return !( $result->in_storage );
+}
1;