Include database title and link to raw ZeeRex XML.
[irspy-moved-to-github.git] / web / htdocs / details / found.mc
1 %# $Id: found.mc,v 1.4 2006-09-19 11:12:33 mike Exp $
2 <%once>
3 use XML::LibXML;
4 use XML::LibXML::XPathContext;
5 </%once>
6 <%perl>
7 my %params = map { ( $_, $r->param($_)) } $r->param();
8 my $query = "";
9 foreach my $key (keys %params) {
10     next if $key =~ /^_/;
11     my $val = $params{$key};
12     next if $val eq "";
13     $query .= " and " if $query ne "";
14     $query .= "$key = ($val)";
15 }
16 $query = 'cql.allRecords=x' if $query eq "";
17
18 ### We can think about keeping the Connection object open to re-use
19 # for multiple requests, but that may not get us much.  Same applies
20 # for the XML parser.
21 my $conn = new ZOOM::Connection("localhost:1313/IR-Explain---1");
22 $conn->option(elementSetName => "zeerex");
23 my $parser = new XML::LibXML();
24
25 my $rs = $conn->search(new ZOOM::Query::CQL($query));
26 my $n = $rs->size();
27
28 my $skip = $params{"_skip"} || 0;
29 my $count = $params{"_count"} || 10;
30
31 my $first = $skip+1;
32 my $last = $first+$count-1;
33 $last = $n if $last > $n;
34 </%perl>
35      <p>
36       <b><% $query %></b>
37       <br/>
38 % if ($n == 0) {
39       No matches
40 % } elsif ($first > $n) {
41 %# "Can't happen"
42       Past end of <% $n %> records
43 % } else {
44       Records <% $first %> to <% $last %> of <% $n %><br/>
45 <%perl>
46 if ($skip > 0) {
47     $params{_skip} = $count < $skip ? $skip-$count : 0;
48     my $prev = "?" . join("&", map { "$_=" . $params{$_}  } sort keys %params);
49     print qq[     <a href="$prev">Prev</a>\n];
50 } else {
51     print qq[     <span class="disabled">Prev</span>\n];
52 }
53 if ($last < $n) {
54     $params{_skip} = $skip+$count;
55     my $next = "?" . join("&", map { "$_=" . $params{$_}  } sort keys %params);
56     print qq[     <a href="$next">Next</a>\n];
57 } else {
58     print qq[     <span class="disabled">Next</span>\n];
59 }
60 </%perl>
61 % }
62      </p>
63 % if ($n > 0 && $first <= $n) {
64      <table width="100%">
65       <tr class="thleft">
66        <th>#</th>
67        <th>Title</th>
68        <th>Host</th>
69        <th>Port</th>
70        <th>DB</th>
71        <th></th>
72        <th></th>
73       </tr>
74 % foreach my $i ($first .. $last) {
75 <%perl>
76 my $rec = $rs->record($i-1);
77 my $xml = $rec->render();
78 my $doc = $parser->parse_string($xml);
79 my $root = $doc->getDocumentElement();
80 my $xc = XML::LibXML::XPathContext->new($root);
81 $xc->registerNs(e => 'http://explain.z3950.org/dtd/2.0/');
82 my $title = $xc->find("e:databaseInfo/e:title");
83 my $host = $xc->find("e:serverInfo/e:host");
84 my $port = $xc->find("e:serverInfo/e:port");
85 my $db = $xc->find("e:serverInfo/e:database");
86 my $id = $xc->find("concat(e:serverInfo/e:host, ':',
87                            e:serverInfo/e:port, '/',
88                            e:serverInfo/e:database)");
89 </%perl>
90       <tr style="background: <% ($i % 2) ? '#ffffc0' : 'white' %>">
91        <td><% $i %></td>
92        <td><% $title %></td>
93        <td><% $host %></td>
94        <td><% $port %></td>
95        <td><% $db %></td>
96        <td><a href="<% "/check.html?id=$id" %>">[Check]</a></td>
97        <td><a href="<% "/raw.html?id=$id" %>">[Raw]</a></td>
98       </tr>
99 %}
100      </table>
101 % }