X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Ffull.mc;h=843841fc6484de7eb2de25119c306c1a38d8525c;hp=62faa57ca77c05b8bda264736e6fce4ef818a280;hb=1562bacbefb64628e0292fc807392c8c39211a1d;hpb=213892fec98c0d68bf358bce336a3ad8d3d2b033 diff --git a/web/htdocs/details/full.mc b/web/htdocs/details/full.mc index 62faa57..843841f 100644 --- a/web/htdocs/details/full.mc +++ b/web/htdocs/details/full.mc @@ -1,4 +1,4 @@ -%# $Id: full.mc,v 1.5 2006-11-06 11:37:43 mike Exp $ +%# $Id: full.mc,v 1.7 2006-11-06 16:22:17 mike Exp $ <%args> $id @@ -43,7 +43,7 @@ if ($n == 0) { [ "Implementation ID" => "i:status/i:implementationId" ], [ "Implementation Name" => "i:status/i:implementationName" ], [ "Implementation Version" => "i:status/i:implementationVersion" ], - [ "Reliability" => sub { "### 97%" } ], + [ "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" } ], @@ -51,14 +51,14 @@ if ($n == 0) { [ "Explain" => sub { "### CategoryList, TargetInfo, DatabaseInfo, RecordSyntaxInfo, AttributeSetInfo, AttributeDetails" } ], ); -

<% xml_encode($id) %>

+

<% xml_encode($xc->find("e:databaseInfo/e:title")) %>

<%perl> foreach my $ref (@fields) { - my($caption, $xpath, %attrs) = @$ref; + my($caption, $xpath, @args) = @$ref; my $data; if (ref $xpath && ref($xpath) eq "CODE") { - $data = &$xpath(); + $data = &$xpath(@args); } else { $data = $xc->find($xpath); } @@ -72,3 +72,15 @@ if ($n == 0) { % }
% } +<%perl> +sub calc_reliability { + my($xc) = @_; + + my @allpings = $xc->findnodes("i:status/i:probe"); + my $nall = @allpings; + return "[untested]" if @allpings == 0; + my @okpings = $xc->findnodes('i:status/i:probe[@ok = "1"]'); + my $nok = @okpings; + return "$nok/$nall = " . int(100*$nok/$nall) . "%"; +} +