More SEE ALSOs
[irspy-moved-to-github.git] / lib / ZOOM / IRSpy.pm
index 06bc931..cf2a91f 100644 (file)
@@ -1,4 +1,4 @@
-# $Id: IRSpy.pm,v 1.15 2006-09-18 16:30:25 mike Exp $
+# $Id: IRSpy.pm,v 1.20 2006-09-26 09:24:45 mike Exp $
 
 package ZOOM::IRSpy;
 
@@ -37,9 +37,13 @@ BEGIN {
 
 sub new {
     my $class = shift();
-    my($dbname) = @_;
+    my($dbname, $user, $password) = @_;
 
-    my $conn = new ZOOM::Connection($dbname)
+    my @options;
+    push @options, (user => $user, password => $password)
+       if defined $user;
+
+    my $conn = new ZOOM::Connection($dbname, 0, @options)
        or die "$0: can't connection to IRSpy database 'dbname'";
 
     my $this = bless {
@@ -70,17 +74,17 @@ sub log {
 #
 sub targets {
     my $this = shift();
-    my($targetList) = @_;
+    my(@targets) = @_;
 
-    $this->log("irspy", "setting explicit list of targets '$targetList'");
+    $this->log("irspy", "setting explicit list of targets ",
+              join(", ", map { "'$_'" } @targets));
     $this->{allrecords} = 0;
-    my @targets = grep { $_ ne "" } split /\s+/, $targetList;
     my @qlist;
     foreach my $target (@targets) {
        my($host, $port, $db, $newtarget) = _parse_target_string($target);
        if ($newtarget ne $target) {
            $this->log("irspy_debug", "rewriting '$target' to '$newtarget'");
-           $target = $newtarget; # This written through the ref
+           $target = $newtarget; # This is written through the ref
        }
        push @qlist,
            (qq[(host = "$host" and port = "$port" and path="$db")]);
@@ -154,7 +158,7 @@ sub initialise {
        my $zeerex = _render_record($rs, $i-1, "zeerex");
        #print STDERR "making '$target' record with '$zeerex'\n";
        $target2record{lc($target)} =
-           new ZOOM::IRSpy::Record($target, $zeerex);
+           new ZOOM::IRSpy::Record($this, $target, $zeerex);
        push @{ $this->{targets} }, $target
            if $this->{allrecords};
     }
@@ -164,7 +168,7 @@ sub initialise {
        if (!defined $record) {
            $this->log("irspy_debug", "made new record for '$target'");
            #print STDERR "making '$target' record without zeerex\n";
-           $target2record{$target} = new ZOOM::IRSpy::Record($target);
+           $target2record{$target} = new ZOOM::IRSpy::Record($this, $target);
        } else {
            $this->log("irspy_debug", "using existing record for '$target'");
        }
@@ -201,13 +205,26 @@ sub check {
     my $res = $this->_run_test("Main");
     foreach my $target (sort keys %{ $this->{target2record} }) {
        my $rec = $this->{target2record}->{$target};
-       # It's a shame that LibXML can't pretty-print this
-       print STDERR "$target: zeerex='", $rec->{zeerex}, "' = \n",
-           $rec->{zeerex}->toString(), "\n";
-       ### Write record back to database, if modified.
+       # Write record back to database
+       my $p = $this->{conn}->package();
+       $p->option(action => "specialUpdate");
+       my $xml = $rec->{zeerex}->toString();
+       $p->option(record => $xml);
+       $p->send("update");
+       $p->destroy();
+
+       $p = $this->{conn}->package();
+       $p->send("commit");
+       $p->destroy();
+       if (0) {
+           $xml =~ s/&/&amp/g;
+           $xml =~ s/</&lt;/g;
+           $xml =~ s/>/&gt;/g;
+           print "Updated with xml=<br/>\n<pre>$xml</pre>\n";
+       }
     }
-    return $res;
 
+    return $res;
 }
 
 
@@ -271,7 +288,10 @@ sub isodate {
 
 =head1 SEE ALSO
 
-ZOOM::IRSpy::Record
+ZOOM::IRSpy::Record,
+ZOOM::IRSpy::Web,
+ZOOM::IRSpy::Test,
+ZOOM::IRSpy::Maintenance.
 
 The ZOOM-Perl module,
 http://search.cpan.org/~mirk/Net-Z3950-ZOOM/