If _query parameter is set, use that verbatim rather than assembling a
[irspy-moved-to-github.git] / web / htdocs / details / found.mc
1 %# $Id: found.mc,v 1.13 2006-10-18 12:36:05 mike Exp $
2 <%once>
3 use XML::LibXML;
4 use XML::LibXML::XPathContext;
5 use URI::Escape;
6
7 sub print_navlink {
8     my($params, $cond, $caption, $skip) = @_;
9
10     if ($cond) {
11         print('     <a href="', navlink($params, $caption, $skip),
12               '"', ">$caption</a>\n");
13     } else {
14         print qq[     <span class="disabled">$caption</span>\n];
15     }
16 }
17
18 sub navlink {
19     my($params, $caption, $skip) = @_;
20     local $params->{_skip} = $skip;
21     my $url = "?" . join("&", map { "$_=" . $params->{$_}  } sort keys %$params);
22     $url = xml_encode($url);
23     return $url;
24 }
25
26 # Just make this once; forge the connection on first use
27 our $conn = undef;
28 </%once>
29 <%perl>
30 my %params = map { ( $_, $r->param($_)) } grep { $r->param($_) } $r->param();
31 my $query;
32 if ($params{_query}) {
33     $query = $params{_query};
34 } else {
35     $query = "";
36     foreach my $key (keys %params) {
37         next if $key =~ /^_/;
38         my $val = $params{$key};
39         next if $val eq "";
40         $query .= " and " if $query ne "";
41         $query .= "$key = ($val)";
42     }
43 }
44 $query = 'cql.allRecords=x' if $query eq "";
45
46 my $sort = $params{"_sort"};
47 if ($sort) {
48     my $modifiers = "";
49     if ($sort =~ s/(\/.*)//) {
50         $modifiers = $1;
51     }
52     $query .= " or $sort=/sort";
53     $query .= "-desc" if $params{_desc};
54     $query .= $modifiers;
55     $query .= " 0";
56 }
57
58 if (!defined $conn) {
59     $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
60 }
61 $conn->option(elementSetName => "zeerex");
62 my $parser = new XML::LibXML();
63
64 my $rs = $conn->search(new ZOOM::Query::CQL($query));
65 my $n = $rs->size();
66
67 my $skip = $params{"_skip"} || 0;
68 my $count = $params{"_count"} || 10;
69
70 my $first = $skip+1;
71 my $last = $first+$count-1;
72 $last = $n if $last > $n;
73 </%perl>
74      <form method="get" action="">
75       <input type="text" name="_query" size="60" value="<% xml_encode($query) %>"/>
76       <input type="submit" name="_search" value="Search"/>
77      </form>
78      <p>
79 % if ($n == 0) {
80       No matches
81 % } elsif ($first > $n) {
82 %# "Can't happen"
83       Past end of <% $n %> records
84 % } else {
85       Records <% $first %> to <% $last %> of <% $n %><br/>
86 <%perl>
87 print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0);
88 print_navlink(\%params, $last < $n, "Next", $skip+$count);
89 </%perl>
90 % }
91      </p>
92 % if ($n > 0 && $first <= $n) {
93      <table width="100%">
94       <tr class="thleft">
95        <th>#</th>
96        <th>Title</th>
97        <th>Author</th>
98        <th>Host</th>
99        <th>Port</th>
100        <th>DB</th>
101        <th></th>
102        <th></th>
103       </tr>
104 % my @ids;
105 % foreach my $i ($first .. $last) {
106 <%perl>
107 my $rec = $rs->record($i-1);
108 my $xml = $rec->render();
109 my $doc = $parser->parse_string($xml);
110 my $root = $doc->getDocumentElement();
111 my $xc = XML::LibXML::XPathContext->new($root);
112 $xc->registerNs(e => 'http://explain.z3950.org/dtd/2.0/');
113 my $title = $xc->find("e:databaseInfo/e:title");
114 my $author = $xc->find("e:databaseInfo/e:author");
115 my $host = $xc->find("e:serverInfo/e:host");
116 my $port = $xc->find("e:serverInfo/e:port");
117 my $db = $xc->find("e:serverInfo/e:database");
118 my $id = $xc->find("concat(e:serverInfo/e:host, ':',
119                            e:serverInfo/e:port, '/',
120                            e:serverInfo/e:database)");
121 push @ids, $id;
122 </%perl>
123       <tr style="background: <% ($i % 2) ? '#ffffc0' : 'white' %>">
124        <td><% $i %></td>
125        <td><% xml_encode($title) %></td>
126        <td><% xml_encode($author) %></td>
127        <td><% xml_encode($host) %></td>
128        <td><% xml_encode($port) %></td>
129        <td><% xml_encode($db) %></td>
130        <td><a href="<% xml_encode("/check.html?id=" . uri_escape($id))
131         %>">[Test]</a></td>
132        <td><a href="<% xml_encode("/raw.html?id=" . uri_escape($id))
133         %>">[Raw]</a></td>
134       </tr>
135 % }
136      </table>
137 <%perl>
138 print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0);
139 print_navlink(\%params, $last < $n, "Next", $skip+$count);
140 </%perl>
141      <p>
142       <a href="<% "/check.html?" .
143         xml_encode(join("&", map { "id=" . uri_escape($_) } @ids))
144         %>">[Test all targets on this list]</a>
145      </p>
146 % }