<%perl>
my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
$conn->option(elementSetName => "zeerex");
<%perl>
my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
$conn->option(elementSetName => "zeerex");
$m->comp("/details/error.mc",
title => "Error", message => "No such ID '$id'");
} else {
$m->comp("/details/error.mc",
title => "Error", message => "No such ID '$id'");
} else {
+ [ Name => "e:databaseInfo/e:title",
+ lang => "en", primary => "true" ],
+ [ Country => "i:status/i:country" ],
[ "Last Checked" => "i:status/i:probe[last()]" ],
[ Protocol => "e:serverInfo/\@protocol" ],
[ Host => "e:serverInfo/e:host" ],
[ Port => "e:serverInfo/e:port" ],
[ "Database Name" => "e:serverInfo/e:database" ],
[ "Last Checked" => "i:status/i:probe[last()]" ],
[ Protocol => "e:serverInfo/\@protocol" ],
[ Host => "e:serverInfo/e:host" ],
[ Port => "e:serverInfo/e:port" ],
[ "Database Name" => "e:serverInfo/e:database" ],
[ "Username (if needed)" =>
"e:serverInfo/e:authentication/e:user" ],
[ "Password (if needed)" =>
"e:serverInfo/e:authentication/e:password" ],
[ "Username (if needed)" =>
"e:serverInfo/e:authentication/e:user" ],
[ "Password (if needed)" =>
"e:serverInfo/e:authentication/e:password" ],
[ Description => "e:databaseInfo/e:description",
lang => "en", primary => "true" ],
[ Author => "e:databaseInfo/e:author" ],
[ Contact => "e:databaseInfo/e:contact" ],
[ Description => "e:databaseInfo/e:description",
lang => "en", primary => "true" ],
[ Author => "e:databaseInfo/e:author" ],
[ Contact => "e:databaseInfo/e:contact" ],
[ Extent => "e:databaseInfo/e:extent" ],
[ History => "e:databaseInfo/e:history" ],
[ "Language of Records" => "e:databaseInfo/e:langUsage" ],
[ Extent => "e:databaseInfo/e:extent" ],
[ History => "e:databaseInfo/e:history" ],
[ "Language of Records" => "e:databaseInfo/e:langUsage" ],
[ "Implementation Name" => "i:status/i:implementationName" ],
[ "Implementation Version" => "i:status/i:implementationVersion" ],
[ "Reliability" => \&calc_reliability, $xc ],
[ "Implementation Name" => "i:status/i:implementationName" ],
[ "Implementation Version" => "i:status/i:implementationVersion" ],
[ "Reliability" => \&calc_reliability, $xc ],
- [ "Services" => sub { "### IRSpy does not yet check for search, present, delSet, concurrentOperations, namedResultSets, etc. and store the information is a usable form." } ],
+ [ "Services" => \&calc_init_options, $xc ],
[ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ],
[ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ],
[ "Operators" => \&calc_boolean, $xc ],
[ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ],
[ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ],
[ "Operators" => \&calc_boolean, $xc ],
- [ "Explain" => sub { "### CategoryList, TargetInfo, DatabaseInfo, RecordSyntaxInfo, AttributeSetInfo, AttributeDetails" } ],
+ [ "Explain" => \&calc_explain, $xc ],
<table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
<%perl>
foreach my $ref (@fields) {
<table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
<%perl>
foreach my $ref (@fields) {
+sub calc_init_options {
+ my($xc) = @_;
+
+ my @ops;
+ my @nodes = $xc->findnodes('e:configInfo/e:supports/@type');
+ foreach my $node (@nodes) {
+ my $type = $node->value();
+ if ($type =~ s/^z3950_//) {
+ push @ops, $type;
+ }
+ }
+
+ return join(", ", @ops);
+}
+
# The standard ZeeRex record should be extended with a
# "supports" type for this.
my @nodes = $xc->findnodes('i:status/i:boolean[@ok = "1"]');
# The standard ZeeRex record should be extended with a
# "supports" type for this.
my @nodes = $xc->findnodes('i:status/i:boolean[@ok = "1"]');
- return join(", ", map { $_->findvalue('@operator') } @nodes);
+ 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";
- return join(", ", map { $_->findvalue('@name') } @nodes);
+ 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;