- my $rec = $rs->record(0);
- my $xc = irspy_xpath_context($rec);
- my @fields = (
- [ Protocol => "e:serverInfo/\@protocol" ],
- [ Host => "e:serverInfo/e:host" ],
- [ Port => "e:serverInfo/e:port" ],
- [ "Database Name" => "e:serverInfo/e:database" ],
- [ "Username (if needed)" =>
- "e:serverInfo/e:authentication/e:user" ],
- [ "Password (if needed)" =>
- "e:serverInfo/e:authentication/e:password" ],
- [ Title => "e:databaseInfo/e:title",
- lang => "en", primary => "true" ],
- [ Description => "e:databaseInfo/e:description",
- lang => "en", primary => "true" ],
- [ Author => "e:databaseInfo/e:author" ],
- [ Contact => "e:databaseInfo/e:contact" ],
- [ Extent => "e:databaseInfo/e:extent" ],
- [ History => "e:databaseInfo/e:history" ],
- [ "Language of Records" => "e:databaseInfo/e:langUsage" ],
- [ Restrictions => "e:databaseInfo/e:restrictions" ],
- [ Subjects => "e:databaseInfo/e:subjects" ],
- ### Remember to set e:metaInfo/e:dateModified
- );
+ # No ID supplied -- this is a brand 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[<p class="error">
+You must specify host, port and database name.</p>\n] if $update;
+ undef $update;
+ } 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[<p class="error">
+There is already
+<a href='?op=edit&id=$fakeid'>a record</a>
+for this host, port and database name.
+</p>\n];
+ undef $update;
+ }
+ }
+}
+
+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) ],
+ );
+
+# Update record with submitted data
+my %fieldsByKey = map { ( $_->[0], $_) } @fields;
+my %data;
+foreach my $key ($r->param()) {
+ next if grep { $key eq $_ } qw(op id update);
+ $data{$key} = $r->param($key);
+}
+my @changedFields = modify_xml_document($xc, \%fieldsByKey, \%data);
+if ($update && @changedFields) {
+ my @x = modify_xml_document($xc, { dateModified =>
+ [ dateModified => 0,
+ "Data/time modified",
+ "e:metaInfo/e:dateModified" ] },
+ { dateModified => isodate(time()) });
+ die "Didn't set dateModified!" if !@x;
+ ZOOM::IRSpy::_really_rewrite_record($conn, $xc->getContextNode());
+}
+