<?xml version="1.0" encoding="UTF-8"?><xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://camel.apache.org/schema/xml-io" elementFormDefault="qualified" targetNamespace="http://camel.apache.org/schema/xml-io" version="1.0">
  <xs:element name="aggregate" type="tns:aggregateDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Aggregates many messages into a single message
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="apiKey" type="tns:apiKeyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security basic auth definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="asn1" type="tns:asn1DataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encode and decode data structures using Abstract Syntax Notation One (ASN.1).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="avro" type="tns:avroDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Serialize and deserialize messages using Apache Avro binary data format.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="barcode" type="tns:barcodeDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Transform strings to various 1D/2D barcode bitmap formats and back.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="base64" type="tns:base64DataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encode and decode data using Base64.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="basicAuth" type="tns:basicAuthDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security basic auth definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="batchConfig" type="tns:batchResequencerConfig">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Configures batch-processing resequence eip.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="bean" type="tns:beanDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Calls a Java bean
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="beanFactory" type="tns:beanFactoryDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Define custom beans that can be used in your Camel routes and in general.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="beanio" type="tns:beanioDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java beans to and from flat files (such as CSV, delimited, or fixed length formats).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="beans" type="tns:beansDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Container for beans, routes, and more. Important this is only supported when using XML DSL with camel-xml-io-dsl. This
is NOT for the classic old Spring XML DSL used by Camel 1.x/2.x.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="bearerToken" type="tns:bearerTokenDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security bearer token authentication definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="bindy" type="tns:bindyDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java beans from and to flat payloads (such as CSV, delimited, fixed length formats, or FIX
messages).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="blacklistServiceFilter" type="tns:blacklistServiceCallServiceFilterConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="cachingServiceDiscovery" type="tns:cachingServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="camel" type="tns:applicationDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Root tag for Camel application, that can contain beans, routes, and more. Important this is only supported when using
XML DSL with camel-xml-io-dsl. This is NOT for the classic old Spring XML DSL used by Camel 1.x/2.x.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="cbor" type="tns:cborDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Unmarshal a CBOR payload to POJO and back.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="choice" type="tns:choiceDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route messages based on a series of predicates
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="circuitBreaker" type="tns:circuitBreakerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route messages in a fault tolerance way using Circuit Breaker
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="claimCheck" type="tns:claimCheckDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
The Claim Check EIP allows you to replace message content with a claim check (a unique key), which can be used to
retrieve the message content at a later time.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="combinedServiceDiscovery" type="tns:combinedServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="combinedServiceFilter" type="tns:combinedServiceCallServiceFilterConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="constant" type="tns:constantExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A fixed value set only once during the route startup.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="consulServiceDiscovery" type="tns:consulServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="contextScan" type="tns:contextScanDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Scans for Java org.apache.camel.builder.RouteBuilder instances in the context org.apache.camel.spi.Registry .
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="convertBodyTo" type="tns:convertBodyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Converts the message body to another type
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="convertHeaderTo" type="tns:convertHeaderDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Converts the message header to another type
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="convertVariableTo" type="tns:convertVariableDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Converts the variable to another type
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="crypto" type="tns:cryptoDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encrypt and decrypt messages using Java Cryptography Extension (JCE).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="csimple" type="tns:cSimpleExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluate a compiled simple expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="csv" type="tns:csvDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Handle CSV (Comma Separated Values) payloads.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="custom" type="tns:customDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Delegate to a custom org.apache.camel.spi.DataFormat implementation via Camel registry.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="customLoadBalancer" type="tns:customLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a custom load balancer implementation.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="customServiceFilter" type="tns:customServiceCallServiceFilterConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="customTransformer" type="tns:customTransformerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a custom transformer on a route level.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="customValidator" type="tns:customValidatorDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a custom validator on the route level.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="dataFormatTransformer" type="tns:dataFormatTransformerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Represents a org.apache.camel.processor.transformer.DataFormatTransformer which leverages
org.apache.camel.spi.DataFormat to perform transformation. One of the DataFormat 'ref' or DataFormat 'type' needs to be
specified.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="dataFormats" type="tns:dataFormatsDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Configure data formats.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="datasonnet" type="tns:datasonnetExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use DataSonnet scripts for message transformations.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="deadLetterChannel" type="tns:deadLetterChannelDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Error handler with dead letter queue.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="defaultErrorHandler" type="tns:defaultErrorHandlerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
The default error handler.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="defaultLoadBalancer" type="tns:defaultServiceCallServiceLoadBalancerConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="delay" type="tns:delayDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Delays processing for a specified length of time
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="delete" type="tns:deleteDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest DELETE command
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="dfdl" type="tns:dfdlDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Handle DFDL (Data Format Description Language) transformation.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="dnsServiceDiscovery" type="tns:dnsServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="doCatch" type="tns:catchDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Catches exceptions as part of a try, catch, finally block
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="doFinally" type="tns:finallyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Path traversed when a try, catch, finally block exits
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="doTry" type="tns:tryDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marks the beginning of a try, catch, finally block
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="dynamicRouter" type="tns:dynamicRouterDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route messages based on dynamic rules
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="endpointTransformer" type="tns:endpointTransformerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a Camel endpoint to perform transformation on the route level.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="endpointValidator" type="tns:endpointValidatorDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a Camel endpoint to perform validation on the route level.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="enrich" type="tns:enrichDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Enriches a message with data from a secondary resource
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="errorHandler" type="tns:errorHandlerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Camel error handling.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="exchangeProperty" type="tns:exchangePropertyExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Gets a property from the Exchange.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="expression" type="tns:expressionSubElementDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A useful base class for an expression
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="expressionDefinition" type="tns:expression"/>
  <xs:element name="failoverLoadBalancer" type="tns:failoverLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
In case of failures the exchange will be tried on the next endpoint.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="faultToleranceConfiguration" type="tns:faultToleranceConfigurationDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
MicroProfile Fault Tolerance Circuit Breaker EIP configuration
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="fhirJson" type="tns:fhirJsonDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshall and unmarshall FHIR objects to/from JSON.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="fhirXml" type="tns:fhirXmlDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshall and unmarshall FHIR objects to/from XML.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="filter" type="tns:filterDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Filter out messages based using a predicate
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="flatpack" type="tns:flatpackDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java lists and maps to/from flat files (such as CSV, delimited, or fixed length formats) using
Flatpack library.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="from" type="tns:fromDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Act as a message source as input to a route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="fury" type="tns:furyDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Serialize and deserialize messages using Apache Fury
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="get" type="tns:getDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest GET command
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="globalOption" type="tns:globalOptionDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Models a string key/value pair for configuring some global options on a Camel context such as max debug log length.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="globalOptions" type="tns:globalOptionsDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Models a series of string key/value pairs for configuring some global options on a Camel context such as max debug log
length.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="grok" type="tns:grokDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Unmarshal unstructured data to objects using Logstash based Grok patterns.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="groovy" type="tns:groovyExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a Groovy script.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="gzipDeflater" type="tns:gzipDeflaterDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Compress and decompress messages using java.util.zip.GZIPStream.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="head" type="tns:headDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest HEAD command
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="header" type="tns:headerExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Gets a header from the Exchange.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="healthyServiceFilter" type="tns:healthyServiceCallServiceFilterConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="hl7" type="tns:hl7DataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal HL7 (Health Care) model objects using the HL7 MLLP codec.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="hl7terser" type="tns:hl7TerserExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Get the value of a HL7 message field specified by terse location specification syntax.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="ical" type="tns:icalDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal iCal (.ics) documents to/from model objects.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="idempotentConsumer" type="tns:idempotentConsumerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Filters out duplicate messages
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="inputType" type="tns:inputTypeDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Set the expected data type of the input message. If the actual message type is different at runtime, camel look for a
required Transformer and apply if exists. If validate attribute is true then camel applies Validator as well. Type name
consists of two parts, 'scheme' and 'name' connected with ':'. For Java type 'name' is a fully qualified class name. For
example {code java:java.lang.String} , {code json:ABCOrder} . It's also possible to specify only scheme part, so that it
works like a wildcard. If only 'xml' is specified, all the XML message matches. It's handy to add only one
transformer/validator for all the transformation from/to XML.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="intercept" type="tns:interceptDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Intercepts a message at each step in the route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="interceptFrom" type="tns:interceptFromDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Intercepts incoming messages
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="interceptSendToEndpoint" type="tns:interceptSendToEndpointDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Intercepts messages being sent to an endpoint
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="jacksonXml" type="tns:jacksonXMLDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Unmarshal an XML payloads to POJOs and back using XMLMapper extension of Jackson.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="java" type="tns:javaExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a Java (Java compiled once at runtime) expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="jaxb" type="tns:jaxbDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Unmarshal XML payloads to POJOs and back using JAXB2 XML marshalling standard.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="joor" type="tns:joorExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: Evaluates a jOOR (Java compiled once at runtime) expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="jq" type="tns:jqExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a JQ expression against a JSON message body.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="js" type="tns:javaScriptExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a JavaScript expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="json" type="tns:jsonDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal POJOs to JSON and back.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="jsonApi" type="tns:jsonApiDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal JSON:API resources using JSONAPI-Converter library.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="jsonpath" type="tns:jsonPathExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a JSONPath expression against a JSON message body.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="jtaTransactionErrorHandler" type="tns:jtaTransactionErrorHandlerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
JTA based transactional error handler (requires camel-jta).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="kamelet" type="tns:kameletDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To call Kamelets in special situations
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="kubernetesServiceDiscovery" type="tns:kubernetesServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="langChain4jCharacterTokenizer" type="tns:langChain4JCharacterTokenizerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Camel AI: Tokenizer for splitting by character.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="langChain4jLineTokenizer" type="tns:langChain4JLineTokenizerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Camel AI: Tokenizer for splitting line by line.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="langChain4jParagraphTokenizer" type="tns:langChain4JParagraphTokenizerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Camel AI: Tokenizer for splitting by paragraphs.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="langChain4jSentenceTokenizer" type="tns:langChain4JSentenceTokenizerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Camel AI: Tokenizer for splitting by sentences.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="langChain4jWordTokenizer" type="tns:langChain4JWordTokenizerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Camel AI: Tokenizer for splitting by word.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="language" type="tns:languageExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a custom language.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="loadBalance" type="tns:loadBalanceDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Balances message processing among a number of nodes
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="loadBalancerConfiguration" type="tns:serviceCallServiceLoadBalancerConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="loadTransformer" type="tns:loadTransformerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To load custom transformers from classpath scanning to be used for route level transformations.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="log" type="tns:logDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Used for printing custom messages to the logger.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="loop" type="tns:loopDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Processes a message multiple times
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="lzf" type="tns:lzfDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Compress and decompress streams using LZF deflate algorithm.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="marshal" type="tns:marshalDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshals data into a specified format for transmission over a transport or component
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="method" type="tns:methodCallExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Calls a Java bean method.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="mimeMultipart" type="tns:mimeMultipartDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal Camel messages with attachments into MIME-Multipart messages and back.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="multicast" type="tns:multicastDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Routes the same message to multiple paths either sequentially or in parallel.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="mutualTLS" type="tns:mutualTLSDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security mutual TLS authentication definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="mvel" type="tns:mvelExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a MVEL template.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="noErrorHandler" type="tns:noErrorHandlerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To not use an error handler.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="oauth2" type="tns:oAuth2Definition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security OAuth2 definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="ognl" type="tns:ognlExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates an OGNL expression (Apache Commons OGNL).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="onCompletion" type="tns:onCompletionDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route to be executed when normal route processing completes
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="onException" type="tns:onExceptionDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route to be executed when an exception is thrown
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="onFallback" type="tns:onFallbackDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route to be executed when Circuit Breaker EIP executes fallback
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="onWhen" type="tns:onWhenDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a predicate to determine when to trigger this.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="openApi" type="tns:openApiDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use OpenApi as contract-first with Camel Rest DSL.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="openIdConnect" type="tns:openIdConnectDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security OpenID Connect definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="optimisticLockRetryPolicy" type="tns:optimisticLockRetryPolicyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure optimistic locking
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="otherwise" type="tns:otherwiseDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route to be executed when all other choices evaluate to false
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="outputType" type="tns:outputTypeDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Set the expected data type of the output message. If the actual message type is different at runtime, camel look for a
required Transformer and apply if exists. If validate attribute is true then camel applies Validator as well. Type name
consists of two parts, 'scheme' and 'name' connected with ':'. For Java type 'name' is a fully qualified class name. For
example {code java:java.lang.String} , {code json:ABCOrder} . It's also possible to specify only scheme part, so that it
works like a wildcard. If only 'xml' is specified, all the XML message matches. It's handy to add only one
transformer/validator for all the XML-Java transformation.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="packageScan" type="tns:packageScanDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Scans for Java org.apache.camel.builder.RouteBuilder classes in java packages
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="param" type="tns:paramDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To specify the rest operation parameters.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="parquetAvro" type="tns:parquetAvroDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Parquet Avro serialization and de-serialization.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="passThroughServiceFilter" type="tns:passThroughServiceCallServiceFilterConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="patch" type="tns:patchDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest PATCH command
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="pausable" type="tns:pausableDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Pausable EIP to support resuming processing from last known offset.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="pgp" type="tns:pgpDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encrypt and decrypt messages using Java Cryptographic Extension (JCE) and PGP.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="pipeline" type="tns:pipelineDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Routes the message to a sequence of processors.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="policy" type="tns:policyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Defines a policy the route will use
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="poll" type="tns:pollDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Polls a message from a static endpoint
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="pollEnrich" type="tns:pollEnrichDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Enriches messages with data polled from a secondary resource
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="post" type="tns:postDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest POST command
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="predicateValidator" type="tns:predicateValidatorDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To use a predicate to perform validation on the route level.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="process" type="tns:processDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Calls a Camel processor
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="property" type="tns:propertyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A key value pair where the value is a literal value
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="propertyExpression" type="tns:propertyExpressionDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A key value pair where the value is an expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="protobuf" type="tns:protobufDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Serialize and deserialize Java objects using Google's Protocol buffers.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="put" type="tns:putDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest PUT command
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="python" type="tns:pythonExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a Python expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="randomLoadBalancer" type="tns:randomLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
The destination endpoints are selected randomly.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="recipientList" type="tns:recipientListDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Route messages to a number of dynamically specified recipients
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="redeliveryPolicy" type="tns:redeliveryPolicyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure re-delivery for error handling
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="ref" type="tns:refExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Uses an existing expression from the registry.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="refErrorHandler" type="tns:refErrorHandlerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
References to an existing or custom error handler.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="removeHeader" type="tns:removeHeaderDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Removes a named header from the message
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="removeHeaders" type="tns:removeHeadersDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Removes message headers whose name matches a specified pattern
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="removeProperties" type="tns:removePropertiesDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Removes message exchange properties whose name matches a specified pattern
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="removeProperty" type="tns:removePropertyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Removes a named property from the message exchange
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="removeVariable" type="tns:removeVariableDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Removes a named variable
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="resequence" type="tns:resequenceDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Resequences (re-order) messages based on an expression
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="resilience4jConfiguration" type="tns:resilience4JConfigurationDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Resilience4j Circuit Breaker EIP configuration
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="responseHeader" type="tns:responseHeaderDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To specify the rest operation response headers.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="responseMessage" type="tns:responseMessageDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To specify the rest operation response messages.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="rest" type="tns:restDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Defines a rest service using the rest-dsl
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="restBinding" type="tns:restBindingDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure rest binding
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="restConfiguration" type="tns:restConfigurationDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure rest
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="restContextRef" type="tns:restContextRefDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To refer to an XML file with rest services defined using the rest-dsl
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="restProperty" type="tns:restPropertyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A key value pair
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="rests" type="tns:restsDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A series of rest services defined using the rest-dsl
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="resumable" type="tns:resumableDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Resume EIP to support resuming processing from last known offset.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="rollback" type="tns:rollbackDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Forces a rollback by stopping routing the message
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="roundRobinLoadBalancer" type="tns:roundRobinLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
The destination endpoints are selected in a round-robin fashion. This is a well-known and classic policy, which spreads
the load evenly.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="route" type="tns:routeDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A Camel route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeBuilder" type="tns:routeBuilderDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To refer to a Java org.apache.camel.builder.RouteBuilder instance to use.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeConfiguration" type="tns:routeConfigurationDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Reusable configuration for Camel route(s).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeConfigurationContextRef" type="tns:routeConfigurationContextRefDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To refer to an XML file with route configuration defined using the xml-dsl
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeConfigurations" type="tns:routeConfigurationsDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A series of route configurations
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeContextRef" type="tns:routeContextRefDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To refer to an XML file with routes defined using the xml-dsl
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeTemplate" type="tns:routeTemplateDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Defines a route template (parameterized routes)
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeTemplateContextRef" type="tns:routeTemplateContextRefDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To refer to an XML file with route templates defined using the xml-dsl
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routeTemplates" type="tns:routeTemplatesDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A series of route templates
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routes" type="tns:routesDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A series of Camel routes
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="routingSlip" type="tns:routingSlipDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Routes a message through a series of steps that are pre-determined (the slip)
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="rss" type="tns:rssDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Transform from ROME SyndFeed Java Objects to XML and vice-versa.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="saga" type="tns:sagaDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Enables Sagas on the route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="sample" type="tns:samplingDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Extract a sample of the messages passing through a route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="script" type="tns:scriptDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Executes a script from a language which does not change the message body.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="security" type="tns:securityDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Rest security definition
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="securityDefinitions" type="tns:restSecuritiesDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure rest security definitions.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="serviceCall" type="tns:serviceCallDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: To call remote services
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="serviceCallConfiguration" type="tns:serviceCallConfigurationDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: Remote service call configuration
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="serviceChooserConfiguration" type="tns:serviceCallServiceChooserConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="serviceDiscoveryConfiguration" type="tns:serviceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="serviceExpression" type="tns:serviceCallExpressionConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="serviceFilterConfiguration" type="tns:serviceCallServiceFilterConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setBody" type="tns:setBodyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sets the contents of the message body
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setExchangePattern" type="tns:setExchangePatternDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sets the exchange pattern on the message exchange
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setHeader" type="tns:setHeaderDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sets the value of a message header
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setHeaders" type="tns:setHeadersDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Allows setting multiple headers on the message at the same time.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setProperty" type="tns:setPropertyDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sets a named property on the message exchange
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setVariable" type="tns:setVariableDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sets the value of a variable
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="setVariables" type="tns:setVariablesDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Allows setting multiple variables at the same time.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="simple" type="tns:simpleExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a Camel simple expression.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="smooks" type="tns:smooksDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Transform and bind XML as well as non-XML data, including EDI, CSV, JSON, and YAML using Smooks.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="soap" type="tns:soapDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal Java objects to SOAP messages and back.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="sort" type="tns:sortDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sorts the contents of the message
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="spel" type="tns:spELExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates a Spring expression (SpEL).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="split" type="tns:splitDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Splits a single message into many sub-messages.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="springTransactionErrorHandler" type="tns:springTransactionErrorHandlerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Spring based transactional error handler (requires camel-spring).
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="staticServiceDiscovery" type="tns:staticServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="step" type="tns:stepDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Routes the message to a sequence of processors which is grouped together as one logical name
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="stickyLoadBalancer" type="tns:stickyLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sticky load balancing using an expression to calculate a correlation key to perform the sticky load balancing.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="stop" type="tns:stopDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Stops the processing of the current message
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="streamConfig" type="tns:streamResequencerConfig">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Configures stream-processing resequence eip.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="swiftMt" type="tns:swiftMtDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encode and decode SWIFT MT messages.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="swiftMx" type="tns:swiftMxDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encode and decode SWIFT MX messages.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="syslog" type="tns:syslogDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshall SyslogMessages to RFC3164 and RFC5424 messages and back.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="tarFile" type="tns:tarFileDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Archive files into tarballs or extract files from tarballs.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="templateParameter" type="tns:routeTemplateParameterDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A route template parameter
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="templatedRoute" type="tns:templatedRouteDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Defines a templated route (a route built from a route template)
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="templatedRouteParameter" type="tns:templatedRouteParameterDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
An input parameter of a route template.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="templatedRoutes" type="tns:templatedRoutesDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A series of templated routes
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="threadPoolProfile" type="tns:threadPoolProfileDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure thread pools
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="threads" type="tns:threadsDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Specifies that all steps after this node are processed asynchronously
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="thrift" type="tns:thriftDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Serialize and deserialize messages using Apache Thrift binary data format.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="throttle" type="tns:throttleDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Controls the rate at which messages are passed to the next node in the route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="throwException" type="tns:throwExceptionDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Throws an exception
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="tidyMarkup" type="tns:tidyMarkupDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Parse (potentially invalid) HTML into valid HTML or DOM.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="to" type="tns:toDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sends the message to a static endpoint
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="toD" type="tns:toDynamicDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Sends the message to a dynamic endpoint
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="tokenize" type="tns:tokenizerExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Tokenize text payloads using delimiter patterns.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="tokenizer" type="tns:tokenizerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Represents a Camel tokenizer for AI.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="topicLoadBalancer" type="tns:topicLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Topic which sends to all destinations.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="transacted" type="tns:transactedDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Enables transaction on the route
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="transform" type="tns:transformDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Transforms the message body based on an expression
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="transformers" type="tns:transformersDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure transformers.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="typeFilter" type="tns:yamlTypeFilterDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="univocityCsv" type="tns:uniVocityCsvDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java objects from and to CSV (Comma Separated Values) using UniVocity Parsers.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="univocityFixed" type="tns:uniVocityFixedDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java objects from and to fixed length records using UniVocity Parsers.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="univocityHeader" type="tns:uniVocityHeader">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure headers for UniVocity data formats.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="univocityTsv" type="tns:uniVocityTsvDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java objects from and to TSV (Tab-Separated Values) records using UniVocity Parsers.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="unmarshal" type="tns:unmarshalDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Converts the message data received from the wire into a format that Apache Camel processors can consume
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="validate" type="tns:validateDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Validates a message based on an expression
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="validators" type="tns:validatorsDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
To configure validators.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="value" type="tns:valueDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
A single value
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="variable" type="tns:variableExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Gets a variable
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="wasm" type="tns:wasmExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Call a wasm (web assembly) function.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="weightedLoadBalancer" type="tns:weightedLoadBalancerDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Uses a weighted load distribution ratio for each server with respect to others.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="when" type="tns:whenDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Triggers a route when the expression evaluates to true
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="wireTap" type="tns:wireTapDefinition">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Routes a copy of a message (or creates a new message) to a secondary destination while continue routing the original
message.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="xmlSecurity" type="tns:xmlSecurityDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Encrypt and decrypt XML payloads using Apache Santuario.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="xpath" type="tns:xPathExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates an XPath expression against an XML payload.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="xquery" type="tns:xQueryExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Evaluates an XQuery expressions against an XML payload.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="xtokenize" type="tns:xmlTokenizerExpression">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Tokenize XML payloads.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="yaml" type="tns:yamlDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Marshal and unmarshal Java objects to and from YAML.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="zipDeflater" type="tns:zipDeflaterDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Compress and decompress streams using java.util.zip.Deflater and java.util.zip.Inflater.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="zipFile" type="tns:zipFileDataFormat">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Compression and decompress streams using java.util.zip.ZipStream.
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:element name="zookeeperServiceDiscovery" type="tns:zooKeeperServiceCallServiceDiscoveryConfiguration">
    <xs:annotation>
      <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: null
]]>
      </xs:documentation>
    </xs:annotation>
  </xs:element>
  <xs:complexType name="output">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="processorDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="disabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to disable this EIP from the route during build time. Once an EIP has been disabled then it cannot be enabled
later at runtime. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="optionalIdentifiedDefinition">
    <xs:sequence/>
    <xs:attribute name="customId" type="xs:boolean"/>
    <xs:attribute name="description" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the description of this node.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="id" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the id of this node.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="aggregateDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element name="correlationExpression" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The expression used to calculate the correlation key to use for aggregation. The Exchange which has the same correlation
