X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=inline;f=web%2Fhtdocs%2Fdetails%2Fedit.mc;h=917c9f3f94cf438d6e17fdadf53af5ecd5f9ab2a;hb=b7b5603afb2143500f0d347bd92a9ca723f55746;hp=38737dfb455adef3b1f3a761be3d36ae5a2d43bd;hpb=2b39e6f80760293f9cf9673e0c2230ec62797001;p=irspy-moved-to-github.git
diff --git a/web/htdocs/details/edit.mc b/web/htdocs/details/edit.mc
index 38737df..917c9f3 100644
--- a/web/htdocs/details/edit.mc
+++ b/web/htdocs/details/edit.mc
@@ -1,70 +1,144 @@
-%# $Id: edit.mc,v 1.2 2006-10-27 00:47:24 mike Exp $
+%# $Id: edit.mc,v 1.17 2006-11-16 17:27:15 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 = '
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 ($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>