use C4::Log;
use C4::Items;
use C4::Debug;
-use C4::Dates;
use C4::Search::History;
+
use URI::Escape;
use POSIX qw(strftime);
template_name => "opac-search-history.tt",
query => $cgi,
type => "opac",
- authnotrequired => 1,
- flagsrequired => {borrowers => 1},
+ authnotrequired => ( C4::Context->preference("OpacPublic") ? 1 : 0 ),
debug => 1,
}
);
+unless ( C4::Context->preference("EnableOpacSearchHistory") ) {
+ print $cgi->redirect("/cgi-bin/koha/errors/404.pl"); # escape early
+ exit;
+}
+
my $type = $cgi->param('type');
my $action = $cgi->param('action') || q{};
my $previous = $cgi->param('previous');
# Deleting search history
if ( $action eq 'delete') {
# Deleting session's search history
- my @id = $cgi->param('id');
+ my @id = $cgi->multi_param('id');
my $all = not scalar( @id );
my $type = $cgi->param('type');
C4::Search::History::set_to_session({ cgi => $cgi, search_history => \@searches });
# Redirecting to this same url so the user won't see the search history link in the header
- my $uri = $cgi->url();
- print $cgi->redirect(-uri => $uri);
+ print $cgi->redirect(-uri => '/cgi-bin/koha/opac-search-history.pl');
# Showing search history
} else {
# Getting the searches from session
# Deleting search history
if ( $action eq 'delete' ) {
- my @id = $cgi->param('id');
+ my @id = $cgi->multi_param('id');
if ( @id ) {
C4::Search::History::delete(
{
- id => [ $cgi->param('id') ],
+ userid => $loggedinuser,
+ id => [ $cgi->param('id') ],
}
);
} else {
);
}
# Redirecting to this same url so the user won't see the search history link in the header
- my $uri = $cgi->url();
- print $cgi->redirect($uri);
+ print $cgi->redirect(-uri => '/cgi-bin/koha/opac-search-history.pl');
# Showing search history
} else {
$template->param(searchhistoryview => 1);
-output_html_with_http_headers $cgi, $cookie, $template->output;
+output_html_with_http_headers $cgi, $cookie, $template->output, undef, { force_no_caching => 1 };