jboss-as-config_1_1.xsd 97 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. ~ JBoss, Home of Professional Open Source.
  4. ~ Copyright 2010, 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. xmlns="urn:jboss:domain:1.1"
  25. targetNamespace="urn:jboss:domain:1.1"
  26. elementFormDefault="qualified"
  27. attributeFormDefault="unqualified"
  28. >
  29. <xs:element name="domain">
  30. <xs:annotation>
  31. <xs:documentation>
  32. Root element for the master document specifying the core configuration
  33. for the servers in a domain. There should be one such master
  34. document per domain, available to the host controller that
  35. is configured to act as the domain controller.
  36. </xs:documentation>
  37. </xs:annotation>
  38. <xs:complexType>
  39. <xs:sequence>
  40. <xs:element name="extensions" type="extensionsType" minOccurs="0" maxOccurs="1"/>
  41. <xs:element name="system-properties" type="properties-with-boottime" minOccurs="0" maxOccurs="1"/>
  42. <xs:element name="paths" type="named-pathsType" minOccurs="0" maxOccurs="1" />
  43. <xs:element name="profiles" type="profilesType" minOccurs="0" maxOccurs="1"/>
  44. <xs:element name="interfaces" type="named-interfacesType" minOccurs="0" maxOccurs="1"/>
  45. <xs:element name="socket-binding-groups" type="socket-binding-groupsType" minOccurs="0" maxOccurs="1"/>
  46. <xs:element name="deployments" type="domain-deploymentsType" minOccurs="0" maxOccurs="1"/>
  47. <xs:element name="server-groups" type="server-groupsType" minOccurs="0" maxOccurs="1"/>
  48. <xs:element name="management-client-content" type="management-client-contentType" minOccurs="0" maxOccurs="1"/>
  49. </xs:sequence>
  50. </xs:complexType>
  51. </xs:element>
  52. <xs:element name="host">
  53. <xs:annotation>
  54. <xs:documentation>
  55. Root element for a document configuring a host controller and
  56. the group of servers under the control of that host controller.
  57. The standard usage would be for a domain to have one such host controller
  58. on each physical (or virtual) host machine. Emphasis in this
  59. document is on enumerating the servers, configuring items that
  60. are specific to the host environment (e.g. IP addresses), and
  61. on any server-specific configuration settings.
  62. </xs:documentation>
  63. </xs:annotation>
  64. <xs:complexType>
  65. <xs:sequence>
  66. <xs:element name="system-properties" type="properties-with-boottime" minOccurs="0"/>
  67. <xs:element name="paths" type="specified-pathsType" minOccurs="0" maxOccurs="1" />
  68. <xs:element name="vault" type="vaultType" minOccurs="0" maxOccurs="1"/>
  69. <xs:element name="management" type="host-managementType" minOccurs="1" maxOccurs="1"/>
  70. <xs:element name="domain-controller" type="domain-controllerType"/>
  71. <xs:element name="interfaces" type="specified-interfacesType" minOccurs="0"/>
  72. <xs:element name="jvms" type="jvmsType" minOccurs="0"/>
  73. <xs:element name="servers" type="serversType" minOccurs="0"/>
  74. </xs:sequence>
  75. <xs:attribute name="name" type="xs:string" use="optional">
  76. <xs:annotation>
  77. <xs:documentation>
  78. The name to use for this host's host controller. Must be unique across the domain.
  79. If not set, defaults to the runtime value "HOSTNAME" or "COMPUTERNAME" environment variables,
  80. or, if neither environment variable is present, to the value of InetAddress.getLocalHost().getHostName().
  81. If the special value "jboss.domain.uuid" is used, a java.util.UUID will be created
  82. and used, based on the value of InetAddress.getLocalHost().
  83. </xs:documentation>
  84. </xs:annotation>
  85. </xs:attribute>
  86. </xs:complexType>
  87. </xs:element>
  88. <xs:element name="server">
  89. <xs:annotation>
  90. <xs:documentation>
  91. Root element for a document specifying the configuration
  92. of a single "standalone" server that does not operate
  93. as part of a domain.
  94. Note that this element is distinct from the 'serverType'
  95. specified in this schema. The latter type forms part of the
  96. configuration of a server that operates as part of a domain.
  97. </xs:documentation>
  98. </xs:annotation>
  99. <xs:complexType>
  100. <xs:sequence>
  101. <xs:element name="extensions" type="extensionsType" minOccurs="0" maxOccurs="1"/>
  102. <xs:element name="system-properties" type="properties" minOccurs="0" maxOccurs="1"/>
  103. <xs:element name="paths" type="specified-pathsType" minOccurs="0" maxOccurs="1"/>
  104. <xs:element name="vault" type="vaultType" minOccurs="0" maxOccurs="1"/>
  105. <xs:element name="management" type="server-managementType" minOccurs="0" maxOccurs="1"/>
  106. <xs:element name="profile" type="standalone-profileType" minOccurs="0"/>
  107. <xs:element name="interfaces" type="specified-interfacesType" minOccurs="0" maxOccurs="1"/>
  108. <xs:element name="socket-binding-group" type="standalone-socket-binding-groupType" minOccurs="0" maxOccurs="1"/>
  109. <xs:element name="deployments" type="server-deploymentsType" minOccurs="0" maxOccurs="1"/>
  110. </xs:sequence>
  111. <xs:attribute name="name" type="xs:string" use="optional">
  112. <xs:annotation>
  113. <xs:documentation>
  114. The name to use for this server.
  115. If not set, defaults to the runtime value "HOSTNAME" or "COMPUTERNAME" environment variables,
  116. or, if neither environment variable is present, to the value of InetAddress.getLocalHost().getHostName().
  117. If the special value "jboss.domain.uuid" is used, a java.util.UUID will be created
  118. and used, based on the value of InetAddress.getLocalHost().
  119. </xs:documentation>
  120. </xs:annotation>
  121. </xs:attribute>
  122. </xs:complexType>
  123. </xs:element>
  124. <xs:complexType name="domain-managementType">
  125. <xs:annotation>
  126. <xs:documentation>
  127. Domain-wide default configuration settings for the management of standalone servers and a Host Controller.
  128. </xs:documentation>
  129. </xs:annotation>
  130. <xs:sequence>
  131. <xs:element name="security-realms" minOccurs="0">
  132. <xs:complexType>
  133. <xs:sequence>
  134. <xs:element name="security-realm" type="security-realmType" minOccurs="1"
  135. maxOccurs="unbounded"/>
  136. </xs:sequence>
  137. </xs:complexType>
  138. </xs:element>
  139. <xs:element name="outbound-connections" minOccurs="0">
  140. <xs:complexType>
  141. <xs:sequence>
  142. <xs:element name="ldap" type="ldapType" minOccurs="1" /> <!-- TODO minOccurs only while ldap is only supported connection. -->
  143. </xs:sequence>
  144. </xs:complexType>
  145. </xs:element>
  146. </xs:sequence>
  147. </xs:complexType>
  148. <xs:complexType name="host-managementType">
  149. <xs:annotation>
  150. <xs:documentation>
  151. The centralized configuration for the management of a Host Controller.
  152. </xs:documentation>
  153. </xs:annotation>
  154. <xs:complexContent>
  155. <xs:extension base="domain-managementType">
  156. <xs:sequence>
  157. <xs:element name="management-interfaces" type="host-management-interfacesType" minOccurs="1"/>
  158. </xs:sequence>
  159. </xs:extension>
  160. </xs:complexContent>
  161. </xs:complexType>
  162. <xs:complexType name="server-managementType">
  163. <xs:annotation>
  164. <xs:documentation>
  165. The centralized configuration for the management of standalone server.
  166. </xs:documentation>
  167. </xs:annotation>
  168. <xs:complexContent>
  169. <xs:extension base="domain-managementType">
  170. <xs:sequence>
  171. <xs:element name="management-interfaces" type="server-management-interfacesType" minOccurs="0"/>
  172. </xs:sequence>
  173. </xs:extension>
  174. </xs:complexContent>
  175. </xs:complexType>
  176. <xs:complexType name="ldapType">
  177. <xs:annotation>
  178. <xs:documentation>
  179. The LDAP connection definition.
  180. </xs:documentation>
  181. </xs:annotation>
  182. <xs:attribute name="name" type="xs:string" use="required">
  183. <xs:annotation>
  184. <xs:documentation>
  185. The name of this connection.
  186. </xs:documentation>
  187. </xs:annotation>
  188. </xs:attribute>
  189. <xs:attribute name="url" type="xs:string" use="required">
  190. <xs:annotation>
  191. <xs:documentation>
  192. The URL to connect to ldap.
  193. </xs:documentation>
  194. </xs:annotation>
  195. </xs:attribute>
  196. <!-- TODO - Later will be optional if we support GSSAPI to connect to LDAP -->
  197. <xs:attribute name="search-dn" type="xs:string" use="required">
  198. <xs:annotation>
  199. <xs:documentation>
  200. The distinguished name to use when connecting to LDAP to perform searches.
  201. </xs:documentation>
  202. </xs:annotation>
  203. </xs:attribute>
  204. <xs:attribute name="search-credential" type="xs:string" use="required">
  205. <xs:annotation>
  206. <xs:documentation>
  207. The credential to use when connecting to perform a search.
  208. </xs:documentation>
  209. </xs:annotation>
  210. </xs:attribute>
  211. <xs:attribute name="initial-context-factory" type="xs:string" default="com.sun.jndi.ldap.LdapCtxFactory">
  212. <xs:annotation>
  213. <xs:documentation>
  214. The initial context factory to establish the LdapContext.
  215. </xs:documentation>
  216. </xs:annotation>
  217. </xs:attribute>
  218. </xs:complexType>
  219. <xs:complexType name="security-realmType">
  220. <xs:annotation>
  221. <xs:documentation>
  222. Configuration of a security realm for securing access to the management interfaces.
  223. </xs:documentation>
  224. </xs:annotation>
  225. <xs:sequence>
  226. <xs:element name="server-identities" type="server-identitiesType" minOccurs="0" />
  227. <xs:element name="authentication" type="authenticationType" minOccurs="0" />
  228. <xs:element name="authorization" type="authorizationType" minOccurs="0" />
  229. </xs:sequence>
  230. <xs:attribute name="name" type="xs:string" use="required">
  231. <xs:annotation>
  232. <xs:documentation>
  233. The name of this security-realm, each security-realm must be assigned a unique name.
  234. </xs:documentation>
  235. </xs:annotation>
  236. </xs:attribute>
  237. </xs:complexType>
  238. <xs:complexType name="authorizationType">
  239. <xs:annotation>
  240. <xs:documentation>
  241. Configuration defining how to load the authorization information for the authenticated user.
  242. After a user has been authenticated additional information such as roles can be loaded and
  243. associated with the user for subsequent authorization checks, this type is used to define
  244. how the roles are loaded.
  245. </xs:documentation>
  246. </xs:annotation>
  247. <xs:sequence>
  248. <xs:element name="properties" type="propertiesFileType" minOccurs="1" /> <!-- minOccurs="1" while this is the only mech -->
  249. </xs:sequence>
  250. </xs:complexType>
  251. <xs:complexType name="server-identitiesType">
  252. <xs:annotation>
  253. <xs:documentation>
  254. Configuration of the identities that represent the server.
  255. </xs:documentation>
  256. </xs:annotation>
  257. <xs:sequence>
  258. <xs:element name="ssl" type="sslType" minOccurs="0" />
  259. <xs:element name="secret" type="secretType" minOccurs="0" />
  260. </xs:sequence>
  261. </xs:complexType>
  262. <xs:complexType name="secretType">
  263. <xs:annotation>
  264. <xs:documentation>
  265. Configuration of the secret/password-based identity of this server.
  266. </xs:documentation>
  267. </xs:annotation>
  268. <xs:attribute name="value" type="xs:string" use="required">
  269. <xs:annotation>
  270. <xs:documentation>
  271. The secret / password - Base64 Encoded
  272. </xs:documentation>
  273. </xs:annotation>
  274. </xs:attribute>
  275. </xs:complexType>
  276. <xs:complexType name="sslType">
  277. <xs:annotation>
  278. <xs:documentation>
  279. Configuration of the SSL identity of this server.
  280. </xs:documentation>
  281. </xs:annotation>
  282. <xs:sequence>
  283. <xs:element name="keystore" type="keystoreType" />
  284. </xs:sequence>
  285. <xs:attribute name="protocol" type="xs:string" default="TLS">
  286. <xs:annotation>
  287. <xs:documentation>
  288. The protocol to use when creating the SSLContext.
  289. </xs:documentation>
  290. </xs:annotation>
  291. </xs:attribute>
  292. </xs:complexType>
  293. <xs:complexType name="keystoreType">
  294. <xs:annotation>
  295. <xs:documentation>
  296. The keystore configuration for the server.
  297. </xs:documentation>
  298. </xs:annotation>
  299. <xs:attribute name="path" type="xs:string" use="required">
  300. <xs:annotation>
  301. <xs:documentation>
  302. The path of the keystore.
  303. </xs:documentation>
  304. </xs:annotation>
  305. </xs:attribute>
  306. <xs:attribute name="relative-to" use="optional" type="xs:string">
  307. <xs:annotation>
  308. <xs:documentation>
  309. The name of another previously named path, or of one of the
  310. standard paths provided by the system. If 'relative-to' is
  311. provided, the value of the 'path' attribute is treated as
  312. relative to the path specified by this attribute.
  313. </xs:documentation>
  314. </xs:annotation>
  315. </xs:attribute>
  316. <xs:attribute name="password" type="xs:string" use="required">
  317. <xs:annotation>
  318. <xs:documentation>
  319. The password to open the keystore.
  320. </xs:documentation>
  321. </xs:annotation>
  322. </xs:attribute>
  323. </xs:complexType>
  324. <xs:complexType name="authenticationType">
  325. <xs:annotation>
  326. <xs:documentation>
  327. Configuration of the server side authentication mechanisms.
  328. Optionally one truststore can be defined and one username/password based store can be defined.
  329. Authentication will first attempt to use the truststore and if this is not available will fall back
  330. to the username/password authentication.
  331. If none of these are specified the only available mechanism will be the local mechanism for the
  332. Native interface and the HTTP interface will not be accessible.
  333. </xs:documentation>
  334. </xs:annotation>
  335. <xs:sequence>
  336. <xs:element name="truststore" type="keystoreType" minOccurs="0">
  337. <xs:annotation>
  338. <xs:documentation>
  339. Configuration of a keystore to use to create a trust manager to verify clients.
  340. </xs:documentation>
  341. </xs:annotation>
  342. </xs:element>
  343. <xs:choice minOccurs="0">
  344. <xs:element name="jaas" type="jaasAuthenticationType" minOccurs="0" />
  345. <xs:element name="ldap" type="ldapAuthenticationType" minOccurs="0" />
  346. <xs:element name="properties" type="propertiesAuthenticationType" minOccurs="0" />
  347. <xs:element name="users" type="usersAuthenticationType" minOccurs="0" />
  348. </xs:choice>
  349. </xs:sequence>
  350. </xs:complexType>
  351. <xs:complexType name="jaasAuthenticationType">
  352. <xs:annotation>
  353. <xs:documentation>
  354. Definition to use a JAAS based configuration for authentication.
  355. </xs:documentation>
  356. </xs:annotation>
  357. <xs:attribute name="name" type="xs:string" use="required">
  358. <xs:annotation>
  359. <xs:documentation>
  360. The name identifying the jaas configuration of LoginModules.
  361. </xs:documentation>
  362. </xs:annotation>
  363. </xs:attribute>
  364. </xs:complexType>
  365. <xs:complexType name="ldapAuthenticationType">
  366. <xs:annotation>
  367. <xs:documentation>
  368. Definition to use LDAP as the user repository.
  369. </xs:documentation>
  370. </xs:annotation>
  371. <xs:choice>
  372. <xs:element name="username-filter">
  373. <xs:complexType>
  374. <xs:attribute name="attribute" type="xs:string" use="required">
  375. <xs:annotation>
  376. <xs:documentation>
  377. The name of the attribute to search for the user, this filter will then perform
  378. a simple search where the username entered by the user matches the attribute
  379. specified here.
  380. </xs:documentation>
  381. </xs:annotation>
  382. </xs:attribute>
  383. </xs:complexType>
  384. </xs:element>
  385. <xs:element name="advanced-filter">
  386. <xs:complexType>
  387. <xs:attribute name="filter" type="xs:string" use="required">
  388. <xs:annotation>
  389. <xs:documentation>
  390. The fully defined filter to be used to search for the user based on their entered
  391. user ID. The filter should contain a variable in the form {0} - this will be
  392. replaced with the username supplied by the user.
  393. </xs:documentation>
  394. </xs:annotation>
  395. </xs:attribute>
  396. </xs:complexType>
  397. </xs:element>
  398. </xs:choice>
  399. <xs:attribute name="connection" type="xs:string" use="required">
  400. <xs:annotation>
  401. <xs:documentation>
  402. The name of the connection to use to connect to LDAP.
  403. </xs:documentation>
  404. </xs:annotation>
  405. </xs:attribute>
  406. <xs:attribute name="base-dn" type="xs:string" use="required">
  407. <xs:annotation>
  408. <xs:documentation>
  409. The base distinguished name to commence the search for the user.
  410. </xs:documentation>
  411. </xs:annotation>
  412. </xs:attribute>
  413. <xs:attribute name="recursive" type="xs:boolean" default="false">
  414. <xs:annotation>
  415. <xs:documentation>
  416. Should the search be recursive.
  417. </xs:documentation>
  418. </xs:annotation>
  419. </xs:attribute>
  420. <xs:attribute name="user-dn" type="xs:string" default="dn">
  421. <xs:annotation>
  422. <xs:documentation>
  423. The name of the attribute which is the users distinguished name.
  424. </xs:documentation>
  425. </xs:annotation>
  426. </xs:attribute>
  427. </xs:complexType>
  428. <xs:complexType name="usersAuthenticationType">
  429. <xs:annotation>
  430. <xs:documentation>
  431. A set of users
  432. </xs:documentation>
  433. </xs:annotation>
  434. <xs:sequence>
  435. <xs:element name="user" type="userType" maxOccurs="unbounded"/>
  436. </xs:sequence>
  437. </xs:complexType>
  438. <xs:complexType name="userType">
  439. <xs:annotation>
  440. <xs:documentation>
  441. A single user.
  442. </xs:documentation>
  443. </xs:annotation>
  444. <xs:choice>
  445. <xs:element name="password" type="xs:string" />
  446. </xs:choice>
  447. <xs:attribute name="username" type="xs:string" use="required">
  448. <xs:annotation>
  449. <xs:documentation>
  450. The users username.
  451. </xs:documentation>
  452. </xs:annotation>
  453. </xs:attribute>
  454. </xs:complexType>
  455. <xs:complexType name="propertiesFileType">
  456. <xs:annotation>
  457. <xs:documentation>
  458. Declaration of a location of a properties file.
  459. </xs:documentation>
  460. </xs:annotation>
  461. <xs:attribute name="relative-to" use="optional" type="xs:string">
  462. <xs:annotation>
  463. <xs:documentation>
  464. The name of another previously named path, or of one of the
  465. standard paths provided by the system. If 'relative-to' is
  466. provided, the value of the 'path' attribute is treated as
  467. relative to the path specified by this attribute.
  468. </xs:documentation>
  469. </xs:annotation>
  470. </xs:attribute>
  471. <xs:attribute name="path" type="xs:string" use="required">
  472. <xs:annotation>
  473. <xs:documentation>
  474. The path of the properties file.
  475. </xs:documentation>
  476. </xs:annotation>
  477. </xs:attribute>
  478. </xs:complexType>
  479. <xs:complexType name="propertiesAuthenticationType">
  480. <xs:annotation>
  481. <xs:documentation>
  482. Declaration of users stored within properties files.
  483. The entries within the properties file are username={credentials} with each user
  484. being specified on it's own line.
  485. </xs:documentation>
  486. </xs:annotation>
  487. <xs:complexContent>
  488. <xs:extension base="propertiesFileType">
  489. <xs:attribute name="plain-text" type="xs:boolean" default="false">
  490. <xs:annotation>
  491. <xs:documentation>
  492. Are the credentials within the properties file stored in plain text, if not
  493. the {credential} is expected to be the hex encoded Digest hash
  494. of 'username : realm : password'.
  495. </xs:documentation>
  496. </xs:annotation>
  497. </xs:attribute>
  498. </xs:extension>
  499. </xs:complexContent>
  500. </xs:complexType>
  501. <xs:complexType name="host-management-interfacesType">
  502. <xs:sequence>
  503. <xs:element name="native-interface" type="host-native-management-interfaceType"/>
  504. <xs:element name="http-interface" type="host-http-management-interfaceType" minOccurs="0"/>
  505. </xs:sequence>
  506. </xs:complexType>
  507. <xs:complexType name="management-interfaceType">
  508. <xs:attribute name="security-realm" type="xs:string" use="optional">
  509. <xs:annotation>
  510. <xs:documentation>
  511. The security realm to use for this management interface, the capabilities
  512. of the security realm will be queried to identify the authentication mechanism(s) to
  513. offer.
  514. </xs:documentation>
  515. </xs:annotation>
  516. </xs:attribute>
  517. </xs:complexType>
  518. <xs:complexType name="host-native-management-interfaceType">
  519. <xs:annotation>
  520. <xs:documentation>
  521. Configuration of a host's exposed native management interface.
  522. </xs:documentation>
  523. </xs:annotation>
  524. <xs:complexContent>
  525. <xs:extension base="management-interfaceType">
  526. <xs:sequence>
  527. <xs:element name="socket" type="native-management-socketType"/>
  528. </xs:sequence>
  529. </xs:extension>
  530. </xs:complexContent>
  531. </xs:complexType>
  532. <xs:complexType name="management-socketType">
  533. <xs:annotation>
  534. <xs:documentation>
  535. Configuration of the socket used by host or standalone server's exposed management interface.
  536. </xs:documentation>
  537. </xs:annotation>
  538. <xs:attribute name="interface" type="xs:string" use="required">
  539. <xs:annotation>
  540. <xs:documentation>
  541. Network interface on which the host's socket for
  542. management communication should be opened.
  543. </xs:documentation>
  544. </xs:annotation>
  545. </xs:attribute>
  546. </xs:complexType>
  547. <xs:complexType name="native-management-socketType">
  548. <xs:annotation>
  549. <xs:documentation>
  550. Configuration of the socket used by host or standalone server's exposed HTTP management interface.
  551. </xs:documentation>
  552. </xs:annotation>
  553. <xs:complexContent>
  554. <xs:extension base="management-socketType">
  555. <xs:attribute name="port" type="xs:int" use="required">
  556. <xs:annotation>
  557. <xs:documentation>
  558. Port on which the host's socket for native
  559. management communication should be opened.
  560. </xs:documentation>
  561. </xs:annotation>
  562. </xs:attribute>
  563. </xs:extension>
  564. </xs:complexContent>
  565. </xs:complexType>
  566. <xs:complexType name="host-http-management-interfaceType">
  567. <xs:annotation>
  568. <xs:documentation>
  569. Configuration of a host's exposed HTTP management interface.
  570. </xs:documentation>
  571. </xs:annotation>
  572. <xs:complexContent>
  573. <xs:extension base="management-interfaceType">
  574. <xs:sequence>
  575. <xs:element name="socket" type="http-management-socketType"/>
  576. </xs:sequence>
  577. <xs:attribute name="console-enabled" type="xs:boolean" use="optional" default="true"/>
  578. </xs:extension>
  579. </xs:complexContent>
  580. </xs:complexType>
  581. <xs:complexType name="http-management-socketType">
  582. <xs:annotation>
  583. <xs:documentation>
  584. Configuration of the socket used by host or standalone server's exposed HTTP management interface.
  585. </xs:documentation>
  586. </xs:annotation>
  587. <xs:complexContent>
  588. <xs:extension base="management-socketType">
  589. <xs:attribute name="port" type="xs:int" use="optional">
  590. <xs:annotation>
  591. <xs:documentation>
  592. Port on which the host's socket for
  593. management communication should be opened.
  594. If not specified the port will not be opened.
  595. </xs:documentation>
  596. </xs:annotation>
  597. </xs:attribute>
  598. <xs:attribute name="secure-port" type="xs:int" use="optional">
  599. <xs:annotation>
  600. <xs:documentation>
  601. Port on which the host's socket for HTTPS
  602. management communication should be opened.
  603. If not specified the port will not be opened.
  604. If specified the security-realm will be required to obtain
  605. the SSL configuration.
  606. </xs:documentation>
  607. </xs:annotation>
  608. </xs:attribute>
  609. </xs:extension>
  610. </xs:complexContent>
  611. </xs:complexType>
  612. <xs:complexType name="server-management-interfacesType">
  613. <xs:sequence>
  614. <xs:element name="native-remoting-interface" type="management-remoting-interfaceType" minOccurs="0"/>
  615. <xs:element name="native-interface" type="server-native-management-interfaceType" minOccurs="0"/>
  616. <xs:element name="http-interface" type="server-http-management-interfaceType" minOccurs="0"/>
  617. </xs:sequence>
  618. </xs:complexType>
  619. <xs:complexType name="server-native-management-interfaceType">
  620. <xs:annotation>
  621. <xs:documentation>
  622. Configuration of the socket used by host or standalone server's exposed HTTP management interface.
  623. </xs:documentation>
  624. </xs:annotation>
  625. <xs:complexContent>
  626. <xs:extension base="management-interfaceType">
  627. <xs:annotation>
  628. <xs:documentation>
  629. Configuration of the socket to use for the native management interface is a choice
  630. between a direct configuration of the address and port, or a reference to a socket-binding
  631. configuration in the server's socket-binding-group element. The latter is the recommended
  632. approach is it makes it easier to avoid port conflicts by taking advantage of the
  633. socket-binding-group's port-offset configuration. Direct configuration of the address and
  634. ports is provided to preserve backward compatibility.
  635. </xs:documentation>
  636. </xs:annotation>
  637. <xs:choice>
  638. <xs:element name="socket" type="native-management-socketType"/>
  639. <xs:element name="socket-binding" type="native-management-socket-binding-refType"/>
  640. </xs:choice>
  641. </xs:extension>
  642. </xs:complexContent>
  643. </xs:complexType>
  644. <xs:complexType name="native-management-socket-binding-refType">
  645. <xs:annotation>
  646. <xs:documentation>
  647. Reference to the configuration of the socket to be used by a standalone server's exposed native management interface.
  648. </xs:documentation>
  649. </xs:annotation>
  650. <xs:attribute name="native" type="xs:string" use="required">
  651. <xs:annotation>
  652. <xs:documentation>
  653. Name of a socket-binding configuration declared in the server's socket-binding-group.
  654. </xs:documentation>
  655. </xs:annotation>
  656. </xs:attribute>
  657. </xs:complexType>
  658. <xs:complexType name="server-http-management-interfaceType">
  659. <xs:annotation>
  660. <xs:documentation>
  661. Configuration of a standalone server's exposed HTTP/HTTPS management interface.
  662. </xs:documentation>
  663. </xs:annotation>
  664. <xs:complexContent>
  665. <xs:extension base="management-interfaceType">
  666. <xs:annotation>
  667. <xs:documentation>
  668. Configuration of the socket to use for the HTTP/HTTPS management interface is a choice
  669. between a direct configuration of the address and ports, or a reference to socket-binding
  670. configurations in the server's socket-binding-group element. The latter is the recommended
  671. approach is it makes it easier to avoid port conflicts by taking advantage of the
  672. socket-binding-group's port-offset configuration. Direct configuration of the address and
  673. ports is provided to preserve backward compatibility.
  674. </xs:documentation>
  675. </xs:annotation>
  676. <xs:choice>
  677. <xs:element name="socket" type="http-management-socketType"/>
  678. <xs:element name="socket-binding" type="http-management-socket-binding-refType"/>
  679. </xs:choice>
  680. <xs:attribute name="console-enabled" type="xs:boolean" use="optional" default="true"/>
  681. </xs:extension>
  682. </xs:complexContent>
  683. </xs:complexType>
  684. <xs:complexType name="http-management-socket-binding-refType">
  685. <xs:annotation>
  686. <xs:documentation>
  687. Reference to the configurations of the sockets to be used by a standalone server's exposed HTTP and HTTPS management interface.
  688. </xs:documentation>
  689. </xs:annotation>
  690. <xs:attribute name="http" type="xs:string" use="optional">
  691. <xs:annotation>
  692. <xs:documentation>
  693. Name of a socket-binding configuration declared in the server's socket-binding-group to use for a HTTP socket.
  694. </xs:documentation>
  695. </xs:annotation>
  696. </xs:attribute>
  697. <xs:attribute name="https" type="xs:string" use="optional">
  698. <xs:annotation>
  699. <xs:documentation>
  700. Name of a socket-binding configuration declared in the server's socket-binding-group to use for a HTTPS socket.
  701. </xs:documentation>
  702. </xs:annotation>
  703. </xs:attribute>
  704. </xs:complexType>
  705. <xs:complexType name="management-remoting-interfaceType">
  706. <xs:annotation>
  707. <xs:documentation>
  708. Makes the native management interface available via the connectors set up in the remoting subsystem,
  709. using the remoting subsystem's endpoint. This should only be used for a server not for a HC/DC.
  710. </xs:documentation>
  711. </xs:annotation>
  712. </xs:complexType>
  713. <xs:complexType name="domain-controllerType">
  714. <xs:choice>
  715. <xs:element name="local" type="domain-controller-localType"/>
  716. <xs:element name="remote" type="domain-controller-remoteType"/>
  717. </xs:choice>
  718. </xs:complexType>
  719. <xs:complexType name="domain-controller-localType" />
  720. <xs:complexType name="domain-controller-remoteType">
  721. <xs:sequence>
  722. <xs:element name="ignored-resources" type="ignored-resourcesType" minOccurs="0" maxOccurs="unbounded"/>
  723. </xs:sequence>
  724. <xs:attribute name="host" type="xs:string" use="required" />
  725. <xs:attribute name="port" type="xs:integer" use="required" />
  726. <xs:attribute name="security-realm" type="xs:string" use="optional" />
  727. </xs:complexType>
  728. <xs:complexType name="ignored-resourcesType">
  729. <xs:annotation>
  730. <xs:documentation>
  731. Provides names of direct child resources of the domain root resource requests for which the
  732. Host Controller should ignore. Only relevant on a slave Host Controller. Configuring such
  733. "ignored resources" may help allow a Host Controller from an earlier release to function as a
  734. slave to a master Host Controller running a later release, by letting the slave ignore portions
  735. of the configuration its version of the software cannot understand. This strategy can only be
  736. successful if the servers managed by the slave Host Controller do not reference any of the
  737. ignored configuration.
  738. Supports the following attributes:
  739. type -- the type of resource (e.g. 'profile' or 'socket-binding-group') certain instances of which
  740. should be ignored. The value corresponds to the 'key' portion of the first element in the
  741. resource's address (e.g. 'profile' in the address /profile=ha/subsystem=web)
  742. wildcard -- if 'true', all resources of the given type should be ignored.
  743. Child elements list the names of specific instances of the given type of resource
  744. that should be ignored. Each element in the list corresponds to the 'value' portion of
  745. the first element in the resource's address (e.g. 'ha' in the address /profile=ha/subsystem=web.)
  746. </xs:documentation>
  747. </xs:annotation>
  748. <xs:sequence>
  749. <xs:element name="instance" type="ignored-resource-instanceType" minOccurs="0" maxOccurs="unbounded"/>
  750. </xs:sequence>
  751. <xs:attribute name="type" type="xs:string" use="required" />
  752. <xs:attribute name="wildcard" type="xs:boolean" use="optional" default="false" />
  753. <xs:attribute name="names" type="xs:string" use="optional" />
  754. </xs:complexType>
  755. <xs:complexType name="ignored-resource-instanceType">
  756. <xs:annotation>
  757. <xs:documentation>
  758. The name of a specific instances of a particular type of resource that should be ignored.
  759. The 'name' attribute corresponds to the 'value' portion of the first element in the resource's address
  760. (e.g. 'ha' in the address /profile=ha/subsystem=web.)
  761. </xs:documentation>
  762. </xs:annotation>
  763. <xs:attribute name="name" type="xs:string" use="required" />
  764. </xs:complexType>
  765. <xs:complexType name="serversType">
  766. <xs:sequence>
  767. <xs:element name="server" type="serverType" minOccurs="0" maxOccurs="unbounded"/>
  768. </xs:sequence>
  769. </xs:complexType>
  770. <xs:complexType name="serverType">
  771. <xs:all>
  772. <xs:element name="paths" type="specified-pathsType" minOccurs="0" maxOccurs="1" />
  773. <xs:element name="interfaces" type="specified-interfacesType" minOccurs="0"/>
  774. <xs:element name="socket-bindings" type="server-socket-bindingsType" minOccurs="0"/>
  775. <!--<xs:element name="loggers" type="loggersType" minOccurs="0"/>-->
  776. <xs:element name="system-properties" type="properties-with-boottime" minOccurs="0"/>
  777. <xs:element name="jvm" minOccurs="0" type="serverJvmType"/>
  778. </xs:all>
  779. <xs:attribute name="name" type="xs:string" use="required"/>
  780. <xs:attribute name="group" type="xs:string" use="required"/>
  781. <xs:attribute name="auto-start" type="xs:boolean" default="true"/>
  782. </xs:complexType>
  783. <xs:complexType name="server-socket-bindingsType">
  784. <xs:annotation>
  785. <xs:documentation>
  786. <![CDATA[
  787. Server-specific overrides to the default socket binding configuration inherited from the server group.
  788. ]]>
  789. </xs:documentation>
  790. </xs:annotation>
  791. <xs:attribute name="socket-binding-group" type="xs:string" use="optional">
  792. <xs:annotation>
  793. <xs:documentation>
  794. <![CDATA[
  795. The socket binding group to use for the server. If undefined, the socket binding group
  796. specified for the server group is used.
  797. ]]>
  798. </xs:documentation>
  799. </xs:annotation>
  800. </xs:attribute>
  801. <xs:attribute name="port-offset" type="xs:int" default="0">
  802. <xs:annotation>
  803. <xs:documentation>
  804. <![CDATA[
  805. Increment to apply to the base port values defined in the
  806. referenced socket binding group to derive the values to use on this
  807. server.
  808. ]]>
  809. </xs:documentation>
  810. </xs:annotation>
  811. </xs:attribute>
  812. </xs:complexType>
  813. <xs:complexType name="extensionsType">
  814. <xs:annotation>
  815. <xs:documentation>Contains a list of extension modules.</xs:documentation>
  816. </xs:annotation>
  817. <xs:sequence>
  818. <xs:element name="extension" type="extensionType" minOccurs="1" maxOccurs="unbounded"/>
  819. </xs:sequence>
  820. </xs:complexType>
  821. <xs:complexType name="extensionType">
  822. <xs:annotation>
  823. <xs:documentation>
  824. A module that extends the standard capabilities of a domain
  825. or a standalone server.
  826. </xs:documentation>
  827. </xs:annotation>
  828. <xs:attribute name="module" use="required" type="xs:string">
  829. <xs:annotation>
  830. <xs:documentation>The name of the module</xs:documentation>
  831. </xs:annotation>
  832. </xs:attribute>
  833. </xs:complexType>
  834. <xs:complexType name="server-groupsType">
  835. <xs:sequence>
  836. <xs:element name="server-group" type="server-groupType" minOccurs="0" maxOccurs="unbounded"/>
  837. </xs:sequence>
  838. </xs:complexType>
  839. <xs:complexType name="server-groupType">
  840. <xs:sequence>
  841. <xs:element name="jvm" type="namedJvmType" minOccurs="0"/>
  842. <xs:element name="socket-binding-group" type="socket-binding-group-refType" minOccurs="1"/>
  843. <xs:element name="deployments" type="server-groupDeploymentsType" minOccurs="0"/>
  844. <xs:element name="system-properties" minOccurs="0" type="properties-with-boottime"/>
  845. </xs:sequence>
  846. <xs:attribute name="name" type="xs:string">
  847. <xs:annotation>
  848. <xs:documentation>
  849. The name of the server group
  850. </xs:documentation>
  851. </xs:annotation>
  852. </xs:attribute>
  853. <xs:attribute name="profile" type="xs:string">
  854. <xs:annotation>
  855. <xs:documentation>
  856. The name of the profile this server is running.
  857. </xs:documentation>
  858. </xs:annotation>
  859. </xs:attribute>
  860. <xs:attribute name="management-subsystem-endpoint" type="xs:boolean" default="false">
  861. <xs:annotation>
  862. <xs:documentation>
  863. Set to true to have servers belonging to the server group connect back to the host controller using the
  864. endpoint from their remoting subsystem. The subsystem must be preset for this to
  865. work.
  866. </xs:documentation>
  867. </xs:annotation>
  868. </xs:attribute>
  869. </xs:complexType>
  870. <xs:complexType name="server-groupDeploymentsType">
  871. <xs:annotation>
  872. <xs:documentation>Contains a list of deployments that have been mapped to a server-group.</xs:documentation>
  873. </xs:annotation>
  874. <xs:sequence>
  875. <xs:element name="deployment" type="base-deploymentType" maxOccurs="unbounded"/>
  876. </xs:sequence>
  877. </xs:complexType>
  878. <xs:complexType name="server-groupDeploymentType">
  879. <xs:annotation>
  880. <xs:documentation>A deployment that has been mapped to a server group.</xs:documentation>
  881. </xs:annotation>
  882. <xs:complexContent>
  883. <xs:extension base="base-deploymentType">
  884. <!-- TODO clarify what a value of 'false' means -->
  885. <xs:attribute name="enabled" use="optional" type="xs:boolean" default="true">
  886. <xs:annotation>
  887. <xs:documentation>Whether the deployment deploy automatically when the server starts up.
  888. </xs:documentation>
  889. </xs:annotation>
  890. </xs:attribute>
  891. </xs:extension>
  892. </xs:complexContent>
  893. </xs:complexType>
  894. <xs:complexType name="base-deploymentType">
  895. <xs:attribute name="name" use="required">
  896. <xs:annotation>
  897. <xs:documentation>Unique identifier of the deployment. Must be unique across all deployments.
  898. </xs:documentation>
  899. </xs:annotation>
  900. </xs:attribute>
  901. <xs:attribute name="runtime-name" use="required">
  902. <xs:annotation>
  903. <xs:documentation>Name by which the deployment will be known within a running server.of the deployment.
  904. Does not need to be unique across all deployments in the domain, although it must be unique within
  905. an individual server. For example, two different deployments running on different servers in
  906. the domain could both have a 'runtime-name' of 'example.war', with one having a 'name'
  907. of 'example.war_v1' and another with an 'name' of 'example.war_v2'.
  908. </xs:documentation>
  909. </xs:annotation>
  910. </xs:attribute>
  911. </xs:complexType>
  912. <xs:complexType name="server-deploymentsType">
  913. <xs:annotation>
  914. <xs:documentation>Contains a list of deployments that have been mapped to a server.</xs:documentation>
  915. </xs:annotation>
  916. <xs:sequence>
  917. <xs:element name="deployment" type="server-deploymentType" maxOccurs="unbounded"/>
  918. </xs:sequence>
  919. </xs:complexType>
  920. <xs:complexType name="server-deploymentType">
  921. <xs:annotation>
  922. <xs:documentation>A deployment that has been mapped to a server.</xs:documentation>
  923. </xs:annotation>
  924. <xs:complexContent>
  925. <xs:extension base="base-deploymentType">
  926. <xs:sequence>
  927. <!-- TODO: maxOccurs should be unbounded once overlays are in place -->
  928. <xs:choice maxOccurs="1">
  929. <xs:element name="content" type="contentType"/>
  930. <xs:element name="fs-archive" type="fs-archiveType"/>
  931. <xs:element name="fs-exploded" type="fs-explodedType"/>
  932. </xs:choice>
  933. </xs:sequence>
  934. <!-- TODO clarify what a value of 'false' means -->
  935. <xs:attribute name="enabled" use="optional" type="xs:boolean" default="true">
  936. <xs:annotation>
  937. <xs:documentation>Whether the deployment deploy automatically when the server starts up.
  938. </xs:documentation>
  939. </xs:annotation>
  940. </xs:attribute>
  941. </xs:extension>
  942. </xs:complexContent>
  943. </xs:complexType>
  944. <xs:complexType name="contentType">
  945. <xs:attribute name="sha1" use="required">
  946. <xs:annotation>
  947. <xs:documentation>The checksum of the content</xs:documentation>
  948. </xs:annotation>
  949. </xs:attribute>
  950. </xs:complexType>
  951. <xs:complexType name="fs-archiveType">
  952. <xs:annotation>
  953. <xs:documentation>Archived content found on the filesystem</xs:documentation>
  954. </xs:annotation>
  955. <xs:complexContent>
  956. <xs:extension base="fs-baseType"/>
  957. </xs:complexContent>
  958. </xs:complexType>
  959. <xs:complexType name="fs-baseType">
  960. <xs:complexContent>
  961. <xs:extension base="pathType"/>
  962. </xs:complexContent>
  963. <!-- TODO: make path required
  964. <xs:complexContent>
  965. <xs:restriction base="pathType">
  966. <xs:attribute name="path" use="required"/>
  967. </xs:restriction>
  968. </xs:complexContent>
  969. -->
  970. </xs:complexType>
  971. <xs:complexType name="fs-explodedType">
  972. <xs:annotation>
  973. <xs:documentation>Exploded content found on the filesystem</xs:documentation>
  974. </xs:annotation>
  975. <xs:complexContent>
  976. <xs:extension base="fs-baseType"/>
  977. </xs:complexContent>
  978. </xs:complexType>
  979. <xs:complexType name="domain-deploymentsType">
  980. <xs:annotation>
  981. <xs:documentation>Contains a list of domain-level deployments</xs:documentation>
  982. </xs:annotation>
  983. <xs:sequence>
  984. <xs:element name="deployment" type="domain-deploymentType" maxOccurs="unbounded"/>
  985. </xs:sequence>
  986. </xs:complexType>
  987. <xs:complexType name="domain-deploymentType">
  988. <xs:annotation>
  989. <xs:documentation>Deployment represents anything that can be deployed (e.g. an application such as EJB-JAR,
  990. WAR, EAR,
  991. any kind of standard archive such as RAR or JBoss-specific deployment),
  992. which can be enabled or disabled on a domain level.
  993. </xs:documentation>
  994. </xs:annotation>
  995. <xs:complexContent>
  996. <xs:extension base="base-deploymentType">
  997. <xs:sequence>
  998. <!-- TODO: maxOccurs should be unbounded once overlays are in place -->
  999. <xs:choice maxOccurs="1">
  1000. <xs:element name="content" type="contentType"/>
  1001. <xs:element name="fs-archive" type="fs-archiveType"/>
  1002. <xs:element name="fs-exploded" type="fs-explodedType"/>
  1003. </xs:choice>
  1004. </xs:sequence>
  1005. </xs:extension>
  1006. </xs:complexContent>
  1007. </xs:complexType>
  1008. <!-- TODO this is not used anywhere yet -->
  1009. <xs:complexType name="clustersType">
  1010. <xs:complexContent>
  1011. <xs:extension base="server-groupType">
  1012. <xs:sequence>
  1013. <xs:element name="partition-name" type="xs:string"/>
  1014. <xs:element name="state-transfer-timeout" type="xs:integer"/>
  1015. <xs:element name="method-call-timeout" type="xs:integer"/>
  1016. </xs:sequence>
  1017. <xs:attribute name="category" type="xs:string" use="required"/>
  1018. </xs:extension>
  1019. </xs:complexContent>
  1020. </xs:complexType>
  1021. <!-- domain-configuration related definitions -->
  1022. <xs:complexType name="domain-configurationType">
  1023. <xs:annotation>
  1024. <xs:documentation>The domain controller/server bootstrap configuration</xs:documentation>
  1025. </xs:annotation>
  1026. <xs:sequence>
  1027. <xs:element ref="bootstrapURI"/>
  1028. </xs:sequence>
  1029. </xs:complexType>
  1030. <xs:element name="bootstrapURI" type="xs:string">
  1031. <xs:annotation>
  1032. <xs:documentation>The URI for bootstrapping a domain server</xs:documentation>
  1033. </xs:annotation>
  1034. </xs:element>
  1035. <xs:complexType name="profilesType">
  1036. <xs:annotation>
  1037. <xs:documentation>Contains a list of profiles available for use in the domain</xs:documentation>
  1038. </xs:annotation>
  1039. <xs:sequence>
  1040. <xs:element name="profile" type="domain-profileType" minOccurs="1" maxOccurs="unbounded"/>
  1041. </xs:sequence>
  1042. </xs:complexType>
  1043. <xs:complexType name="domain-profileType">
  1044. <xs:annotation>
  1045. <xs:documentation>Contains a list of subsystems</xs:documentation>
  1046. </xs:annotation>
  1047. <xs:sequence>
  1048. <xs:any namespace="##other" minOccurs="0" maxOccurs="unbounded">
  1049. <xs:annotation>
  1050. <xs:documentation>A profile declaration may include configuration
  1051. elements from other namespaces for the subsystems that make up the profile.
  1052. </xs:documentation>
  1053. </xs:annotation>
  1054. </xs:any>
  1055. </xs:sequence>
  1056. <xs:attribute name="name" type="xs:string" use="required">
  1057. <xs:annotation>
  1058. <xs:documentation>Name of the profile</xs:documentation>
  1059. </xs:annotation>
  1060. </xs:attribute>
  1061. </xs:complexType>
  1062. <xs:complexType name="standalone-profileType">
  1063. <xs:annotation>
  1064. <xs:documentation>Contains a list of subsystems</xs:documentation>
  1065. </xs:annotation>
  1066. <xs:sequence>
  1067. <xs:choice minOccurs="1" maxOccurs="unbounded">
  1068. <xs:any namespace="##other">
  1069. <xs:annotation>
  1070. <xs:documentation>A profile declaration may include configuration
  1071. elements from other namespaces for the subsystems that make up the profile.
  1072. </xs:documentation>
  1073. </xs:annotation>
  1074. </xs:any>
  1075. </xs:choice>
  1076. </xs:sequence>
  1077. </xs:complexType>
  1078. <!-- general socket definition -->
  1079. <xs:complexType name="socket-binding-groupsType">
  1080. <xs:annotation>
  1081. <xs:documentation>Contains a list of socket binding groups</xs:documentation>
  1082. </xs:annotation>
  1083. <xs:sequence>
  1084. <xs:element name="socket-binding-group" type="socket-binding-groupType" maxOccurs="unbounded"/>
  1085. </xs:sequence>
  1086. </xs:complexType>
  1087. <xs:complexType name="socket-binding-groupType">
  1088. <xs:annotation>
  1089. <xs:documentation>Contains a list of socket configurations</xs:documentation>
  1090. </xs:annotation>
  1091. <xs:sequence>
  1092. <xs:element name="socket-binding" type="socket-bindingType" maxOccurs="unbounded"/>
  1093. <xs:element name="outbound-socket-binding" type="outbound-socket-bindingType" minOccurs="0" maxOccurs="unbounded"/>
  1094. </xs:sequence>
  1095. <xs:attribute name="name" type="xs:string" use="required"/>
  1096. <xs:attribute name="default-interface" type="xs:string" use="required">
  1097. <xs:annotation>
  1098. <xs:documentation>
  1099. Name of an interface that should be used as the interface for
  1100. any sockets that do not explicitly declare one.
  1101. </xs:documentation>
  1102. </xs:annotation>
  1103. </xs:attribute>
  1104. </xs:complexType>
  1105. <xs:complexType name="standalone-socket-binding-groupType">
  1106. <xs:annotation>
  1107. <xs:documentation>Contains a list of socket configurations</xs:documentation>
  1108. </xs:annotation>
  1109. <xs:sequence>
  1110. <xs:element name="socket-binding" type="socket-bindingType" maxOccurs="unbounded"/>
  1111. <xs:element name="outbound-socket-binding" type="outbound-socket-bindingType" minOccurs="0" maxOccurs="unbounded"/>
  1112. </xs:sequence>
  1113. <xs:attribute name="name" type="xs:string" use="required"/>
  1114. <xs:attribute name="default-interface" type="xs:string" use="required">
  1115. <xs:annotation>
  1116. <xs:documentation>
  1117. Name of an interface that should be used as the interface for
  1118. any sockets that do not explicitly declare one.
  1119. </xs:documentation>
  1120. </xs:annotation>
  1121. </xs:attribute>
  1122. <xs:attribute name="port-offset" type="xs:int" use="optional" default="0">
  1123. <xs:annotation>
  1124. <xs:documentation>
  1125. Increment to apply to the base port values defined in the
  1126. socket group to derive the values to use on this
  1127. server.
  1128. </xs:documentation>
  1129. </xs:annotation>
  1130. </xs:attribute>
  1131. </xs:complexType>
  1132. <xs:complexType name="socket-bindingType">
  1133. <xs:annotation>
  1134. <xs:documentation>Configuration information for a socket.</xs:documentation>
  1135. </xs:annotation>
  1136. <xs:choice>
  1137. <xs:element name="client-mapping" type="socket-binding-client-mappingType"
  1138. minOccurs="0" maxOccurs="unbounded">
  1139. <xs:annotation>
  1140. <xs:documentation>
  1141. Specifies zero or more client mappings for this socket binding.
  1142. A client connecting to this socket should use the destination address
  1143. specified in the mapping that matches its desired outbound interface.
  1144. This allows for advanced network topologies that use either network
  1145. address translation, or have bindings on multiple network interfaces
  1146. to function.
  1147. Each mapping should be evaluated in declared order, with the first successful
  1148. match used to determine the destination.
  1149. </xs:documentation>
  1150. </xs:annotation>
  1151. </xs:element>
  1152. </xs:choice>
  1153. <xs:attribute name="name" type="xs:string" use="required"/>
  1154. <xs:attribute name="interface" type="xs:string" use="optional">
  1155. <xs:annotation>
  1156. <xs:documentation>
  1157. Name of the interface to which the socket should be bound, or, for multicast
  1158. sockets, the interface on which it should listen. This should
  1159. be one of the declared interfaces.
  1160. </xs:documentation>
  1161. </xs:annotation>
  1162. </xs:attribute>
  1163. <xs:attribute name="port" type="xs:unsignedShort" use="optional" default="0">
  1164. <xs:annotation>
  1165. <xs:documentation>
  1166. Number of the port to which the socket should be bound.
  1167. </xs:documentation>
  1168. </xs:annotation>
  1169. </xs:attribute>
  1170. <xs:attribute name="fixed-port" type="xs:boolean" use="optional" default="false">
  1171. <xs:annotation>
  1172. <xs:documentation>
  1173. Whether the port value should remain fixed even if numerically offsets
  1174. are applied to the other sockets in the socket group..
  1175. </xs:documentation>
  1176. </xs:annotation>
  1177. </xs:attribute>
  1178. <xs:attribute name="multicast-address" type="xs:string" use="optional">
  1179. <xs:annotation>
  1180. <xs:documentation>
  1181. Multicast address on which the socket should receive multicast
  1182. traffic. If unspecified, the socket will not be configured
  1183. to receive multicast.
  1184. </xs:documentation>
  1185. </xs:annotation>
  1186. </xs:attribute>
  1187. <xs:attribute name="multicast-port" type="xs:positiveInteger" use="optional">
  1188. <xs:annotation>
  1189. <xs:documentation>
  1190. Port on which the socket should receive multicast
  1191. traffic. Must be configured if 'multicast-address' is configured.
  1192. </xs:documentation>
  1193. </xs:annotation>
  1194. </xs:attribute>
  1195. </xs:complexType>
  1196. <xs:complexType name="socket-binding-client-mappingType">
  1197. <xs:annotation>
  1198. <xs:documentation>
  1199. Type definition for a client mapping on a socket binding. A client
  1200. mapping specifies how external clients should connect to this
  1201. socket's port, provided that the client's outbound interface
  1202. match the specified source network value.
  1203. </xs:documentation>
  1204. </xs:annotation>
  1205. <xs:attribute name="source-network" type="xs:string" use="optional">
  1206. <xs:annotation>
  1207. <xs:documentation>
  1208. Source network the client connection binds on. This value is in
  1209. the form of ip/netmask. A client should match this value against
  1210. the desired client host network interface, and if matched the
  1211. client should connect to the corresponding destination values.
  1212. If omitted this mapping should match any interface.
  1213. </xs:documentation>
  1214. </xs:annotation>
  1215. </xs:attribute>
  1216. <xs:attribute name="destination-address" type="xs:string" use="required">
  1217. <xs:annotation>
  1218. <xs:documentation>
  1219. The destination address that a client should connect to if the
  1220. source-network matches. This value can either be a hostname or
  1221. an ip address.
  1222. </xs:documentation>
  1223. </xs:annotation>
  1224. </xs:attribute>
  1225. <xs:attribute name="destination-port" type="xs:string" use="optional">
  1226. <xs:annotation>
  1227. <xs:documentation>
  1228. The destination port that a client should connect to if the
  1229. source-network matches.
  1230. If omitted this mapping will reuse the effective socket binding
  1231. port.
  1232. </xs:documentation>
  1233. </xs:annotation>
  1234. </xs:attribute>
  1235. </xs:complexType>
  1236. <xs:complexType name="outbound-socket-bindingType">
  1237. <xs:annotation>
  1238. <xs:documentation>Configuration information for a outbound socket.</xs:documentation>
  1239. </xs:annotation>
  1240. <xs:choice>
  1241. <xs:element name="remote-destination" type="remote-destinationType" maxOccurs="1"/>
  1242. <xs:element name="local-destination" type="local-destinationType" maxOccurs="1"/>
  1243. </xs:choice>
  1244. <xs:attribute name="name" type="xs:string" use="required">
  1245. <xs:annotation>
  1246. <xs:documentation>
  1247. The name of the outbound socket binding
  1248. </xs:documentation>
  1249. </xs:annotation>
  1250. </xs:attribute>
  1251. <xs:attribute name="source-interface" type="xs:string" use="optional">
  1252. <xs:annotation>
  1253. <xs:documentation>
  1254. The name of the interface that should be used for setting up the source address of the
  1255. outbound socket. This should be one of the declared interfaces.
  1256. </xs:documentation>
  1257. </xs:annotation>
  1258. </xs:attribute>
  1259. <xs:attribute name="source-port" type="xs:positiveInteger" use="optional">
  1260. <xs:annotation>
  1261. <xs:documentation>
  1262. The port number that will be used for setting the source addresss of the outbound socket. If the
  1263. source-interface attribute has been specified and the source-port attribute is absent,
  1264. then the system uses a ephemeral port while binding the socket to a source address.
  1265. </xs:documentation>
  1266. </xs:annotation>
  1267. </xs:attribute>
  1268. <xs:attribute name="fixed-source-port" type="xs:boolean" use="optional" default="false">
  1269. <xs:annotation>
  1270. <xs:documentation>
  1271. Whether the source-port value should remain fixed even if the socket binding group specifies
  1272. a port offset
  1273. </xs:documentation>
  1274. </xs:annotation>
  1275. </xs:attribute>
  1276. </xs:complexType>
  1277. <xs:complexType name="remote-destinationType">
  1278. <xs:attribute name="host" type="xs:string" use="required">
  1279. <xs:annotation>
  1280. <xs:documentation>
  1281. The remote server address to which the outbound socket has to be connect.
  1282. The address can be either a IP address of the host server of the hostname of the server
  1283. </xs:documentation>
  1284. </xs:annotation>
  1285. </xs:attribute>
  1286. <xs:attribute name="port" type="xs:positiveInteger" use="required">
  1287. <xs:annotation>
  1288. <xs:documentation>
  1289. The remote port to which the outbound socket has to connect.
  1290. </xs:documentation>
  1291. </xs:annotation>
  1292. </xs:attribute>
  1293. </xs:complexType>
  1294. <xs:complexType name="local-destinationType">
  1295. <xs:attribute name="socket-binding-ref" type="xs:string" use="required">
  1296. <xs:annotation>
  1297. <xs:documentation>
  1298. The reference to a socket binding that has to be used as the destination for the outbound
  1299. socket binding. This socket binding name should belong to the same socket binding group
  1300. to which this local destination client socket belongs.
  1301. </xs:documentation>
  1302. </xs:annotation>
  1303. </xs:attribute>
  1304. </xs:complexType>
  1305. <xs:complexType name="socket-binding-group-refType">
  1306. <xs:attribute name="ref" type="xs:string">
  1307. <xs:annotation>
  1308. <xs:documentation>
  1309. The socket group to use for the server group or server.
  1310. </xs:documentation>
  1311. </xs:annotation>
  1312. </xs:attribute>
  1313. <xs:attribute name="port-offset" type="xs:int" default="0">
  1314. <xs:annotation>
  1315. <xs:documentation>
  1316. Increment to apply to the base port values defined in the
  1317. referenced socket group to derive the values to use on this
  1318. server.
  1319. </xs:documentation>
  1320. </xs:annotation>
  1321. </xs:attribute>
  1322. </xs:complexType>
  1323. <xs:complexType name="named-interfacesType">
  1324. <xs:annotation>
  1325. <xs:documentation>
  1326. A list of named network interfaces. The interfaces may or may
  1327. not be fully specified (i.e. include criteria on how to determine
  1328. their IP address.)
  1329. </xs:documentation>
  1330. </xs:annotation>
  1331. <xs:sequence>
  1332. <xs:element name="interface" type="named-interfaceType" minOccurs="0" maxOccurs="unbounded"/>
  1333. </xs:sequence>
  1334. </xs:complexType>
  1335. <!-- TODO make this and specified-interfaceType the same except for interface-criteriaGroup minOccurs -->
  1336. <xs:complexType name="named-interfaceType">
  1337. <xs:annotation>
  1338. <xs:documentation>
  1339. A named network interface, but without any criteria
  1340. for determining the IP address to associate with that interface.
  1341. Acts as a placeholder in the model (e.g. at the domain level)
  1342. until a fully specified interface definition is applied at a
  1343. lower level (e.g. at the server level, where available addresses
  1344. are known.)
  1345. </xs:documentation>
  1346. </xs:annotation>
  1347. <xs:group ref="interface-criteriaGroup" minOccurs="0"/>
  1348. <xs:attribute name="name" type="xs:string" use="required"/>
  1349. </xs:complexType>
  1350. <xs:complexType name="specified-interfacesType">
  1351. <xs:annotation>
  1352. <xs:documentation>
  1353. A list of fully specified named network interfaces.
  1354. </xs:documentation>
  1355. </xs:annotation>
  1356. <xs:sequence>
  1357. <xs:element name="interface" type="specified-interfaceType" minOccurs="0" maxOccurs="unbounded"/>
  1358. </xs:sequence>
  1359. </xs:complexType>
  1360. <xs:complexType name="specified-interfaceType">
  1361. <xs:annotation>
  1362. <xs:documentation>
  1363. A named network interface, along with required criteria
  1364. for determining the IP address to associate with that interface.
  1365. </xs:documentation>
  1366. </xs:annotation>
  1367. <xs:group ref="interface-criteriaGroup" minOccurs="1"/>
  1368. <xs:attribute name="name" type="xs:string" use="required"/>
  1369. </xs:complexType>
  1370. <xs:group name="interface-criteriaGroup">
  1371. <xs:annotation>
  1372. <xs:documentation>
  1373. A set of criteria that can be used at runtime to determine
  1374. what IP address to use for an interface.
  1375. </xs:documentation>
  1376. </xs:annotation>
  1377. <xs:choice>
  1378. <xs:element name="any-address" type="any-addressType"/>
  1379. <xs:element name="any-ipv6-address" type="any-ipv6-addressType"/>
  1380. <xs:element name="any-ipv4-address" type="any-ipv4-addressType"/>
  1381. <xs:choice maxOccurs="unbounded">
  1382. <xs:element name="inet-address" type="inet-addressType"/>
  1383. <xs:element name="loopback" type="loopbackType"/>
  1384. <xs:element name="loopback-address" type="loopback-addressType"/>
  1385. <xs:element name="multicast" type="multicastType"/>
  1386. <xs:element name="point-to-point" type="point-to-pointType"/>
  1387. <xs:element name="virtual" type="interface-virtualType"/>
  1388. <xs:element name="up" type="interface-upType"/>
  1389. <xs:element name="public-address" type="public-addressType"/>
  1390. <xs:element name="link-local-address" type="link-local-addressType"/>
  1391. <xs:element name="site-local-address" type="site-local-addressType"/>
  1392. <xs:element name="nic" type="nicType"/>
  1393. <xs:element name="nic-match" type="nic-matchType"/>
  1394. <xs:element name="subnet-match" type="subnet-matchType"/>
  1395. <xs:element name="not" type="address-exclusionType"/>
  1396. <xs:element name="any" type="address-exclusionType"/>
  1397. </xs:choice>
  1398. </xs:choice>
  1399. </xs:group>
  1400. <xs:complexType name="inet-addressType">
  1401. <xs:attribute name="value" type="xs:string" use="required">
  1402. <xs:annotation>
  1403. <xs:documentation>
  1404. Either a IP address in IPv6 or IPv4 dotted decimal notation,
  1405. or a hostname that can be resolved to an IP address.
  1406. </xs:documentation>
  1407. </xs:annotation>
  1408. </xs:attribute>
  1409. </xs:complexType>
  1410. <xs:complexType name="nicType">
  1411. <xs:attribute name="name" type="xs:string" use="required">
  1412. <xs:annotation>
  1413. <xs:documentation>
  1414. The name of a network interface (e.g. eth0, eth1, lo).
  1415. </xs:documentation>
  1416. </xs:annotation>
  1417. </xs:attribute>
  1418. </xs:complexType>
  1419. <xs:complexType name="nic-matchType">
  1420. <xs:attribute name="pattern" type="xs:string" use="required">
  1421. <xs:annotation>
  1422. <xs:documentation>
  1423. A regular expression against which the names of the network
  1424. interfaces available on the machine can be matched to find
  1425. an acceptable interface.
  1426. </xs:documentation>
  1427. </xs:annotation>
  1428. </xs:attribute>
  1429. </xs:complexType>
  1430. <xs:complexType name="subnet-matchType">
  1431. <xs:attribute name="value" type="xs:string" use="required">
  1432. <xs:annotation>
  1433. <xs:documentation>
  1434. A network IP address and the number of bits in the
  1435. address' network prefix, written in "slash notation";
  1436. e.g. "192.168.0.0/16".
  1437. </xs:documentation>
  1438. </xs:annotation>
  1439. </xs:attribute>
  1440. </xs:complexType>
  1441. <xs:complexType name="address-exclusionType">
  1442. <xs:choice>
  1443. <xs:element name="inet-address" type="inet-addressType" minOccurs="0" maxOccurs="unbounded"/>
  1444. <xs:element name="loopback" type="loopbackType"/>
  1445. <xs:element name="loopback-address" type="loopback-addressType"/>
  1446. <xs:element name="multicast" type="multicastType"/>
  1447. <xs:element name="point-to-point" type="point-to-pointType"/>
  1448. <xs:element name="virtual" type="interface-virtualType"/>
  1449. <xs:element name="up" type="interface-upType"/>
  1450. <xs:element name="public-address" type="public-addressType"/>
  1451. <xs:element name="link-local-address" type="link-local-addressType"/>
  1452. <xs:element name="site-local-address" type="site-local-addressType"/>
  1453. <xs:element name="nic" type="nicType" minOccurs="0" maxOccurs="unbounded"/>
  1454. <xs:element name="nic-match" type="nic-matchType" minOccurs="0" maxOccurs="unbounded"/>
  1455. <xs:element name="subnet-match" type="subnet-matchType" minOccurs="0" maxOccurs="unbounded"/>
  1456. </xs:choice>
  1457. </xs:complexType>
  1458. <xs:complexType name="loopbackType">
  1459. <xs:annotation>
  1460. <xs:documentation>
  1461. Empty element indicating that part of the selection criteria
  1462. for an interface should be whether or not it is a loopback
  1463. interface.
  1464. </xs:documentation>
  1465. </xs:annotation>
  1466. </xs:complexType>
  1467. <xs:complexType name="loopback-addressType">
  1468. <xs:annotation>
  1469. <xs:documentation>
  1470. A loopback address that may not actually be configured on the machine's loopback interface.
  1471. Differs from inet-addressType in that the given value will be used even if no NIC can
  1472. be found that has the IP address associated with it.
  1473. </xs:documentation>
  1474. </xs:annotation>
  1475. <xs:attribute name="value" type="xs:string" use="required">
  1476. <xs:annotation>
  1477. <xs:documentation>
  1478. An IP address in IPv6 or IPv4 dotted decimal notation.
  1479. </xs:documentation>
  1480. </xs:annotation>
  1481. </xs:attribute>
  1482. </xs:complexType>
  1483. <xs:complexType name="multicastType">
  1484. <xs:annotation>
  1485. <xs:documentation>
  1486. Empty element indicating that part of the selection criteria
  1487. for an interface should be whether or not it supports
  1488. multicast.
  1489. </xs:documentation>
  1490. </xs:annotation>
  1491. </xs:complexType>
  1492. <xs:complexType name="point-to-pointType">
  1493. <xs:annotation>
  1494. <xs:documentation>
  1495. Empty element indicating that part of the selection criteria
  1496. for an interface should be whether or not it is a point-to-point
  1497. interface.
  1498. </xs:documentation>
  1499. </xs:annotation>
  1500. </xs:complexType>
  1501. <xs:complexType name="interface-upType">
  1502. <xs:annotation>
  1503. <xs:documentation>
  1504. Empty element indicating that part of the selection criteria
  1505. for an interface should be whether or not it is currently up.
  1506. </xs:documentation>
  1507. </xs:annotation>
  1508. </xs:complexType>
  1509. <xs:complexType name="interface-virtualType">
  1510. <xs:annotation>
  1511. <xs:documentation>
  1512. Empty element indicating that part of the selection criteria
  1513. for an interface should be whether or not it is a virtual
  1514. interface.
  1515. </xs:documentation>
  1516. </xs:annotation>
  1517. </xs:complexType>
  1518. <xs:complexType name="public-addressType">
  1519. <xs:annotation>
  1520. <xs:documentation>
  1521. Empty element indicating that part of the selection criteria
  1522. for an interface should be whether or not it has a publicly
  1523. routable address.
  1524. </xs:documentation>
  1525. </xs:annotation>
  1526. </xs:complexType>
  1527. <xs:complexType name="site-local-addressType">
  1528. <xs:annotation>
  1529. <xs:documentation>
  1530. Empty element indicating that part of the selection criteria
  1531. for an interface should be whether or not an address associated
  1532. with it is site-local.
  1533. </xs:documentation>
  1534. </xs:annotation>
  1535. </xs:complexType>
  1536. <xs:complexType name="link-local-addressType">
  1537. <xs:annotation>
  1538. <xs:documentation>
  1539. Empty element indicating that part of the selection criteria
  1540. for an interface should be whether or not an address associated
  1541. with it is link-local.
  1542. </xs:documentation>
  1543. </xs:annotation>
  1544. </xs:complexType>
  1545. <xs:complexType name="any-ipv6-addressType">
  1546. <xs:annotation>
  1547. <xs:documentation>
  1548. Empty element indicating that sockets using this interface
  1549. should be bound to the IPv6 wildcard address (::).
  1550. </xs:documentation>
  1551. </xs:annotation>
  1552. </xs:complexType>
  1553. <xs:complexType name="any-ipv4-addressType">
  1554. <xs:annotation>
  1555. <xs:documentation>
  1556. Empty element indicating that sockets using this interface
  1557. should be bound to the IPv4 wildcard address (0.0.0.0).
  1558. </xs:documentation>
  1559. </xs:annotation>
  1560. </xs:complexType>
  1561. <xs:complexType name="any-addressType">
  1562. <xs:annotation>
  1563. <xs:documentation>
  1564. Empty element indicating that sockets using this interface
  1565. should be bound to a wildcard address. The IPv6 wildcard
  1566. address (::) will be used unless the java.net.preferIpV4Stack
  1567. system property is set to true, in which case the IPv4
  1568. wildcard address (0.0.0.0) will be used. If a socket is
  1569. bound to an IPv6 anylocal address on a dual-stack machine,
  1570. it can accept both IPv6 and IPv4 traffic; if it is bound to
  1571. an IPv4 (IPv4-mapped) anylocal address, it can only accept
  1572. IPv4 traffic.
  1573. </xs:documentation>
  1574. </xs:annotation>
  1575. </xs:complexType>
  1576. <xs:complexType name="socketType">
  1577. <xs:annotation>
  1578. <xs:documentation>Configuration information for a socket.</xs:documentation>
  1579. </xs:annotation>
  1580. <xs:attribute name="name" type="xs:string" use="required"/>
  1581. <xs:attribute name="interface" type="xs:string" use="optional">
  1582. <xs:annotation>
  1583. <xs:documentation>
  1584. Name of the interface to which the socket should be bound, or, for multicast
  1585. sockets, the interface on which it should listen. This should
  1586. be one of the declared interfaces.
  1587. </xs:documentation>
  1588. </xs:annotation>
  1589. </xs:attribute>
  1590. <xs:attribute name="port" type="xs:unsignedShort" use="optional" default="0">
  1591. <xs:annotation>
  1592. <xs:documentation>
  1593. Number of the port to which the socket should be bound.
  1594. </xs:documentation>
  1595. </xs:annotation>
  1596. </xs:attribute>
  1597. <xs:attribute name="fixed-port" type="xs:boolean" use="optional" default="false">
  1598. <xs:annotation>
  1599. <xs:documentation>
  1600. Whether the port value should remain fixed even if numerically offsets
  1601. are applied to the other sockets in the socket group..
  1602. </xs:documentation>
  1603. </xs:annotation>
  1604. </xs:attribute>
  1605. <xs:attribute name="multicast-address" type="xs:string" use="optional">
  1606. <xs:annotation>
  1607. <xs:documentation>
  1608. Multicast address on which the socket should receive multicast
  1609. traffic. If unspecified, the socket will not be configured
  1610. to receive multicast.
  1611. </xs:documentation>
  1612. </xs:annotation>
  1613. </xs:attribute>
  1614. <xs:attribute name="multicast-port" type="xs:positiveInteger" use="optional">
  1615. <xs:annotation>
  1616. <xs:documentation>
  1617. Port on which the socket should receive multicast
  1618. traffic. If unspecified, the socket will not be configured
  1619. to receive multicast.
  1620. </xs:documentation>
  1621. </xs:annotation>
  1622. </xs:attribute>
  1623. </xs:complexType>
  1624. <!-- Path configurations -->
  1625. <xs:complexType name="named-pathsType">
  1626. <xs:annotation>
  1627. <xs:documentation>
  1628. A list of named filesystem paths. The paths may or may
  1629. not be fully specified (i.e. include the actual paths.)
  1630. </xs:documentation>
  1631. </xs:annotation>
  1632. <xs:sequence>
  1633. <xs:element name="path" type="named-pathType" minOccurs="0" maxOccurs="unbounded"/>
  1634. </xs:sequence>
  1635. </xs:complexType>
  1636. <xs:complexType name="named-pathType">
  1637. <xs:annotation>
  1638. <xs:documentation>
  1639. A named filesystem path, but without a requirement to specify
  1640. the actual path. If no actual path is specified, acts as a
  1641. as a placeholder in the model (e.g. at the domain level)
  1642. until a fully specified path definition is applied at a
  1643. lower level (e.g. at the host level, where available addresses
  1644. are known.)
  1645. </xs:documentation>
  1646. </xs:annotation>
  1647. <xs:complexContent>
  1648. <xs:extension base="pathType">
  1649. <xs:attribute name="name" type="xs:string" use="required">
  1650. <xs:annotation>
  1651. <xs:documentation>
  1652. The name of the path. Cannot be one of the standard fixed paths
  1653. provided by the system:
  1654. jboss.home - the root directory of the JBoss AS distribution
  1655. user.home - user's home directory
  1656. user.dir - user's current working directory
  1657. java.home - java installation directory
  1658. jboss.server.base.dir - root directory for an individual server
  1659. instance
  1660. Note that the system provides other standard paths that can be
  1661. overridden by declaring them in the configuration file. See
  1662. the 'relative-to' attribute documentation for a complete
  1663. list of standard paths.
  1664. </xs:documentation>
  1665. </xs:annotation>
  1666. </xs:attribute>
  1667. </xs:extension>
  1668. </xs:complexContent>
  1669. </xs:complexType>
  1670. <xs:complexType name="pathType">
  1671. <xs:attribute name="path">
  1672. <xs:annotation>
  1673. <xs:documentation>
  1674. The actual filesystem path. Treated as an absolute path, unless the
  1675. 'relative-to' attribute is specified, in which case the value
  1676. is treated as relative to that path.
  1677. If treated as an absolute path, the actual runtime pathname specified
  1678. by the value of this attribute will be determined as follows:
  1679. If this value is already absolute, then the value is directly
  1680. used. Otherwise the runtime pathname is resolved in a
  1681. system-dependent way. On UNIX systems, a relative pathname is
  1682. made absolute by resolving it against the current user directory.
  1683. On Microsoft Windows systems, a relative pathname is made absolute
  1684. by resolving it against the current directory of the drive named by the
  1685. pathname, if any; if not, it is resolved against the current user
  1686. directory.
  1687. </xs:documentation>
  1688. </xs:annotation>
  1689. <xs:simpleType>
  1690. <xs:restriction base="xs:string">
  1691. <xs:minLength value="1"/>
  1692. </xs:restriction>
  1693. </xs:simpleType>
  1694. </xs:attribute>
  1695. <xs:attribute name="relative-to" type="xs:string" use="optional">
  1696. <xs:annotation>
  1697. <xs:documentation>
  1698. The name of another previously named path, or of one of the
  1699. standard paths provided by the system. If 'relative-to' is
  1700. provided, the value of the 'path' attribute is treated as
  1701. relative to the path specified by this attribute. The standard
  1702. paths provided by the system include:
  1703. jboss.home - the root directory of the JBoss AS distribution
  1704. user.home - user's home directory
  1705. user.dir - user's current working directory
  1706. java.home - java installation directory
  1707. jboss.server.base.dir - root directory for an individual server
  1708. instance
  1709. jboss.server.config.dir - directory in which server configuration
  1710. files are stored.
  1711. jboss.server.data.dir - directory the server will use for persistent
  1712. data file storage
  1713. jboss.server.log.dir - directory the server will use for
  1714. log file storage
  1715. jboss.server.temp.dir - directory the server will use for
  1716. temporary file storage
  1717. jboss.domain.servers.dir - directory under which a host controller
  1718. will create the working area for
  1719. individual server instances
  1720. </xs:documentation>
  1721. </xs:annotation>
  1722. </xs:attribute>
  1723. </xs:complexType>
  1724. <xs:complexType name="specified-pathsType">
  1725. <xs:annotation>
  1726. <xs:documentation>
  1727. A list of named filesystem paths.
  1728. </xs:documentation>
  1729. </xs:annotation>
  1730. <xs:sequence>
  1731. <xs:element name="path" type="specified-pathType" minOccurs="0" maxOccurs="unbounded"/>
  1732. </xs:sequence>
  1733. </xs:complexType>
  1734. <xs:complexType name="specified-pathType">
  1735. <xs:annotation>
  1736. <xs:documentation>
  1737. A named filesystem path.
  1738. </xs:documentation>
  1739. </xs:annotation>
  1740. <xs:attribute name="name" type="xs:string" use="required">
  1741. <xs:annotation>
  1742. <xs:documentation>
  1743. The name of the path. Cannot be one of the standard fixed paths
  1744. provided by the system:
  1745. jboss.home.dir - the root directory of the JBoss AS distribution
  1746. user.home - user's home directory
  1747. user.dir - user's current working directory
  1748. java.home - java installation directory
  1749. jboss.server.base.dir - root directory for an individual server
  1750. instance
  1751. Note that the system provides other standard paths that can be
  1752. overridden by declaring them in the configuration file. See
  1753. the 'relative-to' attribute documentation for a complete
  1754. list of standard paths.
  1755. </xs:documentation>
  1756. </xs:annotation>
  1757. </xs:attribute>
  1758. <xs:attribute name="path" use="required">
  1759. <xs:annotation>
  1760. <xs:documentation>
  1761. The actual filesystem path. Treated as an absolute path, unless the
  1762. 'relative-to' attribute is specified, in which case the value
  1763. is treated as relative to that path.
  1764. If treated as an absolute path, the actual runtime pathname specified
  1765. by the value of this attribute will be determined as follows:
  1766. If this value is already absolute, then the value is directly
  1767. used. Otherwise the runtime pathname is resolved in a
  1768. system-dependent way. On UNIX systems, a relative pathname is
  1769. made absolute by resolving it against the current user directory.
  1770. On Microsoft Windows systems, a relative pathname is made absolute
  1771. by resolving it against the current directory of the drive named by the
  1772. pathname, if any; if not, it is resolved against the current user
  1773. directory.
  1774. Note relative path declarations have to use '/' as file separator.
  1775. </xs:documentation>
  1776. </xs:annotation>
  1777. <xs:simpleType>
  1778. <xs:restriction base="xs:string">
  1779. <xs:minLength value="1"/>
  1780. </xs:restriction>
  1781. </xs:simpleType>
  1782. </xs:attribute>
  1783. <xs:attribute name="relative-to" type="xs:string" use="optional">
  1784. <xs:annotation>
  1785. <xs:documentation>
  1786. The name of another previously named path, or of one of the
  1787. standard paths provided by the system. If 'relative-to' is
  1788. provided, the value of the 'path' attribute is treated as
  1789. relative to the path specified by this attribute. The standard
  1790. paths provided by the system include:
  1791. jboss.home.dir - the root directory of the JBoss AS distribution
  1792. user.home - user's home directory
  1793. user.dir - user's current working directory
  1794. java.home - java installation directory
  1795. jboss.server.base.dir - root directory for an individual server
  1796. instance
  1797. jboss.server.config.dir - directory in which server configuration
  1798. files are stored.
  1799. jboss.server.data.dir - directory the server will use for persistent
  1800. data file storage
  1801. jboss.server.log.dir - directory the server will use for
  1802. log file storage
  1803. jboss.server.temp.dir - directory the server will use for
  1804. temporary file storage
  1805. jboss.domain.servers.dir - directory under which a host controller
  1806. will create the working area for
  1807. individual server instances
  1808. </xs:documentation>
  1809. </xs:annotation>
  1810. </xs:attribute>
  1811. </xs:complexType>
  1812. <!-- JVM configurations -->
  1813. <xs:complexType name="jvmsType">
  1814. <xs:sequence>
  1815. <xs:element name="jvm" type="namedJvmType" minOccurs="0" maxOccurs="unbounded"/>
  1816. </xs:sequence>
  1817. </xs:complexType>
  1818. <xs:complexType name="jvmType">
  1819. <xs:all minOccurs="0" maxOccurs="1">
  1820. <xs:element name="heap" type="heapType" minOccurs="0"/>
  1821. <!-- XX:PermSize, XX:MaxPermSize -->
  1822. <xs:element name="permgen" type="bounded-memory-sizeType" minOccurs="0"/>
  1823. <!-- Xss -->
  1824. <xs:element name="stack" type="memory-sizeType" minOccurs="0"/>
  1825. <xs:element name="agent-lib" type="jvm-agentLibType" minOccurs="0"/>
  1826. <xs:element name="agent-path" type="jvm-agentPathType" minOccurs="0"/>
  1827. <xs:element name="java-agent" type="jvm-javaagentType" minOccurs="0"/>
  1828. <xs:element name="jvm-options" type="jvm-optionsType" minOccurs="0"/>
  1829. <xs:element name="environment-variables" type="environmentVariablesType" minOccurs="0"/>
  1830. </xs:all>
  1831. <xs:attribute name="java-home" type="xs:string"/>
  1832. <xs:attribute name="type" default="SUN">
  1833. <xs:simpleType>
  1834. <xs:restriction base="xs:token">
  1835. <xs:enumeration value="SUN">
  1836. <xs:annotation>
  1837. <xs:documentation>Allows the full set of JVM options to be set via the jvm schema elements</xs:documentation>
  1838. </xs:annotation>
  1839. </xs:enumeration>
  1840. <xs:enumeration value="IBM">
  1841. <xs:annotation>
  1842. <xs:documentation>Sets a subset of the JVM options via the jvm schema elements</xs:documentation>
  1843. </xs:annotation>
  1844. </xs:enumeration>
  1845. </xs:restriction>
  1846. </xs:simpleType>
  1847. </xs:attribute>
  1848. <xs:attribute name="env-classpath-ignored" default="true" type="xs:boolean"/>
  1849. </xs:complexType>
  1850. <xs:complexType name="namedJvmType">
  1851. <xs:complexContent>
  1852. <xs:extension base="jvmType">
  1853. <xs:attribute name="name" type="xs:string"/>
  1854. </xs:extension>
  1855. </xs:complexContent>
  1856. </xs:complexType>
  1857. <xs:complexType name="serverJvmType">
  1858. <xs:complexContent>
  1859. <xs:extension base="namedJvmType">
  1860. <xs:attribute name="debug-enabled" type="xs:boolean" default="false"/>
  1861. <xs:attribute name="debug-options" type="xs:string" />
  1862. </xs:extension>
  1863. </xs:complexContent>
  1864. </xs:complexType>
  1865. <xs:complexType name="heapType">
  1866. <xs:attribute name="size" use="optional">
  1867. <xs:annotation>
  1868. <xs:documentation>Initial JVM heap size</xs:documentation>
  1869. </xs:annotation>
  1870. </xs:attribute>
  1871. <xs:attribute name="max-size" use="optional">
  1872. <xs:annotation>
  1873. <xs:documentation>Maximum JVM heap size</xs:documentation>
  1874. </xs:annotation>
  1875. </xs:attribute>
  1876. </xs:complexType>
  1877. <xs:complexType name="jvm-optionsType">
  1878. <xs:sequence>
  1879. <xs:element name="option" type="jvm-optionType" minOccurs="0" maxOccurs="unbounded"/>
  1880. </xs:sequence>
  1881. </xs:complexType>
  1882. <xs:complexType name="jvm-optionType">
  1883. <xs:attribute name="value" use="required">
  1884. <xs:annotation>
  1885. <xs:documentation>JVM option value</xs:documentation>
  1886. </xs:annotation>
  1887. </xs:attribute>
  1888. </xs:complexType>
  1889. <xs:complexType name="jvm-agentLibType">
  1890. <xs:attribute name="value" use="required">
  1891. <xs:annotation>
  1892. <xs:documentation>JVM agent lib value </xs:documentation>
  1893. </xs:annotation>
  1894. </xs:attribute>
  1895. </xs:complexType>
  1896. <xs:complexType name="jvm-agentPathType">
  1897. <xs:attribute name="value" use="required">
  1898. <xs:annotation>
  1899. <xs:documentation>JVM agent path value </xs:documentation>
  1900. </xs:annotation>
  1901. </xs:attribute>
  1902. </xs:complexType>
  1903. <xs:complexType name="jvm-javaagentType">
  1904. <xs:attribute name="value" use="required">
  1905. <xs:annotation>
  1906. <xs:documentation>JVM javaagent value </xs:documentation>
  1907. </xs:annotation>
  1908. </xs:attribute>
  1909. </xs:complexType>
  1910. <xs:complexType name="bounded-memory-sizeType">
  1911. <xs:attribute name="size" type="xs:string"/>
  1912. <xs:attribute name="max-size" type="xs:string"/>
  1913. </xs:complexType>
  1914. <xs:complexType name="memory-sizeType">
  1915. <xs:attribute name="size" type="xs:string" use="required"/>
  1916. </xs:complexType>
  1917. <xs:complexType name="properties-with-boottime">
  1918. <xs:sequence>
  1919. <xs:element name="property" type="boottimePropertyType" maxOccurs="unbounded"/>
  1920. </xs:sequence>
  1921. </xs:complexType>
  1922. <xs:complexType name="properties">
  1923. <xs:sequence>
  1924. <xs:element name="property" type="propertyType" maxOccurs="unbounded"/>
  1925. </xs:sequence>
  1926. </xs:complexType>
  1927. <xs:complexType name="environmentVariablesType">
  1928. <xs:sequence>
  1929. <xs:element name="variable" type="propertyType" maxOccurs="unbounded"/>
  1930. </xs:sequence>
  1931. </xs:complexType>
  1932. <xs:complexType name="propertyType">
  1933. <xs:attribute name="name" use="required"/>
  1934. <xs:attribute name="value" use="optional"/>
  1935. </xs:complexType>
  1936. <xs:complexType name="boottimePropertyType">
  1937. <xs:complexContent>
  1938. <xs:extension base="propertyType">
  1939. <xs:attribute name="boot-time" type="xs:boolean" default="true"/>
  1940. </xs:extension>
  1941. </xs:complexContent>
  1942. </xs:complexType>
  1943. <xs:complexType name="vaultType">
  1944. <xs:annotation>
  1945. <xs:documentation>
  1946. <![CDATA[
  1947. Vault Configuration.
  1948. ]]>
  1949. </xs:documentation>
  1950. </xs:annotation>
  1951. <xs:sequence>
  1952. <xs:element name="vault-option" type="propertyType" minOccurs="0" maxOccurs="unbounded"/>
  1953. </xs:sequence>
  1954. <xs:attribute name="code" type="xs:string" use="optional"/>
  1955. </xs:complexType>
  1956. <xs:complexType name="management-client-contentType">
  1957. <xs:annotation>
  1958. <xs:documentation>
  1959. <![CDATA[
  1960. Storage information about re-usable chunks of data useful to management clients that are stored
  1961. in the domain content repository.
  1962. ]]>
  1963. </xs:documentation>
  1964. </xs:annotation>
  1965. <xs:sequence>
  1966. <xs:element name="rollout-plans" type="contentType" minOccurs="0" maxOccurs="1">
  1967. <xs:annotation>
  1968. <xs:documentation>
  1969. <![CDATA[
  1970. Storage information about a set of named management update rollout plans useful to management
  1971. clients that are stored in the domain content repository. The management API exposed by the domain
  1972. controller provides access to these plans to management clients, allowing clients to use the plans
  1973. by referencing them by name, avoiding the need to recreate them for each use.
  1974. ]]>
  1975. </xs:documentation>
  1976. </xs:annotation>
  1977. </xs:element>
  1978. </xs:sequence>
  1979. </xs:complexType>
  1980. </xs:schema>