-%# $Id: full.mc,v 1.7 2006-11-06 16:22:17 mike Exp $
+%# $Id: full.mc,v 1.14 2006-11-14 16:24:39 mike Exp $
<%args>
$id
</%args>
[ "Implementation Name" => "i:status/i:implementationName" ],
[ "Implementation Version" => "i:status/i:implementationVersion" ],
[ "Reliability" => \&calc_reliability, $xc ],
- [ "Services" => sub { "### search, present, delSet, concurrentOperations, namedResultSets" } ],
- [ "Bib-1 Use attributes" => sub { "### 4-5, 7-8, 12, 21, 31, 54, 58, 63, 1003-1005, 1009, 1011-1012, 1016, 1031" } ],
- [ "Operators" => sub { "### and, or, not" } ],
- [ "Record syntaxes" => sub { "### SUTRS, USmarc, Danmarc" } ],
- [ "Explain" => sub { "### CategoryList, TargetInfo, DatabaseInfo, RecordSyntaxInfo, AttributeSetInfo, AttributeDetails" } ],
+ [ "Services" => sub { "
+### IRSpy does not yet check for search, present, delSet,
+concurrentOperations, namedResultSets, etc. and store the information
+is a usable form. This information should probably be harvested from
+the Init Response.
+" } ],
+ [ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ],
+ [ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ],
+ [ "Operators" => \&calc_boolean, $xc ],
+ [ "Named Result Sets" => \&calc_nrs, $xc ],
+ [ "Record syntaxes" => \&calc_recsyn, $xc ],
+ [ "Explain" => \&calc_explain, $xc ],
);
</%perl>
- <h2><% xml_encode($xc->find("e:databaseInfo/e:title")) %></h2>
+ <h2><% xml_encode($xc->find("e:databaseInfo/e:title"), "") %></h2>
<table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
<%perl>
foreach my $ref (@fields) {
</table>
% }
<%perl>
+
sub calc_reliability {
my($xc) = @_;
my @allpings = $xc->findnodes("i:status/i:probe");
my $nall = @allpings;
- return "[untested]" if @allpings == 0;
+ return "[untested]" if $nall == 0;
my @okpings = $xc->findnodes('i:status/i:probe[@ok = "1"]');
my $nok = @okpings;
return "$nok/$nall = " . int(100*$nok/$nall) . "%";
}
+
+sub calc_ap {
+ my($xc, $set) = @_;
+
+ my $expr = 'e:indexInfo/e:index/e:map/e:attr[
+ @set = "'.$set.'" and @type = "1"]';
+ my @bib1nodes = $xc->findnodes($expr);
+ my $nbib1 = @bib1nodes;
+ return "[none]" if $nbib1 == 0;
+
+ my $res = "";
+ my($first, $last);
+ @bib1nodes = sort { $a->findvalue(".") <=> $b->findvalue(".") } @bib1nodes;
+ foreach my $node (@bib1nodes) {
+ my $ap .= $node->findvalue(".");
+ if (!defined $first) {
+ $first = $ap;
+ } elsif (!defined $last || $last == $ap-1) {
+ $last = $ap;
+ } else {
+ # Got a complete range
+ $res .= ", " if $res ne "";
+ $res .= "$first";
+ $res .= "-$last" if defined $last;
+ $first = $ap;
+ $last = undef;
+ }
+ }
+
+ # Leftovers
+ if (defined $first) {
+ $res .= ", " if $res ne "";
+ $res .= "$first";
+ $res .= "-$last" if defined $last;
+ }
+
+ return "$nbib1 access points: $res";
+}
+
+sub calc_boolean {
+ my($xc) = @_;
+
+ ### Note that we are currently interrogating an IRSpy extension.
+ # The standard ZeeRex record should be extended with a
+ # "supports" type for this.
+ my @nodes = $xc->findnodes('i:status/i:boolean[@ok = "1"]');
+ my $res = join(", ", map { $_->findvalue('@operator') } @nodes);
+ $res = "[none]" if $res eq "";
+ return $res;
+}
+
+sub calc_nrs {
+ my($xc) = @_;
+
+ my @nodes = $xc->findnodes('i:status/i:named_resultset[@ok = "1"]');
+ return @nodes ? "Yes" : "No";
+}
+
+sub calc_recsyn {
+ my($xc) = @_;
+
+ my @nodes = $xc->findnodes('e:recordInfo/e:recordSyntax');
+ my $res = join(", ", map { $_->findvalue('@name') } @nodes);
+ $res = "[none]" if $res eq "";
+ return $res;
+}
+
+sub calc_explain {
+ my($xc) = @_;
+
+ my @nodes = $xc->findnodes('i:status/i:explain[@ok = "1"]');
+ my $res = join(", ", map { $_->findvalue('@category') } @nodes);
+ $res = "[none]" if $res eq "";
+ return $res;
+}
+
</%perl>