key is aggregated together. If the correlation key could not be evaluated an Exception is thrown. You can disable this
by using the ignoreBadCorrelationKeys option.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" name="completionPredicate" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
A Predicate to indicate when an aggregated exchange is complete. If this is not specified and the AggregationStrategy
object implements Predicate, the aggregationStrategy object will be used as the completionPredicate.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" name="completionTimeoutExpression" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Time in millis that an aggregated exchange should be inactive before its complete (timeout). This option can be set as
either a fixed value or using an Expression which allows you to evaluate a timeout dynamically - will use Long as
result. If both are set Camel will fallback to use the fixed value if the Expression result was null or 0. You cannot
use this option together with completionInterval, only one of the two can be used. By default the timeout checker runs
every second, you can use the completionTimeoutCheckerInterval option to configure how frequently to run the checker.
The timeout is an approximation and there is no guarantee that the a timeout is triggered exactly after the timeout
value. It is not recommended to use very low timeout values or checker intervals.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" name="completionSizeExpression" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Number of messages aggregated before the aggregation is complete. This option can be set as either a fixed value or
using an Expression which allows you to evaluate a size dynamically - will use Integer as result. If both are set Camel
will fallback to use the fixed value if the Expression result was null or 0.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" ref="tns:optimisticLockRetryPolicy"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="parallelProcessing" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When aggregated are completed they are being send out of the aggregator. This option indicates whether or not Camel
should use a thread pool with multiple threads for concurrency. If no custom thread pool has been specified then Camel
creates a default pool with 10 concurrent threads. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="optimisticLocking" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Turns on using optimistic locking, which requires the aggregationRepository being used, is supporting this by
implementing org.apache.camel.spi.OptimisticLockingAggregationRepository . Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If using parallelProcessing you can specify a custom thread pool to be used. In fact also if you are not using
parallelProcessing this custom thread pool is used to send out aggregated exchanges as well.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutCheckerExecutorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If using either of the completionTimeout, completionTimeoutExpression, or completionInterval options a background thread
is created to check for the completion for every aggregator. Set this option to provide a custom thread pool to be used
rather than creating a new thread for every aggregator.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregateController" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a org.apache.camel.processor.aggregate.AggregateController to allow external sources to control this aggregator.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationRepository" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The AggregationRepository to use. Sets the custom aggregate repository to use. Will by default use
org.apache.camel.processor.aggregate.MemoryAggregationRepository.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategy" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The AggregationStrategy to use. For example to lookup a bean with the name foo, the value is simply just #bean:foo.
Configuring an AggregationStrategy is required, and is used to merge the incoming Exchange with the existing already
merged exchanges. At first call the oldExchange parameter is null. On subsequent invocations the oldExchange contains
the merged exchanges and newExchange is of course the new incoming Exchange.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using beans as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodAllowNull" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used for the very first aggregation. If this option is true
then null values is used as the oldExchange (at the very first aggregation), when using beans as the
AggregationStrategy. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Number of messages aggregated before the aggregation is complete. This option can be set as either a fixed value or
using an Expression which allows you to evaluate a size dynamically - will use Integer as result. If both are set Camel
will fallback to use the fixed value if the Expression result was null or 0.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionInterval" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A repeating period in millis by which the aggregator will complete all current aggregated exchanges. Camel has a
background task which is triggered every period. You cannot use this option together with completionTimeout, only one of
them can be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionTimeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Time in millis that an aggregated exchange should be inactive before its complete (timeout). This option can be set as
either a fixed value or using an Expression which allows you to evaluate a timeout dynamically - will use Long as
result. If both are set Camel will fallback to use the fixed value if the Expression result was null or 0. You cannot
use this option together with completionInterval, only one of the two can be used. By default the timeout checker runs
every second, you can use the completionTimeoutCheckerInterval option to configure how frequently to run the checker.
The timeout is an approximation and there is no guarantee that the a timeout is triggered exactly after the timeout
value. It is not recommended to use very low timeout values or checker intervals.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionTimeoutCheckerInterval" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Interval in millis that is used by the background task that checks for timeouts ( org.apache.camel.TimeoutMap ). By
default the timeout checker runs every second. The timeout is an approximation and there is no guarantee that the a
timeout is triggered exactly after the timeout value. It is not recommended to use very low timeout values or checker
intervals. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionFromBatchConsumer" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables the batch completion mode where we aggregate from a org.apache.camel.BatchConsumer and aggregate the total
number of exchanges the org.apache.camel.BatchConsumer has reported as total by checking the exchange property
org.apache.camel.Exchange#BATCH_COMPLETE when its complete. This option cannot be used together with
discardOnAggregationFailure. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionOnNewCorrelationGroup" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables completion on all previous groups when a new incoming correlation group. This can for example be used to
complete groups with same correlation keys when they are in consecutive order. Notice when this is enabled then only 1
correlation group can be in progress as when a new correlation group starts, then the previous groups is forced
completed. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="eagerCheckCompletion" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Use eager completion checking which means that the completionPredicate will use the incoming Exchange. As opposed to
without eager completion checking the completionPredicate will use the aggregated Exchange. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidCorrelationKeys" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If a correlation key cannot be successfully evaluated it will be ignored by logging a DEBUG and then just ignore the
incoming Exchange. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="closeCorrelationKeyOnCompletion" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Closes a correlation key when its complete. Any late received exchanges which has a correlation key that has been
closed, it will be defined and a ClosedCorrelationKeyException is thrown.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="discardOnCompletionTimeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Discards the aggregated message on completion timeout. This means on timeout the aggregated message is dropped and not
sent out of the aggregator. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="discardOnAggregationFailure" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Discards the aggregated message when aggregation failed (an exception was thrown from AggregationStrategy . This means
the partly aggregated message is dropped and not sent out of the aggregator. This option cannot be used together with
completionFromBatchConsumer. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="forceCompletionOnStop" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Indicates to complete all current aggregated exchanges when the context is stopped. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completeAllOnStop" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Indicates to wait to complete all current and partial (pending) aggregated exchanges when the context is stopped. This
also means that we will wait for all pending exchanges which are stored in the aggregation repository to complete so the
repository is empty before we can stop. You may want to enable this when using the memory based aggregation repository
that is memory based only, and do not store data on disk. When this option is enabled, then the aggregator is waiting to
complete all those exchanges before its stopped, when stopping CamelContext or the route using it. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="expressionSubElementDefinition">
    <xs:choice>
      <xs:element ref="tns:expressionDefinition"/>
      <xs:element ref="tns:csimple"/>
      <xs:element ref="tns:constant"/>
      <xs:element ref="tns:datasonnet"/>
      <xs:element ref="tns:exchangeProperty"/>
      <xs:element ref="tns:groovy"/>
      <xs:element ref="tns:header"/>
      <xs:element ref="tns:hl7terser"/>
      <xs:element ref="tns:java"/>
      <xs:element ref="tns:js"/>
      <xs:element ref="tns:joor"/>
      <xs:element ref="tns:jq"/>
      <xs:element ref="tns:jsonpath"/>
      <xs:element ref="tns:language"/>
      <xs:element ref="tns:method"/>
      <xs:element ref="tns:mvel"/>
      <xs:element ref="tns:ognl"/>
      <xs:element ref="tns:python"/>
      <xs:element ref="tns:ref"/>
      <xs:element ref="tns:simple"/>
      <xs:element ref="tns:spel"/>
      <xs:element ref="tns:tokenize"/>
      <xs:element ref="tns:variable"/>
      <xs:element ref="tns:wasm"/>
      <xs:element ref="tns:xtokenize"/>
      <xs:element ref="tns:xpath"/>
      <xs:element ref="tns:xquery"/>
    </xs:choice>
  </xs:complexType>
  <xs:complexType name="expression">
    <xs:simpleContent>
      <xs:extension base="xs:string">
        <xs:attribute name="id" type="xs:ID">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the id of this node.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="trim" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to trim the value to remove leading and trailing whitespaces and line breaks. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="optimisticLockRetryPolicyDefinition">
    <xs:sequence/>
    <xs:attribute name="maximumRetries" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum number of retries.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="retryDelay" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the delay in millis between retries. Default value: 50
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="maximumRetryDelay" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the upper value of retry in millis between retries, when using exponential or random backoff. Default value: 1000
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="exponentialBackOff" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Enable exponential backoff. Default value: true
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="randomBackOff" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Enables random backoff. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="beanDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to an existing bean to use, which is looked up from the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="method" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the method name on the bean to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="beanType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the class name (fully qualified) of the bean to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="scope" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Scope of bean. When using singleton scope (default) the bean is created or looked up only once and reused for the
lifetime of the endpoint. The bean should be thread-safe in case concurrent threads is calling the bean at the same
time. When using request scope the bean is created or looked up once per request (exchange). This can be used if you
want to store state on a bean while processing a request and you want to call the same bean instance multiple times
while processing the request. The bean does not have to be thread-safe as the instance is only called from the same
request. When using prototype scope, then the bean will be looked up or created per call. However in case of lookup then
this is delegated to the bean registry such as Spring or CDI (if in use), which depends on their configuration can act
as either singleton or prototype scope. So when using prototype scope then this depends on the bean registry
implementation. Default value: Singleton
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="noOutputDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="beanFactoryDefinition">
    <xs:sequence>
      <xs:element minOccurs="0" name="constructors" type="tns:beanConstructorsDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Optional constructor arguments for creating the bean. Arguments correspond to specific index of the constructor argument
list, starting from zero.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element minOccurs="0" name="properties" type="tns:beanPropertiesDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Optional properties to set on the created bean.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element minOccurs="0" name="script" type="xs:string">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
The script to execute that creates the bean when using scripting languages. If the script use the prefix resource: such
as resource:classpath:com/foo/myscript.groovy, resource:file:/var/myscript.groovy, then its loaded from the external
resource.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="name" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the bean (bean id).
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="type" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The class name (fully qualified) of the bean.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="initMethod" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the custom initialization method to invoke after setting bean properties. The method must have no arguments,
but may throw any exception.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="destroyMethod" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the custom destroy method to invoke on bean shutdown, such as when Camel is shutting down. The method must
have no arguments, but may throw any exception.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="factoryMethod" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Name of method to invoke when creating the bean via a factory bean.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="factoryBean" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Name of factory bean (bean id) to use for creating the bean.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="builderClass" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Fully qualified class name of builder class to use for creating and configuring the bean. The builder will use the
properties values to configure the bean.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="builderMethod" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Name of method when using builder class. This method is invoked after configuring to create the actual bean. This method
is often named build (used by default). Default value: build
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="scriptLanguage" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The script language to use when using inlined script for creating the bean, such as groovy, java, javascript etc.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="beanConstructorsDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="constructor" type="tns:beanConstructorDefinition"/>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="beanConstructorDefinition">
    <xs:sequence/>
    <xs:attribute name="index" type="xs:int"/>
    <xs:attribute name="value" type="xs:string" use="required"/>
  </xs:complexType>
  <xs:complexType name="beanPropertiesDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="property" type="tns:beanPropertyDefinition"/>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="beanPropertyDefinition">
    <xs:sequence>
      <xs:element minOccurs="0" name="properties" type="tns:beanPropertiesDefinition"/>
    </xs:sequence>
    <xs:attribute name="key" type="xs:string"/>
    <xs:attribute name="value" type="xs:string"/>
  </xs:complexType>
  <xs:complexType name="catchDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="exception" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The exception(s) to catch.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" ref="tns:onWhen"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="onWhenDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="choiceDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:when"/>
          <xs:element minOccurs="0" ref="tns:otherwise"/>
        </xs:sequence>
        <xs:attribute name="precondition" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Indicates whether this Choice EIP is in precondition mode or not. If so its branches (when/otherwise) are evaluated
during startup to keep at runtime only the branch that matched. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="whenDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="disabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Disables this EIP from the route during build time. Once an EIP has been disabled then it cannot be enabled late at
runtime. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="otherwiseDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="disabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Disables this EIP from the route during build time. Once an EIP has been disabled then it cannot be enabled late at
runtime. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="circuitBreakerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:resilience4jConfiguration"/>
          <xs:element minOccurs="0" ref="tns:faultToleranceConfiguration"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
          <xs:element minOccurs="0" ref="tns:onFallback"/>
        </xs:sequence>
        <xs:attribute name="configuration" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a circuit breaker configuration (such as resillience4j, or microprofile-fault-tolerance) to use for
configuring the circuit breaker EIP.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inheritErrorHandler" type="xs:boolean">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To turn on or off Camel error handling during circuit breaker. If this is enabled then Camel error handler will first
trigger if there is an error in the circuit breaker, which allows to let Camel handle redeliveries. If all attempts is
failed, then after the circuit breaker is finished, then Camel error handler can handle the error as well such as the
dead letter channel. By default, Camel error handler is turned off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="resilience4JConfigurationDefinition">
    <xs:complexContent>
      <xs:extension base="tns:resilience4JConfigurationCommon">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="resilience4JConfigurationCommon">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="recordException" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Configure a list of exceptions that are recorded as a failure and thus increase the failure rate. Any exception matching
or inheriting from one of the list counts as a failure, unless explicitly ignored via ignoreExceptions.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="ignoreException" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Configure a list of exceptions that are ignored and neither count as a failure nor success. Any exception matching or
inheriting from one of the list will not count as a failure nor success, even if the exceptions is part of
recordExceptions.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="circuitBreaker" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to an existing io.github.resilience4j.circuitbreaker.CircuitBreaker instance to lookup and use from the registry.
When using this, then any other circuit breaker options are not in use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="config" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to an existing io.github.resilience4j.circuitbreaker.CircuitBreakerConfig instance to lookup and use from the
registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="failureRateThreshold" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the failure rate threshold in percentage. If the failure rate is equal or greater than the threshold the
CircuitBreaker transitions to open and starts short-circuiting calls. The threshold must be greater than 0 and not
greater than 100. Default value is 50 percentage. Default value: 50
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="permittedNumberOfCallsInHalfOpenState" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the number of permitted calls when the CircuitBreaker is half open. The size must be greater than 0. Default
size is 10. Default value: 10
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="throwExceptionWhenHalfOpenOrOpenState" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to throw io.github.resilience4j.circuitbreaker.CallNotPermittedException when the call is rejected due circuit
breaker is half open or open. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="slidingWindowSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the size of the sliding window which is used to record the outcome of calls when the CircuitBreaker is
closed. slidingWindowSize configures the size of the sliding window. Sliding window can either be count-based or
time-based. If slidingWindowType is COUNT_BASED, the last slidingWindowSize calls are recorded and aggregated. If
slidingWindowType is TIME_BASED, the calls of the last slidingWindowSize seconds are recorded and aggregated. The
slidingWindowSize must be greater than 0. The minimumNumberOfCalls must be greater than 0. If the slidingWindowType is
COUNT_BASED, the minimumNumberOfCalls cannot be greater than slidingWindowSize . If the slidingWindowType is TIME_BASED,
you can pick whatever you want. Default slidingWindowSize is 100. Default value: 100
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="slidingWindowType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the type of the sliding window which is used to record the outcome of calls when the CircuitBreaker is
closed. Sliding window can either be count-based or time-based. If slidingWindowType is COUNT_BASED, the last
slidingWindowSize calls are recorded and aggregated. If slidingWindowType is TIME_BASED, the calls of the last
slidingWindowSize seconds are recorded and aggregated. Default slidingWindowType is COUNT_BASED. Default value:
COUNT_BASED
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="minimumNumberOfCalls" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the minimum number of calls which are required (per sliding window period) before the CircuitBreaker can
calculate the error rate. For example, if minimumNumberOfCalls is 10, then at least 10 calls must be recorded, before
the failure rate can be calculated. If only 9 calls have been recorded the CircuitBreaker will not transition to open
even if all 9 calls have failed. Default minimumNumberOfCalls is 100. Default value: 100
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="writableStackTraceEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables writable stack traces. When set to false, Exception.getStackTrace returns a zero length array. This may be used
to reduce log spam when the circuit breaker is open as the cause of the exceptions is already known (the circuit breaker
is short-circuiting calls). Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="waitDurationInOpenState" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the wait duration (in seconds) which specifies how long the CircuitBreaker should stay open, before it
switches to half open. Default value is 60 seconds. Default value: 60
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="automaticTransitionFromOpenToHalfOpenEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables automatic transition from OPEN to HALF_OPEN state once the waitDurationInOpenState has passed. Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="slowCallRateThreshold" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures a threshold in percentage. The CircuitBreaker considers a call as slow when the call duration is greater than
slowCallDurationThreshold Duration. When the percentage of slow calls is equal or greater the threshold, the
CircuitBreaker transitions to open and starts short-circuiting calls. The threshold must be greater than 0 and not
greater than 100. Default value is 100 percentage which means that all recorded calls must be slower than
slowCallDurationThreshold. Default value: 100
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="slowCallDurationThreshold" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the duration threshold (seconds) above which calls are considered as slow and increase the slow calls
percentage. Default value is 60 seconds. Default value: 60
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bulkheadEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether bulkhead is enabled or not on the circuit breaker. Default is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bulkheadMaxConcurrentCalls" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the max amount of concurrent calls the bulkhead will support. Default value: 25
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bulkheadMaxWaitDuration" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures a maximum amount of time which the calling thread will wait to enter the bulkhead. If bulkhead has space
available, entry is guaranteed and immediate. If bulkhead is full, calling threads will contest for space, if it becomes
available. maxWaitDuration can be set to 0. Note: for threads running on an event-loop or equivalent (rx computation
pool, etc), setting maxWaitDuration to 0 is highly recommended. Blocking an event-loop thread will most likely have a
negative effect on application throughput. Default value: 0
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether timeout is enabled or not on the circuit breaker. Default is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutExecutorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References to a custom thread pool to use when timeout is enabled (uses ForkJoinPool#commonPool() by default).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutDuration" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the thread execution timeout. Default value is 1 second. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutCancelRunningFuture" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures whether cancel is called on the running future. Defaults to true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="identifiedType">
    <xs:sequence/>
    <xs:attribute name="id" type="xs:ID">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The id of this node.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="faultToleranceConfigurationDefinition">
    <xs:complexContent>
      <xs:extension base="tns:faultToleranceConfigurationCommon">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="faultToleranceConfigurationCommon">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
        <xs:attribute name="typedGuard" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to an existing io.smallrye.faulttolerance.api.TypedGuard instance to lookup and use from the registry. When using
this, then any other TypedGuard circuit breaker options are not in use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="delay" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Control how long the circuit breaker stays open. The default is 5 seconds. Default value: 5000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="successThreshold" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Controls the number of trial calls which are allowed when the circuit breaker is half-open. Default value: 1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="requestVolumeThreshold" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Controls the size of the rolling window used when the circuit breaker is closed. Default value: 20
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="failureRatio" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the failure rate threshold in percentage. If the failure rate is equal or greater than the threshold the
CircuitBreaker transitions to open and starts short-circuiting calls. The threshold must be greater than 0 and not
greater than 100. Default value is 50 percentage. Default value: 50
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether timeout is enabled or not on the circuit breaker. Default is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutDuration" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the thread execution timeout. Default value is 1 second. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeoutPoolSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the pool size of the thread pool when timeout is enabled. Default value is 10. Default value: 10
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bulkheadEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether bulkhead is enabled or not on the circuit breaker. Default is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bulkheadMaxConcurrentCalls" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the max amount of concurrent calls the bulkhead will support. Default value: 10
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bulkheadWaitingTaskQueue" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Configures the task queue size for holding waiting tasks to be processed by the bulkhead. Default value: 10
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="threadOffloadExecutorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References a custom thread pool to use when offloading a guarded action to another thread.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="onFallbackDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="fallbackViaNetwork" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the fallback goes over the network. If the fallback will go over the network it is another possible point of
failure. It is important to execute the fallback command on a separate thread-pool, otherwise if the main command were
to become latent and fill the thread-pool this would prevent the fallback from running if the two commands share the
same pool. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="claimCheckDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="operation" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The claim check operation to use. The following operations are supported: Get - Gets (does not remove) the claim check
by the given key. GetAndRemove - Gets and removes the claim check by the given key. Set - Sets a new (will override if
key already exists) claim check with the given key. Push - Sets a new claim check on the stack (does not use key). Pop -
Gets the latest claim check from the stack (does not use key).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="key" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a specific key for claim check id (for dynamic keys use simple language syntax as the key).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="filter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Specify a filter to control what data gets merged data back from the claim check repository. The following syntax is
supported: body - to aggregate the message body attachments - to aggregate all the message attachments headers - to
aggregate all the message headers header:pattern - to aggregate all the message headers that matches the pattern. The
following pattern rules are applied in this order: exact match, returns true wildcard match (pattern ends with a and the
name starts with the pattern), returns true regular expression match, returns true otherwise returns false You can
specify multiple rules separated by comma. For example, the following includes the message body and all headers starting
with foo: body,header:foo. The syntax supports the following prefixes which can be used to specify include,exclude, or
remove - to include (which is the default mode) - - to exclude (exclude takes precedence over include) -- - to remove
(remove takes precedence) For example to exclude a header name foo, and remove all headers starting with bar,
-header:foo,--headers:bar Note you cannot have both include and exclude header:pattern at the same time.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom AggregationStrategy instead of the default implementation. Notice you cannot use both custom aggregation
strategy and configure data at the same time.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType final="extension restriction" name="constants">
    <xs:sequence/>
  </xs:complexType>
  <xs:complexType name="contextScanDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="excludes" type="xs:string">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Exclude finding route builder from these java package names.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="includes" type="xs:string">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Include finding route builder from these java package names.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="includeNonSingletons" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to include non-singleton beans (prototypes) By default only singleton beans is included in the context scan.
Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="convertBodyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="type" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The java type to convert to.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mandatory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When mandatory then the conversion must return a value (cannot be null), if this is not possible then
NoTypeConversionAvailableException is thrown. Setting this to false could mean conversion is not possible and the value
is null. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="charset" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a specific charset when converting.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="convertHeaderDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of message header to convert its value The simple language can be used to define a dynamic evaluated header name to
be used. Otherwise a constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="type" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The java type to convert to.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="toName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use another header to store the result. By default, the result is stored in the same header. This option allows to
use another header. The simple language can be used to define a dynamic evaluated header name to be used. Otherwise a
constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mandatory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When mandatory then the conversion must return a value (cannot be null), if this is not possible then
NoTypeConversionAvailableException is thrown. Setting this to false could mean conversion is not possible and the value
is null. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="charset" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a specific charset when converting.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="convertVariableDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of variable to convert its value The simple language can be used to define a dynamic evaluated header name to be
used. Otherwise a constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="type" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The java type to convert to.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="toName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use another variable to store the result. By default, the result is stored in the same variable. This option allows
to use another variable. The simple language can be used to define a dynamic evaluated variable name to be used.
Otherwise a constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mandatory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When mandatory then the conversion must return a value (cannot be null), if this is not possible then
NoTypeConversionAvailableException is thrown. Setting this to false could mean conversion is not possible and the value
is null. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="charset" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a specific charset when converting.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="dataFormat">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="delayDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="asyncDelayed" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables asynchronous delay which means the thread will not block while delaying. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="callerRunsWhenRejected" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the caller should run the task when it was rejected by the thread pool. Is by default true. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom Thread Pool if asyncDelay has been enabled.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="dynamicRouterDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="uriDelimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the uri delimiter to use. Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidEndpoints" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Ignore the invalidate endpoint exception when try to create a producer with that endpoint. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cacheSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum size used by the org.apache.camel.spi.ProducerCache which is used to cache and reuse producers when
using this dynamic router, when uris are reused. Beware that when using dynamic endpoints then it affects how well the
cache can be utilized. If each dynamic endpoint is unique then its best to turn off caching by setting this to -1, which
allows Camel to not cache both the producers and endpoints; they are regarded as prototype scoped and will be stopped
and discarded after use. This reduces memory usage as otherwise producers/endpoints are stored in memory in the caches.
However if there are a high degree of dynamic endpoints that have been used before, then it can benefit to use the cache
to reuse both producers and endpoints and therefore the cache size can be set accordingly or rely on the default size
(1000). If there is a mix of unique and used before dynamic endpoints, then setting a reasonable cache size can help
reduce memory usage to avoid storing too many non frequent used producers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="enrichDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="variableSend" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store the received message body (only body, not headers). This makes it handy to use variables for
user data and to easily control what data to use for sending and receiving. Important: When using receive variable then
the received body is stored only in this variable and not on the current message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable as the source for the message body to send. This makes it handy to use variables for user data and to
easily control what data to use for sending and receiving. Important: When using send variable then the message body is
taken from this variable instead of the current message, however the headers from the message will still be used as
well. In other words, the variable is used instead of the message body, but everything else is as usual.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the AggregationStrategy to be used to merge the reply from the external service, into a single outgoing message. By
default Camel will use the reply from the external service as outgoing message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodAllowNull" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was no data to enrich. If this option is true
then null values is used as the oldExchange (when no data to enrich), when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregateOnException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was an exception thrown while trying to retrieve
the data to enrich from the resource. Setting this option to true allows end users to control what to do if there was an
exception in the aggregate method. For example to suppress the exception or set a custom message body etc. Default
value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shareUnitOfWork" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Shares the org.apache.camel.spi.UnitOfWork with the parent and the resource exchange. Enrich will by default not share
unit of work between the parent exchange and the resource exchange. This means the resource exchange has its own
individual unit of work. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cacheSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum size used by the org.apache.camel.spi.ProducerCache which is used to cache and reuse producer when uris
are reused. Beware that when using dynamic endpoints then it affects how well the cache can be utilized. If each dynamic
endpoint is unique then its best to turn off caching by setting this to -1, which allows Camel to not cache both the
producers and endpoints; they are regarded as prototype scoped and will be stopped and discarded after use. This reduces
memory usage as otherwise producers/endpoints are stored in memory in the caches. However if there are a high degree of
dynamic endpoints that have been used before, then it can benefit to use the cache to reuse both producers and endpoints
and therefore the cache size can be set accordingly or rely on the default size (1000). If there is a mix of unique and
used before dynamic endpoints, then setting a reasonable cache size can help reduce memory usage to avoid storing too
many non frequent used producers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidEndpoint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Ignore the invalidate endpoint exception when try to create a producer with that endpoint. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowOptimisedComponents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow components to optimise enricher if they are org.apache.camel.spi.SendDynamicAware . Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoStartComponents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to auto startup components when enricher is starting up. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="errorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:deadLetterChannel"/>
            <xs:element ref="tns:defaultErrorHandler"/>
            <xs:element ref="tns:noErrorHandler"/>
            <xs:element ref="tns:refErrorHandler"/>
            <xs:element ref="tns:jtaTransactionErrorHandler"/>
            <xs:element ref="tns:springTransactionErrorHandler"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="deadLetterChannelDefinition">
    <xs:complexContent>
      <xs:extension base="tns:defaultErrorHandlerDefinition">
        <xs:sequence/>
        <xs:attribute name="deadLetterUri" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The dead letter endpoint uri for the Dead Letter error handler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="deadLetterHandleNewException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the dead letter channel should handle (and ignore) any new exception that may been thrown during sending the
message to the dead letter endpoint. The default value is true which means any such kind of exception is handled and
ignored. Set this to false to let the exception be propagated back on the org.apache.camel.Exchange . This can be used
in situations where you use transactions, and want to use Camel's dead letter channel to deal with exceptions during
routing, but if the dead letter channel itself fails because of a new exception being thrown, then by setting this to
false the new exceptions is propagated back and set on the org.apache.camel.Exchange , which allows the transaction to
detect the exception, and rollback. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="defaultErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:baseErrorHandlerDefinition">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:redeliveryPolicy"/>
        </xs:sequence>
        <xs:attribute name="useOriginalMessage" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will use the original input org.apache.camel.Message (original body and headers) when an org.apache.camel.Exchange is
moved to the dead letter queue. Notice: this only applies when all redeliveries attempt have failed and the
org.apache.camel.Exchange is doomed for failure. Instead of using the current inprogress org.apache.camel.Exchange IN
message we use the original IN message instead. This allows you to store the original input in the dead letter queue
instead of the inprogress snapshot of the IN message. For instance if you route transform the IN body during routing and
then failed. With the original exchange store in the dead letter queue it might be easier to manually re submit the
org.apache.camel.Exchange again as the IN message is the same as when Camel received it. So you should be able to send
the org.apache.camel.Exchange to the same input. The difference between useOriginalMessage and useOriginalBody is that
the former includes both the original body and headers, where as the latter only includes the original body. You can use
the latter to enrich the message with custom headers and include the original message body. The former wont let you do
this, as its using the original message body and headers as they are. You cannot enable both useOriginalMessage and
useOriginalBody. The original input message is defensively copied, and the copied message body is converted to
org.apache.camel.StreamCache if possible (stream caching is enabled, can be disabled globally or on the original route),
to ensure the body can be read when the original message is being used later. If the body is converted to
org.apache.camel.StreamCache then the message body on the current org.apache.camel.Exchange is replaced with the
org.apache.camel.StreamCache body. If the body is not converted to org.apache.camel.StreamCache then the body will not
be able to re-read when accessed later. Important: The original input means the input message that are bounded by the
current org.apache.camel.spi.UnitOfWork . An unit of work typically spans one route, or multiple routes if they are
connected using internal endpoints such as direct or seda. When messages is passed via external endpoints such as JMS or
HTTP then the consumer will create a new unit of work, with the message it received as input as the original input. Also
some EIP patterns such as splitter, multicast, will create a new unit of work boundary for the messages in their
sub-route (eg the splitted message); however these EIPs have an option named shareUnitOfWork which allows to combine
with the parent unit of work in regard to error handling and therefore use the parent original message. By default this
feature is off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useOriginalBody" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will use the original input org.apache.camel.Message body (original body only) when an org.apache.camel.Exchange is
moved to the dead letter queue. Notice: this only applies when all redeliveries attempt have failed and the
org.apache.camel.Exchange is doomed for failure. Instead of using the current inprogress org.apache.camel.Exchange IN
message we use the original IN message instead. This allows you to store the original input in the dead letter queue
instead of the inprogress snapshot of the IN message. For instance if you route transform the IN body during routing and
then failed. With the original exchange store in the dead letter queue it might be easier to manually re submit the
org.apache.camel.Exchange again as the IN message is the same as when Camel received it. So you should be able to send
the org.apache.camel.Exchange to the same input. The difference between useOriginalMessage and useOriginalBody is that
the former includes both the original body and headers, where as the latter only includes the original body. You can use
the latter to enrich the message with custom headers and include the original message body. The former wont let you do
this, as its using the original message body and headers as they are. You cannot enable both useOriginalMessage and
useOriginalBody. The original input message is defensively copied, and the copied message body is converted to
org.apache.camel.StreamCache if possible (stream caching is enabled, can be disabled globally or on the original route),
to ensure the body can be read when the original message is being used later. If the body is converted to
org.apache.camel.StreamCache then the message body on the current org.apache.camel.Exchange is replaced with the
org.apache.camel.StreamCache body. If the body is not converted to org.apache.camel.StreamCache then the body will not
be able to re-read when accessed later. Important: The original input means the input message that are bounded by the
current org.apache.camel.spi.UnitOfWork . An unit of work typically spans one route, or multiple routes if they are
connected using internal endpoints such as direct or seda. When messages is passed via external endpoints such as JMS or
HTTP then the consumer will create a new unit of work, with the message it received as input as the original input. Also
some EIP patterns such as splitter, multicast, will create a new unit of work boundary for the messages in their
sub-route (eg the splitted message); however these EIPs have an option named shareUnitOfWork which allows to combine
with the parent unit of work in regard to error handling and therefore use the parent original message. By default this
feature is off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="redeliveryPolicyRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a RedeliveryPolicy to be used for redelivery settings.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="loggerRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References to a logger to use as logger for the error handler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="level" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Logging level to use by error handler. Default value: ERROR
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of the logger to use by the error handler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onRedeliveryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a processor that should be processed before a redelivery attempt. Can be used to change the
org.apache.camel.Exchange before its being redelivered.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onExceptionOccurredRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a processor that should be processed just after an exception occurred. Can be used to perform custom
logging about the occurred exception at the exact time it happened. Important: Any exception thrown from this processor
will be ignored.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onPrepareFailureRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a processor to prepare the org.apache.camel.Exchange before handled by the failure processor / dead
letter channel. This allows for example to enrich the message before sending to a dead letter queue.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="retryWhileRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a retry while predicate. Will continue retrying until the predicate evaluates to false.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorServiceRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a thread pool to be used by the error handler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="baseErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="redeliveryPolicyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
        <xs:attribute name="maximumRedeliveries" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum redeliveries x = redeliver at most x times 0 = no redeliveries -1 = redeliver forever.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="redeliveryDelay" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the initial redelivery delay. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="asyncDelayedRedelivery" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Allow asynchronous delayed redelivery. The route, in particular the consumer's component, must support the Asynchronous
Routing Engine (e.g. seda). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="backOffMultiplier" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the back off multiplier. Default value: 2.0
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useExponentialBackOff" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Turn on exponential back off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="collisionAvoidanceFactor" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the collision avoidance factor. Default value: 0.15
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useCollisionAvoidance" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Turn on collision avoidance. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maximumRedeliveryDelay" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum delay between redelivery. Default value: 60000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="retriesExhaustedLogLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the logging level to use when retries have been exhausted. Default value: ERROR
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="retryAttemptedLogLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the logging level to use for logging retry attempts. Default value: DEBUG
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="retryAttemptedLogInterval" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the interval to use for logging retry attempts. Default value: 1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logRetryAttempted" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether retry attempts should be logged or not. Can be used to include or reduce verbose. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logStackTrace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether stack traces should be logged. Can be used to include or reduce verbose. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logRetryStackTrace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether stack traces should be logged when an retry attempt failed. Can be used to include or reduce verbose.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logHandled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether handled exceptions should be logged or not. Can be used to include or reduce verbose. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logNewException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether new exceptions should be logged or not. Can be used to include or reduce verbose. A new exception is an
exception that was thrown while handling a previous exception. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logContinued" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether continued exceptions should be logged or not. Can be used to include or reduce verbose. Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logExhausted" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether exhausted exceptions should be logged or not. Can be used to include or reduce verbose. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logExhaustedMessageHistory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether exhausted exceptions should be logged including message history or not (supports property placeholders).
Can be used to include or reduce verbose. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logExhaustedMessageBody" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether exhausted message body should be logged including message history or not (supports property placeholders).
Can be used to include or reduce verbose. Requires logExhaustedMessageHistory to be enabled. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disableRedelivery" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Disables redelivery (same as setting maximum redeliveries to 0). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="delayPattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the delay pattern with delay intervals.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowRedeliveryWhileStopping" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Controls whether to allow redelivery while stopping/shutting down a route that uses error handling. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="exchangeFormatterRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the reference of the instance of org.apache.camel.spi.ExchangeFormatter to generate the log message from exchange.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="noErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:baseErrorHandlerDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="refErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:baseErrorHandlerDefinition">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References to an existing or custom error handler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="jtaTransactionErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:transactionErrorHandlerDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="transactionErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:defaultErrorHandlerDefinition">
        <xs:sequence/>
        <xs:attribute name="transactedPolicyRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The transacted policy to use that is configured for either Spring or JTA based transactions. If no policy has been
configured then Camel will attempt to auto-discover.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rollbackLoggingLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the logging level to use for logging transactional rollback. This option is default WARN. Default value: WARN
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="springTransactionErrorHandlerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:transactionErrorHandlerDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="filterDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="statusPropertyName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of exchange property to use for storing the status of the filtering. Setting this allows to know if the filter
predicate evaluated as true or false.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="finallyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="fromDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the URI of the endpoint to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store a copy of the received message body (only body, not headers). This is handy for easy access
to the received message body via variables.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="globalOptionDefinition">
    <xs:sequence/>
    <xs:attribute name="key" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Global option key.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="value" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Global option value.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="globalOptionsDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:globalOption"/>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="idempotentConsumerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="idempotentRepository" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the reference name of the message id repository.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="eager" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether to eagerly add the key to the idempotent repository or wait until the exchange is complete. Eager is
default enabled. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionEager" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether to complete the idempotent consumer eager or when the exchange is done. If this option is true to complete
eager, then the idempotent consumer will trigger its completion when the exchange reached the end of the block of the
idempotent consumer pattern. So if the exchange is continued routed after the block ends, then whatever happens there
does not affect the state. If this option is false (default) to not complete eager, then the idempotent consumer will
complete when the exchange is done being routed. So if the exchange is continued routed after the block ends, then
whatever happens there also affect the state. For example if the exchange failed due to an exception, then the state of
the idempotent consumer will be a rollback. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipDuplicate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether to skip duplicates or not. The default behavior is to skip duplicates. A duplicate message would have the
Exchange property org.apache.camel.Exchange#DUPLICATE_MESSAGE set to a Boolean#TRUE value. A none duplicate message will
not have this property set. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="removeOnFailure" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether to remove or keep the key on failure. The default behavior is to remove the key on failure. Default value:
true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="inputTypeDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="urn" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The input type URN.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="validate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether if validation is required for this input type. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="interceptDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:onWhen"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="interceptFromDefinition">
    <xs:complexContent>
      <xs:extension base="tns:interceptDefinition">
        <xs:sequence/>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Intercept incoming messages from the uri or uri pattern. If this option is not configured, then all incoming messages is
intercepted.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="interceptSendToEndpointDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:onWhen"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="uri" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Intercept sending to the uri or uri pattern.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipSendToOriginalEndpoint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true then the message is not sent to the original endpoint. By default (false) the message is both intercepted
and then sent to the original endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="afterUri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
After sending to the endpoint then send the message to this uri which allows to process its result.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="kameletDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of the Kamelet (templateId/routeId) to call. Options for the kamelet can be specified using uri syntax, eg
mynamecount=4&type=gold.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="loadBalanceDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:customLoadBalancer"/>
            <xs:element ref="tns:failoverLoadBalancer"/>
            <xs:element ref="tns:randomLoadBalancer"/>
            <xs:element ref="tns:roundRobinLoadBalancer"/>
            <xs:element ref="tns:stickyLoadBalancer"/>
            <xs:element ref="tns:topicLoadBalancer"/>
            <xs:element ref="tns:weightedLoadBalancer"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="customLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to the custom load balancer to lookup from the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="loadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="failoverLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="exception" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
A list of class names for specific exceptions to monitor. If no exceptions are configured then all exceptions are
monitored.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="roundRobin" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the failover load balancer should operate in round robin mode or not. If not, then it will always start
from the first endpoint when a new message is to be processed. In other words it restart from the top for every message.
If round robin is enabled, then it keeps state and will continue with the next endpoint in a round robin fashion. You
can also enable sticky mode together with round robin, if so then it will pick the last known good endpoint to use when
starting the load balancing (instead of using the next when starting).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="sticky" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the failover load balancer should operate in sticky mode or not. If not, then it will always start from
the first endpoint when a new message is to be processed. In other words it restart from the top for every message. If
sticky is enabled, then it keeps state and will continue with the last known good endpoint. You can also enable sticky
mode together with round robin, if so then it will pick the last known good endpoint to use when starting the load
balancing (instead of using the next when starting).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maximumFailoverAttempts" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A value to indicate after X failover attempts we should exhaust (give up). Use -1 to indicate never give up and
continuously try to failover. Use 0 to never failover. And use e.g. 3 to failover at most 3 times before giving up. This
option can be used whether roundRobin is enabled or not. Default value: -1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inheritErrorHandler" type="xs:boolean">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To turn off Camel error handling during load balancing. By default, Camel error handler will attempt calling a service,
which means you can specify retires and other fine-grained settings. And only when Camel error handler have failed all
attempts, then this load balancer will fail over to the next endpoint and try again. You can turn this off, and then
this load balancer will fail over immediately on an error. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="randomLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="roundRobinLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="stickyLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence>
          <xs:element name="correlationExpression" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The correlation expression to use to calculate the correlation key.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="topicLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="weightedLoadBalancerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:loadBalancerDefinition">
        <xs:sequence/>
        <xs:attribute name="distributionRatio" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The distribution ratio is a delimited String consisting on integer weights separated by delimiters for example 2,3,5.
The distributionRatio must match the number of endpoints and/or processors specified in the load balancer list.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="distributionRatioDelimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Delimiter used to specify the distribution ratio. The default value is , (comma). Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="roundRobin" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To enable round robin mode. By default the weighted distribution mode is used. The default value is false. Default
value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="logDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="message" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the log message (uses simple language).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="loggingLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the logging level. The default value is INFO. Default value: INFO
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the name of the logger. The name is default the routeId or the source:line if source location is enabled. You can
also specify the name using tokens: ${class} - the logger class name (org.apache.camel.processor.LogProcessor)
${contextId} - the camel context id ${routeId} - the route id ${groupId} - the route group id ${nodeId} - the node id
${nodePrefixId} - the node prefix id ${source} - the source:line (source location must be enabled) ${source.name} - the
source filename (source location must be enabled) ${source.line} - the source line number (source location must be
enabled) For example to use the route and node id you can specify the name as: ${routeId}/${nodeId}.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="marker" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use slf4j marker.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logger" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To refer to a custom logger instance to lookup from the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logLanguage" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To configure the language to use. By default, the simple language is used. However, Camel also supports other languages
such as groovy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="loopDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="copy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the copy attribute is true, a copy of the input Exchange is used for each iteration. That means each iteration will
start from a copy of the same message. By default loop will loop the same exchange all over, so each iteration may have
different message content. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="doWhile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables the while loop that loops until the predicate evaluates to false or null. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="breakOnShutdown" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the breakOnShutdown attribute is true, then the loop will not iterate until it reaches the end when Camel is shut
down. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onPrepare" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses the Processor when preparing the org.apache.camel.Exchange for each loop iteration. This can be used to deep-clone
messages, or any custom logic needed before the looping executes.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="marshalDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:asn1"/>
            <xs:element ref="tns:avro"/>
            <xs:element ref="tns:barcode"/>
            <xs:element ref="tns:base64"/>
            <xs:element ref="tns:beanio"/>
            <xs:element ref="tns:bindy"/>
            <xs:element ref="tns:cbor"/>
            <xs:element ref="tns:crypto"/>
            <xs:element ref="tns:csv"/>
            <xs:element ref="tns:custom"/>
            <xs:element ref="tns:dfdl"/>
            <xs:element ref="tns:fhirJson"/>
            <xs:element ref="tns:fhirXml"/>
            <xs:element ref="tns:flatpack"/>
            <xs:element ref="tns:fury"/>
            <xs:element ref="tns:grok"/>
            <xs:element ref="tns:gzipDeflater"/>
            <xs:element ref="tns:hl7"/>
            <xs:element ref="tns:ical"/>
            <xs:element ref="tns:jacksonXml"/>
            <xs:element ref="tns:jaxb"/>
            <xs:element ref="tns:json"/>
            <xs:element ref="tns:jsonApi"/>
            <xs:element ref="tns:lzf"/>
            <xs:element ref="tns:mimeMultipart"/>
            <xs:element ref="tns:parquetAvro"/>
            <xs:element ref="tns:protobuf"/>
            <xs:element ref="tns:rss"/>
            <xs:element ref="tns:smooks"/>
            <xs:element ref="tns:soap"/>
            <xs:element ref="tns:swiftMt"/>
            <xs:element ref="tns:swiftMx"/>
            <xs:element ref="tns:syslog"/>
            <xs:element ref="tns:tarFile"/>
            <xs:element ref="tns:thrift"/>
            <xs:element ref="tns:tidyMarkup"/>
            <xs:element ref="tns:univocityCsv"/>
            <xs:element ref="tns:univocityFixed"/>
            <xs:element ref="tns:univocityTsv"/>
            <xs:element ref="tns:xmlSecurity"/>
            <xs:element ref="tns:pgp"/>
            <xs:element ref="tns:yaml"/>
            <xs:element ref="tns:zipDeflater"/>
            <xs:element ref="tns:zipFile"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="variableSend" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable as the source for the message body to send. This makes it handy to use variables for user data and to
easily control what data to use for sending and receiving. Important: When using send variable then the message body is
taken from this variable instead of the current message, however the headers from the message will still be used as
well. In other words, the variable is used instead of the message body, but everything else is as usual.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store the received message body (only body, not headers). This makes it handy to use variables for
user data and to easily control what data to use for sending and receiving. Important: When using receive variable then
the received body is stored only in this variable and not on the current message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="asn1DataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="usingIterator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the asn1 file has more than one entry, the setting this option to true, allows working with the splitter EIP, to
split the data using an iterator in a streaming mode. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="avroDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="instanceClassName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name to use for marshal and unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="library" type="tns:avroLibrary">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Which Avro library to use. Default value: avroJackson
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="objectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Lookup and use the existing ObjectMapper with the given id when using Jackson.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useDefaultObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to lookup and use default Jackson ObjectMapper from the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="jsonView" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When marshalling a POJO to JSON you might want to exclude certain fields from the JSON output. With Jackson you can use
JSON views to accomplish this. This option is to refer to the class which has JsonView annotations.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="include" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If you want to marshal a pojo to JSON, and the pojo has some fields with null values. And you want to skip these null
values, you can set this option to NON_NULL.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowJmsType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for JMS users to allow the JMSType header from the JMS spec to specify a FQN classname to use to unmarshal to.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="collectionType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom collection type to lookup in the registry to use. This option should rarely be used, but allows to
use different collection types than java.util.Collection based as default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useList" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To unmarshal to a List of Map or a List of Pojo. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleClassNames" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules com.fasterxml.jackson.databind.Module specified as a String with FQN class names. Multiple
classes can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleRefs" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules referred from the Camel registry. Multiple modules can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to enable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name that
matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to disable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name
that matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowUnmarshallType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Jackson is allowed to attempt to use the CamelJacksonUnmarshalType header during the unmarshalling. This
should only be enabled when desired to be used. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timezone" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set then Jackson will use the Timezone when marshalling/unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoDiscoverObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true then Jackson will lookup for an objectMapper into the registry. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schemaResolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Optional schema resolver used to lookup schemas for the data in transit.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoDiscoverSchemaResolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When not disabled, the SchemaResolver will be looked up into the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="barcodeDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="barcodeFormat" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Barcode format such as QR-Code.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="imageType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Image type of the barcode such as png.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="width" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Width of the barcode.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="height" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Height of the barcode.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="base64DataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="lineLength" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To specific a maximum line length for the encoded data. By default 76 is used. Default value: 76
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="lineSeparator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The line separators to use. Uses new line characters (CRLF) by default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="urlSafe" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Instead of emitting '' and '/' we emit '-' and '_' respectively. urlSafe is only applied to encode operations. Decoding
seamlessly handles both modes. Is by default false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="beanioDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="mapping" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The BeanIO mapping file. Is by default loaded from the classpath. You can prefix with file:, http:, or classpath: to
denote from where to load the mapping file.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="streamName" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The name of the stream to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreUnidentifiedRecords" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore unidentified records. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreUnexpectedRecords" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore unexpected records. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidRecords" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore invalid records. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="encoding" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The charset to use. Is by default the JVM platform default charset.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="beanReaderErrorHandlerType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom org.apache.camel.dataformat.beanio.BeanIOErrorHandler as error handler while parsing. Configure the
fully qualified class name of the error handler. Notice the options ignoreUnidentifiedRecords, ignoreUnexpectedRecords,
and ignoreInvalidRecords may not be in use when you use a custom error handler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalSingleObject" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This options controls whether to unmarshal as a list of objects or as a single object only. The former is the default
mode, and the latter is only intended in special use-cases where beanio maps the Camel message to a single POJO bean.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="bindyDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="type" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to use Csv, Fixed, or KeyValue.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="classType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of model class to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowEmptyStream" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow empty streams in the unmarshal process. If true, no exception will be thrown when a body without
records is provided. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unwrapSingleInstance" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When unmarshalling should a single instance be unwrapped and returned instead of wrapped in a java.util.List. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="locale" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To configure a default locale to use, such as us for united states. To use the JVM platform default locale then use the
name default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="cborDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="objectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Lookup and use the existing CBOR ObjectMapper with the given id when using Jackson.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useDefaultObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to lookup and use default Jackson CBOR ObjectMapper from the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="collectionType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom collection type to lookup in the registry to use. This option should rarely be used, but allows to
use different collection types than java.util.Collection based as default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useList" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To unmarshal to a List of Map or a List of Pojo. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowUnmarshallType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Jackson CBOR is allowed to attempt to use the CamelCBORUnmarshalType header during the unmarshalling.
This should only be enabled when desired to be used. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="prettyPrint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To enable pretty printing output nicely formatted. Is by default false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowJmsType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for JMS users to allow the JMSType header from the JMS spec to specify a FQN classname to use to unmarshal to.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to enable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name that
matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to disable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name
that matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="cryptoDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="algorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The JCE algorithm name indicating the cryptographic algorithm that will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keyRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to the secret key to lookup from the register to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cryptoProvider" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The name of the JCE Security Provider that should be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="initVectorRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a byte array containing the Initialization Vector that will be used to initialize the Cipher.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="algorithmParameterRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A JCE AlgorithmParameterSpec used to initialize the Cipher. Will lookup the type using the given name as a
java.security.spec.AlgorithmParameterSpec type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bufferSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The size of the buffer used in the signature process. Default value: 4096
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="macAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The JCE algorithm name indicating the Message Authentication algorithm. Default value: HmacSHA1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shouldAppendHMAC" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Flag indicating that a Message Authentication Code should be calculated and appended to the encrypted data. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inline" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Flag indicating that the configured IV should be inlined into the encrypted data stream. Is by default false. Default
value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="csvDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="header" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
To configure the CSV headers.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="formatRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The reference format to use, it will be updated with the other format options, the default value is CSVFormat.DEFAULT.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="formatName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The name of the format to use, the default value is CSVFormat.DEFAULT. Default value: DEFAULT
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="commentMarkerDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Disables the comment marker of the reference format. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="commentMarker" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the comment marker of the reference format.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="delimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the delimiter to use. The default value is , (comma).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="escapeDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Use for disabling using escape character. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="escape" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the escape character to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="headerDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Use for disabling headers. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowMissingColumnNames" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow missing column names. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreEmptyLines" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore empty lines. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreSurroundingSpaces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore surrounding spaces. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="nullStringDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used to disable null strings. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="nullString" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the null string.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="quoteDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used to disable quotes. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="quote" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the quote to use which by default is double-quote character.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="recordSeparatorDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for disabling record separator.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="recordSeparator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the record separator (aka new line) which by default is new line characters (CRLF).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipHeaderRecord" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to skip the header record in the output. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="quoteMode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the quote mode.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreHeaderCase" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether or not to ignore case when accessing header names. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="trim" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether or not to trim leading and trailing blanks. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="trailingDelimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether or not to add a trailing delimiter. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="marshallerFactoryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the implementation of the CsvMarshallerFactory interface which is able to customize marshalling/unmarshalling
behavior by extending CsvMarshaller or creating it from scratch.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="lazyLoad" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should produce an iterator that reads the lines on the fly or if all the lines must be read at
one. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useMaps" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should produce maps (HashMap)for the lines values instead of lists. It requires to have header
(either defined or collected). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useOrderedMaps" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should produce ordered maps (LinkedHashMap) for the lines values instead of lists. It requires
to have header (either defined or collected). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="recordConverterRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom CsvRecordConverter to lookup from the registry to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="captureHeaderRecord" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should capture the header record and store it in the message header. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="customDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to the custom org.apache.camel.spi.DataFormat to lookup from the Camel registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="dfdlDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="schemaUri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The path to the DFDL schema file.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rootElement" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The root element name of the schema to use. If not specified, the first root element in the schema will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rootNamespace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The root namespace of the schema to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="fhirJsonDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:fhirDataformat">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="fhirDataformat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="fhirVersion" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The version of FHIR to use. Possible values are: DSTU2,DSTU2_HL7ORG,DSTU2_1,DSTU3,R4,R5. Default value: R4
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="fhirContext" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom fhir context. Reference to object of type ca.uhn.fhir.context.FhirContext.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="prettyPrint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the pretty print flag, meaning that the parser will encode resources with human-readable spacing and newlines
between elements instead of condensing output as much as possible. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parserErrorHandler" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Registers an error handler which will be invoked when any parse errors are found. Reference to object of type
ca.uhn.fhir.parser.IParserErrorHandler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parserOptions" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the parser options object which will be used to supply default options to newly created parsers. Reference to
object of type ca.uhn.fhir.context.ParserOptions.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="preferTypes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set (FQN class names), when parsing resources the parser will try to use the given types when possible, in the order
that they are provided (from highest to lowest priority). For example, if a custom type which declares to implement the
Patient resource is passed in here, and the parser is parsing a Bundle containing a Patient resource, the parser will
use the given custom type. Multiple class names can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="forceResourceId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When encoding, force this resource ID to be encoded as the resource ID. Reference to object of type
org.hl7.fhir.instance.model.api.IIdType.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serverBaseUrl" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the server's base URL used by this parser. If a value is set, resource references will be turned into relative
references if they are provided as absolute URLs but have a base matching the given base.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="omitResourceId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true (default is false) the ID of any resources being encoded will not be included in the output. Note that
this does not apply to contained resources, only to root resources. In other words, if this is set to true, contained
resources will still have local IDs but the outer/containing ID will not have an ID. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="encodeElementsAppliesToChildResourcesOnly" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true (default is false), the values supplied to setEncodeElements(Set) will not be applied to the root
resource (typically a Bundle), but will be applied to any sub-resources contained within it (i.e. search result
resources in that bundle). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="encodeElements" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If provided, specifies the elements which should be encoded, to the exclusion of all others. Multiple elements can be
separated by comma when using String parameter. Valid values for this field would include: Patient - Encode patient and
all its children Patient.name - Encode only the patient's name Patient.name.family - Encode only the patient's family
name .text - Encode the text element on any resource (only the very first position may contain a wildcard) .(mandatory)
- This is a special case which causes any mandatory fields (min 0) to be encoded.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="dontEncodeElements" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If provided, specifies the elements which should NOT be encoded. Multiple elements can be separated by comma when using
String parameter. Valid values for this field would include: Patient - Don't encode patient and all its children
Patient.name - Don't encode the patient's name Patient.name.family - Don't encode the patient's family name .text -
Don't encode the text element on any resource (only the very first position may contain a wildcard) DSTU2 note: Note
that values including meta, such as Patient.meta will work for DSTU2 parsers, but values with subelements on meta such
as Patient.meta.lastUpdated will only work in DSTU3 mode.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="stripVersionsFromReferences" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true (which is the default), resource references containing a version will have the version removed when the
resource is encoded. This is generally good behaviour because in most situations, references from one resource to
another should be to the resource by ID, not by ID and version. In some cases though, it may be desirable to preserve
the version in resource links. In that case, this value should be set to false. This method provides the ability to
globally disable reference encoding. If finer-grained control is needed, use
setDontStripVersionsFromReferencesAtPaths(List). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="overrideResourceIdWithBundleEntryFullUrl" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true (which is the default), the Bundle.entry.fullUrl will override the Bundle.entry.resource's resource id if
the fullUrl is defined. This behavior happens when parsing the source data into a Bundle object. Set this to false if
this is not the desired behavior (e.g. the client code wishes to perform additional validation checks between the
fullUrl and the resource id). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="summaryMode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true (default is false) only elements marked by the FHIR specification as being summary elements will be
included. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="suppressNarratives" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true (default is false), narratives will not be included in the encoded values. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="dontStripVersionsFromReferencesAtPaths" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If supplied value(s), any resource references at the specified paths will have their resource versions encoded instead
of being automatically stripped during the encoding process. This setting has no effect on the parsing process. Multiple
elements can be separated by comma when using String parameter. This method provides a finer-grained level of control
than setStripVersionsFromReferences(String) and any paths specified by this method will be encoded even if
setStripVersionsFromReferences(String) has been set to true (which is the default).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="fhirXmlDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:fhirDataformat">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="flatpackDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="definition" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The flatpack pzmap configuration file. Can be omitted in simpler situations, but its preferred to use the pzmap.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="fixed" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Delimited or fixed. Is by default false = delimited. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="delimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The delimiter char (could be ; , or similar). Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreFirstRecord" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the first line is ignored for delimited files (for the column headers). Is by default true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowShortLines" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Allows for lines to be shorter than expected and ignores the extra characters. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreExtraColumns" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Allows for lines to be longer than expected and ignores the extra characters. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="textQualifier" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the text is qualified with a character. Uses quote character by default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parserFactoryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References to a custom parser factory to lookup in the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="furyDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="requireClassRegistration" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to require register classes. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="threadSafe" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to use the threadsafe fury. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowAutoWiredFury" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to auto-discover Fury from the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="grokDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="pattern" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The grok pattern to match lines of input.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="flattened" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Turns on flattened mode. In flattened mode the exception is thrown when there are multiple pattern matches with same
key. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowMultipleMatchesPerLine" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If false, every line of input is matched for pattern only once. Otherwise the line can be scanned multiple times when
non-terminal pattern is used. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="namedOnly" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to capture named expressions only or not (i.e. %{IP:ip} but not ${IP}). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="gzipDeflaterDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="hl7DataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="validate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to validate the HL7 message Is by default true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="icalDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="validating" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to validate. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="jacksonXMLDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="xmlMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Lookup and use the existing XmlMapper with the given id.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="prettyPrint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To enable pretty printing output nicely formatted. Is by default false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowUnmarshallType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Jackson is allowed to attempt to use the CamelJacksonUnmarshalType header during the unmarshalling. This
should only be enabled when desired to be used. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="jsonView" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When marshalling a POJO to JSON you might want to exclude certain fields from the JSON output. With Jackson you can use
JSON views to accomplish this. This option is to refer to the class which has JsonView annotations.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="include" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If you want to marshal a pojo to JSON, and the pojo has some fields with null values. And you want to skip these null
values, you can set this option to NON_NULL.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowJmsType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for JMS users to allow the JMSType header from the JMS spec to specify a FQN classname to use to unmarshal to.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="collectionType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom collection type to lookup in the registry to use. This option should rarely be used, but allows to
use different collection types than java.util.Collection based as default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useList" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To unmarshal to a List of Map or a List of Pojo. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timezone" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set then Jackson will use the Timezone when marshalling/unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableJaxbAnnotationModule" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable the JAXB annotations module when using jackson. When enabled then JAXB annotations can be used by
Jackson. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleClassNames" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules com.fasterxml.jackson.databind.Module specified as a String with FQN class names. Multiple
classes can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleRefs" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules referred from the Camel registry. Multiple modules can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to enable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name that
matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to disable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name
that matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="jaxbDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="contextPath" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Package name where your JAXB classes are located.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contextPathIsClassName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This can be set to true to mark that the contextPath is referring to a classname and not a package name. Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schema" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To validate against an existing schema. Your can use the prefix classpath:, file: or http: to specify how the resource
should be resolved. You can separate multiple schema files by using the ',' character.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schemaSeverityLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the schema severity level to use when validating against a schema. This level determines the minimum severity error
that triggers JAXB to stop continue parsing. The default value of 0 (warning) means that any error (warning, error or
fatal error) will trigger JAXB to stop. There are the following three levels: 0=warning, 1=error, 2=fatal error. Default
value: 0
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="prettyPrint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To enable pretty printing output nicely formatted. Is by default false. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="objectFactory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow using ObjectFactory classes to create the POJO classes during marshalling. This only applies to POJO
classes that has not been annotated with JAXB and providing jaxb.index descriptor files. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreJAXBElement" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore JAXBElement elements - only needed to be set to false in very special use-cases. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mustBeJAXBElement" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether marhsalling must be java objects with JAXB annotations. And if not then it fails. This option can be set to
false to relax that, such as when the data is already in XML format. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="filterNonXmlChars" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To ignore non xml characheters and replace them with an empty space. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="encoding" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To overrule and use a specific encoding.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="fragment" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To turn on marshalling XML fragment trees. By default JAXB looks for XmlRootElement annotation on given class to operate
on whole XML tree. This is useful but not always - sometimes generated code does not have XmlRootElement annotation,
sometimes you need unmarshall only part of tree. In that case you can use partial unmarshalling. To enable this
behaviours you need set property partClass. Camel will pass this class to JAXB's unmarshaler. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="partClass" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of class used for fragment parsing. See more details at the fragment option.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="partNamespace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
XML namespace to use for fragment parsing. See more details at the fragment option.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="namespacePrefixRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When marshalling using JAXB or SOAP then the JAXB implementation will automatic assign namespace prefixes, such as ns2,
ns3, ns4 etc. To control this mapping, Camel allows you to refer to a map which contains the desired mapping.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="xmlStreamWriterWrapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom xml stream writer.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schemaLocation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the location of the schema.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="noNamespaceSchemaLocation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the location of the namespaceless schema.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="jaxbProviderProperties" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom java.util.Map to lookup in the registry containing custom JAXB provider properties to be used with
the JAXB marshaller.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="accessExternalSchemaProtocols" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Only in use if schema validation has been enabled. Restrict access to the protocols specified for external reference set
by the schemaLocation attribute, Import and Include element. Examples of protocols are file, http, jar:file. false or
none to deny all access to external references; a specific protocol, such as file, to give permission to only the
protocol; the keyword all to grant permission to all protocols. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="jsonDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="objectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Lookup and use the existing ObjectMapper with the given id when using Jackson.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useDefaultObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to lookup and use default Jackson ObjectMapper from the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoDiscoverObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true then Jackson will look for an objectMapper to use from the registry. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="prettyPrint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To enable pretty printing output nicely formatted. Is by default false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="library" type="tns:jsonLibrary">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Which json library to use. Default value: Jackson
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="combineUnicodeSurrogates" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Force generator that outputs JSON content to combine surrogate pairs (if any) into 4-byte characters. This should be
preferred when using 4-byte characters such as Japanese. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="jsonView" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When marshalling a POJO to JSON you might want to exclude certain fields from the JSON output. With Jackson you can use
JSON views to accomplish this. This option is to refer to the class which has JsonView annotations.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="include" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If you want to marshal a pojo to JSON, and the pojo has some fields with null values. And you want to skip these null
values, you can set this option to NON_NULL.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowJmsType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for JMS users to allow the JMSType header from the JMS spec to specify a FQN classname to use to unmarshal to.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="collectionType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom collection type to lookup in the registry to use. This option should rarely be used, but allows using
different collection types than java.util.Collection based as default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useList" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To unmarshal to a List of Map or a List of Pojo. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleClassNames" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules com.fasterxml.jackson.databind.Module specified as a String with FQN class names. Multiple
classes can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleRefs" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules referred from the Camel registry. Multiple modules can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to enable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name that
matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to disable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name
that matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowUnmarshallType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Jackson is allowed to attempt to use the CamelJacksonUnmarshalType header during the unmarshalling. This
should only be enabled when desired to be used. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timezone" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set then Jackson will use the Timezone when marshalling/unmarshalling. This option will have no effect on the others
Json DataFormat, like gson and fastjson.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schemaResolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Optional schema resolver used to lookup schemas for the data in transit.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoDiscoverSchemaResolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When not disabled, the SchemaResolver will be looked up into the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="namingStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set then Jackson will use the the defined Property Naming Strategy.Possible values are: LOWER_CAMEL_CASE,
LOWER_DOT_CASE, LOWER_CASE, KEBAB_CASE, SNAKE_CASE and UPPER_CAMEL_CASE.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="dateFormatPattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To configure the date format while marshall or unmarshall Date fields in JSON using Gson.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="jsonApiDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="dataFormatTypes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The classes to take into account for the marshalling. Multiple classes can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mainFormatType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The class to take into account while unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="lzfDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="usingParallelCompression" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enable encoding (compress) using multiple processing cores. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="mimeMultipartDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="multipartSubType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Specify the subtype of the MIME Multipart. Default is mixed. Default value: mixed
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="multipartWithoutAttachment" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Defines whether a message without attachment is also marshaled into a MIME Multipart (with only one body part). Default
is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="headersInline" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Defines whether the MIME-Multipart headers are part of the message body (true) or are set as Camel headers (false).
Default is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="includeHeaders" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A regex that defines which Camel headers are also included as MIME headers into the MIME multipart. This will only work
if headersInline is set to true. Default is to include no headers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="binaryContent" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Defines whether the content of binary parts in the MIME multipart is binary (true) or Base-64 encoded (false) Default is
false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="parquetAvroDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="compressionCodecName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Compression codec to use when marshalling. Default value: GZIP
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class to use when (un)marshalling. If omitted, parquet files are converted into Avro's GenericRecords for unmarshalling
and input objects are assumed as GenericRecords for marshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="lazyLoad" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should produce an iterator of records or read all the records at once. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="protobufDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="instanceClass" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of class to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="objectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Lookup and use the existing ObjectMapper with the given id when using Jackson.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useDefaultObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to lookup and use default Jackson ObjectMapper from the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoDiscoverObjectMapper" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set to true then Jackson will lookup for an objectMapper into the registry. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="library" type="tns:protobufLibrary">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Which Protobuf library to use. Default value: GoogleProtobuf
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="jsonView" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When marshalling a POJO to JSON you might want to exclude certain fields from the JSON output. With Jackson you can use
JSON views to accomplish this. This option is to refer to the class which has JsonView annotations.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="include" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If you want to marshal a pojo to JSON, and the pojo has some fields with null values. And you want to skip these null
values, you can set this option to NON_NULL.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowJmsType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for JMS users to allow the JMSType header from the JMS spec to specify a FQN classname to use to unmarshal to.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="collectionType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom collection type to lookup in the registry to use. This option should rarely be used, but allows to
use different collection types than java.util.Collection based as default.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useList" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To unmarshal to a List of Map or a List of Pojo. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleClassNames" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules com.fasterxml.jackson.databind.Module specified as a String with FQN class names. Multiple
classes can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="moduleRefs" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use custom Jackson modules referred from the Camel registry. Multiple modules can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to enable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name that
matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disableFeatures" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set of features to disable on the Jackson com.fasterxml.jackson.databind.ObjectMapper. The features should be a name
that matches a enum from com.fasterxml.jackson.databind.SerializationFeature,
com.fasterxml.jackson.databind.DeserializationFeature, or com.fasterxml.jackson.databind.MapperFeature Multiple features
can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowUnmarshallType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Jackson is allowed to attempt to use the CamelJacksonUnmarshalType header during the unmarshalling. This
should only be enabled when desired to be used. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timezone" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If set then Jackson will use the Timezone when marshalling/unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schemaResolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Optional schema resolver used to lookup schemas for the data in transit.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoDiscoverSchemaResolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When not disabled, the SchemaResolver will be looked up into the registry. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeFormat" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Defines a content type format in which protobuf message will be serialized/deserialized from(to) the Java been. The
format can either be native or json for either native protobuf or json fields representation. The default value is
native. Default value: native
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="rssDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="smooksDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="smooksConfig" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Path to the Smooks configuration file.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="soapDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="contextPath" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Package name where your JAXB classes are located.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="encoding" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To overrule and use a specific encoding.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="elementNameStrategyRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to an element strategy to lookup from the registry. An element name strategy is used for two purposes. The first
is to find a xml element name for a given object and soap action when marshaling the object into a SOAP message. The
second is to find an Exception class for a given soap fault name. The following three element strategy class name is
provided out of the box. QNameStrategy - Uses a fixed qName that is configured on instantiation. Exception lookup is not
supported TypeNameStrategy - Uses the name and namespace from the XMLType annotation of the given type. If no namespace
is set then package-info is used. Exception lookup is not supported ServiceInterfaceStrategy - Uses information from a
webservice interface to determine the type name and to find the exception class for a SOAP fault All three classes is
located in the package name org.apache.camel.dataformat.soap.name If you have generated the web service stub code with
cxf-codegen or a similar tool then you probably will want to use the ServiceInterfaceStrategy. In the case you have no
annotated service interface you should use QNameStrategy or TypeNameStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="version" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
SOAP version should either be 1.1 or 1.2. Is by default 1.1. Default value: 1.1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="namespacePrefixRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When marshalling using JAXB or SOAP then the JAXB implementation will automatic assign namespace prefixes, such as ns2,
ns3, ns4 etc. To control this mapping, Camel allows you to refer to a map which contains the desired mapping.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="schema" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To validate against an existing schema. Your can use the prefix classpath:, file: or http: to specify how the resource
should be resolved. You can separate multiple schema files by using the ',' character.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="swiftMtDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="writeInJson" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The flag indicating that messages must be marshalled in a JSON format. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="swiftMxDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="writeConfigRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a specific configuration to use when marshalling a message to lookup from the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="writeInJson" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The flag indicating that messages must be marshalled in a JSON format. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="readMessageId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The type of MX message to produce when unmarshalling an input stream. If not set, it will be automatically detected from
the namespace used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="readConfigRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a specific configuration to use when unmarshalling an input stream to lookup from the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="syslogDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="tarFileDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="usingIterator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the tar file has more than one entry, the setting this option to true, allows working with the splitter EIP, to split
the data using an iterator in a streaming mode. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowEmptyDirectory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the tar file has more than one entry, setting this option to true, allows to get the iterator even if the directory
is empty. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="preservePathElements" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the file name contains path elements, setting this option to true, allows the path to be maintained in the tar file.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxDecompressedSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the maximum decompressed size of a tar file (in bytes). The default value if not specified corresponds to 1
gigabyte. An IOException will be thrown if the decompressed size exceeds this amount. Set to -1 to disable setting a
maximum decompressed size. Default value: 1073741824
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="thriftDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="instanceClass" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of class to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeFormat" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Defines a content type format in which thrift message will be serialized/deserialized from(to) the Java been. The format
can either be native or json for either native binary thrift, json or simple json fields representation. The default
value is binary. Default value: binary
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="contentTypeHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the data format should set the Content-Type header with the type from the data format. For example
application/xml for data formats marshalling to XML, or application/json for data formats marshalling to JSON. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="tidyMarkupDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="dataObjectType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
What data type to unmarshal as, can either be org.w3c.dom.Node or java.lang.String. Is by default org.w3c.dom.Node.
Default value: org.w3c.dom.Node
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="omitXmlDeclaration" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When returning a String, do we omit the XML declaration in the top. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="uniVocityCsvDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:uniVocityAbstractDataFormat">
        <xs:sequence/>
        <xs:attribute name="delimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The delimiter of values. Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="quoteAllFields" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not all values must be quoted when writing them. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="quote" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The quote symbol. Default value: "
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="quoteEscape" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The quote escape symbol. Default value: "
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="uniVocityAbstractDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:univocityHeader"/>
        </xs:sequence>
        <xs:attribute name="nullValue" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The string representation of a null value. The default value is null.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipEmptyLines" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the empty lines must be ignored. The default value is true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreTrailingWhitespaces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the trailing white spaces must be ignored. The default value is true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreLeadingWhitespaces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the leading white spaces must be ignored. The default value is true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="headersDisabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the headers are disabled. When defined, this option explicitly sets the headers as null which indicates
that there is no header. The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="headerExtractionEnabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the header must be read in the first line of the test document. The default value is false. Default
value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="numberOfRecordsToRead" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The maximum number of record to read.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="emptyValue" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The String representation of an empty value.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="lineSeparator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The line separator of the files. The default value is to use the JVM platform line separator.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="normalizedLineSeparator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The normalized line separator of the files. The default value is a new line character.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="comment" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The comment symbol. The default value is #. Default value: #
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="lazyLoad" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should produce an iterator that reads the lines on the fly or if all the lines must be read at
once. The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="asMap" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the unmarshalling should produce maps for the lines values instead of lists. It requires to have header (either
defined or collected). The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="uniVocityHeader">
    <xs:simpleContent>
      <xs:extension base="xs:string">
        <xs:attribute name="length" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Header length.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="uniVocityFixedDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:uniVocityAbstractDataFormat">
        <xs:sequence/>
        <xs:attribute name="padding" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The padding character. The default value is a space.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipTrailingCharsUntilNewline" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the trailing characters until new line must be ignored. The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="recordEndsOnNewline" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the record ends on new line. The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="uniVocityTsvDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:uniVocityAbstractDataFormat">
        <xs:sequence/>
        <xs:attribute name="escapeChar" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The escape character. Default value: \
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="xmlSecurityDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="xmlCipherAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The cipher algorithm to be used for encryption/decryption of the XML message content. The available choices are:
XMLCipher.TRIPLEDES XMLCipher.AES_128 XMLCipher.AES_128_GCM XMLCipher.AES_192 XMLCipher.AES_192_GCM XMLCipher.AES_256
XMLCipher.AES_256_GCM XMLCipher.SEED_128 XMLCipher.CAMELLIA_128 XMLCipher.CAMELLIA_192 XMLCipher.CAMELLIA_256 The
default value is XMLCipher.AES_256_GCM. Default value: AES-256-GCM
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="passPhrase" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A String used as passPhrase to encrypt/decrypt content. The passPhrase has to be provided. The passPhrase needs to be
put together in conjunction with the appropriate encryption algorithm. For example using TRIPLEDES the passPhase can be
a Only another 24 Byte key.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="passPhraseByte" type="xs:base64Binary">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A byte used as passPhrase to encrypt/decrypt content. The passPhrase has to be provided. The passPhrase needs to be put
together in conjunction with the appropriate encryption algorithm. For example using TRIPLEDES the passPhase can be a
Only another 24 Byte key.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="secureTag" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The XPath reference to the XML Element selected for encryption/decryption. If no tag is specified, the entire payload is
encrypted/decrypted.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="secureTagContents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A boolean value to specify whether the XML Element is to be encrypted or the contents of the XML Element. false =
Element Level. true = Element Content Level. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keyCipherAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The cipher algorithm to be used for encryption/decryption of the asymmetric key. The available choices are:
XMLCipher.RSA_v1dot5 XMLCipher.RSA_OAEP XMLCipher.RSA_OAEP_11 The default value is XMLCipher.RSA_OAEP. Default value:
RSA_OAEP
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="recipientKeyAlias" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The key alias to be used when retrieving the recipient's public or private key from a KeyStore when performing
asymmetric key encryption or decryption.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keyOrTrustStoreParametersRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a KeyStore instance to lookup in the registry, which is used for configuration options for creating and
loading a KeyStore instance that represents the sender's trustStore or recipient's keyStore.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keyPassword" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The password to be used for retrieving the private key from the KeyStore. This key is used for asymmetric decryption.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="digestAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The digest algorithm to use with the RSA OAEP algorithm. The available choices are: XMLCipher.SHA1 XMLCipher.SHA256
XMLCipher.SHA512 The default value is XMLCipher.SHA1. Default value: SHA1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mgfAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The MGF Algorithm to use with the RSA OAEP algorithm. The available choices are: EncryptionConstants.MGF1_SHA1
EncryptionConstants.MGF1_SHA256 EncryptionConstants.MGF1_SHA512 The default value is EncryptionConstants.MGF1_SHA1.
Default value: MGF1_SHA1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="addKeyValueForEncryptedKey" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to add the public key used to encrypt the session key as a KeyValue in the EncryptedKey structure or not.
Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="pgpDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="keyUserid" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The user ID of the key in the PGP keyring used during encryption. Can also be only a part of a user ID. For example, if
the user ID is Test User then you can use the part Test User or to address the user ID.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="signatureKeyUserid" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
User ID of the key in the PGP keyring used for signing (during encryption) or signature verification (during
decryption). During the signature verification process the specified User ID restricts the public keys from the public
keyring which can be used for the verification. If no User ID is specified for the signature verficiation then any
public key in the public keyring can be used for the verification. Can also be only a part of a user ID. For example, if
the user ID is Test User then you can use the part Test User or to address the User ID.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="password" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Password used when opening the private key (not used for encryption).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="signaturePassword" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Password used when opening the private key used for signing (during encryption).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keyFileName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Filename of the keyring; must be accessible as a classpath resource (but you can specify a location in the file system
by using the file: prefix).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="signatureKeyFileName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Filename of the keyring to use for signing (during encryption) or for signature verification (during decryption); must
be accessible as a classpath resource (but you can specify a location in the file system by using the file: prefix).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="signatureKeyRing" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Keyring used for signing/verifying as byte array. You can not set the signatureKeyFileName and signatureKeyRing at the
same time.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="armored" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option will cause PGP to base64 encode the encrypted text, making it available for copy/paste, etc. Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="integrity" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Adds an integrity check/sign into the encryption file. The default value is true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="provider" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Java Cryptography Extension (JCE) provider, default is Bouncy Castle (BC). Alternatively you can use, for example, the
IAIK JCE provider; in this case the provider must be registered beforehand and the Bouncy Castle provider must not be
registered beforehand. The Sun JCE provider does not work.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="algorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Symmetric key encryption algorithm; possible values are defined in org.bouncycastle.bcpg.SymmetricKeyAlgorithmTags; for
example 2 (= TRIPLE DES), 3 (= CAST5), 4 (= BLOWFISH), 6 (= DES), 7 (= AES_128). Only relevant for encrypting.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="compressionAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Compression algorithm; possible values are defined in org.bouncycastle.bcpg.CompressionAlgorithmTags; for example 0 (=
UNCOMPRESSED), 1 (= ZIP), 2 (= ZLIB), 3 (= BZIP2). Only relevant for encrypting.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="hashAlgorithm" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Signature hash algorithm; possible values are defined in org.bouncycastle.bcpg.HashAlgorithmTags; for example 2 (=
SHA1), 8 (= SHA256), 9 (= SHA384), 10 (= SHA512), 11 (=SHA224). Only relevant for signing.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="signatureVerificationOption" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Controls the behavior for verifying the signature during unmarshaling. There are 4 values possible: optional: The PGP
message may or may not contain signatures; if it does contain signatures, then a signature verification is executed.
required: The PGP message must contain at least one signature; if this is not the case an exception (PGPException) is
thrown. A signature verification is executed. ignore: Contained signatures in the PGP message are ignored; no signature
verification is executed. no_signature_allowed: The PGP message must not contain a signature; otherwise an exception
(PGPException) is thrown.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="yamlDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:typeFilter"/>
        </xs:sequence>
        <xs:attribute name="library" type="tns:yamlLibrary">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Which yaml library to use. By default it is SnakeYAML. Default value: SnakeYAML
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unmarshalType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name of the java type to use when unmarshalling.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="constructor" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
BaseConstructor to construct incoming documents.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="representer" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Representer to emit outgoing objects.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="dumperOptions" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
DumperOptions to configure outgoing objects.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="resolver" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Resolver to detect implicit type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useApplicationContextClassLoader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Use ApplicationContextClassLoader as custom ClassLoader. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="prettyFlow" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Force the emitter to produce a pretty YAML document when using the flow style. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowAnyType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Allow any class to be un-marshaled. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxAliasesForCollections" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the maximum amount of aliases allowed for collections. Default value: 50
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowRecursiveKeys" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set whether recursive keys are allowed. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="yamlTypeFilterDefinition">
    <xs:sequence/>
    <xs:attribute name="value" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Value of type such as class name or regular expression.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="type" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to filter by class type or regular expression.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="zipDeflaterDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="compressionLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To specify a specific compression between 0-9. -1 is default compression, 0 is no compression, and 9 is the best
compression. Default value: -1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="zipFileDataFormat">
    <xs:complexContent>
      <xs:extension base="tns:dataFormat">
        <xs:sequence/>
        <xs:attribute name="usingIterator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the zip file has more than one entry, the setting this option to true, allows working with the splitter EIP, to split
the data using an iterator in a streaming mode. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowEmptyDirectory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the zip file has more than one entry, setting this option to true, allows to get the iterator even if the directory
is empty. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="preservePathElements" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the file name contains path elements, setting this option to true, allows the path to be maintained in the zip file.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxDecompressedSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the maximum decompressed size of a zip file (in bytes). The default value if not specified corresponds to 1
gigabyte. An IOException will be thrown if the decompressed size exceeds this amount. Set to -1 to disable setting a
maximum decompressed size. Default value: 1073741824
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="modelLifecycleStrategySupport">
    <xs:sequence/>
  </xs:complexType>
  <xs:complexType name="multicastDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="aggregationStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to an AggregationStrategy to be used to assemble the replies from the multicasts, into a single outgoing message
from the Multicast. By default Camel will use the last reply as the outgoing message. You can also use a POJO as the
AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodAllowNull" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was no data to enrich. If this option is true
then null values is used as the oldExchange (when no data to enrich), when using POJOs as the AggregationStrategy.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelAggregate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: If enabled then the aggregate method on AggregationStrategy can be called concurrently. Notice that this
would require the implementation of AggregationStrategy to be implemented as thread-safe. By default this is false
meaning that Camel synchronizes the call to the aggregate method. Though in some use-cases this can be used to archive
higher performance when the AggregationStrategy is implemented as thread-safe. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelProcessing" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then sending messages to the multicasts occurs concurrently. Note the caller thread will still wait until all
messages has been fully processed, before it continues. Its only the sending and processing the replies from the
multicasts which happens concurrently. When parallel processing is enabled, then the Camel routing engin will continue
processing using last used thread from the parallel thread pool. However, if you want to use the original thread that
called the multicast, then make sure to enable the synchronous option as well. In parallel processing mode, you may want
to also synchronous = true to force this EIP to process the sub-tasks using the upper bounds of the thread-pool. If
using synchronous = false then Camel will allow its reactive routing engine to use as many threads as possible, which
may be available due to sub-tasks using other thread-pools such as CompletableFuture.runAsync or others. Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="synchronous" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether synchronous processing should be strictly used. When enabled then the same thread is used to continue
routing after the multicast is complete, even if parallel processing is enabled. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="streaming" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Camel will process replies out-of-order, eg in the order they come back. If disabled, Camel will process
replies in the same order as defined by the multicast. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="stopOnException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will now stop further processing if an exception or failure occurred during processing of an org.apache.camel.Exchange
and the caused exception will be thrown. Will also stop if processing the exchange failed (has a fault message) or an
exception was thrown and handled by the error handler (such as using onException). In all situations the multicast will
stop further processing. This is the same behavior as in pipeline, which is used by the routing engine. The default
behavior is to not stop but continue processing till the end. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a total timeout specified in millis, when using parallel processing. If the Multicast hasn't been able to send and
process all replies within the given timeframe, then the timeout triggers and the Multicast breaks out and continues.
Notice if you provide a TimeoutAwareAggregationStrategy then the timeout method is invoked before breaking out. If the
timeout is reached with running tasks still remaining, certain tasks for which it is difficult for Camel to shut down in
a graceful manner may continue to run. So use this option with a bit of care. Default value: 0
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a custom Thread Pool to be used for parallel processing. Notice if you set this option, then parallel
processing is automatic implied, and you do not have to enable that option as well.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onPrepare" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses the Processor when preparing the org.apache.camel.Exchange to be send. This can be used to deep-clone messages that
should be send, or any custom logic needed before the exchange is send.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shareUnitOfWork" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Shares the org.apache.camel.spi.UnitOfWork with the parent and each of the sub messages. Multicast will by default not
share unit of work between the parent exchange and each multicasted exchange. This means each sub exchange has its own
individual unit of work. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="onCompletionDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:onWhen"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="mode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the on completion mode. The default value is AfterConsumer. Default value: AfterConsumer
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onCompleteOnly" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will only synchronize when the org.apache.camel.Exchange completed successfully (no errors). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onFailureOnly" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will only synchronize when the org.apache.camel.Exchange ended with failure (exception or FAULT message). Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelProcessing" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then the on completion process will run asynchronously by a separate thread from a thread pool. By default
this is false, meaning the on completion process will run synchronously using the same caller thread as from the route.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom Thread Pool to be used for parallel processing. Notice if you set this option, then parallel processing
is automatic implied, and you do not have to enable that option as well.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useOriginalMessage" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will use the original input message body when an org.apache.camel.Exchange for this on completion. The original input
message is defensively copied, and the copied message body is converted to org.apache.camel.StreamCache if possible
(stream caching is enabled, can be disabled globally or on the original route), to ensure the body can be read when the
original message is being used later. If the body is converted to org.apache.camel.StreamCache then the message body on
the current org.apache.camel.Exchange is replaced with the org.apache.camel.StreamCache body. If the body is not
converted to org.apache.camel.StreamCache then the body will not be able to re-read when accessed later. Important: The
original input means the input message that are bounded by the current org.apache.camel.spi.UnitOfWork . An unit of work
typically spans one route, or multiple routes if they are connected using internal endpoints such as direct or seda.
When messages is passed via external endpoints such as JMS or HTTP then the consumer will create a new unit of work,
with the message it received as input as the original input. Also some EIP patterns such as splitter, multicast, will
create a new unit of work boundary for the messages in their sub-route (eg the split message); however these EIPs have
an option named shareUnitOfWork which allows to combine with the parent unit of work in regard to error handling and
therefore use the parent original message. By default this feature is off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="onExceptionDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" name="exception" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
A set of exceptions to react upon.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" ref="tns:onWhen"/>
          <xs:element minOccurs="0" name="retryWhile" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Sets the retry while predicate. Will continue retrying until predicate returns false.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" ref="tns:redeliveryPolicy"/>
          <xs:element minOccurs="0" name="handled" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Sets whether the exchange should be marked as handled or not.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" name="continued" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Sets whether the exchange should handle and continue routing from the point of failure. If this option is enabled then
its considered handled as well.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="redeliveryPolicyRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a redelivery policy to lookup in the org.apache.camel.spi.Registry to be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onRedeliveryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a processor that should be processed before a redelivery attempt. Can be used to change the
org.apache.camel.Exchange before its being redelivered.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onExceptionOccurredRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a processor that should be processed just after an exception occurred. Can be used to perform custom
logging about the occurred exception at the exact time it happened. Important: Any exception thrown from this processor
will be ignored.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useOriginalMessage" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will use the original input org.apache.camel.Message (original body and headers) when an org.apache.camel.Exchange is
moved to the dead letter queue. Notice: this only applies when all redeliveries attempt have failed and the
org.apache.camel.Exchange is doomed for failure. Instead of using the current inprogress org.apache.camel.Exchange IN
message we use the original IN message instead. This allows you to store the original input in the dead letter queue
instead of the inprogress snapshot of the IN message. For instance if you route transform the IN body during routing and
then failed. With the original exchange store in the dead letter queue it might be easier to manually re submit the
org.apache.camel.Exchange again as the IN message is the same as when Camel received it. So you should be able to send
the org.apache.camel.Exchange to the same input. The difference between useOriginalMessage and useOriginalBody is that
the former includes both the original body and headers, where as the latter only includes the original body. You can use
the latter to enrich the message with custom headers and include the original message body. The former wont let you do
this, as its using the original message body and headers as they are. You cannot enable both useOriginalMessage and
useOriginalBody. The original input message is defensively copied, and the copied message body is converted to
org.apache.camel.StreamCache if possible (stream caching is enabled, can be disabled globally or on the original route),
to ensure the body can be read when the original message is being used later. If the body is converted to
org.apache.camel.StreamCache then the message body on the current org.apache.camel.Exchange is replaced with the
org.apache.camel.StreamCache body. If the body is not converted to org.apache.camel.StreamCache then the body will not
be able to re-read when accessed later. Important: The original input means the input message that are bounded by the
current org.apache.camel.spi.UnitOfWork . An unit of work typically spans one route, or multiple routes if they are
connected using internal endpoints such as direct or seda. When messages is passed via external endpoints such as JMS or
HTTP then the consumer will create a new unit of work, with the message it received as input as the original input. Also
some EIP patterns such as splitter, multicast, will create a new unit of work boundary for the messages in their
sub-route (eg the split message); however these EIPs have an option named shareUnitOfWork which allows to combine with
the parent unit of work in regard to error handling and therefore use the parent original message. By default this
feature is off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="useOriginalBody" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will use the original input org.apache.camel.Message body (original body only) when an org.apache.camel.Exchange is
moved to the dead letter queue. Notice: this only applies when all redeliveries attempt have failed and the
org.apache.camel.Exchange is doomed for failure. Instead of using the current inprogress org.apache.camel.Exchange IN
message we use the original IN message instead. This allows you to store the original input in the dead letter queue
instead of the inprogress snapshot of the IN message. For instance if you route transform the IN body during routing and
then failed. With the original exchange store in the dead letter queue it might be easier to manually re submit the
org.apache.camel.Exchange again as the IN message is the same as when Camel received it. So you should be able to send
the org.apache.camel.Exchange to the same input. The difference between useOriginalMessage and useOriginalBody is that
the former includes both the original body and headers, where as the latter only includes the original body. You can use
the latter to enrich the message with custom headers and include the original message body. The former wont let you do
this, as its using the original message body and headers as they are. You cannot enable both useOriginalMessage and
useOriginalBody. The original input message is defensively copied, and the copied message body is converted to
org.apache.camel.StreamCache if possible (stream caching is enabled, can be disabled globally or on the original route),
to ensure the body can be read when the original message is being used later. If the body is converted to
org.apache.camel.StreamCache then the message body on the current org.apache.camel.Exchange is replaced with the
org.apache.camel.StreamCache body. If the body is not converted to org.apache.camel.StreamCache then the body will not
be able to re-read when accessed later. Important: The original input means the input message that are bounded by the
current org.apache.camel.spi.UnitOfWork . An unit of work typically spans one route, or multiple routes if they are
connected using internal endpoints such as direct or seda. When messages is passed via external endpoints such as JMS or
HTTP then the consumer will create a new unit of work, with the message it received as input as the original input. Also
some EIP patterns such as splitter, multicast, will create a new unit of work boundary for the messages in their
sub-route (eg the split message); however these EIPs have an option named shareUnitOfWork which allows to combine with
the parent unit of work in regard to error handling and therefore use the parent original message. By default this
feature is off. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="outputTypeDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="urn" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set output type URN.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="validate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether if validation is required for this output type. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="packageScanDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" name="package" type="xs:string">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Sets the java package names to use for scanning for route builder classes.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="excludes" type="xs:string">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Exclude finding route builder from these java package names.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="includes" type="xs:string">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Include finding route builder from these java package names.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="pausableDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="consumerListener" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the consumer listener to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="untilCheck" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References to a java.util.function.Predicate to use for until checks. The predicate is responsible for evaluating
whether the processing can resume or not. Such predicate should return true if the consumption can resume, or false
otherwise. The exact point of when the predicate is called is dependent on the component, and it may be called on either
one of the available events. Implementations should not assume the predicate to be called at any specific point.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="pipelineDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="policyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="ref" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to use for lookup the policy in the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="pollDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store the received message body (only body, not headers). This makes it handy to use variables for
user data and to easily control what data to use for sending and receiving. Important: When using receive variable then
the received body is stored only in this variable and not on the current message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the uri of the endpoint to poll from.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Timeout in millis when polling from the external service. The timeout has influence about the poll enrich behavior. It
basically operations in three different modes: negative value - Waits until a message is available and then returns it.
Warning that this method could block indefinitely if no messages are available. 0 - Attempts to receive a message
exchange immediately without waiting and returning null if a message exchange is not available yet. positive value -
Attempts to receive a message exchange, waiting up to the given timeout to expire if a message is not yet available.
Returns null if timed out The default value is 20000 (20 seconds). Default value: 20000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="pollEnrichDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store the received message body (only body, not headers). This makes it handy to use variables for
user data and to easily control what data to use for sending and receiving. Important: When using receive variable then
the received body is stored only in this variable and not on the current message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the AggregationStrategy to be used to merge the reply from the external service, into a single outgoing message. By
default Camel will use the reply from the external service as outgoing message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodAllowNull" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was no data to enrich. If this option is true
then null values is used as the oldExchange (when no data to enrich), when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregateOnException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was an exception thrown while trying to retrieve
the data to enrich from the resource. Setting this option to true allows end users to control what to do if there was an
exception in the aggregate method. For example to suppress the exception or set a custom message body etc. Default
value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Timeout in millis when polling from the external service. The timeout has influence about the poll enrich behavior. It
basically operations in three different modes: negative value - Waits until a message is available and then returns it.
Warning that this method could block indefinitely if no messages are available. 0 - Attempts to receive a message
exchange immediately without waiting and returning null if a message exchange is not available yet. positive value -
Attempts to receive a message exchange, waiting up to the given timeout to expire if a message is not yet available.
Returns null if timed out The default value is -1 and therefore the method could block indefinitely, and therefore its
recommended to use a timeout value. Default value: -1
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cacheSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum size used by the org.apache.camel.spi.ConsumerCache which is used to cache and reuse consumers when
uris are reused. Beware that when using dynamic endpoints then it affects how well the cache can be utilized. If each
dynamic endpoint is unique then its best to turn off caching by setting this to -1, which allows Camel to not cache both
the producers and endpoints; they are regarded as prototype scoped and will be stopped and discarded after use. This
reduces memory usage as otherwise producers/endpoints are stored in memory in the caches. However if there are a high
degree of dynamic endpoints that have been used before, then it can benefit to use the cache to reuse both producers and
endpoints and therefore the cache size can be set accordingly or rely on the default size (1000). If there is a mix of
unique and used before dynamic endpoints, then setting a reasonable cache size can help reduce memory usage to avoid
storing too many non frequent used producers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidEndpoint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Ignore the invalidate endpoint exception when try to create a producer with that endpoint. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowOptimisedComponents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow components to optimise if they are org.apache.camel.spi.SendDynamicAware . Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoStartComponents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to auto startup components when poll enricher is starting up. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="processDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to the Processor to lookup in the registry to use. A Processor is a class of type org.apache.camel.Processor,
which can are to be called by this EIP. In this processor you have custom Java code, that can work with the message,
such as to do custom business logic, special message manipulations and so on. By default, the ref, will lookup the bean
in the Camel registry. The ref can use prefix that controls how the processor is obtained. You can use #bean:myBean
where myBean is the id of the Camel processor (lookup). Can also be used for creating new beans by their class name by
prefixing with #class, eg #class:com.foo.MyClassType. And it is also possible to refer to singleton beans by their type
in the registry by prefixing with #type: syntax, eg #type:com.foo.MyClassType.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="propertyDefinition">
    <xs:sequence/>
    <xs:attribute name="key" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the property.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="value" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The property value.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="propertyDefinitions">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:property"/>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="propertyExpressionDefinition">
    <xs:choice>
      <xs:element ref="tns:expressionDefinition"/>
      <xs:element ref="tns:csimple"/>
      <xs:element ref="tns:constant"/>
      <xs:element ref="tns:datasonnet"/>
      <xs:element ref="tns:exchangeProperty"/>
      <xs:element ref="tns:groovy"/>
      <xs:element ref="tns:header"/>
      <xs:element ref="tns:hl7terser"/>
      <xs:element ref="tns:java"/>
      <xs:element ref="tns:js"/>
      <xs:element ref="tns:joor"/>
      <xs:element ref="tns:jq"/>
      <xs:element ref="tns:jsonpath"/>
      <xs:element ref="tns:language"/>
      <xs:element ref="tns:method"/>
      <xs:element ref="tns:mvel"/>
      <xs:element ref="tns:ognl"/>
      <xs:element ref="tns:python"/>
      <xs:element ref="tns:ref"/>
      <xs:element ref="tns:simple"/>
      <xs:element ref="tns:spel"/>
      <xs:element ref="tns:tokenize"/>
      <xs:element ref="tns:variable"/>
      <xs:element ref="tns:wasm"/>
      <xs:element ref="tns:xtokenize"/>
      <xs:element ref="tns:xpath"/>
      <xs:element ref="tns:xquery"/>
    </xs:choice>
    <xs:attribute name="key" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Property key.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="recipientListDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="delimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Delimiter used if the Expression returned multiple endpoints. Can be turned off using the value false. The default value
is ,. Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the AggregationStrategy to be used to assemble the replies from the recipients, into a single outgoing message from
the RecipientList. By default Camel will use the last reply as the outgoing message. You can also use a POJO as the
AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodAllowNull" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was no data to enrich. If this option is true
then null values is used as the oldExchange (when no data to enrich), when using POJOs as the AggregationStrategy.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelAggregate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: If enabled then the aggregate method on AggregationStrategy can be called concurrently. Notice that this
would require the implementation of AggregationStrategy to be implemented as thread-safe. By default this is false
meaning that Camel synchronizes the call to the aggregate method. Though in some use-cases this can be used to archive
higher performance when the AggregationStrategy is implemented as thread-safe. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelProcessing" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then sending messages to the recipients occurs concurrently. Note the caller thread will still wait until all
messages has been fully processed, before it continues. Its only the sending and processing the replies from the
recipients which happens concurrently. When parallel processing is enabled, then the Camel routing engin will continue
processing using last used thread from the parallel thread pool. However, if you want to use the original thread that
called the recipient list, then make sure to enable the synchronous option as well. In parallel processing mode, you may
want to also synchronous = true to force this EIP to process the sub-tasks using the upper bounds of the thread-pool. If
using synchronous = false then Camel will allow its reactive routing engine to use as many threads as possible, which
may be available due to sub-tasks using other thread-pools such as CompletableFuture.runAsync or others. Default value:
false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="synchronous" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether synchronous processing should be strictly used. When enabled then the same thread is used to continue
routing after the recipient list is complete, even if parallel processing is enabled. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a total timeout specified in millis, when using parallel processing. If the Recipient List hasn't been able to send
and process all replies within the given timeframe, then the timeout triggers and the Recipient List breaks out and
continues. Notice if you provide a TimeoutAwareAggregationStrategy then the timeout method is invoked before breaking
out. If the timeout is reached with running tasks still remaining, certain tasks for which it is difficult for Camel to
shut down in a graceful manner may continue to run. So use this option with a bit of care. Default value: 0
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom Thread Pool to be used for parallel processing. Notice if you set this option, then parallel processing
is automatic implied, and you do not have to enable that option as well.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="stopOnException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will now stop further processing if an exception or failure occurred during processing of an org.apache.camel.Exchange
and the caused exception will be thrown. Will also stop if processing the exchange failed (has a fault message) or an
exception was thrown and handled by the error handler (such as using onException). In all situations the recipient list
will stop further processing. This is the same behavior as in pipeline, which is used by the routing engine. The default
behavior is to not stop but continue processing till the end. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidEndpoints" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Ignore the invalidate endpoint exception when try to create a producer with that endpoint. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="streaming" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then Camel will process replies out-of-order, eg in the order they come back. If disabled, Camel will process
replies in the same order as defined by the recipient list. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onPrepare" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses the Processor when preparing the org.apache.camel.Exchange to be used send. This can be used to deep-clone messages
that should be send, or any custom logic needed before the exchange is send.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cacheSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum size used by the org.apache.camel.spi.ProducerCache which is used to cache and reuse producers when
using this recipient list, when uris are reused. Beware that when using dynamic endpoints then it affects how well the
cache can be utilized. If each dynamic endpoint is unique then its best to turn off caching by setting this to -1, which
allows Camel to not cache both the producers and endpoints; they are regarded as prototype scoped and will be stopped
and discarded after use. This reduces memory usage as otherwise producers/endpoints are stored in memory in the caches.
However if there are a high degree of dynamic endpoints that have been used before, then it can benefit to use the cache
to reuse both producers and endpoints and therefore the cache size can be set accordingly or rely on the default size
(1000). If there is a mix of unique and used before dynamic endpoints, then setting a reasonable cache size can help
reduce memory usage to avoid storing too many non frequent used producers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shareUnitOfWork" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Shares the org.apache.camel.spi.UnitOfWork with the parent and each of the sub messages. Recipient List will by default
not share unit of work between the parent exchange and each recipient exchange. This means each sub exchange has its own
individual unit of work. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="removeHeaderDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of header to remove.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="removeHeadersDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="pattern" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name or pattern of headers to remove. The pattern is matched in the following order: 1 = exact match 2 = wildcard
(pattern ends with a and the name starts with the pattern) 3 = regular expression (all of above is case in-sensitive).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="excludePattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name or patter of headers to not remove. The pattern is matched in the following order: 1 = exact match 2 = wildcard
(pattern ends with a and the name starts with the pattern) 3 = regular expression (all of above is case in-sensitive).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="removePropertiesDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="pattern" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name or pattern of properties to remove. The pattern is matched in the following order: 1 = exact match 2 = wildcard
(pattern ends with a and the name starts with the pattern) 3 = regular expression (all of above is case in-sensitive).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="excludePattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name or pattern of properties to not remove. The pattern is matched in the following order: 1 = exact match 2 = wildcard
(pattern ends with a and the name starts with the pattern) 3 = regular expression (all of above is case in-sensitive).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="removePropertyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of property to remove.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="removeVariableDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of variable to remove.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="resequenceDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:batchConfig"/>
            <xs:element ref="tns:streamConfig"/>
          </xs:choice>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="batchResequencerConfig">
    <xs:complexContent>
      <xs:extension base="tns:resequencerConfig">
        <xs:sequence/>
        <xs:attribute name="batchSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the size of the batch to be re-ordered. The default size is 100. Default value: 100
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="batchTimeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the timeout for collecting elements to be re-ordered. The default timeout is 1000 msec. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowDuplicates" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow duplicates. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="reverse" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to reverse the ordering. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidExchanges" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore invalid exchanges. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="resequencerConfig">
    <xs:sequence/>
  </xs:complexType>
  <xs:complexType name="streamResequencerConfig">
    <xs:complexContent>
      <xs:extension base="tns:resequencerConfig">
        <xs:sequence/>
        <xs:attribute name="capacity" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the capacity of the resequencer inbound queue. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets minimum time (milliseconds) to wait for missing elements (messages). Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="deliveryAttemptInterval" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the interval in milliseconds the stream resequencer will at most wait while waiting for condition of being able to
deliver. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidExchanges" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore invalid exchanges. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rejectOld" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If true, throws an exception when messages older than the last delivered message are processed. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="comparator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom comparator as a org.apache.camel.processor.resequencer.ExpressionResultComparator type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="restContextRefDefinition">
    <xs:sequence/>
    <xs:attribute name="ref" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Reference to the rest-dsl.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="resumableDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="resumeStrategy" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the resume strategy to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="loggingLevel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The logging level to use in case of failures. Default value: ERROR
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="intermittent" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether the offsets will be intermittently present or whether they must be present in every exchange. Default
value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="rollbackDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="message" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Message to use in rollback exception.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="markRollbackOnly" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Mark the transaction for rollback only (cannot be overruled to commit). Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="markRollbackOnlyLast" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Mark only last sub transaction for rollback only. When using sub transactions (if the transaction manager support this).
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routeBuilderDefinition">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to the route builder instance.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routeConfigurationContextRefDefinition">
    <xs:sequence/>
    <xs:attribute name="ref" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Reference to the route templates in the xml dsl.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="routeConfigurationDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:errorHandler"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:intercept"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:interceptFrom"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:interceptSendToEndpoint"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:onException"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:onCompletion"/>
        </xs:sequence>
        <xs:attribute name="precondition" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The predicate of the precondition in simple language to evaluate in order to determine if this route configuration
should be included or not.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routeConfigurationsDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:routeConfiguration"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routeContextRefDefinition">
    <xs:sequence/>
    <xs:attribute name="ref" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Reference to the routes in the xml dsl.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="routeDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="routeProperty" type="tns:propertyDefinition"/>
          <xs:element minOccurs="0" ref="tns:errorHandler"/>
          <xs:element minOccurs="0" ref="tns:from"/>
          <xs:element minOccurs="0" ref="tns:inputType"/>
          <xs:element minOccurs="0" ref="tns:outputType"/>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="autoStartup" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to auto start this route. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="delayer" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to slow down processing messages by a given delay in msec. Default value: advanced
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="errorHandlerRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the bean ref name of the error handler builder to use on this route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="group" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The group name for this route. Multiple routes can belong to the same group.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="kamelet" type="xs:boolean"/>
        <xs:attribute name="logMask" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether security mask for Logging is enabled on this route. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="messageHistory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether message history is enabled on this route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="nodePrefixId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a prefix to use for all node ids (not route id).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="precondition" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The predicate of the precondition in simple language to evaluate in order to determine if this route should be included
or not.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rest" type="xs:boolean"/>
        <xs:attribute name="routeConfigurationId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The route configuration id or pattern this route should use for configuration. Multiple id/pattern can be separated by
comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="routePolicyRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to custom org.apache.camel.spi.RoutePolicy to use by the route. Multiple policies can be configured by
separating values using comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shutdownRoute" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To control how to shutdown the route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shutdownRunningTask" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To control how to shut down the route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="startupOrder" type="xs:int">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To configure the ordering of the routes being started.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="streamCache" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether stream caching is enabled on this route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="template" type="xs:boolean"/>
        <xs:attribute name="trace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether tracing is enabled on this route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routeTemplateContextRefDefinition">
    <xs:sequence/>
    <xs:attribute name="ref" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Reference to the route templates in the xml dsl.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="routeTemplateDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:templateParameter"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="templateBean" type="tns:beanFactoryDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Adds a local bean the route template uses.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element ref="tns:route"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routeTemplateParameterDefinition">
    <xs:sequence/>
    <xs:attribute name="name" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the parameter.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="required" type="xs:boolean">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether the parameter is required or not. A parameter is required unless this option is set to false or a default value
has been configured. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="defaultValue" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Default value of the parameter. If a default value is provided then the parameter is implied not to be required.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="description" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Description of the parameter.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="routeTemplatesDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:routeTemplate"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routesDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:route"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="routingSlipDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="uriDelimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the uri delimiter to use. Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidEndpoints" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Ignore the invalidate endpoint exception when try to create a producer with that endpoint. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cacheSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum size used by the org.apache.camel.spi.ProducerCache which is used to cache and reuse producers when
using this routing slip, when uris are reused. Beware that when using dynamic endpoints then it affects how well the
cache can be utilized. If each dynamic endpoint is unique then its best to turn off caching by setting this to -1, which
allows Camel to not cache both the producers and endpoints; they are regarded as prototype scoped and will be stopped
and discarded after use. This reduces memory usage as otherwise producers/endpoints are stored in memory in the caches.
However if there are a high degree of dynamic endpoints that have been used before, then it can benefit to use the cache
to reuse both producers and endpoints and therefore the cache size can be set accordingly or rely on the default size
(1000). If there is a mix of unique and used before dynamic endpoints, then setting a reasonable cache size can help
reduce memory usage to avoid storing too many non frequent used producers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="sagaActionUriDefinition">
    <xs:complexContent>
      <xs:extension base="tns:sendDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="sendDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the uri of the endpoint to send to.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="sagaDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:element minOccurs="0" name="compensation" type="tns:sagaActionUriDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The compensation endpoint URI that must be called to compensate all changes done in the route. The route corresponding
to the compensation URI must perform compensation and complete without error. If errors occur during compensation, the
saga service may call again the compensation URI to retry.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element minOccurs="0" name="completion" type="tns:sagaActionUriDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The completion endpoint URI that will be called when the Saga is completed successfully. The route corresponding to the
completion URI must perform completion tasks and terminate without error. If errors occur during completion, the saga
service may call again the completion URI to retry.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="option" type="tns:propertyExpressionDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Allows to save properties of the current exchange in order to re-use them in a compensation/completion callback route.
Options are usually helpful e.g. to store and retrieve identifiers of objects that should be deleted in compensating
actions. Option values will be transformed into input headers of the compensation/completion exchange.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="sagaService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to the id to lookup in the registry for the specific CamelSagaService to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="propagation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the Saga propagation mode (REQUIRED, REQUIRES_NEW, MANDATORY, SUPPORTS, NOT_SUPPORTED, NEVER). Default value:
REQUIRED
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="completionMode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Determine how the saga should be considered complete. When set to AUTO, the saga is completed when the exchange that
initiates the saga is processed successfully, or compensated when it completes exceptionally. When set to MANUAL, the
user must complete or compensate the saga using the saga:complete or saga:compensate endpoints. Default value: AUTO
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the maximum amount of time for the Saga. After the timeout is expired, the saga will be compensated automatically
(unless a different decision has been taken in the meantime).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="samplingDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="samplePeriod" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the sample period during which only a single Exchange will pass through. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="messageFrequency" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the sample message count which only a single Exchange will pass through after this many received.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="scriptDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setBodyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setExchangePatternDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="pattern" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the new exchange pattern of the Exchange to be used from this point forward.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setHeaderDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of message header to set a new value The simple language can be used to define a dynamic evaluated header name to
be used. Otherwise a constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setHeadersDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:setHeader"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setPropertyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of exchange property to set a new value. The simple language can be used to define a dynamic evaluated exchange
property name to be used. Otherwise a constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setVariableDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of variable to set a new value The simple language can be used to define a dynamic evaluated variable name to be
used. Otherwise a constant name will be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="setVariablesDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:setVariable"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="sortDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="comparator" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the comparator to use for sorting.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="splitDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="delimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Delimiter used in splitting messages. Can be turned off using the value false. To force not splitting then the delimiter
can be set to single to use the value as a single list, this can be needed in some special situations. The default value
is comma. Default value: ,
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to the AggregationStrategy to be used to assemble the replies from the split messages, into a single
outgoing message from the Splitter. By default Camel will use the original incoming message to the splitter (leave it
unchanged). You can also use a POJO as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aggregationStrategyMethodAllowNull" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If this option is false then the aggregate method is not used if there was no data to enrich. If this option is true
then null values is used as the oldExchange (when no data to enrich), when using POJOs as the AggregationStrategy.
Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelAggregate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Deprecated: If enabled then the aggregate method on AggregationStrategy can be called concurrently. Notice that this
would require the implementation of AggregationStrategy to be implemented as thread-safe. By default this is false
meaning that Camel synchronizes the call to the aggregate method. Though in some use-cases this can be used to archive
higher performance when the AggregationStrategy is implemented as thread-safe. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="parallelProcessing" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If enabled then processing each split messages occurs concurrently. Note the caller thread will still wait until all
messages has been fully processed, before it continues. It's only processing the sub messages from the splitter which
happens concurrently. When parallel processing is enabled, then the Camel routing engin will continue processing using
last used thread from the parallel thread pool. However, if you want to use the original thread that called the
splitter, then make sure to enable the synchronous option as well. In parallel processing mode, you may want to also
synchronous = true to force this EIP to process the sub-tasks using the upper bounds of the thread-pool. If using
synchronous = false then Camel will allow its reactive routing engine to use as many threads as possible, which may be
available due to sub-tasks using other thread-pools such as CompletableFuture.runAsync or others. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="synchronous" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether synchronous processing should be strictly used. When enabled then the same thread is used to continue
routing after the split is complete, even if parallel processing is enabled. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="streaming" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
When in streaming mode, then the splitter splits the original message on-demand, and each split message is processed one
by one. This reduces memory usage as the splitter do not split all the messages first, but then we do not know the total
size, and therefore the org.apache.camel.Exchange#SPLIT_SIZE is empty. In non-streaming mode (default) the splitter will
split each message first, to know the total size, and then process each message one by one. This requires to keep all
the split messages in memory and therefore requires more memory. The total size is provided in the
org.apache.camel.Exchange#SPLIT_SIZE header. The streaming mode also affects the aggregation behavior. If enabled then
Camel will process replies out-of-order, e.g. in the order they come back. If disabled, Camel will process replies in
the same order as the messages was split. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="stopOnException" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Will now stop further processing if an exception or failure occurred during processing of an org.apache.camel.Exchange
and the caused exception will be thrown. Will also stop if processing the exchange failed (has a fault message) or an
exception was thrown and handled by the error handler (such as using onException). In all situations the splitter will
stop further processing. This is the same behavior as in pipeline, which is used by the routing engine. The default
behavior is to not stop but continue processing till the end. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a total timeout specified in millis, when using parallel processing. If the Splitter hasn't been able to split and
process all the sub messages within the given timeframe, then the timeout triggers and the Splitter breaks out and
continues. Notice if you provide a TimeoutAwareAggregationStrategy then the timeout method is invoked before breaking
out. If the timeout is reached with running tasks still remaining, certain tasks for which it is difficult for Camel to
shut down in a graceful manner may continue to run. So use this option with a bit of care. Default value: 0
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom Thread Pool to be used for parallel processing. Notice if you set this option, then parallel processing
is automatically implied, and you do not have to enable that option as well.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onPrepare" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses the Processor when preparing the org.apache.camel.Exchange to be sent. This can be used to deep-clone messages that
should be sent, or any custom logic needed before the exchange is sent.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="shareUnitOfWork" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Shares the org.apache.camel.spi.UnitOfWork with the parent and each of the sub messages. Splitter will by default not
share unit of work between the parent exchange and each split exchange. This means each split exchange has its own
individual unit of work. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="stepDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="stopDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="templatedRouteDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="parameter" type="tns:templatedRouteParameterDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Adds an input parameter of the template to build the route.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="bean" type="tns:beanFactoryDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Adds a local bean as input of the template to build the route.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="routeTemplateRef" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the id of the route template to use to build the route.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="routeId" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the id of the route built from the route template.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="prefixId" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets a prefix to use for all node ids (not route id).
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="templatedRouteParameterDefinition">
    <xs:sequence/>
    <xs:attribute name="name" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the parameter.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="value" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The value of the parameter.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="templatedRoutesDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:templatedRoute"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="threadPoolProfileDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="defaultProfile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether this profile is the default thread pool profile. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="poolSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the core pool size.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxPoolSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum pool size.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keepAliveTime" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the keep alive time for idle threads in the pool.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeUnit" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the time unit to use for keep alive time By default SECONDS is used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxQueueSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum number of tasks in the work queue. Use -1 or Integer.MAX_VALUE for an unbounded queue.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowCoreThreadTimeOut" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether idle core threads is allowed to timeout and therefore can shrink the pool size below the core pool size Is by
default true. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rejectedPolicy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the handler for tasks which cannot be executed by the thread pool.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="threadsDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom thread pool.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="poolSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the core pool size.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxPoolSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum pool size.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="keepAliveTime" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the keep alive time for idle threads.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timeUnit" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the keep alive time unit. By default SECONDS is used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxQueueSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum number of tasks in the work queue. Use -1 or Integer.MAX_VALUE for an unbounded queue.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowCoreThreadTimeOut" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether idle core threads are allowed to timeout and therefore can shrink the pool size below the core pool size Is by
default false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="threadName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the thread name to use. Default value: Threads
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rejectedPolicy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the handler for tasks which cannot be executed by the thread pool.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="callerRunsWhenRejected" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not to use as caller runs as fallback when a task is rejected being added to the thread pool (when its full).
This is only used as fallback if no rejectedPolicy has been configured, or the thread pool has no configured rejection
handler. Is by default true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="throttleDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:sequence>
          <xs:choice>
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
          <xs:element minOccurs="0" name="correlationExpression" type="tns:expressionSubElementDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The expression used to calculate the correlation key to use for throttle grouping. The Exchange which has the same
correlation key is throttled together.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="mode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the throttling mode to one of the available modes enumerated in ThrottlingMode. Default value: TotalRequests
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a custom thread pool (ScheduledExecutorService) by the throttler.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="asyncDelayed" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enables asynchronous delay which means the thread will not block while delaying. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="callerRunsWhenRejected" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not the caller should run the task when it was rejected by the thread pool. Is by default true. Default
value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="rejectExecution" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether or not throttler throws the ThrottlerRejectedExecutionException when the exchange exceeds the request limit Is
by default false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="timePeriodMillis" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the time period during which the maximum request count is valid for. Default value: 1000
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="throwExceptionDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="message" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To create a new exception instance and use the given message as caused message (supports simple language).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="exceptionType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The class of the exception to create using the message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to the exception instance to lookup from the registry to throw.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="toDefinition">
    <xs:complexContent>
      <xs:extension base="tns:sendDefinition">
        <xs:sequence/>
        <xs:attribute name="variableSend" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable as the source for the message body to send. This makes it handy to use variables for user data and to
easily control what data to use for sending and receiving. Important: When using send variable then the message body is
taken from this variable instead of the current message, however the headers from the message will still be used as
well. In other words, the variable is used instead of the message body, but everything else is as usual.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store the received message body (only body, not headers). This makes it handy to use variables for
user data and to easily control what data to use for sending and receiving. Important: When using receive variable then
the received body is stored only in this variable and not on the current message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="pattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the optional ExchangePattern used to invoke this endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="toDynamicDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence/>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The uri of the endpoint to send to. The uri can be dynamic computed using the
org.apache.camel.language.simple.SimpleLanguage expression.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableSend" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable as the source for the message body to send. This makes it handy to use variables for user data and to
easily control what data to use for sending and receiving. Important: When using send variable then the message body is
taken from this variable instead of the current message, however the headers from the message will still be used as
well. In other words, the variable is used instead of the message body, but everything else is as usual.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable as the source for the message body to send. This makes it handy to use variables for user data and to
easily control what data to use for sending and receiving. Important: When using send variable then the message body is
taken from this variable instead of the current Message , however the headers from the Message will still be used as
well. In other words, the variable is used instead of the message body, but everything else is as usual.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="pattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the optional ExchangePattern used to invoke this endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="cacheSize" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum size used by the org.apache.camel.spi.ProducerCache which is used to cache and reuse producers when
using this recipient list, when uris are reused. Beware that when using dynamic endpoints then it affects how well the
cache can be utilized. If each dynamic endpoint is unique then its best to turn off caching by setting this to -1, which
allows Camel to not cache both the producers and endpoints; they are regarded as prototype scoped and will be stopped
and discarded after use. This reduces memory usage as otherwise producers/endpoints are stored in memory in the caches.
However if there are a high degree of dynamic endpoints that have been used before, then it can benefit to use the cache
to reuse both producers and endpoints and therefore the cache size can be set accordingly or rely on the default size
(1000). If there is a mix of unique and used before dynamic endpoints, then setting a reasonable cache size can help
reduce memory usage to avoid storing too many non frequent used producers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="ignoreInvalidEndpoint" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to ignore invalid endpoint URIs and skip sending the message. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowOptimisedComponents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow components to optimise toD if they are org.apache.camel.spi.SendDynamicAware . Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="autoStartComponents" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to auto startup components when toD is starting up. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="tokenizerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:langChain4jCharacterTokenizer"/>
            <xs:element ref="tns:langChain4jLineTokenizer"/>
            <xs:element ref="tns:langChain4jParagraphTokenizer"/>
            <xs:element ref="tns:langChain4jSentenceTokenizer"/>
            <xs:element ref="tns:langChain4jWordTokenizer"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="langChain4JCharacterTokenizerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:langChain4jTokenizerImplementation">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="langChain4jTokenizerImplementation">
    <xs:complexContent>
      <xs:extension base="tns:tokenizerImplementation">
        <xs:sequence/>
        <xs:attribute name="tokenizerType" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the tokenizer type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxTokens" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum number of tokens on each segment.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="maxOverlap" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the maximum number of tokens that can overlap in each segment.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="tokenizerImplementation">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="langChain4JLineTokenizerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:langChain4jTokenizerImplementation">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="langChain4JParagraphTokenizerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:langChain4jTokenizerImplementation">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="langChain4JSentenceTokenizerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:langChain4jTokenizerImplementation">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="langChain4JWordTokenizerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:langChain4jTokenizerImplementation">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="transactedDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to use for lookup the policy in the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="transformDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="fromType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
From type used in data type transformation.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="toType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To type used as a target data type in the transformation.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="tryDefinition">
    <xs:complexContent>
      <xs:extension base="tns:output">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:aggregate"/>
            <xs:element ref="tns:bean"/>
            <xs:element ref="tns:doCatch"/>
            <xs:element ref="tns:choice"/>
            <xs:element ref="tns:circuitBreaker"/>
            <xs:element ref="tns:claimCheck"/>
            <xs:element ref="tns:convertBodyTo"/>
            <xs:element ref="tns:convertHeaderTo"/>
            <xs:element ref="tns:convertVariableTo"/>
            <xs:element ref="tns:delay"/>
            <xs:element ref="tns:dynamicRouter"/>
            <xs:element ref="tns:enrich"/>
            <xs:element ref="tns:filter"/>
            <xs:element ref="tns:doFinally"/>
            <xs:element ref="tns:idempotentConsumer"/>
            <xs:element ref="tns:intercept"/>
            <xs:element ref="tns:interceptFrom"/>
            <xs:element ref="tns:interceptSendToEndpoint"/>
            <xs:element ref="tns:kamelet"/>
            <xs:element ref="tns:loadBalance"/>
            <xs:element ref="tns:log"/>
            <xs:element ref="tns:loop"/>
            <xs:element ref="tns:marshal"/>
            <xs:element ref="tns:multicast"/>
            <xs:element ref="tns:onCompletion"/>
            <xs:element ref="tns:onException"/>
            <xs:element ref="tns:pausable"/>
            <xs:element ref="tns:pipeline"/>
            <xs:element ref="tns:policy"/>
            <xs:element ref="tns:poll"/>
            <xs:element ref="tns:pollEnrich"/>
            <xs:element ref="tns:process"/>
            <xs:element ref="tns:recipientList"/>
            <xs:element ref="tns:removeHeader"/>
            <xs:element ref="tns:removeHeaders"/>
            <xs:element ref="tns:removeProperties"/>
            <xs:element ref="tns:removeProperty"/>
            <xs:element ref="tns:removeVariable"/>
            <xs:element ref="tns:resequence"/>
            <xs:element ref="tns:resumable"/>
            <xs:element ref="tns:rollback"/>
            <xs:element ref="tns:route"/>
            <xs:element ref="tns:routingSlip"/>
            <xs:element ref="tns:saga"/>
            <xs:element ref="tns:sample"/>
            <xs:element ref="tns:script"/>
            <xs:element ref="tns:setBody"/>
            <xs:element ref="tns:setExchangePattern"/>
            <xs:element ref="tns:setHeader"/>
            <xs:element ref="tns:setHeaders"/>
            <xs:element ref="tns:setProperty"/>
            <xs:element ref="tns:setVariable"/>
            <xs:element ref="tns:setVariables"/>
            <xs:element ref="tns:sort"/>
            <xs:element ref="tns:split"/>
            <xs:element ref="tns:step"/>
            <xs:element ref="tns:stop"/>
            <xs:element ref="tns:threads"/>
            <xs:element ref="tns:throttle"/>
            <xs:element ref="tns:throwException"/>
            <xs:element ref="tns:to"/>
            <xs:element ref="tns:toD"/>
            <xs:element ref="tns:tokenizer"/>
            <xs:element ref="tns:transacted"/>
            <xs:element ref="tns:transform"/>
            <xs:element ref="tns:doTry"/>
            <xs:element ref="tns:unmarshal"/>
            <xs:element ref="tns:validate"/>
            <xs:element ref="tns:wireTap"/>
            <xs:element ref="tns:serviceCall"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="unmarshalDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:asn1"/>
            <xs:element ref="tns:avro"/>
            <xs:element ref="tns:barcode"/>
            <xs:element ref="tns:base64"/>
            <xs:element ref="tns:beanio"/>
            <xs:element ref="tns:bindy"/>
            <xs:element ref="tns:cbor"/>
            <xs:element ref="tns:crypto"/>
            <xs:element ref="tns:csv"/>
            <xs:element ref="tns:custom"/>
            <xs:element ref="tns:dfdl"/>
            <xs:element ref="tns:fhirJson"/>
            <xs:element ref="tns:fhirXml"/>
            <xs:element ref="tns:flatpack"/>
            <xs:element ref="tns:fury"/>
            <xs:element ref="tns:grok"/>
            <xs:element ref="tns:gzipDeflater"/>
            <xs:element ref="tns:hl7"/>
            <xs:element ref="tns:ical"/>
            <xs:element ref="tns:jacksonXml"/>
            <xs:element ref="tns:jaxb"/>
            <xs:element ref="tns:json"/>
            <xs:element ref="tns:jsonApi"/>
            <xs:element ref="tns:lzf"/>
            <xs:element ref="tns:mimeMultipart"/>
            <xs:element ref="tns:parquetAvro"/>
            <xs:element ref="tns:protobuf"/>
            <xs:element ref="tns:rss"/>
            <xs:element ref="tns:smooks"/>
            <xs:element ref="tns:soap"/>
            <xs:element ref="tns:swiftMt"/>
            <xs:element ref="tns:swiftMx"/>
            <xs:element ref="tns:syslog"/>
            <xs:element ref="tns:tarFile"/>
            <xs:element ref="tns:thrift"/>
            <xs:element ref="tns:tidyMarkup"/>
            <xs:element ref="tns:univocityCsv"/>
            <xs:element ref="tns:univocityFixed"/>
            <xs:element ref="tns:univocityTsv"/>
            <xs:element ref="tns:xmlSecurity"/>
            <xs:element ref="tns:pgp"/>
            <xs:element ref="tns:yaml"/>
            <xs:element ref="tns:zipDeflater"/>
            <xs:element ref="tns:zipFile"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="variableSend" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable as the source for the message body to send. This makes it handy to use variables for user data and to
easily control what data to use for sending and receiving. Important: When using send variable then the message body is
taken from this variable instead of the current message, however the headers from the message will still be used as
well. In other words, the variable is used instead of the message body, but everything else is as usual.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="variableReceive" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a variable to store the received message body (only body, not headers). This makes it handy to use variables for
user data and to easily control what data to use for sending and receiving. Important: When using receive variable then
the received body is stored only in this variable and not on the current message.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowNullBody" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Indicates whether null is allowed as value of a body to unmarshall. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="validateDefinition">
    <xs:complexContent>
      <xs:extension base="tns:processorDefinition">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
        <xs:attribute name="predicateExceptionFactory" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The bean id of custom PredicateExceptionFactory to use for creating the exception when the validation fails. By default,
Camel will throw PredicateValidationException. By using a custom factory you can control which exception to throw
instead.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:simpleType name="valueDefinition">
    <xs:restriction base="xs:string"/>
  </xs:simpleType>
  <xs:complexType name="wireTapDefinition">
    <xs:complexContent>
      <xs:extension base="tns:toDynamicDefinition">
        <xs:sequence/>
        <xs:attribute name="copy" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses a copy of the original exchange. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="dynamicUri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the uri is dynamic or static. If the uri is dynamic then the simple language is used to evaluate a dynamic uri
to use as the wire-tap destination, for each incoming message. This works similar to how the toD EIP pattern works. If
static then the uri is used as-is as the wire-tap destination. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="onPrepare" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses the Processor when preparing the org.apache.camel.Exchange to be sent. This can be used to deep-clone messages that
should be sent, or any custom logic needed before the exchange is sent.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="executorService" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Uses a custom thread pool.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="applicationDefinition">
    <xs:complexContent>
      <xs:extension base="tns:beansDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="beansDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="component-scan" type="tns:componentScanDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Component scanning that can auto-discover Camel route builders from the classpath.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="bean" type="tns:beanFactoryDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
List of bean.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:any maxOccurs="unbounded" minOccurs="0" namespace="##other" processContents="skip"/>
      <xs:element minOccurs="0" name="dataFormats">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
List of data formats.
]]>
          </xs:documentation>
        </xs:annotation>
        <xs:complexType>
          <xs:sequence>
            <xs:element maxOccurs="unbounded" minOccurs="0" name="dataFormat" type="tns:dataFormat">
              <xs:annotation>
                <xs:documentation xml:lang="en">
