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.
164 lines
4.6 KiB
164 lines
4.6 KiB
package Koha::Patron::Modifications;
|
|
|
|
# Copyright 2012 ByWater Solutions
|
|
# 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
|
|
|
|
Koha::Patron::Modifications
|
|
|
|
=cut
|
|
|
|
use Modern::Perl;
|
|
|
|
use C4::Context;
|
|
|
|
use Koha::Patron::Attribute;
|
|
use Koha::Patron::Modification;
|
|
|
|
use JSON;
|
|
use List::Util qw /any none/;
|
|
|
|
use base qw(Koha::Objects);
|
|
|
|
=head2 pending_count
|
|
|
|
$count = Koha::Patron::Modifications->pending_count();
|
|
|
|
Returns the number of pending modifications for existing patrons.
|
|
|
|
=cut
|
|
|
|
sub pending_count {
|
|
my ( $self, $branchcode ) = @_;
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
my $query = "
|
|
SELECT COUNT(*) AS count
|
|
FROM borrower_modifications, borrowers
|
|
WHERE borrower_modifications.borrowernumber > 0
|
|
AND borrower_modifications.borrowernumber = borrowers.borrowernumber
|
|
";
|
|
|
|
my $userenv = C4::Context->userenv;
|
|
my @branchcodes;
|
|
if ( $userenv and $userenv->{number} ) {
|
|
my $logged_in_user = Koha::Patrons->find( $userenv->{number} );
|
|
if ($branchcode) {
|
|
return 0 unless $logged_in_user->can_see_patrons_from($branchcode);
|
|
@branchcodes = ( $branchcode );
|
|
}
|
|
else {
|
|
@branchcodes = $logged_in_user->libraries_where_can_see_patrons;
|
|
}
|
|
}
|
|
my @sql_params;
|
|
if ( @branchcodes ) {
|
|
$query .= ' AND borrowers.branchcode IN ( ' . join( ',', ('?') x @branchcodes ) . ' )';
|
|
push( @sql_params, @branchcodes );
|
|
}
|
|
|
|
my ( $count ) = $dbh->selectrow_array( $query, undef, @sql_params );
|
|
return $count;
|
|
}
|
|
|
|
=head2 pending
|
|
|
|
$arrayref = Koha::Patron::Modifications->pending();
|
|
|
|
Returns an arrayref of hashrefs for all pending modifications for existing patrons.
|
|
|
|
=cut
|
|
|
|
sub pending {
|
|
my ( $self, $branchcode ) = @_;
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
my $query = "
|
|
SELECT borrower_modifications.*
|
|
FROM borrower_modifications, borrowers
|
|
WHERE borrower_modifications.borrowernumber > 0
|
|
AND borrower_modifications.borrowernumber = borrowers.borrowernumber
|
|
";
|
|
|
|
my $userenv = C4::Context->userenv;
|
|
my @branchcodes;
|
|
if ( $userenv ) {
|
|
my $logged_in_user = Koha::Patrons->find( $userenv->{number} );
|
|
if ($branchcode) {
|
|
return 0 unless $logged_in_user->can_see_patrons_from($branchcode);
|
|
@branchcodes = ( $branchcode );
|
|
}
|
|
else {
|
|
@branchcodes = $logged_in_user->libraries_where_can_see_patrons;
|
|
}
|
|
}
|
|
my @sql_params;
|
|
if ( @branchcodes ) {
|
|
$query .= ' AND borrowers.branchcode IN ( ' . join( ',', ('?') x @branchcodes ) . ' )';
|
|
push( @sql_params, @branchcodes );
|
|
}
|
|
$query .= " ORDER BY borrowers.surname, borrowers.firstname";
|
|
my $sth = $dbh->prepare($query);
|
|
$sth->execute(@sql_params);
|
|
|
|
my @m;
|
|
while ( my $row = $sth->fetchrow_hashref() ) {
|
|
my @changed_keys = split /,/, $row->{changed_fields};
|
|
foreach my $key ( keys %$row ) {
|
|
if ($key eq 'changed_fields') {
|
|
delete $row->{$key};
|
|
next;
|
|
}
|
|
if ( defined $row->{$key} && $key eq 'extended_attributes' ) {
|
|
my $attributes = from_json( $row->{$key} );
|
|
my @pending_attributes;
|
|
foreach my $attr ( @{$attributes} ) {
|
|
push @pending_attributes,
|
|
Koha::Patron::Attribute->new(
|
|
{ borrowernumber => $row->{borrowernumber},
|
|
code => $attr->{code},
|
|
attribute => exists $attr->{attribute} ? $attr->{attribute} : $attr->{value},
|
|
}
|
|
);
|
|
}
|
|
|
|
$row->{$key} = \@pending_attributes;
|
|
}
|
|
if (none { $_ eq $key } @changed_keys) {
|
|
delete $row->{$key} unless defined $row->{$key};
|
|
}
|
|
}
|
|
|
|
push( @m, $row );
|
|
}
|
|
|
|
return \@m;
|
|
}
|
|
|
|
sub _type {
|
|
return 'BorrowerModification';
|
|
}
|
|
|
|
=head3 object_class
|
|
|
|
=cut
|
|
|
|
sub object_class {
|
|
return 'Koha::Patron::Modification';
|
|
}
|
|
|
|
1;
|
|
|