<filters> element is now optional.
[metaproxy-moved-to-github.git] / etc / config.xsd
1 <?xml version="1.0" encoding="UTF-8"?>
2 <!-- $Id: config.xsd,v 1.9 2006-01-17 13:46:52 mike Exp $ -->
3 <!--
4         This Schema prescribes the format of YP2 configuration files.
5         Invoke it like this:
6                 xmllint -noout -schema config.xsd config1.xml
7         But use double-dashes for the option names instead of single.
8         (I couldn't include them literally, as, believe it or not,
9         it's an error to include a double dash in an XML comment.
10 -->
11 <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
12            elementFormDefault="qualified"
13            targetNamespace="http://indexdata.dk/yp2/config/1"
14            xmlns:config="http://indexdata.dk/yp2/config/1">
15
16   <xs:element name="yp2">
17     <xs:complexType>
18       <xs:sequence>
19         <xs:element ref="config:start"/>
20         <xs:element minOccurs="0" ref="config:filters"/>
21         <xs:element ref="config:routes"/>
22       </xs:sequence>
23     </xs:complexType>
24   </xs:element>
25
26
27   <xs:element name="start">
28     <xs:complexType>
29       <!-- Absence of elements listed here mandates that <start> is empty -->
30       <xs:attribute name="route" use="required" type="xs:NCName"/>
31     </xs:complexType>
32   </xs:element>
33
34
35   <xs:element name="filters">
36     <xs:complexType>
37       <xs:sequence>
38         <xs:element maxOccurs="unbounded" ref="config:filter"/>
39       </xs:sequence>
40     </xs:complexType>
41   </xs:element>
42
43   <xs:element name="filter">
44     <xs:complexType>
45       <xs:choice>
46         <!-- In general, the content depends on the "type" attribute.
47              Perhaps the various filter-types' configuration
48              structures should each be described by their own little
49              subschemas? -->
50
51         <!-- type="frontend_net" -->
52         <xs:sequence>
53           <xs:element minOccurs="0" ref="config:threads"/>
54           <xs:element ref="config:port"/>
55         </xs:sequence>
56
57         <!-- type="z3950_client" -->
58         <xs:element ref="config:timeout"/>
59
60         <!-- type="log" -->
61         <xs:element ref="config:message"/>
62
63         <!-- type="virt_db" or type="multi" -->
64         <xs:element minOccurs="0" maxOccurs="unbounded" ref="config:virtual"/>
65
66         <!-- type="auth_simple" -->
67         <xs:element ref="config:filename"/>
68
69         <!-- type="backend_test" -->
70         <!-- No elements included -->
71
72         <!-- type="session_shared" -->
73         <!-- No example configuration to deduce from yet -->
74
75         <!-- type="template" -->
76         <!-- No example configuration to deduce from yet -->
77
78       </xs:choice>
79       <xs:attribute name="id" type="xs:NCName"/>
80       <xs:attribute name="refid" type="xs:NCName"/>
81       <xs:attribute name="type">
82         <xs:simpleType>
83           <xs:restriction base="xs:NCName">
84             <xs:enumeration value="frontend_net"/>
85             <xs:enumeration value="z3950_client"/>
86             <xs:enumeration value="log"/>
87             <xs:enumeration value="virt_db"/>
88             <xs:enumeration value="auth_simple"/>
89             <xs:enumeration value="backend_test"/>
90             <xs:enumeration value="multi"/>
91             <xs:enumeration value="session_shared"/>
92             <xs:enumeration value="template"/>
93           </xs:restriction>
94         </xs:simpleType>
95       </xs:attribute>
96     </xs:complexType>
97   </xs:element>
98
99   <xs:element name="threads" type="xs:integer"/>
100   <xs:element name="port" type="xs:string"/>
101   <xs:element name="timeout" type="xs:integer"/>
102   <xs:element name="message" type="xs:NCName"/>
103   <xs:element name="filename" type="xs:string"/>
104
105   <!-- ### This is used differently depending on whether it occurs
106        within a "virt_db" or "multi" filter: for the former, it
107        contains one database and one target; for the latter, it
108        contains an optional vhost and one or more targets.  This
109        schema should be tweaked to enforce this. -->
110   <xs:element name="virtual">
111     <xs:complexType>
112       <xs:sequence>
113         <xs:element minOccurs="0" ref="config:database"/>
114         <xs:element minOccurs="0" ref="config:vhost"/>
115         <xs:element maxOccurs="unbounded" ref="config:target"/>
116       </xs:sequence>
117       <xs:attribute name="route" type="xs:NCName"/>
118     </xs:complexType>
119   </xs:element>
120
121   <xs:element name="database" type="xs:NCName"/>
122   <xs:element name="vhost" type="xs:NCName"/>
123   <xs:element name="target" type="xs:anyURI"/>
124
125
126   <xs:element name="routes">
127     <xs:complexType>
128       <xs:sequence>
129         <xs:element maxOccurs="unbounded" ref="config:route"/>
130       </xs:sequence>
131     </xs:complexType>
132   </xs:element>
133
134   <xs:element name="route">
135     <xs:complexType>
136       <xs:sequence>
137         <xs:element maxOccurs="unbounded" ref="config:filter"/>
138       </xs:sequence>
139       <xs:attribute name="id" use="required" type="xs:NCName"/>
140     </xs:complexType>
141   </xs:element>
142 </xs:schema>