jboss-as-remoting_1_1.xsd 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. ~ JBoss, Home of Professional Open Source.
  4. ~ Copyright 2011, Red Hat, Inc., and individual contributors
  5. ~ as indicated by the @author tags. See the copyright.txt file in the
  6. ~ distribution for a full listing of individual contributors.
  7. ~
  8. ~ This is free software; you can redistribute it and/or modify it
  9. ~ under the terms of the GNU Lesser General Public License as
  10. ~ published by the Free Software Foundation; either version 2.1 of
  11. ~ the License, or (at your option) any later version.
  12. ~
  13. ~ This software is distributed in the hope that it will be useful,
  14. ~ but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. ~ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. ~ Lesser General Public License for more details.
  17. ~
  18. ~ You should have received a copy of the GNU Lesser General Public
  19. ~ License along with this software; if not, write to the Free
  20. ~ Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  21. ~ 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  22. -->
  23. <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
  24. targetNamespace="urn:jboss:domain:remoting:1.1"
  25. xmlns="urn:jboss:domain:remoting:1.1"
  26. elementFormDefault="qualified"
  27. attributeFormDefault="unqualified"
  28. version="1.0">
  29. <!-- The remoting subsystem root element -->
  30. <xs:element name="subsystem" type="subsystem"/>
  31. <xs:complexType name="subsystem">
  32. <xs:annotation>
  33. <xs:documentation>
  34. <![CDATA[
  35. The configuration of the Remoting subsystem.
  36. The 'worker-thread-pool' element configures the worker thread pool.
  37. The nested "connector" element(s) define connectors for this subsystem.
  38. ]]>
  39. </xs:documentation>
  40. </xs:annotation>
  41. <xs:sequence>
  42. <xs:element name="worker-thread-pool" type="workerThreadsType" minOccurs="0"/>
  43. <xs:element name="connector" type="connector" minOccurs="0" maxOccurs="unbounded"/>
  44. <xs:element name="outbound-connections" minOccurs="0" type="outbound-connectionsType" />
  45. </xs:sequence>
  46. </xs:complexType>
  47. <xs:complexType name="workerThreadsType">
  48. <xs:annotation>
  49. <xs:documentation>
  50. <![CDATA[
  51. The configuration of the worker thread pool.
  52. The attributes correspond to the following xnio options:
  53. ]]>
  54. </xs:documentation>
  55. </xs:annotation>
  56. <xs:attribute name="read-threads" type="xs:integer" use="optional"/>
  57. <xs:attribute name="write-threads" type="xs:integer" use="optional"/>
  58. <xs:attribute name="task-core-threads" type="xs:integer" use="optional"/>
  59. <xs:attribute name="task-max-threads" type="xs:integer" use="optional"/>
  60. <xs:attribute name="task-keepalive" type="xs:integer" use="optional"/>
  61. <xs:attribute name="task-limit" type="xs:integer" use="optional"/>
  62. </xs:complexType>
  63. <xs:complexType name="connector">
  64. <xs:annotation>
  65. <xs:documentation>
  66. <![CDATA[
  67. The configuration of a Remoting connector.
  68. The "name" attribute specifies the unique name of this connector.
  69. The "socket-binding" attribute specifies the name (or names) of the socket binding(s) to attach to.
  70. The optional nested "sasl" element contains the SASL authentication configuration for this connector.
  71. The optional nested "authentication-provider" element contains the name of the authentication provider to
  72. use for incoming connections.
  73. ]]>
  74. </xs:documentation>
  75. </xs:annotation>
  76. <xs:all>
  77. <xs:element name="sasl" type="sasl" minOccurs="0"/>
  78. <xs:element name="authentication-provider" type="ref" minOccurs="0"/>
  79. <xs:element name="properties" type="properties" minOccurs="0"/>
  80. </xs:all>
  81. <xs:attribute name="socket-binding" type="name-list" use="required"/>
  82. <xs:attribute name="name" type="xs:string" use="required"/>
  83. <xs:attribute name="security-realm" type="xs:string" use="optional"/>
  84. </xs:complexType>
  85. <xs:complexType name="sasl">
  86. <xs:annotation>
  87. <xs:documentation>
  88. <![CDATA[
  89. The configuration of the SASL authentication layer for this server.
  90. The optional nested "include-mechanisms" element contains a whitelist of allowed SASL mechanism names.
  91. No mechanisms will be allowed which are not present in this list.
  92. The optional nested "qop" element contains a list of quality-of-protection values, in decreasing order
  93. of preference.
  94. The optional nested "strength" element contains a list of cipher strength values, in decreasing order
  95. of preference.
  96. The optional nested "reuse-session" boolean element specifies whether or not the server should attempt
  97. to reuse previously authenticated session information. The mechanism may or may not support such reuse,
  98. and other factors may also prevent it.
  99. The optional nested "server-auth" boolean element specifies whether the server should authenticate to the
  100. client. Not all mechanisms may support this setting.
  101. The optional nested "policy" boolean element specifies a policy to use to narrow down the available set
  102. of mechanisms.
  103. ]]>
  104. </xs:documentation>
  105. </xs:annotation>
  106. <xs:all>
  107. <xs:element name="include-mechanisms" type="name-listType" minOccurs="0"/>
  108. <xs:element name="qop" type="qop-listType" minOccurs="0"/>
  109. <xs:element name="strength" type="strength" minOccurs="0"/>
  110. <xs:element name="reuse-session" type="boolean-element" minOccurs="0"/>
  111. <xs:element name="server-auth" type="boolean-element" minOccurs="0"/>
  112. <xs:element name="policy" type="policy" minOccurs="0"/>
  113. <xs:element name="properties" type="properties" minOccurs="0"/>
  114. </xs:all>
  115. </xs:complexType>
  116. <xs:complexType name="policy">
  117. <xs:annotation>
  118. <xs:documentation>
  119. <![CDATA[
  120. Policy criteria items to use in order to choose a SASL mechanism.
  121. The optional nested "forward-secrecy" element contains a boolean value which specifies whether mechanisms
  122. that implement forward secrecy between sessions are required. Forward secrecy means that breaking into
  123. one session will not automatically provide information for breaking into future sessions.
  124. The optional nested "no-active" element contains a boolean value which specifies whether mechanisms
  125. susceptible to active (non-dictionary) attacks are not permitted. "false" to permit, "true" to deny.
  126. The optional nested "no-anonymous" element contains a boolean value which specifies whether mechanisms
  127. that accept anonymous login are permitted. "false" to permit, "true" to deny.
  128. The optional nested "no-dictionary" element contains a boolean value which specifies whether mechanisms
  129. susceptible to passive dictionary attacks are permitted. "false" to permit, "true" to deny.
  130. The optional nested "no-plain-text" element contains a boolean value which specifies whether mechanisms
  131. susceptible to simple plain passive attacks (e.g., "PLAIN") are not permitted. "false" to permit, "true" to deny.
  132. The optional nested "pass-credentials" element contains a boolean value which specifies whether
  133. mechanisms that pass client credentials are required.
  134. ]]>
  135. </xs:documentation>
  136. </xs:annotation>
  137. <xs:all>
  138. <xs:element name="forward-secrecy" type="boolean-element" minOccurs="0"/>
  139. <xs:element name="no-active" type="boolean-element" minOccurs="0"/>
  140. <xs:element name="no-anonymous" type="boolean-element" minOccurs="0"/>
  141. <xs:element name="no-dictionary" type="boolean-element" minOccurs="0"/>
  142. <xs:element name="no-plain-text" type="boolean-element" minOccurs="0"/>
  143. <xs:element name="pass-credentials" type="boolean-element" minOccurs="0"/>
  144. </xs:all>
  145. </xs:complexType>
  146. <xs:complexType name="boolean-element">
  147. <xs:annotation>
  148. <xs:documentation>
  149. <![CDATA[
  150. An element specifying a boolean value.
  151. ]]>
  152. </xs:documentation>
  153. </xs:annotation>
  154. <xs:attribute name="value" type="xs:boolean" use="required"/>
  155. </xs:complexType>
  156. <xs:complexType name="name-listType">
  157. <xs:annotation>
  158. <xs:documentation>
  159. <![CDATA[
  160. An element specifying a string list.
  161. ]]>
  162. </xs:documentation>
  163. </xs:annotation>
  164. <xs:attribute name="value" type="name-list" use="required"/>
  165. </xs:complexType>
  166. <xs:simpleType name="name-list">
  167. <xs:annotation>
  168. <xs:documentation>
  169. <![CDATA[
  170. A set of string items.
  171. ]]>
  172. </xs:documentation>
  173. </xs:annotation>
  174. <xs:list itemType="xs:string"/>
  175. </xs:simpleType>
  176. <xs:complexType name="qop-listType">
  177. <xs:annotation>
  178. <xs:documentation>
  179. <![CDATA[
  180. An element specifying a qop list.
  181. ]]>
  182. </xs:documentation>
  183. </xs:annotation>
  184. <xs:attribute name="value" type="qop-list" use="required"/>
  185. </xs:complexType>
  186. <xs:simpleType name="qop-list">
  187. <xs:annotation>
  188. <xs:documentation>
  189. <![CDATA[
  190. The SASL quality-of-protection value list. See http://download.oracle.com/docs/cd/E17409_01/javase/6/docs/api/javax/security/sasl/Sasl.html#QOP
  191. for more information.
  192. ]]>
  193. </xs:documentation>
  194. </xs:annotation>
  195. <xs:list>
  196. <xs:simpleType>
  197. <xs:restriction base="xs:token">
  198. <xs:enumeration value="auth"/>
  199. <xs:enumeration value="auth-int"/>
  200. <xs:enumeration value="auth-conf"/>
  201. </xs:restriction>
  202. </xs:simpleType>
  203. </xs:list>
  204. </xs:simpleType>
  205. <xs:simpleType name="strength">
  206. <xs:annotation>
  207. <xs:documentation>
  208. <![CDATA[
  209. The SASL strength value list. See http://download.oracle.com/docs/cd/E17409_01/javase/6/docs/api/javax/security/sasl/Sasl.html#STRENGTH
  210. for more information.
  211. ]]>
  212. </xs:documentation>
  213. </xs:annotation>
  214. <xs:list>
  215. <xs:simpleType>
  216. <xs:restriction base="xs:token">
  217. <xs:enumeration value="low"/>
  218. <xs:enumeration value="medium"/>
  219. <xs:enumeration value="high"/>
  220. </xs:restriction>
  221. </xs:simpleType>
  222. </xs:list>
  223. </xs:simpleType>
  224. <xs:complexType name="properties">
  225. <xs:annotation>
  226. <xs:documentation>
  227. <![CDATA[
  228. A set of free-form properties.
  229. ]]>
  230. </xs:documentation>
  231. </xs:annotation>
  232. <xs:choice minOccurs="0" maxOccurs="unbounded">
  233. <xs:element name="property" type="property"/>
  234. </xs:choice>
  235. </xs:complexType>
  236. <xs:complexType name="property">
  237. <xs:annotation>
  238. <xs:documentation>
  239. <![CDATA[
  240. A free-form property. The name is required; the value is optional.
  241. ]]>
  242. </xs:documentation>
  243. </xs:annotation>
  244. <xs:attribute name="name" type="xs:string" use="required"/>
  245. <xs:attribute name="value" type="xs:string" use="optional"/>
  246. </xs:complexType>
  247. <xs:complexType name="ref">
  248. <xs:annotation>
  249. <xs:documentation>
  250. <![CDATA[
  251. A reference to another named service.
  252. ]]>
  253. </xs:documentation>
  254. </xs:annotation>
  255. <xs:attribute name="name" type="xs:string" use="required"/>
  256. </xs:complexType>
  257. <xs:complexType name="outbound-connectionsType">
  258. <xs:choice minOccurs="0" maxOccurs="unbounded">
  259. <xs:element name="local-outbound-connection" type="local-outbound-connectionType" />
  260. <xs:element name="remote-outbound-connection" type="remote-outbound-connectionType" />
  261. <xs:element name="outbound-connection" type="outbound-connectionType" />
  262. </xs:choice>
  263. </xs:complexType>
  264. <xs:complexType name="base-outbound-connectionType">
  265. <xs:all>
  266. <xs:element name="properties" type="properties" minOccurs="0"/>
  267. </xs:all>
  268. <xs:attribute name="name" type="xs:string" use="required"/>
  269. </xs:complexType>
  270. <xs:complexType name="outbound-connectionType">
  271. <xs:complexContent>
  272. <xs:extension base="base-outbound-connectionType">
  273. <xs:attribute name="uri" type="xs:anyURI" use="required"/>
  274. </xs:extension>
  275. </xs:complexContent>
  276. </xs:complexType>
  277. <xs:complexType name="local-outbound-connectionType">
  278. <xs:complexContent>
  279. <xs:extension base="base-outbound-connectionType">
  280. <xs:attribute name="outbound-socket-binding-ref" type="xs:string" use="required"/>
  281. </xs:extension>
  282. </xs:complexContent>
  283. </xs:complexType>
  284. <xs:complexType name="remote-outbound-connectionType">
  285. <xs:complexContent>
  286. <xs:extension base="base-outbound-connectionType">
  287. <xs:attribute name="outbound-socket-binding-ref" type="xs:string" use="required"/>
  288. <xs:attribute name="username" type="xs:string" use="optional"/>
  289. <xs:attribute name="security-realm" type="xs:string" use="optional"/>
  290. </xs:extension>
  291. </xs:complexContent>
  292. </xs:complexType>
  293. </xs:schema>