X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=svc%2Freport;h=0cff7dc4c1ccce9743926b31356a7516498612d9;hb=71f0d1639784aab68013ef3d052852f7c605cc66;hp=b0507bd33dbfe5751fa17b35448b5082343c08a0;hpb=b7b92a4c812570894286bbd2094ff0377c35221f;p=koha.git diff --git a/svc/report b/svc/report index b0507bd33d..0cff7dc4c1 100755 --- a/svc/report +++ b/svc/report @@ -1,25 +1,24 @@ #!/usr/bin/perl -# Copyright 2011 Chris Cormack -# # 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 2 of the License, or (at your option) any later -# version. +# Copyright (C) 2011 Chris Cormack +# Copyright (C) 2013 Mark Tompsett # -# 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. +# 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. # -# You should have received a copy of the GNU General Public License along with -# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place, -# Suite 330, Boston, MA 02111-1307 USA +# 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 . -use strict; -use warnings; +use Modern::Perl; use C4::Auth; use C4::Reports::Guided; @@ -32,13 +31,10 @@ use Koha::Cache; my $query = CGI->new(); my $report_id = $query->param('id'); my $report_name = $query->param('name'); +my $report_annotation = $query->param('annotated'); -my $cache; -my $sql; -my $type; -my $notes; -my $cache_expiry; -my $public; +my $report_rec = get_saved_report( $report_name ? { 'name' => $report_name } : { 'id' => $report_id } ); +if (!$report_rec) { die "There is no such report.\n"; } my ( $template, $loggedinuser, $cookie ) = get_template_and_user( { @@ -50,39 +46,39 @@ my ( $template, $loggedinuser, $cookie ) = get_template_and_user( } ); -if (Koha::Cache->is_cache_active) { - if ($report_name) { # When retrieving by name, we have to hit the - # database to get the ID before we can check - # the cache. Yuck. - ( $sql, $type, $report_name, $notes, $cache_expiry, $public, $report_id ) = - get_saved_report( { 'name' => $report_name } ); - } - +my $cache_active = Koha::Cache->is_cache_active; +my ($cache_key, $cache, $json_text); +if ($cache_active) { + $cache_key = "intranet:report:".($report_name ? "name:$report_name" : "id:$report_id"); $cache = Koha::Cache->new(); - my $page = $cache->get_from_cache("intranet:report:$report_id"); - if ($page) { - print $query->header; - print $page; - exit; - } + $json_text = $cache->get_from_cache($cache_key); } -print $query->header; - -# $public isnt used for intranet -unless ($sql) { - ( $sql, $type, $report_name, $notes, $cache_expiry, $public, $report_id ) = - get_saved_report($report_name ? { 'name' => $report_name } : { 'id' => $report_id } ); -} -if ($sql) { +unless ($json_text) { my $offset = 0; my $limit = C4::Context->preference("SvcMaxReportRows") || 10; - my ( $sth, $errors ) = execute_query( $sql, $offset, $limit ); - my $lines = $sth->fetchall_arrayref; - my $json_text = to_json($lines); - print $json_text; + my ( $sth, $errors ) = execute_query( $report_rec->{savedsql}, $offset, $limit ); + if ($sth) { + my $lines; + if ($report_annotation) { + $lines = $sth->fetchall_arrayref({}); + } + else { + $lines = $sth->fetchall_arrayref; + } + $json_text = to_json($lines); - if (Koha::Cache->is_cache_active) { - $cache->set_in_cache( "intranet:report:$report_id", $json_text, $cache_expiry ); + if ($cache_active) { + $cache->set_in_cache( $cache_key, $json_text, $report_rec->{cache_expiry} ); + } + } + else { + $json_text = to_json($errors); } } + +print $query->header( + -charset => 'UTF-8', + -type => 'application/json' +); +print $json_text;