5 my $db = ZOOM::IRSpy::connect_to_registry();
6 my $conn = new ZOOM::Connection($db);
7 $conn->option(elementSetName => "zeerex");
8 my $query = cql_target($id);
9 my $rs = $conn->search(new ZOOM::Query::CQL($query));
12 $m->comp("/details/error.mc",
13 title => "Error", message => "No such ID '$id'");
15 my $xc = irspy_xpath_context($rs->record(0));
17 [ Name => "e:databaseInfo/e:title",
18 lang => "en", primary => "true" ],
19 [ Country => "i:status/i:country" ],
20 [ "Last Checked" => "i:status/i:probe[last()]" ],
21 [ Protocol => "e:serverInfo/\@protocol" ],
22 [ Host => "e:serverInfo/e:host" ],
23 [ Port => "e:serverInfo/e:port" ],
24 [ "Database Name" => "e:serverInfo/e:database" ],
25 [ "Type of Library" => "i:status/i:libraryType" ],
26 # [ "Username (if needed)" => "e:serverInfo/e:authentication/e:user" ],
27 # [ "Password (if needed)" => "e:serverInfo/e:authentication/e:password" ],
28 [ "Server ID" => 'i:status/i:serverImplementationId/@value' ],
29 [ "Server Name" => 'i:status/i:serverImplementationName/@value' ],
30 [ "Server Version" => 'i:status/i:serverImplementationVersion/@value' ],
31 [ Description => "e:databaseInfo/e:description",
32 lang => "en", primary => "true" ],
33 [ Author => "e:databaseInfo/e:author" ],
34 [ Contact => "e:databaseInfo/e:contact" ],
35 [ "URL to Hosting Organisation" => "i:status/i:hostURL" ],
36 [ Extent => "e:databaseInfo/e:extent" ],
37 [ History => "e:databaseInfo/e:history" ],
38 [ "Language of Records" => "e:databaseInfo/e:langUsage" ],
39 [ Restrictions => "e:databaseInfo/e:restrictions" ],
40 [ Subjects => "e:databaseInfo/e:subjects" ],
41 [ "Implementation ID" => "i:status/i:implementationId" ],
42 [ "Implementation Name" => "i:status/i:implementationName" ],
43 [ "Implementation Version" => "i:status/i:implementationVersion" ],
44 [ "Reliability/reliability" => \&calc_reliability_wrapper, $xc ],
45 [ "Services" => \&calc_init_options, $xc ],
46 [ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ],
47 [ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ],
48 [ "Bath Profile searches" => \&calc_bath, $xc ],
49 [ "Operators" => \&calc_boolean, $xc ],
50 [ "Named Result Sets" => \&calc_nrs, $xc ],
51 [ "Record syntaxes" => \&calc_recsyn, $xc ],
52 [ "Explain" => \&calc_explain, $xc ],
53 [ "Multiple OPAC records" => \&calc_mor, $xc ],
54 [ "Piggback searching" => \&calc_piggyback, $xc ],
56 my $title = $xc->find("e:databaseInfo/e:title");
58 <h2><% xml_encode($title, "") %></h2>
59 <table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
61 foreach my $ref (@fields) {
62 my($caption, $xpath, @args) = @$ref;
64 if (ref $xpath && ref($xpath) eq "CODE") {
65 ($data, $linkURL) = &$xpath($id, @args);
67 $data = $xc->find($xpath);
71 $caption =~ s/\/(.*)//;
73 my($linkstart, $linkend) = ("", "");
74 if (defined $linkURL) {
75 $linkstart = '<a href="' . xml_encode($linkURL) . '">';
79 <th><% xml_encode($caption) %><%
80 !defined $help ? "" : $m->comp("/help/link.mc", help =>"info/$help")
82 <td><% $linkstart . xml_encode($data) . $linkend %></td>
88 % my $target = irspy_identifier2target($id);
89 % $target =~ s/^tcp://; # Apparently ZAP can't handle the leading "tcp:"
90 <a href="<% xml_encode("http://targettest.indexdata.com/targettest/search/index.zap?" .
92 "target=" . uri_escape_utf8($target),
93 "name=" . uri_escape_utf8($title),
94 "attr=" . join(" ", _list_ap($xc, "bib-1")),
95 "formats=" . calc_recsyn($id, $xc, " ")))
96 %>">Search this target.</a>
101 sub calc_reliability_wrapper {
103 return calc_reliability_string($xc);
106 sub calc_init_options {
110 my @nodes = $xc->findnodes('e:configInfo/e:supports/@type');
111 foreach my $node (@nodes) {
112 my $type = $node->value();
113 if ($type =~ s/^z3950_//) {
118 return join(", ", @ops);
122 my($id, $xc, $set) = @_;
124 my @aps = _list_ap($xc, $set);
126 return "[none]" if $n == 0;
130 foreach my $ap (@aps) {
131 if (!defined $first) {
132 $first = $last = $ap;
133 } elsif ($ap == $last+1) {
136 # Got a complete range
137 $res .= ", " if $res ne "";
139 $res .= "-$last" if $last > $first;
140 $first = $last = $ap;
145 if (defined $first) {
146 $res .= ", " if $res ne "";
148 $res .= "-$last" if $last > $first;
151 return ("$n access points: $res",
152 "/ap.html?id=$id&set=$set");
158 my $expr = 'e:indexInfo/e:index[@search = "true"]/e:map/e:attr[
159 @set = "'.$set.'" and @type = "1"]';
160 my @nodes = $xc->findnodes($expr);
161 return sort { $a <=> $b } map { $_->findvalue(".") } @nodes;
167 my @nodes = $xc->findnodes('i:status/i:search_bath[@ok = "1"]');
168 my $res = join(", ", map { $_->findvalue('@name') } @nodes);
169 $res = "[none]" if $res eq "";
176 ### Note that we are currently interrogating an IRSpy extension.
177 # The standard ZeeRex record should be extended with a
178 # "supports" type for this.
179 my @nodes = $xc->findnodes('i:status/i:boolean[@ok = "1"]');
180 my $res = join(", ", map { $_->findvalue('@operator') } @nodes);
181 $res = "[none]" if $res eq "";
185 sub calc_nrs { _calc_boolean(@_, 'i:status/i:named_resultset[@ok = "1"]') }
186 sub calc_mor { _calc_boolean(@_, 'i:status/i:multiple_opac[@ok = "1"]') }
187 sub calc_piggyback { _calc_boolean(@_, 'i:status/i:piggback[@ok = "1"]') }
190 my($id, $xc, $xpath) = @_;
192 my @nodes = $xc->findnodes($xpath);
193 return @nodes ? "Yes" : "No";
197 my($id, $xc, $sep) = @_;
198 $sep = ", " if !defined $sep;
200 my @nodes = $xc->findnodes('e:recordInfo/e:recordSyntax');
201 my $res = join($sep, map { $_->findvalue('@name') } @nodes);
202 $res = "[none]" if $res eq "";
209 my @nodes = $xc->findnodes('i:status/i:explain[@ok = "1"]');
210 my $res = join(", ", map { $_->findvalue('@category') } @nodes);
211 $res = "[none]" if $res eq "";