<![CDATA[
Camel data formats.
]]>
                </xs:documentation>
              </xs:annotation>
            </xs:element>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:restConfiguration"/>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:rest"/>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:routeConfiguration"/>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:routeTemplate"/>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:templatedRoute"/>
      <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:route"/>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="componentScanDefinition">
    <xs:sequence/>
    <xs:attribute name="base-package" type="xs:string"/>
  </xs:complexType>
  <xs:complexType name="restConfigurationDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="componentProperty" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Allows to configure as many additional properties for the rest component in use.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="endpointProperty" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Allows to configure as many additional properties for the rest endpoint in use.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="consumerProperty" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Allows to configure as many additional properties for the rest consumer in use.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="dataFormatProperty" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Allows to configure as many additional properties for the data formats in use. For example set property prettyPrint to
true to have json outputted in pretty mode. The properties can be prefixed to denote the option is only for either JSON
or XML and for either the IN or the OUT. The prefixes are: json.in. json.out. xml.in. xml.out. For example a key with
value xml.out.mustBeJAXBElement is only for the XML data format for the outgoing. A key without a prefix is a common key
for all situations.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="apiProperty" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Allows to configure as many additional properties for the api documentation. For example set property api.title to my
cool stuff.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="corsHeaders" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Allows to configure custom CORS headers.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="component" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The Camel Rest component to use for the REST transport (consumer), such as netty-http, jetty, servlet, undertow. If no
component has been explicit configured, then Camel will lookup if there is a Camel component that integrates with the
Rest DSL, or if a org.apache.camel.spi.RestConsumerFactory is registered in the registry. If either one is found, then
that is being used.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="apiComponent" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The name of the Camel component to use as the REST API. If no API Component has been explicit configured, then Camel
will lookup if there is a Camel component responsible for servicing and generating the REST API documentation, or if a
org.apache.camel.spi.RestApiProcessorFactory is registered in the registry. If either one is found, then that is being
used.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="producerComponent" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the name of the Camel component to use as the REST producer.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="scheme" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The scheme to use for exposing the REST service. Usually http or https is supported. The default value is http.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="host" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The hostname to use for exposing the REST service.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="port" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The port number to use for exposing the REST service. Notice if you use servlet component then the port number
configured here does not apply, as the port number in use is the actual port number the servlet component is using. eg
if using Apache Tomcat its the tomcat http port, if using Apache Karaf its the HTTP service in Karaf that uses port 8181
by default etc. Though in those situations setting the port number here, allows tooling and JMX to know the port number,
so its recommended to set the port number to the number that the servlet engine uses.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="apiHost" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
To use a specific hostname for the API documentation (such as swagger or openapi) This can be used to override the
generated host with this configured hostname.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="useXForwardHeaders" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to use X-Forward headers to set host etc. for OpenApi. This may be needed in special cases involving
reverse-proxy and networking going from HTTP to HTTPS etc. Then the proxy can send X-Forward headers (X-Forwarded-Proto)
that influences the host names in the OpenAPI schema that camel-openapi-java generates from Rest DSL routes. Default
value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="producerApiDoc" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the location of the api document the REST producer will use to validate the REST uri and query parameters are valid
accordingly to the api document. The location of the api document is loaded from classpath by default, but you can use
file: or http: to refer to resources to load from file or http url.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="contextPath" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets a leading context-path the REST services will be using. This can be used when using components such as
camel-servlet where the deployed web application is deployed using a context-path. Or for components such as camel-jetty
or camel-netty-http that includes a HTTP server.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="apiContextPath" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets a leading context-path the REST API will be using. This can be used when using components such as camel-servlet
where the deployed web application is deployed using a context-path.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="apiContextRouteId" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the route id to use for the route that services the REST API. The route will by default use an auto assigned route
id.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="apiVendorExtension" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether vendor extension is enabled in the Rest APIs. If enabled then Camel will include additional information as
vendor extension (eg keys starting with x-) such as route ids, class names etc. Not all 3rd party API gateways and tools
supports vendor-extensions when importing your API docs. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="hostNameResolver" type="tns:restHostNameResolver">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
If no hostname has been explicit configured, then this resolver is used to compute the hostname the REST service will be
using. Default value: allLocalIp
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="bindingMode" type="tns:restBindingMode">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the binding mode to use. The default value is off. Default value: off
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="bindingPackageScan" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Package name to use as base (offset) for classpath scanning of POJO classes are located when using binding mode is
enabled for JSon or XML. Multiple package names can be separated by comma.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="skipBindingOnErrorCode" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to skip binding on output if there is a custom HTTP error code header. This allows to build custom error
messages that do not bind to json / xml etc, as success messages otherwise will do. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="clientRequestValidation" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable validation of the client request to check: 1) Content-Type header matches what the Rest DSL consumes;
returns HTTP Status 415 if validation error. 2) Accept header matches what the Rest DSL produces; returns HTTP Status
406 if validation error. 3) Missing required data (query parameters, HTTP headers, body); returns HTTP Status 400 if
validation error. 4) Parsing error of the message body (JSon, XML or Auto binding mode must be enabled); returns HTTP
Status 400 if validation error. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="enableCORS" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable CORS headers in the HTTP response. The default value is false. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="enableNoContentResponse" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Whether to return HTTP 204 with an empty body when a response contains an empty JSON object or XML root object. The
default value is false. Default value: false
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="inlineRoutes" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Inline routes in rest-dsl which are linked using direct endpoints. Each service in Rest DSL is an individual route,
meaning that you would have at least two routes per service (rest-dsl, and the route linked from rest-dsl). By inlining
(default) allows Camel to optimize and inline this as a single route, however this requires to use direct endpoints,
which must be unique per service. If a route is not using direct endpoint then the rest-dsl is not inlined, and will
become an individual route. This option is default true. Default value: true
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="jsonDataFormat" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Name of specific json data format to use. By default jackson will be used. Important: This option is only for setting a
custom name of the data format, not to refer to an existing data format instance.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="xmlDataFormat" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Name of specific XML data format to use. By default jaxb will be used. Important: This option is only for setting a
custom name of the data format, not to refer to an existing data format instance.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="restPropertyDefinition">
    <xs:sequence/>
    <xs:attribute name="key" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Property key.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="value" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Property value.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="restDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element minOccurs="0" ref="tns:openApi"/>
          <xs:element minOccurs="0" ref="tns:securityDefinitions"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="securityRequirements" type="tns:securityDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Sets the security requirement(s) for all endpoints.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:delete"/>
            <xs:element ref="tns:get"/>
            <xs:element ref="tns:head"/>
            <xs:element ref="tns:patch"/>
            <xs:element ref="tns:post"/>
            <xs:element ref="tns:put"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="path" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Path of the rest service, such as /foo.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="consumes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the content type what the REST service consumes (accept as input), such as application/xml or
