%# $Id: edit.mc,v 1.30 2007-04-27 14:04:40 mike Exp $ <%args> $op $id => undef $update => undef <%doc> Since this form is used in many different situations, some care is merited in considering the possibilities: Situation Op ID Update ---------------------------------------------------------------------- Blank form for adding a new target new New target rejected, changes required new X New target accepted and added new X --------------------------------------------------------------------- Existing target to be edited edit X Edit rejected, changes required edit X X Target successfully updated edit X X ---------------------------------------------------------------------- Existing target to be copied copy X New target rejected, changes required copy X X New target accepted and added copy X X ---------------------------------------------------------------------- Submissions, whether of new targets, edits or copies, may be rejected due either to missing mandatory fields or host/name/port that form a duplicate ID. <%perl> # Sanity checking die "op = new but id defined" if $op eq "new" && defined $id; die "op != new but id undefined" if $op ne "new" && !defined $id; my $conn = new ZOOM::Connection("localhost:8018/IR-Explain---1", 0, user => "admin", password => "fruitbat", elementSetName => "zeerex"); my $rec = ''; if (defined $id && ($op ne "copy" || !$update)) { # Existing record my $query = cql_target($id); my $rs = $conn->search(new ZOOM::Query::CQL($query)); if ($rs->size() > 0) { $rec = $rs->record(0); } else { ### Is this an error? I don't think the UI will ever provoke it print qq[

(New ID specified.)

\n]; $id = undef; } } else { # No ID supplied -- this is a brand new record my $protocol = $r->param("protocol"); my $host = $r->param("host"); my $port = $r->param("port"); my $dbname = $r->param("dbname"); if (!defined $protocol || $protocol eq "" || !defined $host || $host eq "" || !defined $port || $port eq "" || !defined $dbname || $dbname eq "") { print qq[

You must specify protocol, host, port and database name.

\n] if $update; undef $update; } else { ### Should use a utility function for this my $query = cql_target($protocol, $host, $port, $dbname); my $rs = $conn->search(new ZOOM::Query::CQL($query)); if ($rs->size() > 0) { my $fakeid = xml_encode(uri_escape(irspy_make_identifier($protocol, $host, $port, $dbname))); print qq[

There is already a record for this host, port and database name.

\n]; undef $update; } } } my $xc = irspy_xpath_context($rec); my @fields = ( [ title => 0, "Name", "e:databaseInfo/e:title", qw() ], [ country => $m->comp("country-list.mc"), "Country", "i:status/i:country" ], [ 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 => $m->comp("libtype-list.mc"), "Type of Library", "i:status/i:libraryType" ], [ 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) ], [ 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 => [ # This list was produced by feeding # http://www.loc.gov/standards/iso639-2/ISO-639-2_values_8bits.txt # through the filter # awk -F'|' '$3 {print$4}' # and shortening some of the longer names by hand "", "English", "Afar", "Abkhazian", "Afrikaans", "Akan", "Albanian", "Amharic", "Arabic", "Aragonese", "Armenian", "Assamese", "Avaric", "Avestan", "Aymara", "Azerbaijani", "Bashkir", "Bambara", "Basque", "Belarusian", "Bengali", "Bihari", "Bislama", "Bosnian", "Breton", "Bulgarian", "Burmese", "Catalan; Valencian", "Chamorro", "Chechen", "Chinese", "Church Slavic; Old Slavonic", "Chuvash", "Cornish", "Corsican", "Cree", "Czech", "Danish", "Divehi; Dhivehi; Maldivian", "Dutch; Flemish", "Dzongkha", "Esperanto", "Estonian", "Ewe", "Faroese", "Fijian", "Finnish", "French", "Western Frisian", "Fulah", "Georgian", "German", "Gaelic; Scottish Gaelic", "Irish", "Galician", "Manx", "Greek, Modern (1453-)", "Guarani", "Gujarati", "Haitian; Haitian Creole", "Hausa", "Hebrew", "Herero", "Hindi", "Hiri Motu", "Hungarian", "Igbo", "Icelandic", "Ido", "Sichuan Yi", "Inuktitut", "Interlingue", "Interlingua", "Indonesian", "Inupiaq", "Italian", "Javanese", "Japanese", "Kalaallisut; Greenlandic", "Kannada", "Kashmiri", "Kanuri", "Kazakh", "Khmer", "Kikuyu; Gikuyu", "Kinyarwanda", "Kirghiz", "Komi", "Kongo", "Korean", "Kuanyama; Kwanyama", "Kurdish", "Lao", "Latin", "Latvian", "Limburgan; Limburger; Limburgish", "Lingala", "Lithuanian", "Luxembourgish; Letzeburgesch", "Luba-Katanga", "Ganda", "Macedonian", "Marshallese", "Malayalam", "Maori", "Marathi", "Malay", "Malagasy", "Maltese", "Moldavian", "Mongolian", "Nauru", "Navajo; Navaho", "Ndebele, South; South Ndebele", "Ndebele, North; North Ndebele", "Ndonga", "Nepali", "Norwegian Nynorsk", "Norwegian Bokmål", "Norwegian", "Chichewa; Chewa; Nyanja", "Occitan (post 1500); Provençal", "Ojibwa", "Oriya", "Oromo", "Ossetian; Ossetic", "Panjabi; Punjabi", "Persian", "Pali", "Polish", "Portuguese", "Pushto", "Quechua", "Raeto-Romance", "Romanian", "Rundi", "Russian", "Sango", "Sanskrit", "Serbian", "Croatian", "Sinhala; Sinhalese", "Slovak", "Slovenian", "Northern Sami", "Samoan", "Shona", "Sindhi", "Somali", "Sotho, Southern", "Spanish; Castilian", "Sardinian", "Swati", "Sundanese", "Swahili", "Swedish", "Tahitian", "Tamil", "Tatar", "Telugu", "Tajik", "Tagalog", "Thai", "Tibetan", "Tigrinya", "Tonga (Tonga Islands)", "Tswana", "Tsonga", "Turkmen", "Turkish", "Twi", "Uighur; Uyghur", "Ukrainian", "Urdu", "Uzbek", "Venda", "Vietnamese", "Volapük", "Welsh", "Walloon", "Wolof", "Xhosa", "Yiddish", "Yoruba", "Zhuang; Chuang", "Zulu", ], "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(), $id); }

<% xml_encode($xc->find("e:databaseInfo/e:title"), "[Untitled]") %>

% if ($update && @changedFields) { % my $nchanges = @changedFields;

The record has been <% $op ne "edit" ? "created" : "updated" %>.
Changed <% $nchanges %> field<% $nchanges == 1 ? "" : "s" %>: <% join(", ", map { xml_encode($_->[2]) } @changedFields) %>.

% }
<%perl> foreach my $ref (@fields) { my($name, $nlines, $caption, $xpath, @addAfter) = @$ref; % }
<% $caption %> % my $rawval = $xc->findvalue($xpath); % my $val = xml_encode($rawval, ""); % if (ref $nlines) { % } elsif ($nlines) { % } else { % } <& /help/link.mc, help => "edit/$name" &>
% if (defined $id) { % }
<%perl> if (@changedFields && 0) { my $x = $xc->getContextNode()->toString(); $x = xml_encode($x); #$x =~ s/$//gm; print "
$x
\n"; }