diff options
author | Rob Austein <sra@hactrn.net> | 2010-09-16 21:30:30 +0000 |
---|---|---|
committer | Rob Austein <sra@hactrn.net> | 2010-09-16 21:30:30 +0000 |
commit | be7b735fa44c0158d8ab0bc65157df45a7b45783 (patch) | |
tree | 87cfad3c536758d9eeaf96a3d16d2ad57ba5e7a5 /rpkid.without_tls/up-down-schema.rnc | |
parent | 46f13adda8ac616fa45410dc2e28a2dcc006e973 (diff) |
Preliminary version of rpkid et al with all the TLS code ripped out.
Not quite ready for cutover yet, may need some conversion tools and
instructions, but checking this into a branch (well, sort of) so that
others can look at the code changes involved, try it out themselves,
etc. At some point this will merge back into rpkid/ directory and
there will be only one, without TLS, but converting the testbed is
going to require a flag day, so need to keep the TLS version around
until then.
svn path=/rpkid.without_tls; revision=3449
Diffstat (limited to 'rpkid.without_tls/up-down-schema.rnc')
-rw-r--r-- | rpkid.without_tls/up-down-schema.rnc | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/rpkid.without_tls/up-down-schema.rnc b/rpkid.without_tls/up-down-schema.rnc new file mode 100644 index 00000000..ad3c9a82 --- /dev/null +++ b/rpkid.without_tls/up-down-schema.rnc @@ -0,0 +1,71 @@ +# $Id$ +# +# RelaxNG Scheme for up-down protocol, extracted from APNIC Wiki. +# +# libxml2 (including xmllint) only groks the XML syntax of RelaxNG, so +# run the compact syntax through trang to get XML syntax. + +default namespace = "http://www.apnic.net/specs/rescerts/up-down/" + +grammar { + start = element message { + attribute version { xsd:positiveInteger { maxInclusive="1" } }, + attribute sender { xsd:token { maxLength="1024" } }, + attribute recipient { xsd:token { maxLength="1024" } }, + payload + } + + payload |= attribute type { "list" }, list_request + payload |= attribute type { "list_response"}, list_response + payload |= attribute type { "issue" }, issue_request + payload |= attribute type { "issue_response"}, issue_response + payload |= attribute type { "revoke" }, revoke_request + payload |= attribute type { "revoke_response"}, revoke_response + payload |= attribute type { "error_response"}, error_response + + list_request = empty + list_response = class* + + class = element class { + attribute class_name { xsd:token { maxLength="1024" } }, + attribute cert_url { xsd:string { maxLength="4096" } }, + attribute resource_set_as { xsd:string { maxLength="512000" pattern="[\-,0-9]*" } }, + attribute resource_set_ipv4 { xsd:string { maxLength="512000" pattern="[\-,/.0-9]*" } }, + attribute resource_set_ipv6 { xsd:string { maxLength="512000" pattern="[\-,/:0-9a-fA-F]*" } }, + attribute resource_set_notafter { xsd:dateTime { pattern=".*Z" } }?, + attribute suggested_sia_head { xsd:anyURI { maxLength="1024" pattern="rsync://.+"} }?, + element certificate { + attribute cert_url { xsd:string { maxLength="4096" } }, + attribute req_resource_set_as { xsd:string { maxLength="512000" pattern="[\-,0-9]*" } }?, + attribute req_resource_set_ipv4 { xsd:string { maxLength="512000" pattern="[\-,/.0-9]*" } }?, + attribute req_resource_set_ipv6 { xsd:string { maxLength="512000" pattern="[\-,/:0-9a-fA-F]*" } }?, + xsd:base64Binary { maxLength="512000" } + }*, + element issuer { xsd:base64Binary { maxLength="512000" } } + } + + issue_request = element request { + attribute class_name { xsd:token { maxLength="1024" } }, + attribute req_resource_set_as { xsd:string { maxLength="512000" pattern="[\-,0-9]*" } }?, + attribute req_resource_set_ipv4 { xsd:string { maxLength="512000" pattern="[\-,/.0-9]*" } }?, + attribute req_resource_set_ipv6 { xsd:string { maxLength="512000" pattern="[\-,/:0-9a-fA-F]*" } }?, + xsd:base64Binary { maxLength="512000" } + } + issue_response = class + + revoke_request = revocation + revoke_response = revocation + + revocation = element key { + attribute class_name { xsd:token { maxLength="1024" } }, + attribute ski { xsd:token { maxLength="1024" } } + } + + error_response = + element status { xsd:positiveInteger { maxInclusive="999999999999999" } }, + element description { attribute xml:lang { xsd:language }, xsd:string { maxLength="1024" } }? +} + +# Local Variables: +# indent-tabs-mode: nil +# End: |