X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Fedit.mc;h=1d789f0655d32243c2513428d59e5a9c50a1c287;hb=de9c3da6b5dbbcd6e43d8974328c0fd42f70c9d2;hp=6987d88accb0475ecce453090137e73d4eda708b;hpb=c61b4e8dac52975ffa741d9643e3c1b94d9db6df;p=irspy-moved-to-github.git
diff --git a/web/htdocs/details/edit.mc b/web/htdocs/details/edit.mc
index 6987d88..1d789f0 100644
--- a/web/htdocs/details/edit.mc
+++ b/web/htdocs/details/edit.mc
@@ -1,103 +1,177 @@
-%# $Id: edit.mc,v 1.3 2006-10-27 16:58:41 mike Exp $
+%# $Id: edit.mc,v 1.20 2006-11-17 22:39:17 mike Exp $
+<%doc>
+Since this form is used in many different situations, some care is
+merited in considering the possibilities:
+
+New? Copy ID? Situation
+--------------------------------------------------------------------------
+Y Blank form for adding a new target.
+Y New target submitted successfully.
+Y Partial new target submitted, requiring more
+
+ Y Existing target to be edited.
+ Y Existing target has been updated.
+
+ Y Y Existing target to be copied.
+ Y New or copied target rejected due to duplicate ID.
+--------------------------------------------------------------------------
+%doc>
<%args>
-$id
+$new => undef
+$copy => undef
+$id => undef
%args>
-<%once>
-use ZOOM;
-%once>
<%perl>
my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1", 0,
- user => "admin", password => "fruitbat");
-$conn->option(elementSetName => "zeerex");
-my $qid = $id;
-$qid =~ s/"/\\"/g;
-my $query = qq[rec.id="$qid"];
-my $rs = $conn->search(new ZOOM::Query::CQL($query));
-my $n = $rs->size();
-if ($n == 0) {
- $m->comp("/details/error.mc",
- title => "Error", message => "No such ID '$id'");
+ user => "admin", password => "fruitbat",
+ elementSetName => "zeerex");
+my $rec = '
\n";
- } elsif ($node->isa("XML::LibXML::Element")) {
- my $child = $node->firstChild();
- die "element child $child is not text"
- if !ref $child || !$child->isa("XML::LibXML::Text");
- $child->setData($value);
- print "Elem $key <- '$value' ($xpath)
\n";
- } else {
- warn "unexpected node type $node";
- }
- } else {
- print "$key='$value' ($xpath) no nodes
\n";
- ### Make new node ... heaven knows how ...
- }
+ # New record
+ my $host = $r->param("host");
+ my $port = $r->param("port");
+ my $dbname = $r->param("dbname");
+ if (!defined $host || $host eq "" ||
+ !defined $port || $port eq "" ||
+ !defined $dbname || $dbname eq "") {
+ print qq[
+You must specify host, port and database name.
\n]; + $r->param(update => 0); + } else { + my $query = cql_target($host, $port, $dbname); + my $rs = $conn->search(new ZOOM::Query::CQL($query)); + if ($rs->size() > 0) { + my $fakeid = xml_encode(uri_escape("$host:$port/$dbname")); + print qq[+There is already +a record +for this host, port and database name. +
\n]; } - ZOOM::IRSpy::_really_rewrite_record($conn, $xc->getContextNode()); } +} + +my $xc = irspy_xpath_context($rec); +my @fields = + ( + [ protocol => [ qw(Z39.50 SRW SRU SRW/U) ], + "Protocol", "e:serverInfo/\@protocol" ], + [ host => 0, "Host", "e:serverInfo/e:host" ], + [ port => 0, "Port", "e:serverInfo/e:port" ], + [ dbname => 0, "Database Name", "e:serverInfo/e:database", + qw(e:host e:port) ], + [ type => [ qw(Academic Public Corporate Special National Education Other) ], + "Type of Library", "i:status/i:libraryType" ], + [ country => 0, "Country", "i:status/i:country" ], + [ username => 0, "Username (if needed)", "e:serverInfo/e:authentication/e:user", + qw() ], + [ password => 0, "Password (if needed)", "e:serverInfo/e:authentication/e:password", + qw(e:user) ], + [ title => 0, "Title", "e:databaseInfo/e:title", + qw() ], + [ description => 5, "Description", "e:databaseInfo/e:description", + qw(e:title) ], + [ author => 0, "Author", "e:databaseInfo/e:author", + qw(e:title e:description) ], + [ hosturl => 0, "URL to Hosting Organisation", "i:status/i:hostURL" ], + [ contact => 0, "Contact", "e:databaseInfo/e:contact", + qw(e:title e:description) ], + [ extent => 3, "Extent", "e:databaseInfo/e:extent", + qw(e:title e:description) ], + [ history => 5, "History", "e:databaseInfo/e:history", + qw(e:title e:description) ], + [ language => 0, "Language of Records", "e:databaseInfo/e:langUsage", + qw(e:title e:description) ], + [ restrictions => 2, "Restrictions", "e:databaseInfo/e:restrictions", + qw(e:title e:description) ], + [ subjects => 2, "Subjects", "e:databaseInfo/e:subjects", + qw(e:title e:description) ], + ); + +my $nchanges = 0; +my $update = $r->param("update"); + + # Update record with submitted data + my %fieldsByKey = map { ( $_->[0], $_) } @fields; + my %data; + foreach my $key ($r->param()) { + next if grep { $key eq $_ } qw(id update new copy); + $data{$key} = $r->param($key); + } + my $mynchanges = modify_xml_document($xc, \%fieldsByKey, \%data); + +if ($update) { + $nchanges = $mynchanges; + if ($nchanges) { + ### Set e:metaInfo/e:dateModified + } + ZOOM::IRSpy::_really_rewrite_record($conn, $xc->getContextNode()); +} %perl> -Thanks for the update!
\n" if defined $update; - +<%perl> + if ($nchanges && 0) { + my $x = $xc->getContextNode()->toString(); + $x = xml_encode($x); + #$x =~ s/$/$x\n"; + } +%perl>