=cut
+=head2 search_limited
+
+my $reviews = Koha::Reviews->search_limited( $params, $attributes );
+
+Search for reviews according to logged in patron restrictions
+
+=cut
+
+sub search_limited {
+ my ( $self, $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;
+ }
+ # TODO This 'borrowernumber' relation name is confusing and needs to be renamed
+ $params->{'borrowernumber.branchcode'} = { -in => \@restricted_branchcodes } if @restricted_branchcodes;
+ $attributes->{join} = 'borrowernumber';
+ return $self->search( $params, $attributes );
+}
+
=head3 type
=cut
use Modern::Perl;
-use Test::More tests => 7;
+use Test::More tests => 8;
-use Koha::Review;
+use Koha::Patrons;
use Koha::Reviews;
use Koha::Database;
$schema->storage->txn_begin;
my $builder = t::lib::TestBuilder->new;
-my $patron_1 = $builder->build({ source => 'Borrower' });
+my $patron_1 = $builder->build({ source => 'Borrower', value => { flags => undef } });
my $patron_2 = $builder->build({ source => 'Borrower' });
+$patron_1 = Koha::Patrons->find( $patron_1->{borrowernumber} );
+$patron_2 = Koha::Patrons->find( $patron_2->{borrowernumber} );
my $biblio_1 = $builder->build({ source => 'Biblio' });
my $biblio_2 = $builder->build({ source => 'Biblio' });
my $nb_of_reviews = Koha::Reviews->search->count;
my $nb_of_approved_reviews = Koha::Reviews->search({ approved => 1 })->count;
my $new_review_1_1 = Koha::Review->new({
- borrowernumber => $patron_1->{borrowernumber},
+ borrowernumber => $patron_1->borrowernumber,
biblionumber => $biblio_1->{biblionumber},
review => 'a kind review',
})->store;
my $new_review_1_2 = Koha::Review->new({
- borrowernumber => $patron_1->{borrowernumber},
+ borrowernumber => $patron_1->borrowernumber,
biblionumber => $biblio_2->{biblionumber},
review => 'anoter kind review',
})->store;
my $new_review_2_1 = Koha::Review->new({
- borrowernumber => $patron_2->{borrowernumber},
+ borrowernumber => $patron_2->borrowernumber,
biblionumber => $biblio_1->{biblionumber},
review => 'just anoter review',
})->store;
my $retrieved_review_1_1 = Koha::Reviews->find( $new_review_1_1->reviewid );
is( $retrieved_review_1_1->review, $new_review_1_1->review, 'Find a review by id should return the correct review' );
+subtest 'search_limited' => sub {
+ plan tests => 2;
+ C4::Context->_new_userenv('xxx');
+ my $group_1 = Koha::Library::Group->new( { title => 'TEST Group 1' } )->store;
+ my $group_2 = Koha::Library::Group->new( { title => 'TEST Group 2' } )->store;
+ Koha::Library::Group->new({ parent_id => $group_1->id, branchcode => $patron_1->branchcode })->store();
+ Koha::Library::Group->new({ parent_id => $group_2->id, branchcode => $patron_2->branchcode })->store();
+ set_logged_in_user( $patron_1 );
+ is( Koha::Reviews->search->count, $nb_of_approved_reviews + 3, 'Koha::Reviews->search should return all reviews' );
+ is( Koha::Reviews->search_limited->count, $nb_of_approved_reviews + 2, 'Koha::Reviews->search_limited should return reviews depending on patron permissions' );
+};
+
$retrieved_review_1_1->delete;
is( Koha::Reviews->search->count, $nb_of_reviews + 2, 'Delete should have deleted the review' );
$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,
+ '', ''
+ );
+}