X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=xml%2Fschema%2Fmetaproxy.rnc;h=d6b6057bb873425f5ca45bb67342cf3e85e6a1ba;hb=511c535c4938dfc01450e8748508899401a5e4ea;hp=8e92daa1bcdbec9bd96256bc41b79db6003ff6a0;hpb=9c37ed608370ee5d47d5290593bd5a5eeba13594;p=metaproxy-moved-to-github.git diff --git a/xml/schema/metaproxy.rnc b/xml/schema/metaproxy.rnc index 8e92daa..d6b6057 100644 --- a/xml/schema/metaproxy.rnc +++ b/xml/schema/metaproxy.rnc @@ -1,5 +1,5 @@ # Metaproxy XML config file schemas -# $Id: metaproxy.rnc,v 1.5 2006-10-10 15:10:18 marc Exp $ +# $Id: metaproxy.rnc,v 1.13 2007-01-02 15:35:36 marc Exp $ # # Copyright (c) 2005-2006, Index Data. # @@ -19,33 +19,38 @@ # For information on RelaxNG see http://relaxng.org # see also http://books.xmlschemata.org/relaxng/ -default namespace = "http://indexdata.dk/yp2/config/1" -start = metaproxy +namespace mp = "http://indexdata.com/metaproxy" + +start |= metaproxy + +include "retrievalinfo.rnc" metaproxy = - element yp2 { - element start { - attribute route { xsd:NCName } + element mp:metaproxy { + attribute version { "1.0" }, + element mp:start { + attribute route { xsd:NCName } }, - element filters { filter+ }?, - element routes { route+ } + element mp:filters { filter+ }?, + element mp:routes { route+ } } route = - element route { + element mp:route { attribute id { xsd:NCName }, filter+ } filter = - element filter { + element mp:filter { filter_refid | filter_auth_simple | filter_backend_test | filter_bounce | filter_frontend_net | filter_http_file + | filter_load_balance | filter_log | filter_multi | filter_query_rewrite @@ -54,6 +59,7 @@ filter = | filter_sru_z3950 | filter_virt_db | filter_z3950_client + | filter_zeerex_explain } filter_refid = attribute refid { xsd:NCName } @@ -62,9 +68,9 @@ filter_auth_simple = attribute type { "auth_simple" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element userRegister { xsd:string }?, - element targetRegister { xsd:string }?, - element discardUnauthorisedTargets { empty }? + element mp:userRegister { xsd:string }?, + element mp:targetRegister { xsd:string }?, + element mp:discardUnauthorisedTargets { empty }? filter_backend_test = attribute type { "backend_test" }, @@ -80,26 +86,32 @@ filter_frontend_net = attribute type { "frontend_net" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element threads { xsd:integer }?, - element port { xsd:string } + element mp:threads { xsd:integer }?, + element mp:port { xsd:string }, + element mp:timeout { xsd:integer }? filter_http_file = attribute type { "http_file" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element mimetypes { xsd:string }, - element area { - element documentroot { xsd:string }, - element prefix { xsd:string } + element mp:mimetypes { xsd:string }, + element mp:area { + element mp:documentroot { xsd:string }, + element mp:prefix { xsd:string } } +filter_load_balance = + attribute type { "load_balance" }, + attribute id { xsd:NCName }?, + attribute name { xsd:NCName }? + filter_log = attribute type { "log" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element message { xsd:string }?, - element filename { xsd:string }?, - element category { + element mp:message { xsd:string }?, + element mp:filename { xsd:string }?, + element mp:category { attribute init-options { xsd:boolean }?, attribute request-session { xsd:boolean }?, attribute response-session { xsd:boolean }?, @@ -112,17 +124,19 @@ filter_multi = attribute type { "multi" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element target { + element mp:target { attribute route { xsd:string }, xsd:string }*, - element hideunavailable { empty }? + element mp:hideunavailable { empty }? filter_query_rewrite = attribute type { "query_rewrite" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element xslt { xsd:string } + element mp:xslt { + attribute stylesheet { xsd:string } + } filter_record_transform = attribute type { "record_transform" }, @@ -134,11 +148,11 @@ filter_session_shared = attribute type { "session_shared" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element resultset { + element mp:resultset { attribute max { xsd:integer }, attribute ttl { xsd:integer } }, - element session { + element mp:session { attribute ttl { xsd:integer } } @@ -151,35 +165,19 @@ filter_virt_db = attribute type { "virt_db" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element virtual { + element mp:virtual { attribute route { xsd:NCName }?, - element database { xsd:NCName }, - element target { xsd:string }+ + element mp:database { xsd:NCName }, + element mp:target { xsd:string }+ }+ filter_z3950_client = attribute type { "z3950_client" }, attribute id { xsd:NCName }?, attribute name { xsd:NCName }?, - element timeout { xsd:integer }? - -retrievalinfo = - element retrievalinfo { - element retrieval { - attribute syntax { xsd:string }, - attribute name { xsd:string }?, - attribute identifier { xsd:string }?, - attribute backendsyntax { xsd:string }?, - attribute backendname { xsd:string }?, - element convert { - element marc { - attribute inputformat { xsd:string }, - attribute outputformat { xsd:string }, - attribute inputcharset { xsd:string } - }, - element xslt { - attribute stylesheet { xsd:string } - }? - }? - }+ - } + element mp:timeout { xsd:integer }? + +filter_zeerex_explain = + attribute type { "zeerex_explain" }, + attribute id { xsd:NCName }?, + attribute name { xsd:NCName }?