application/json. This option will override what may be configured on a parent level.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="produces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the content type what the REST service produces (uses for output), such as application/xml or application/json
This option will override what may be configured on a parent level.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to disable this REST service from the route during build time. Once an REST service has been disabled then it
cannot be enabled later at runtime. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bindingMode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the binding mode to use. This option will override what may be configured on a parent level The default value is
auto. Default value: off
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipBindingOnErrorCode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to skip binding on output if there is a custom HTTP error code header. This allows to build custom error
messages that do not bind to json / xml etc, as success messages otherwise will do. This option will override what may
be configured on a parent level. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientRequestValidation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable validation of the client request to check: 1) Content-Type header matches what the Rest DSL consumes;
returns HTTP Status 415 if validation error. 2) Accept header matches what the Rest DSL produces; returns HTTP Status
406 if validation error. 3) Missing required data (query parameters, HTTP headers, body); returns HTTP Status 400 if
validation error. 4) Parsing error of the message body (JSon, XML or Auto binding mode must be enabled); returns HTTP
Status 400 if validation error. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableCORS" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable CORS headers in the HTTP response. This option will override what may be configured on a parent level
The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableNoContentResponse" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to return HTTP 204 with an empty body when a response contains an empty JSON object or XML root object. The
default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="apiDocs" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to include or exclude this rest operation in API documentation. This option will override what may be configured
on a parent level. The default value is true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="tag" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To configure a special tag for the operations within this rest definition.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="openApiDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="specification" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Path to the OpenApi specification file.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="apiContextPath" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable api-doc that exposes the OpenAPI specification file as a REST endpoint. This allows clients to obtain
the specification from the running Camel application.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="routeId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the id of the route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to disable all the REST services from the OpenAPI contract from the route during build time. Once an REST
service has been disabled then it cannot be enabled later at runtime. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="missingOperation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to fail, ignore or return a mock response for OpenAPI operations that are not mapped to a corresponding route.
Default value: fail
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="mockIncludePattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Used for inclusive filtering of mock data from directories. The pattern is using Ant-path style pattern. Multiple
patterns can be specified separated by comma. Default value: classpath:camel-mock/**
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="restSecuritiesDefinition">
    <xs:sequence>
      <xs:choice maxOccurs="unbounded" minOccurs="0">
        <xs:element ref="tns:apiKey"/>
        <xs:element ref="tns:basicAuth"/>
        <xs:element ref="tns:bearerToken"/>
        <xs:element ref="tns:oauth2"/>
        <xs:element ref="tns:openIdConnect"/>
        <xs:element ref="tns:mutualTLS"/>
      </xs:choice>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="apiKeyDefinition">
    <xs:complexContent>
      <xs:extension base="tns:restSecurityDefinition">
        <xs:sequence/>
        <xs:attribute name="name" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The name of the header or query parameter to be used.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use header as the location of the API key. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inQuery" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use query parameter as the location of the API key. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inCookie" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To use a cookie as the location of the API key. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="restSecurityDefinition">
    <xs:sequence/>
    <xs:attribute name="key" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Key used to refer to this security definition.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="description" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
A short description for security scheme.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="basicAuthDefinition">
    <xs:complexContent>
      <xs:extension base="tns:restSecurityDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="bearerTokenDefinition">
    <xs:complexContent>
      <xs:extension base="tns:restSecurityDefinition">
        <xs:sequence/>
        <xs:attribute name="format" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A hint to the client to identify how the bearer token is formatted.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="oAuth2Definition">
    <xs:complexContent>
      <xs:extension base="tns:restSecurityDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="scopes" type="tns:restPropertyDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
The available scopes for an OAuth2 security scheme.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="authorizationUrl" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The authorization URL to be used for this flow. This SHOULD be in the form of a URL. Required for implicit and access
code flows.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="tokenUrl" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The token URL to be used for this flow. This SHOULD be in the form of a URL. Required for password, application, and
access code flows.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="refreshUrl" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The URL to be used for obtaining refresh tokens. This MUST be in the form of a URL.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="flow" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The flow used by the OAuth2 security scheme. Valid values are implicit, password, application or accessCode.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="openIdConnectDefinition">
    <xs:complexContent>
      <xs:extension base="tns:restSecurityDefinition">
        <xs:sequence/>
        <xs:attribute name="url" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
OpenId Connect URL to discover OAuth2 configuration values.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="mutualTLSDefinition">
    <xs:complexContent>
      <xs:extension base="tns:restSecurityDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="securityDefinition">
    <xs:sequence/>
    <xs:attribute name="key" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Key used to refer to this security definition.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="scopes" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The scopes to allow (separate multiple scopes by comma).
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType abstract="true" name="verbDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:param"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:responseMessage"/>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:security"/>
          <xs:element ref="tns:to"/>
        </xs:sequence>
        <xs:attribute name="path" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The path mapping URIs of this REST operation such as /{id}.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="consumes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the content type what the REST service consumes (accept as input), such as application/xml or
application/json. This option will override what may be configured on a parent level.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="produces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the content type what the REST service produces (uses for output), such as application/xml or application/json
This option will override what may be configured on a parent level.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="disabled" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to disable this REST service from the route during build time. Once an REST service has been disabled then it
cannot be enabled later at runtime. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="type" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the class name to use for binding from input to POJO for the incoming data This option will override what may be
configured on a parent level. The name of the class of the input data. Append a to the end of the name if you want the
input to be an array type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="outType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the class name to use for binding from POJO to output for the outgoing data This option will override what may be
configured on a parent level The name of the class of the input data. Append a to the end of the name if you want the
input to be an array type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bindingMode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the binding mode to use. This option will override what may be configured on a parent level The default value is
off. Default value: off
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipBindingOnErrorCode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to skip binding on output if there is a custom HTTP error code header. This allows to build custom error
messages that do not bind to json / xml etc, as success messages otherwise will do. This option will override what may
be configured on a parent level. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientRequestValidation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable validation of the client request to check: 1) Content-Type header matches what the Rest DSL consumes;
returns HTTP Status 415 if validation error. 2) Accept header matches what the Rest DSL produces; returns HTTP Status
406 if validation error. 3) Missing required data (query parameters, HTTP headers, body); returns HTTP Status 400 if
validation error. 4) Parsing error of the message body (JSon, XML or Auto binding mode must be enabled); returns HTTP
Status 400 if validation error. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableCORS" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable CORS headers in the HTTP response. This option will override what may be configured on a parent level
The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableNoContentResponse" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to return HTTP 204 with an empty body when a response contains an empty JSON object or XML root object. The
default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="apiDocs" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to include or exclude this rest operation in API documentation. The default value is true. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="deprecated" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Marks this rest operation as deprecated in OpenApi documentation. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="streamCache" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether stream caching is enabled on this rest operation. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="routeId" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the id of the route.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="paramDefinition">
    <xs:sequence>
      <xs:element minOccurs="0" name="allowableValues">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter list of allowable values (enum).
]]>
          </xs:documentation>
        </xs:annotation>
        <xs:complexType>
          <xs:sequence>
            <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:value"/>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="examples" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter examples.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="name" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter name.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="type" type="tns:restParamType" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter type. Default value: path
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="description" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter description.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="defaultValue" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter default value.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="required" type="xs:boolean">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter required flag. Default value: true
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="collectionFormat" type="tns:collectionFormat">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter collection format. Default value: csv
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="arrayType" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter array type. Required if data type is array. Describes the type of items in the array. Default value:
string
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="dataType" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter data type. Default value: string
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="dataFormat" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter data format.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="responseMessageDefinition">
    <xs:sequence>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="header" type="tns:responseHeaderDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Adds a response header.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
      <xs:element maxOccurs="unbounded" minOccurs="0" name="examples" type="tns:restPropertyDefinition">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Examples of response messages.
]]>
          </xs:documentation>
        </xs:annotation>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="code" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The response code such as a HTTP status code. Default value: 200
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="message" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The response message (description).
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="responseModel" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
The response model.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="responseHeaderDefinition">
    <xs:sequence>
      <xs:element minOccurs="0" name="allowableValues">
        <xs:annotation>
          <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter list of allowable values.
]]>
          </xs:documentation>
        </xs:annotation>
        <xs:complexType>
          <xs:sequence>
            <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:value"/>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
    </xs:sequence>
    <xs:attribute name="name" type="xs:string" use="required">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Name of the parameter. This option is mandatory.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="description" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Description of the parameter.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="collectionFormat" type="tns:collectionFormat">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter collection format. Default value: csv
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="arrayType" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter array type. Required if data type is array. Describes the type of items in the array. Default value:
string
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="dataType" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the header data type. Default value: string
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="dataFormat" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the parameter data format.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="example" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Sets the example.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="blacklistServiceCallServiceFilterConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceFilterConfiguration">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="servers" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Sets the server blacklist. Each entry can be a list of servers separated by comma in the format:
servicehost:port,servicehost2:port,servicehost3:port.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="serviceCallServiceFilterConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="serviceCallConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="properties" type="tns:propertyDefinition">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Set client properties to use. These properties are specific to what service call implementation are in use. For example
if using a different one, then the client properties are defined according to the specific service in use.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="cachingServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:consulServiceDiscovery"/>
            <xs:element ref="tns:dnsServiceDiscovery"/>
            <xs:element ref="tns:kubernetesServiceDiscovery"/>
            <xs:element ref="tns:combinedServiceDiscovery"/>
            <xs:element ref="tns:staticServiceDiscovery"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="timeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the time the services will be retained. Default value: 60
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="units" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the time unit for the timeout. Default value: SECONDS
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="serviceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="consulServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence/>
        <xs:attribute name="url" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The Consul agent URL.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="datacenter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The data center.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="aclToken" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the ACL token to be used with Consul.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="userName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the username to be used for basic authentication.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="password" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the password to be used for basic authentication.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="connectTimeoutMillis" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Connect timeout for OkHttpClient.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="readTimeoutMillis" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Read timeout for OkHttpClient.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="writeTimeoutMillis" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Write timeout for OkHttpClient.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="blockSeconds" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The seconds to wait for a watch event, default 10 seconds. Default value: 10
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="dnsServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence/>
        <xs:attribute name="proto" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The transport protocol of the desired service. Default value: _tcp
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="domain" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The domain name;.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="kubernetesServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence/>
        <xs:attribute name="lookup" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
How to perform service lookup. Possible values: client, dns, environment. When using client, then the client queries the
kubernetes master to obtain a list of active pods that provides the service, and then random (or round robin) select a
pod. When using dns the service name is resolved as name.namespace.svc.dnsDomain. When using dnssrv the service name is
resolved with SRV query for _._...svc... When using environment then environment variables are used to lookup the
service. By default environment is used. Default value: environment
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="dnsDomain" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the DNS domain to use for DNS lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="portName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Port Name to use for DNS/DNSSRV lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="portProtocol" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Port Protocol to use for DNS/DNSSRV lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="namespace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the namespace to use. Will by default use namespace from the ENV variable KUBERNETES_MASTER.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="apiVersion" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the API version when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="masterUrl" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the URL to the master when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="username" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the username for authentication when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="password" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the password for authentication when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="oauthToken" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the OAUTH token for authentication (instead of username/password) when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="caCertData" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Certificate Authority data when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="caCertFile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Certificate Authority data that are loaded from the file when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientCertData" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Client Certificate data when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientCertFile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Client Certificate data that are loaded from the file when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientKeyAlgo" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Client Keystore algorithm, such as RSA when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientKeyData" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Client Keystore data when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientKeyFile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Client Keystore data that are loaded from the file when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientKeyPassphrase" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the Client Keystore passphrase when using client lookup.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="trustCerts" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets whether to turn on trust certificate check when using client lookup. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="combinedServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:consulServiceDiscovery"/>
            <xs:element ref="tns:dnsServiceDiscovery"/>
            <xs:element ref="tns:kubernetesServiceDiscovery"/>
            <xs:element ref="tns:staticServiceDiscovery"/>
            <xs:element ref="tns:cachingServiceDiscovery"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="staticServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" name="servers" type="xs:string">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Sets the server list. Each entry can be a list of servers separated by comma in the format:
servicehost:port,servicehost2:port,servicehost3:port.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="combinedServiceCallServiceFilterConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceFilterConfiguration">
        <xs:sequence>
          <xs:choice maxOccurs="unbounded" minOccurs="0">
            <xs:element ref="tns:blacklistServiceFilter"/>
            <xs:element ref="tns:customServiceFilter"/>
            <xs:element ref="tns:healthyServiceFilter"/>
            <xs:element ref="tns:passThroughServiceFilter"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="customServiceCallServiceFilterConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceFilterConfiguration">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference of a ServiceFilter.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="healthyServiceCallServiceFilterConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceFilterConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="passThroughServiceCallServiceFilterConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceFilterConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="defaultServiceCallServiceLoadBalancerConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceLoadBalancerConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="serviceCallServiceLoadBalancerConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="serviceCallConfigurationDefinition">
    <xs:complexContent>
      <xs:extension base="tns:identifiedType">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:cachingServiceDiscovery"/>
            <xs:element ref="tns:combinedServiceDiscovery"/>
            <xs:element ref="tns:consulServiceDiscovery"/>
            <xs:element ref="tns:dnsServiceDiscovery"/>
            <xs:element ref="tns:kubernetesServiceDiscovery"/>
            <xs:element ref="tns:staticServiceDiscovery"/>
            <xs:element ref="tns:zookeeperServiceDiscovery"/>
          </xs:choice>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:blacklistServiceFilter"/>
            <xs:element ref="tns:combinedServiceFilter"/>
            <xs:element ref="tns:customServiceFilter"/>
            <xs:element ref="tns:healthyServiceFilter"/>
            <xs:element ref="tns:passThroughServiceFilter"/>
          </xs:choice>
          <xs:element minOccurs="0" ref="tns:defaultLoadBalancer"/>
          <xs:element minOccurs="0" name="expression" type="tns:serviceCallExpressionConfiguration">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Configures the Expression using the given configuration.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The uri of the endpoint to send to. The uri can be dynamic computed using the simple language expression.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="component" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The component to use. Default value: http
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="pattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the optional ExchangePattern used to invoke this endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serviceDiscoveryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceDiscovery to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serviceFilterRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceFilter to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serviceChooserRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceChooser to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="loadBalancerRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceLoadBalancer to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="expressionRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set a reference to a custom Expression to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="zooKeeperServiceCallServiceDiscoveryConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallServiceDiscoveryConfiguration">
        <xs:sequence/>
        <xs:attribute name="nodes" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
A comma separate list of servers to connect to in the form host:port.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="namespace" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
As ZooKeeper is a shared space, users of a given cluster should stay within a pre-defined namespace. If a namespace is
set here, all paths will get pre-pended with the namespace.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="reconnectBaseSleepTime" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Initial amount of time to wait between retries.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="reconnectMaxSleepTime" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Max time in ms to sleep on each retry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="reconnectMaxRetries" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Max number of times to retry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="sessionTimeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Session timeout.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="connectionTimeout" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Connection timeout.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="basePath" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the base path to store in ZK.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="serviceCallExpressionConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallConfiguration">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:expressionDefinition"/>
            <xs:element ref="tns:csimple"/>
            <xs:element ref="tns:constant"/>
            <xs:element ref="tns:datasonnet"/>
            <xs:element ref="tns:exchangeProperty"/>
            <xs:element ref="tns:groovy"/>
            <xs:element ref="tns:header"/>
            <xs:element ref="tns:hl7terser"/>
            <xs:element ref="tns:java"/>
            <xs:element ref="tns:js"/>
            <xs:element ref="tns:joor"/>
            <xs:element ref="tns:jq"/>
            <xs:element ref="tns:jsonpath"/>
            <xs:element ref="tns:language"/>
            <xs:element ref="tns:method"/>
            <xs:element ref="tns:mvel"/>
            <xs:element ref="tns:ognl"/>
            <xs:element ref="tns:python"/>
            <xs:element ref="tns:ref"/>
            <xs:element ref="tns:simple"/>
            <xs:element ref="tns:spel"/>
            <xs:element ref="tns:tokenize"/>
            <xs:element ref="tns:variable"/>
            <xs:element ref="tns:wasm"/>
            <xs:element ref="tns:xtokenize"/>
            <xs:element ref="tns:xpath"/>
            <xs:element ref="tns:xquery"/>
          </xs:choice>
        </xs:sequence>
        <xs:attribute name="hostHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The header that holds the service host information, default ServiceCallConstants.SERVICE_HOST. Default value:
CamelServiceCallServiceHost
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="portHeader" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The header that holds the service port information, default ServiceCallConstants.SERVICE_PORT. Default value:
CamelServiceCallServicePort
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="serviceCallDefinition">
    <xs:complexContent>
      <xs:extension base="tns:noOutputDefinition">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:cachingServiceDiscovery"/>
            <xs:element ref="tns:combinedServiceDiscovery"/>
            <xs:element ref="tns:consulServiceDiscovery"/>
            <xs:element ref="tns:dnsServiceDiscovery"/>
            <xs:element ref="tns:kubernetesServiceDiscovery"/>
            <xs:element ref="tns:staticServiceDiscovery"/>
            <xs:element ref="tns:zookeeperServiceDiscovery"/>
          </xs:choice>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:blacklistServiceFilter"/>
            <xs:element ref="tns:combinedServiceFilter"/>
            <xs:element ref="tns:customServiceFilter"/>
            <xs:element ref="tns:healthyServiceFilter"/>
            <xs:element ref="tns:passThroughServiceFilter"/>
          </xs:choice>
          <xs:element minOccurs="0" ref="tns:defaultLoadBalancer"/>
          <xs:element minOccurs="0" name="expression" type="tns:serviceCallExpressionConfiguration">
            <xs:annotation>
              <xs:documentation xml:lang="en">
<![CDATA[
Configures the Expression using the given configuration.
]]>
              </xs:documentation>
            </xs:annotation>
          </xs:element>
        </xs:sequence>
        <xs:attribute name="name" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the name of the service to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The uri of the endpoint to send to. The uri can be dynamic computed using the
org.apache.camel.language.simple.SimpleLanguage expression.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="component" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The component to use. Default value: http
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="pattern" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the optional ExchangePattern used to invoke this endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="configurationRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Refers to a ServiceCall configuration to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serviceDiscoveryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceDiscovery to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serviceFilterRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceFilter to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="serviceChooserRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceChooser to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="loadBalancerRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets a reference to a custom ServiceLoadBalancer to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="expressionRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set a reference to a custom Expression to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType final="extension restriction" name="serviceCallDefinitionConstants">
    <xs:sequence/>
  </xs:complexType>
  <xs:complexType name="serviceCallServiceChooserConfiguration">
    <xs:complexContent>
      <xs:extension base="tns:serviceCallConfiguration">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="dataFormatsDefinition">
    <xs:sequence>
      <xs:choice maxOccurs="unbounded" minOccurs="0">
        <xs:element ref="tns:asn1"/>
        <xs:element ref="tns:avro"/>
        <xs:element ref="tns:barcode"/>
        <xs:element ref="tns:base64"/>
        <xs:element ref="tns:beanio"/>
        <xs:element ref="tns:bindy"/>
        <xs:element ref="tns:cbor"/>
        <xs:element ref="tns:crypto"/>
        <xs:element ref="tns:csv"/>
        <xs:element ref="tns:custom"/>
        <xs:element ref="tns:fhirJson"/>
        <xs:element ref="tns:fhirXml"/>
        <xs:element ref="tns:flatpack"/>
        <xs:element ref="tns:fury"/>
        <xs:element ref="tns:grok"/>
        <xs:element ref="tns:gzipDeflater"/>
        <xs:element ref="tns:hl7"/>
        <xs:element ref="tns:ical"/>
        <xs:element ref="tns:jacksonXml"/>
        <xs:element ref="tns:jaxb"/>
        <xs:element ref="tns:json"/>
        <xs:element ref="tns:jsonApi"/>
        <xs:element ref="tns:lzf"/>
        <xs:element ref="tns:mimeMultipart"/>
        <xs:element ref="tns:parquetAvro"/>
        <xs:element ref="tns:pgp"/>
        <xs:element ref="tns:protobuf"/>
        <xs:element ref="tns:rss"/>
        <xs:element ref="tns:smooks"/>
        <xs:element ref="tns:soap"/>
        <xs:element ref="tns:swiftMt"/>
        <xs:element ref="tns:swiftMx"/>
        <xs:element ref="tns:syslog"/>
        <xs:element ref="tns:tarFile"/>
        <xs:element ref="tns:thrift"/>
        <xs:element ref="tns:tidyMarkup"/>
        <xs:element ref="tns:univocityCsv"/>
        <xs:element ref="tns:univocityFixed"/>
        <xs:element ref="tns:univocityTsv"/>
        <xs:element ref="tns:xmlSecurity"/>
        <xs:element ref="tns:yaml"/>
        <xs:element ref="tns:zipDeflater"/>
        <xs:element ref="tns:zipFile"/>
      </xs:choice>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="cSimpleExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="typedExpressionDefinition">
    <xs:simpleContent>
      <xs:extension base="tns:expression">
        <xs:attribute name="resultType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the class of the result type (type from output).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="constantExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="datasonnetExpression">
    <xs:simpleContent>
      <xs:extension base="tns:singleInputTypedExpressionDefinition">
        <xs:attribute name="bodyMediaType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The String representation of the message's body MediaType.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="outputMediaType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The String representation of the MediaType to output.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="singleInputTypedExpressionDefinition">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition">
        <xs:attribute name="source" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Source to use, instead of message body. You can prefix with variable:, header:, or property: to specify kind of source.
Otherwise, the source is assumed to be a variable. Use empty or null to use default source, which is the message body.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="exchangePropertyExpression">
    <xs:simpleContent>
      <xs:extension base="tns:expression"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="groovyExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="headerExpression">
    <xs:simpleContent>
      <xs:extension base="tns:expression"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="hl7TerserExpression">
    <xs:simpleContent>
      <xs:extension base="tns:singleInputTypedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="javaExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition">
        <xs:attribute name="preCompile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the expression should be pre compiled once during initialization phase. If this is turned off, then the
expression is reloaded and compiled on each evaluation. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="singleQuotes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether single quotes can be used as replacement for double quotes. This is convenient when you need to work with
strings inside strings. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="javaScriptExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="joorExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition">
        <xs:attribute name="preCompile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the expression should be pre compiled once during initialization phase. If this is turned off, then the
expression is reloaded and compiled on each evaluation. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="singleQuotes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether single quotes can be used as replacement for double quotes. This is convenient when you need to work with
strings inside strings. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="jqExpression">
    <xs:simpleContent>
      <xs:extension base="tns:singleInputTypedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="jsonPathExpression">
    <xs:simpleContent>
      <xs:extension base="tns:singleInputTypedExpressionDefinition">
        <xs:attribute name="suppressExceptions" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to suppress exceptions such as PathNotFoundException. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowSimple" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow in inlined Simple exceptions in the JSONPath expression. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="allowEasyPredicate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to allow using the easy predicate parser to pre-parse predicates. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="writeAsString" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to write the output of each row/element as a JSON String value instead of a Map/POJO value. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="unpackArray" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to unpack a single element json-array into an object. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="option" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To configure additional options on JSONPath. Multiple values can be separated by comma.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="languageExpression">
    <xs:simpleContent>
      <xs:extension base="tns:expression">
        <xs:attribute name="language" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The name of the language to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="methodCallExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition">
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to an existing bean (bean id) to lookup in the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="method" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of method to call.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="beanType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Class name (fully qualified) of the bean to use Will lookup in registry and if there is a single instance of the same
type, then the existing bean is used, otherwise a new bean is created (requires a default no-arg constructor).
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="scope" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Scope of bean. When using singleton scope (default) the bean is created or looked up only once and reused for the
lifetime of the endpoint. The bean should be thread-safe in case concurrent threads is calling the bean at the same
time. When using request scope the bean is created or looked up once per request (exchange). This can be used if you
want to store state on a bean while processing a request and you want to call the same bean instance multiple times
while processing the request. The bean does not have to be thread-safe as the instance is only called from the same
request. When using prototype scope, then the bean will be looked up or created per call. However in case of lookup then
this is delegated to the bean registry such as Spring or CDI (if in use), which depends on their configuration can act
as either singleton or prototype scope. So when using prototype scope then this depends on the bean registry
implementation. Default value: Singleton
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="validate" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to validate the bean has the configured method. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="mvelExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="namespaceAwareExpression">
    <xs:simpleContent>
      <xs:extension base="tns:singleInputTypedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="ognlExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="pythonExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="refExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="simpleExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="spELExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="tokenizerExpression">
    <xs:simpleContent>
      <xs:extension base="tns:singleInputTypedExpressionDefinition">
        <xs:attribute name="token" type="xs:string" use="required">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The (start) token to use as tokenizer, for example you can use the new line token. You can use simple language as the
token to support dynamic tokens.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="endToken" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The end token to use as tokenizer if using start/end token pairs. You can use simple language as the token to support
dynamic tokens.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="inheritNamespaceTagName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To inherit namespaces from a root/parent tag name when using XML You can use simple language as the tag name to support
dynamic names.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="regex" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
If the token is a regular expression pattern. The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="xml" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether the input is XML messages. This option must be set to true if working with XML payloads. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="includeTokens" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to include the tokens in the parts when using pairs. When including tokens then the endToken property must also
be configured (to use pair mode). The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="group" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To group N parts together, for example to split big files into chunks of 1000 lines. You can use simple language as the
group to support dynamic group sizes.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="groupDelimiter" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the delimiter to use when grouping. If this has not been set then token will be used as the delimiter.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipFirst" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To skip the very first element. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="variableExpression">
    <xs:simpleContent>
      <xs:extension base="tns:expression"/>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="wasmExpression">
    <xs:simpleContent>
      <xs:extension base="tns:typedExpressionDefinition">
        <xs:attribute name="module" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the module (the distributable, loadable, and executable unit of code in WebAssembly) resource that provides the
expression function.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="xmlTokenizerExpression">
    <xs:simpleContent>
      <xs:extension base="tns:namespaceAwareExpression">
        <xs:attribute name="mode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The extraction mode. The available extraction modes are: i - injecting the contextual namespace bindings into the
extracted token (default) w - wrapping the extracted token in its ancestor context u - unwrapping the extracted token to
its child content t - extracting the text content of the specified element. Default value: i
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="group" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To group N parts together.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="xPathExpression">
    <xs:simpleContent>
      <xs:extension base="tns:namespaceAwareExpression">
        <xs:attribute name="documentType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Name of class for document type The default value is org.w3c.dom.Document.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="resultQName" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the output type supported by XPath. Default value: NODESET
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="saxon" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to use Saxon. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="factoryRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
References to a custom XPathFactory to lookup in the registry.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="objectModel" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
The XPath object model to use.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="logNamespaces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to log namespaces which can assist during troubleshooting. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="threadSafety" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable thread-safety for the returned result of the xpath expression. This applies to when using NODESET as
the result type, and the returned set has multiple elements. In this situation there can be thread-safety issues if you
process the NODESET concurrently such as from a Camel Splitter EIP in parallel processing mode. This option prevents
concurrency issues by doing defensive copies of the nodes. It is recommended to turn this option on if you are using
camel-saxon or Saxon in your application. Saxon has thread-safety issues which can be prevented by turning this option
on. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="preCompile" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable pre-compiling the xpath expression during initialization phase. pre-compile is enabled by default.
This can be used to turn off, for example in cases the compilation phase is desired at the starting phase, such as if
the application is ahead of time compiled (for example with camel-quarkus) which would then load the xpath factory of
the built operating system, and not a JVM runtime. Default value: true
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="xQueryExpression">
    <xs:simpleContent>
      <xs:extension base="tns:namespaceAwareExpression">
        <xs:attribute name="configurationRef" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Reference to a saxon configuration instance in the registry to use for xquery (requires camel-saxon). This may be needed
to add custom functions to a saxon configuration, so these custom functions can be used in xquery expressions.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:simpleContent>
  </xs:complexType>
  <xs:complexType name="deleteDefinition">
    <xs:complexContent>
      <xs:extension base="tns:verbDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="getDefinition">
    <xs:complexContent>
      <xs:extension base="tns:verbDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="headDefinition">
    <xs:complexContent>
      <xs:extension base="tns:verbDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="patchDefinition">
    <xs:complexContent>
      <xs:extension base="tns:verbDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="postDefinition">
    <xs:complexContent>
      <xs:extension base="tns:verbDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="putDefinition">
    <xs:complexContent>
      <xs:extension base="tns:verbDefinition">
        <xs:sequence/>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="restBindingDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence/>
        <xs:attribute name="consumes" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the content type what the REST service consumes (accept as input), such as application/xml or
application/json.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="produces" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
To define the content type what the REST service produces (uses for output), such as application/xml or
application/json.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="bindingMode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the binding mode to use. The default value is off. Default value: off
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="type" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the class name to use for binding from input to POJO for the incoming data The name of the class of the input data.
Append a to the end of the name if you want the input to be an array type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="outType" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the class name to use for binding from POJO to output for the outgoing data The name of the class of the input
data. Append a to the end of the name if you want the input to be an array type.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="skipBindingOnErrorCode" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to skip binding on output if there is a custom HTTP error code header. This allows to build custom error
messages that do not bind to json / xml etc, as success messages otherwise will do. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="clientRequestValidation" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable validation of the client request to check: 1) Content-Type header matches what the Rest DSL consumes;
returns HTTP Status 415 if validation error. 2) Accept header matches what the Rest DSL produces; returns HTTP Status
406 if validation error. 3) Missing required data (query parameters, HTTP headers, body); returns HTTP Status 400 if
validation error. 4) Parsing error of the message body (JSon, XML or Auto binding mode must be enabled); returns HTTP
Status 400 if validation error. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableCORS" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to enable CORS headers in the HTTP response. The default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="enableNoContentResponse" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Whether to return HTTP 204 with an empty body when a response contains an empty JSON object or XML root object. The
default value is false. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="component" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Sets the component name that this definition will apply to.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="restsDefinition">
    <xs:complexContent>
      <xs:extension base="tns:optionalIdentifiedDefinition">
        <xs:sequence>
          <xs:element maxOccurs="unbounded" minOccurs="0" ref="tns:rest"/>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="customTransformerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:transformer">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set a bean reference of the Transformer.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="className" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set a class name of the Transformer.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="transformer">
    <xs:sequence/>
    <xs:attribute name="scheme" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Set a scheme name supported by the transformer. If you specify 'csv', the transformer will be picked up for all of 'csv'
from/to Java transformation. Note that the scheme matching is performed only when no exactly matched transformer exists.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="name" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Set the transformer name under which the transformer gets referenced when specifying the input/output data type on
routes. If you specify a transformer name that matches a data type scheme like 'csv' the transformer will be picked up
for all of 'csv:' from/to Java transformation. Note that the scheme matching is performed only when no exactly matched
transformer exists.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="fromType" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Set the 'from' data type name. If you specify 'xml:XYZ', the transformer will be picked up if source type is 'xml:XYZ'.
If you specify just 'xml', the transformer matches with all of 'xml' source type like 'xml:ABC' or 'xml:DEF'.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
    <xs:attribute name="toType" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Set the 'to' data type name. If you specify 'json:XYZ', the transformer will be picked up if destination type is
'json:XYZ'. If you specify just 'json', the transformer matches with all of 'json' destination type like 'json:ABC' or
'json:DEF'.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="dataFormatTransformerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:transformer">
        <xs:sequence>
          <xs:choice minOccurs="0">
            <xs:element ref="tns:asn1"/>
            <xs:element ref="tns:avro"/>
            <xs:element ref="tns:barcode"/>
            <xs:element ref="tns:base64"/>
            <xs:element ref="tns:beanio"/>
            <xs:element ref="tns:bindy"/>
            <xs:element ref="tns:cbor"/>
            <xs:element ref="tns:crypto"/>
            <xs:element ref="tns:csv"/>
            <xs:element ref="tns:custom"/>
            <xs:element ref="tns:fhirJson"/>
            <xs:element ref="tns:fhirXml"/>
            <xs:element ref="tns:flatpack"/>
            <xs:element ref="tns:fury"/>
            <xs:element ref="tns:grok"/>
            <xs:element ref="tns:gzipDeflater"/>
            <xs:element ref="tns:hl7"/>
            <xs:element ref="tns:ical"/>
            <xs:element ref="tns:jacksonXml"/>
            <xs:element ref="tns:jaxb"/>
            <xs:element ref="tns:json"/>
            <xs:element ref="tns:jsonApi"/>
            <xs:element ref="tns:lzf"/>
            <xs:element ref="tns:mimeMultipart"/>
            <xs:element ref="tns:parquetAvro"/>
            <xs:element ref="tns:protobuf"/>
            <xs:element ref="tns:rss"/>
            <xs:element ref="tns:smooks"/>
            <xs:element ref="tns:soap"/>
            <xs:element ref="tns:swiftMt"/>
            <xs:element ref="tns:swiftMx"/>
            <xs:element ref="tns:syslog"/>
            <xs:element ref="tns:tarFile"/>
            <xs:element ref="tns:thrift"/>
            <xs:element ref="tns:tidyMarkup"/>
            <xs:element ref="tns:univocityCsv"/>
            <xs:element ref="tns:univocityFixed"/>
            <xs:element ref="tns:univocityTsv"/>
            <xs:element ref="tns:xmlSecurity"/>
            <xs:element ref="tns:pgp"/>
            <xs:element ref="tns:yaml"/>
            <xs:element ref="tns:zipDeflater"/>
            <xs:element ref="tns:zipFile"/>
          </xs:choice>
        </xs:sequence>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="endpointTransformerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:transformer">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the reference of the Endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the URI of the Endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="loadTransformerDefinition">
    <xs:complexContent>
      <xs:extension base="tns:transformer">
        <xs:sequence/>
        <xs:attribute name="packageScan" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the classpath location to scan for annotated transformers.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="defaults" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Enable loading of default transformers. Default value: false
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="transformersDefinition">
    <xs:sequence>
      <xs:choice maxOccurs="unbounded" minOccurs="0">
        <xs:element ref="tns:dataFormatTransformer"/>
        <xs:element ref="tns:endpointTransformer"/>
        <xs:element ref="tns:loadTransformer"/>
        <xs:element ref="tns:customTransformer"/>
      </xs:choice>
    </xs:sequence>
  </xs:complexType>
  <xs:complexType name="customValidatorDefinition">
    <xs:complexContent>
      <xs:extension base="tns:validator">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set a bean reference of the Validator.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="className" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set a class name of the Validator.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType abstract="true" name="validator">
    <xs:sequence/>
    <xs:attribute name="type" type="xs:string">
      <xs:annotation>
        <xs:documentation xml:lang="en">
<![CDATA[
Set the data type name. If you specify 'xml:XYZ', the validator will be picked up if message type is 'xml:XYZ'. If you
specify just 'xml', the validator matches with all of 'xml' message type like 'xml:ABC' or 'xml:DEF'.
]]>
        </xs:documentation>
      </xs:annotation>
    </xs:attribute>
  </xs:complexType>
  <xs:complexType name="endpointValidatorDefinition">
    <xs:complexContent>
      <xs:extension base="tns:validator">
        <xs:sequence/>
        <xs:attribute name="ref" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the reference of the Endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
        <xs:attribute name="uri" type="xs:string">
          <xs:annotation>
            <xs:documentation xml:lang="en">
<![CDATA[
Set the URI of the Endpoint.
]]>
            </xs:documentation>
          </xs:annotation>
        </xs:attribute>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="predicateValidatorDefinition">
    <xs:complexContent>
      <xs:extension base="tns:validator">
        <xs:choice>
          <xs:element ref="tns:expressionDefinition"/>
          <xs:element ref="tns:csimple"/>
          <xs:element ref="tns:constant"/>
          <xs:element ref="tns:datasonnet"/>
          <xs:element ref="tns:exchangeProperty"/>
          <xs:element ref="tns:groovy"/>
          <xs:element ref="tns:header"/>
          <xs:element ref="tns:hl7terser"/>
          <xs:element ref="tns:java"/>
          <xs:element ref="tns:js"/>
          <xs:element ref="tns:joor"/>
          <xs:element ref="tns:jq"/>
          <xs:element ref="tns:jsonpath"/>
          <xs:element ref="tns:language"/>
          <xs:element ref="tns:method"/>
          <xs:element ref="tns:mvel"/>
          <xs:element ref="tns:ognl"/>
          <xs:element ref="tns:python"/>
          <xs:element ref="tns:ref"/>
          <xs:element ref="tns:simple"/>
          <xs:element ref="tns:spel"/>
          <xs:element ref="tns:tokenize"/>
          <xs:element ref="tns:variable"/>
          <xs:element ref="tns:wasm"/>
          <xs:element ref="tns:xtokenize"/>
          <xs:element ref="tns:xpath"/>
          <xs:element ref="tns:xquery"/>
        </xs:choice>
      </xs:extension>
    </xs:complexContent>
  </xs:complexType>
  <xs:complexType name="validatorsDefinition">
    <xs:sequence>
      <xs:choice maxOccurs="unbounded" minOccurs="0">
        <xs:element ref="tns:endpointValidator"/>
        <xs:element ref="tns:predicateValidator"/>
        <xs:element ref="tns:customValidator"/>
      </xs:choice>
    </xs:sequence>
  </xs:complexType>
  <xs:simpleType name="beanScope">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Singleton"/>
      <xs:enumeration value="Request"/>
      <xs:enumeration value="Prototype"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="exchangePattern">
    <xs:restriction base="xs:string">
      <xs:enumeration value="InOnly"/>
      <xs:enumeration value="InOut"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="loggingLevel">
    <xs:restriction base="xs:string">
      <xs:enumeration value="TRACE"/>
      <xs:enumeration value="DEBUG"/>
      <xs:enumeration value="INFO"/>
      <xs:enumeration value="WARN"/>
      <xs:enumeration value="ERROR"/>
      <xs:enumeration value="OFF"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="managementStatisticsLevel">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Extended"/>
      <xs:enumeration value="Default"/>
      <xs:enumeration value="RoutesOnly"/>
      <xs:enumeration value="Off"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="shutdownRoute">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Default"/>
      <xs:enumeration value="Defer"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="shutdownRunningTask">
    <xs:restriction base="xs:string">
      <xs:enumeration value="CompleteCurrentTaskOnly"/>
      <xs:enumeration value="CompleteAllTasks"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="startupSummaryLevel">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Verbose"/>
      <xs:enumeration value="Default"/>
      <xs:enumeration value="Brief"/>
      <xs:enumeration value="Oneline"/>
      <xs:enumeration value="Off"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="typeConverterExists">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Override"/>
      <xs:enumeration value="Ignore"/>
      <xs:enumeration value="Fail"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="waitForTaskToComplete">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Never"/>
      <xs:enumeration value="IfReplyExpected"/>
      <xs:enumeration value="Always"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="claimCheckOperation">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Get"/>
      <xs:enumeration value="GetAndRemove"/>
      <xs:enumeration value="Set"/>
      <xs:enumeration value="Push"/>
      <xs:enumeration value="Pop"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="avroLibrary">
    <xs:restriction base="xs:string">
      <xs:enumeration value="ApacheAvro"/>
      <xs:enumeration value="Jackson"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="jsonLibrary">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Fastjson"/>
      <xs:enumeration value="Gson"/>
      <xs:enumeration value="Jackson"/>
      <xs:enumeration value="Jsonb"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="protobufLibrary">
    <xs:restriction base="xs:string">
      <xs:enumeration value="GoogleProtobuf"/>
      <xs:enumeration value="Jackson"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="yamlLibrary">
    <xs:restriction base="xs:string">
      <xs:enumeration value="SnakeYAML"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="onCompletionMode">
    <xs:restriction base="xs:string">
      <xs:enumeration value="AfterConsumer"/>
      <xs:enumeration value="BeforeConsumer"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="sagaCompletionMode">
    <xs:restriction base="xs:string">
      <xs:enumeration value="AUTO"/>
      <xs:enumeration value="MANUAL"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="sagaPropagation">
    <xs:restriction base="xs:string">
      <xs:enumeration value="REQUIRED"/>
      <xs:enumeration value="REQUIRES_NEW"/>
      <xs:enumeration value="MANDATORY"/>
      <xs:enumeration value="SUPPORTS"/>
      <xs:enumeration value="NOT_SUPPORTED"/>
      <xs:enumeration value="NEVER"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="throttlingMode">
    <xs:restriction base="xs:string">
      <xs:enumeration value="TotalRequests"/>
      <xs:enumeration value="ConcurrentRequests"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="restHostNameResolver">
    <xs:restriction base="xs:string">
      <xs:enumeration value="allLocalIp"/>
      <xs:enumeration value="localIp"/>
      <xs:enumeration value="localHostName"/>
      <xs:enumeration value="none"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="restBindingMode">
    <xs:restriction base="xs:string">
      <xs:enumeration value="auto"/>
      <xs:enumeration value="off"/>
      <xs:enumeration value="json"/>
      <xs:enumeration value="xml"/>
      <xs:enumeration value="json_xml"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="restParamType">
    <xs:restriction base="xs:string">
      <xs:enumeration value="body"/>
      <xs:enumeration value="formData"/>
      <xs:enumeration value="header"/>
      <xs:enumeration value="path"/>
      <xs:enumeration value="query"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="collectionFormat">
    <xs:restriction base="xs:string">
      <xs:enumeration value="csv"/>
      <xs:enumeration value="ssv"/>
      <xs:enumeration value="tsv"/>
      <xs:enumeration value="pipes"/>
      <xs:enumeration value="multi"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="bindyType">
    <xs:restriction base="xs:string">
      <xs:enumeration value="Csv"/>
      <xs:enumeration value="Fixed"/>
      <xs:enumeration value="KeyValue"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="yamlTypeFilterType">
    <xs:restriction base="xs:string">
      <xs:enumeration value="type"/>
      <xs:enumeration value="regexp"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="option">
    <xs:restriction base="xs:string">
      <xs:enumeration value="DEFAULT_PATH_LEAF_TO_NULL"/>
      <xs:enumeration value="ALWAYS_RETURN_LIST"/>
      <xs:enumeration value="AS_PATH_LIST"/>
      <xs:enumeration value="SUPPRESS_EXCEPTIONS"/>
      <xs:enumeration value="REQUIRE_PROPERTIES"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="scope">
    <xs:restriction base="xs:string">
      <xs:enumeration value="SINGLETON"/>
      <xs:enumeration value="REQUEST"/>
      <xs:enumeration value="PROTOTYPE"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="mode">
    <xs:restriction base="xs:string">
      <xs:enumeration value="INJECTING_CONTEXTUAL_NAMESPACE_BINDINGS"/>
      <xs:enumeration value="WRAPPING_EXTRACTED_TOKEN"/>
      <xs:enumeration value="UNWRAPPING_EXTRACTED_TOKEN"/>
      <xs:enumeration value="EXTRACTING_TEXT_CONTENT"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="resultQName">
    <xs:restriction base="xs:string">
      <xs:enumeration value="NUMBER"/>
      <xs:enumeration value="STRING"/>
      <xs:enumeration value="BOOLEAN"/>
      <xs:enumeration value="NODESET"/>
      <xs:enumeration value="NODE"/>
    </xs:restriction>
  </xs:simpleType>
  <xs:simpleType name="tokenizerType">
    <xs:restriction base="xs:string">
      <xs:enumeration value="OPEN_AI"/>
      <xs:enumeration value="AZURE"/>
      <xs:enumeration value="QWEN"/>
    </xs:restriction>
  </xs:simpleType>
</xs:schema>