X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=web%2Fhtdocs%2Fdetails%2Fedit.mc;h=7f16a1bd18dba6ca9a91838a2bdf039672a3d3be;hb=c48b25b45d787d09baa6437121c70a457537fd50;hp=38737dfb455adef3b1f3a761be3d36ae5a2d43bd;hpb=b3131b1fc7f1a37e362f1ac342f3bf5833f049a0;p=irspy-moved-to-github.git
diff --git a/web/htdocs/details/edit.mc b/web/htdocs/details/edit.mc
index 38737df..7f16a1b 100644
--- a/web/htdocs/details/edit.mc
+++ b/web/htdocs/details/edit.mc
@@ -1,70 +1,146 @@
-%# $Id: edit.mc,v 1.2 2006-10-27 00:47:24 mike Exp $
+%# $Id: edit.mc,v 1.16 2006-11-16 17:14:46 mike Exp $
<%args>
-$id
+$id => undef
%args>
-<%once>
-use ZOOM;
-%once>
<%perl>
-my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
-$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'");
+my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1", 0,
+ user => "admin", password => "fruitbat",
+ elementSetName => "zeerex");
+my $rec = '
\n";
+ # Existing record
+ my $query = 'rec.id="' . cql_quote($id) . '"';
+ my $rs = $conn->search(new ZOOM::Query::CQL($query));
+ my $n = $rs->size();
+ if ($n == 0) {
+ $id = undef;
+ } else {
+ $rec = $rs->record(0);
+ }
+
} else {
- my $rec = $rs->record(0);
- my $xc = irspy_xpath_context($rec);
- my @fields =
- (
- [ protocol => 0, "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" ],
- [ username => 0, "Username (if needed)", "e:serverInfo/e:authentication/e:user" ],
- [ password => 0, "Password (if needed)", "e:serverInfo/e:authentication/e:password" ],
- [ title => 0, "title", "e:databaseInfo/e:title", lang => "en", primary => "true" ],
- [ description => 5, "Description", "e:databaseInfo/e:description", lang => "en", primary => "true" ],
- [ author => 0, "Author", "e:databaseInfo/e:author" ],
- [ contact => 0, "Contact", "e:databaseInfo/e:contact" ],
- [ extent => 3, "Extent", "e:databaseInfo/e:extent" ],
- [ history => 5, "History", "e:databaseInfo/e:history" ],
- [ language => 0, "Language of Records", "e:databaseInfo/e:langUsage" ],
- [ restrictions => 2, "Restrictions", "e:databaseInfo/e:restrictions" ],
- [ subjects => 2, "Subjects", "e:databaseInfo/e:subjects" ],
- ### Remember to set e:metaInfo/e:dateModified
- );
+ # New record
+ print "New record
\n";
+ 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); + } + + my $query = cql_target($host, $port, $dbname); +} + +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"); +if (defined $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); + } + + $nchanges = modify_xml_document($xc, \%fieldsByKey, \%data); + if ($nchanges) { + ### Set e:metaInfo/e:dateModified + } + ZOOM::IRSpy::_really_rewrite_record($conn, $xc->getContextNode()); +} %perl> -$x\n"; + } +%perl>