$values->{validated} = { '!=', undef };
}
- my $rs = Koha::Database->new->schema->resultset('Discharge');
- return $rs->search( $values )->count;
+ return search_limited( $values )->count;
}
sub can_be_discharged {
my $borrowernumber = $params->{borrowernumber};
my $restricted = Koha::Patrons->find( $borrowernumber )->is_debarred;
- my $validated = get_validated({borrowernumber => $borrowernumber});
+ my @validated = get_validated({borrowernumber => $borrowernumber});
- if ($restricted && $validated) {
+ if ($restricted && @validated) {
return 1;
} else {
return 0;
( defined $branchcode ? ( 'borrower.branchcode' => $branchcode ) : () ),
};
- my $rs = Koha::Database->new->schema->resultset('Discharge');
- my @rs = $rs->search( $cond, { join => 'borrower' } );
- return \@rs;
+ return search_limited( $cond );
}
sub get_validated {
( defined $branchcode ? ( 'borrower.branchcode' => $branchcode ) : () ),
};
- my $rs = Koha::Database->new->schema->resultset('Discharge');
- my @rs = $rs->search( $cond, { join => 'borrower' } );
- return \@rs;
+ return search_limited( $cond );
}
+# TODO This module should be based on Koha::Object[s]
+sub search_limited {
+ my ( $params, $attributes ) = @_;
+ my $userenv = C4::Context->userenv;
+ my @restricted_branchcodes;
+ if ( $userenv ) {
+ my $logged_in_user = Koha::Patrons->find( $userenv->{number} );
+ @restricted_branchcodes = $logged_in_user->libraries_where_can_see_patrons;
+ }
+ $params->{'borrower.branchcode'} = { -in => \@restricted_branchcodes } if @restricted_branchcodes;
+ $attributes->{join} = 'borrower';
+
+ my $rs = Koha::Database->new->schema->resultset('Discharge');
+ return $rs->search( $params, { join => 'borrower' } );
+}
1;
# with Koha; if not, see <http://www.gnu.org/licenses>.
use Modern::Perl;
-use Test::More tests => 18;
+use Test::More tests => 19;
use Test::Warn;
use MARC::Record;
my $itemtype = $builder->build({ source => 'Itemtype' })->{itemtype};
C4::Context->_new_userenv('xxx');
-C4::Context->set_userenv(0, 0, 0, 'firstname', 'surname', $library->{branchcode}, $library->{branchcode}, '', '', '', '');
my $patron = $builder->build({
source => 'Borrower',
value => {
branchcode => $library->{branchcode},
+ flags => 1, # superlibrarian
}
});
+my $p = Koha::Patrons->find( $patron->{borrowernumber} );
+set_logged_in_user( $p );
+
my $patron2 = $builder->build({
source => 'Borrower',
value => {
source => 'Borrower',
value => {
branchcode => $another_library->{branchcode},
+ flags => undef,
}
});
+my $p3 = Koha::Patrons->find( $patron3->{borrowernumber} );
# Discharge not possible with issues
my ( $biblionumber ) = AddBiblio( MARC::Record->new, '');
is( Koha::Patron::Discharge::request({ borrowernumber => $patron->{borrowernumber} }), undef, 'No request done if patron has issues' );
is( Koha::Patron::Discharge::discharge({ borrowernumber => $patron->{borrowernumber} }), undef, 'No discharge done if patron has issues' );
-is_deeply( Koha::Patron::Discharge::get_pendings(), [], 'There is no pending discharge request' );
-is_deeply( Koha::Patron::Discharge::get_validated(), [], 'There is no validated discharge' );
+is_deeply( [ Koha::Patron::Discharge::get_pendings ], [], 'There is no pending discharge request' );
+is_deeply( [ Koha::Patron::Discharge::get_validated ], [], 'There is no validated discharge' );
AddReturn( $barcode );
Koha::Patron::Discharge::discharge( { borrowernumber => $patron3->{borrowernumber} } );
is( Koha::Patron::Discharge::is_discharged( { borrowernumber => $patron->{borrowernumber} } ), 1, 'The patron has been discharged' );
is( Koha::Patrons->find( $patron->{borrowernumber} )->is_debarred, '9999-12-31', 'The patron has been debarred after discharge' );
-is( scalar( @{ Koha::Patron::Discharge::get_validated() } ), 3, 'There are 3 validated discharges' );
-is( scalar( @{ Koha::Patron::Discharge::get_validated( { borrowernumber => $patron->{borrowernumber} } ) } ), 1, 'There is 1 validated discharge for a given patron' );
-is( scalar( @{ Koha::Patron::Discharge::get_validated( { branchcode => $library->{branchcode} } ) } ), 2, 'There is 2 validated discharges for a given branchcode' ); # This is not used in the code yet
+is( scalar( Koha::Patron::Discharge::get_validated ), 3, 'There are 3 validated discharges' );
+is( scalar( Koha::Patron::Discharge::get_validated( { borrowernumber => $patron->{borrowernumber} } ) ), 1, 'There is 1 validated discharge for a given patron' );
+is( scalar( Koha::Patron::Discharge::get_validated( { branchcode => $library->{branchcode} } ) ), 2, 'There is 2 validated discharges for a given branchcode' ); # This is not used in the code yet
Koha::Patron::Debarments::DelUniqueDebarment( { 'borrowernumber' => $patron->{borrowernumber}, 'type' => 'DISCHARGE' } );
ok( !Koha::Patrons->find( $patron->{borrowernumber} )->is_debarred, 'The debarment has been lifted' );
ok( !Koha::Patron::Discharge::is_discharged( { borrowernumber => $patron->{borrowernumber} } ), 'The patron is not discharged after the restriction has been lifted' );
# Verify that the discharge works multiple times
Koha::Patron::Discharge::request({ borrowernumber => $patron->{borrowernumber} });
-is(scalar( @{ Koha::Patron::Discharge::get_pendings() }), 1, 'There is a pending discharge request (second time)');
+is(scalar( Koha::Patron::Discharge::get_pendings ), 1, 'There is a pending discharge request (second time)');
Koha::Patron::Discharge::discharge( { borrowernumber => $patron->{borrowernumber} } );
-is_deeply( Koha::Patron::Discharge::get_pendings(), [], 'There is no pending discharge request (second time)');
+is_deeply( [ Koha::Patron::Discharge::get_pendings ], [], 'There is no pending discharge request (second time)');
# Check if PDF::FromHTML is installed.
my $check = eval { require PDF::FromHTML; };
# FIXME Should be a Koha::Object object
is( ref(Koha::Patron::Discharge::request({ borrowernumber => $patron->{borrowernumber} })), 'Koha::Schema::Result::Discharge', 'Discharge request sent' );
+subtest 'search_limited' => sub {
+ plan tests => 4;
+ $dbh->do(q|DELETE FROM discharges|);
+ my $group_1 = Koha::Library::Group->new( { title => 'TEST Group 1' } )->store;
+ my $group_2 = Koha::Library::Group->new( { title => 'TEST Group 2' } )->store;
+ # $patron and $patron2 are from the same library, $patron3 from another one
+ # Logged in user is $patron, superlibrarian
+ set_logged_in_user( $p );
+ Koha::Library::Group->new({ parent_id => $group_1->id, branchcode => $patron->{branchcode} })->store();
+ Koha::Library::Group->new({ parent_id => $group_2->id, branchcode => $patron3->{branchcode} })->store();
+ Koha::Patron::Discharge::request({ borrowernumber => $patron->{borrowernumber} });
+ Koha::Patron::Discharge::request({ borrowernumber => $patron2->{borrowernumber} });
+ Koha::Patron::Discharge::request({ borrowernumber => $patron3->{borrowernumber} });
+ is( scalar( Koha::Patron::Discharge::get_pendings), 3, 'With permission, all discharges are visible' );
+ is( Koha::Patron::Discharge::count({pending => 1}), 3, 'With permission, all discharges are visible' );
+
+ # With patron 3 logged in, only discharges from their group are visible
+ set_logged_in_user( $p3 );
+ is( scalar( Koha::Patron::Discharge::get_pendings), 1, 'Without permission, only discharge from our group are visible' );
+ is( Koha::Patron::Discharge::count({pending => 1}), 1, 'Without permission, only discharge from our group are visible' );
+};
+
$schema->storage->txn_rollback;
+sub set_logged_in_user {
+ my ($patron) = @_;
+ C4::Context->set_userenv(
+ $patron->borrowernumber, $patron->userid,
+ $patron->cardnumber, 'firstname',
+ 'surname', $patron->library->branchcode,
+ 'Midway Public Library', $patron->flags,
+ '', ''
+ );
+}