diff --git a/catalog/camel-catalog/src/generated/resources/org/apache/camel/catalog/components/as2.json b/catalog/camel-catalog/src/generated/resources/org/apache/camel/catalog/components/as2.json
index 0988917f675f5..e3408145423d7 100644
--- a/catalog/camel-catalog/src/generated/resources/org/apache/camel/catalog/components/as2.json
+++ b/catalog/camel-catalog/src/generated/resources/org/apache/camel/catalog/components/as2.json
@@ -66,24 +66,30 @@
"exceptionHandler": { "index": 30, "kind": "parameter", "displayName": "Exception Handler", "group": "consumer (advanced)", "label": "consumer,advanced", "required": false, "type": "object", "javaType": "org.apache.camel.spi.ExceptionHandler", "optionalPrefix": "consumer.", "deprecated": false, "autowired": false, "secret": false, "description": "To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored." },
"exchangePattern": { "index": 31, "kind": "parameter", "displayName": "Exchange Pattern", "group": "consumer (advanced)", "label": "consumer,advanced", "required": false, "type": "object", "javaType": "org.apache.camel.ExchangePattern", "enum": [ "InOnly", "InOut" ], "deprecated": false, "autowired": false, "secret": false, "description": "Sets the exchange pattern when the consumer creates an exchange." },
"lazyStartProducer": { "index": 32, "kind": "parameter", "displayName": "Lazy Start Producer", "group": "producer (advanced)", "label": "producer,advanced", "required": false, "type": "boolean", "javaType": "boolean", "deprecated": false, "autowired": false, "secret": false, "defaultValue": false, "description": "Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing." },
- "decryptingPrivateKey": { "index": 33, "kind": "parameter", "displayName": "Decrypting Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to encrypt the EDI message." },
- "encryptingAlgorithm": { "index": 34, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to encrypt EDI message." },
- "encryptingCertificateChain": { "index": 35, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to encrypt EDI message." },
- "hostnameVerifier": { "index": 36, "kind": "parameter", "displayName": "Hostname Verifier", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.HostnameVerifier", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set hostname verifier for SSL session." },
- "signedReceiptMicAlgorithms": { "index": 37, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The list of algorithms, in order of preference, requested to generate a message integrity check (MIC) returned in message disposition notification (MDN). Multiple algorithms can be separated by comma." },
- "signingAlgorithm": { "index": 38, "kind": "parameter", "displayName": "Signing Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to sign EDI message." },
- "signingCertificateChain": { "index": 39, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to sign EDI message." },
- "signingPrivateKey": { "index": 40, "kind": "parameter", "displayName": "Signing Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to sign the EDI message." },
- "sslContext": { "index": 41, "kind": "parameter", "displayName": "Ssl Context", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.SSLContext", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set SSL context for connection to remote server." },
- "validateSigningCertificateChain": { "index": 42, "kind": "parameter", "displayName": "Validate Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Certificates to validate the message's signature against. If not supplied, validation will not take place. Server: validates the received message. Client: not yet implemented, should validate the MDN" }
+ "accessToken": { "index": 33, "kind": "parameter", "displayName": "Access Token", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The access token that is used by the client for bearer authentication." },
+ "decryptingPrivateKey": { "index": 34, "kind": "parameter", "displayName": "Decrypting Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to encrypt the EDI message." },
+ "encryptingAlgorithm": { "index": 35, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to encrypt EDI message." },
+ "encryptingCertificateChain": { "index": 36, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to encrypt EDI message." },
+ "hostnameVerifier": { "index": 37, "kind": "parameter", "displayName": "Hostname Verifier", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.HostnameVerifier", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set hostname verifier for SSL session." },
+ "mdnAccessToken": { "index": 38, "kind": "parameter", "displayName": "Mdn Access Token", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The access token that is used by the server when it sends an async MDN." },
+ "mdnPassword": { "index": 39, "kind": "parameter", "displayName": "Mdn Password", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The password that is used by the server for basic authentication when it sends an async MDN." },
+ "mdnUserName": { "index": 40, "kind": "parameter", "displayName": "Mdn User Name", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The user-name that is used by the server for basic authentication when it sends an async MDN. If options for basic authentication and bearer authentication are both set then basic authentication takes precedence." },
+ "password": { "index": 41, "kind": "parameter", "displayName": "Password", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The password that is used by the client for basic authentication." },
+ "signedReceiptMicAlgorithms": { "index": 42, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The list of algorithms, in order of preference, requested to generate a message integrity check (MIC) returned in message disposition notification (MDN). Multiple algorithms can be separated by comma." },
+ "signingAlgorithm": { "index": 43, "kind": "parameter", "displayName": "Signing Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to sign EDI message." },
+ "signingCertificateChain": { "index": 44, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to sign EDI message." },
+ "signingPrivateKey": { "index": 45, "kind": "parameter", "displayName": "Signing Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to sign the EDI message." },
+ "sslContext": { "index": 46, "kind": "parameter", "displayName": "Ssl Context", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.SSLContext", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set SSL context for connection to remote server." },
+ "userName": { "index": 47, "kind": "parameter", "displayName": "User Name", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The user-name that is used by the client for basic authentication. If options for basic authentication and bearer authentication are both set then basic authentication takes precedence." },
+ "validateSigningCertificateChain": { "index": 48, "kind": "parameter", "displayName": "Validate Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Certificates to validate the message's signature against. If not supplied, validation will not take place. Server: validates the received message. Client: not yet implemented, should validate the MDN" }
},
"apis": {
- "client": { "consumerOnly": false, "producerOnly": true, "description": "Sends EDI Messages over HTTP", "methods": { "send": { "description": "Send ediMessage to trading partner", "signatures": [ "org.apache.hc.core5.http.protocol.HttpCoreContext send(Object ediMessage, String requestUri, String subject, String from, String as2From, String as2To, org.apache.camel.component.as2.api.AS2MessageStructure as2MessageStructure, String ediMessageContentType, String ediMessageCharset, String ediMessageTransferEncoding, org.apache.camel.component.as2.api.AS2SignatureAlgorithm signingAlgorithm, java.security.cert.Certificate[] signingCertificateChain, java.security.PrivateKey signingPrivateKey, org.apache.camel.component.as2.api.AS2CompressionAlgorithm compressionAlgorithm, String dispositionNotificationTo, String signedReceiptMicAlgorithms, org.apache.camel.component.as2.api.AS2EncryptionAlgorithm encryptingAlgorithm, java.security.cert.Certificate[] encryptingCertificateChain, String attachedFileName, String receiptDeliveryOption)" ] } } },
+ "client": { "consumerOnly": false, "producerOnly": true, "description": "Sends EDI Messages over HTTP", "methods": { "send": { "description": "Send ediMessage to trading partner", "signatures": [ "org.apache.hc.core5.http.protocol.HttpCoreContext send(Object ediMessage, String requestUri, String subject, String from, String as2From, String as2To, org.apache.camel.component.as2.api.AS2MessageStructure as2MessageStructure, String ediMessageContentType, String ediMessageCharset, String ediMessageTransferEncoding, org.apache.camel.component.as2.api.AS2SignatureAlgorithm signingAlgorithm, java.security.cert.Certificate[] signingCertificateChain, java.security.PrivateKey signingPrivateKey, org.apache.camel.component.as2.api.AS2CompressionAlgorithm compressionAlgorithm, String dispositionNotificationTo, String signedReceiptMicAlgorithms, org.apache.camel.component.as2.api.AS2EncryptionAlgorithm encryptingAlgorithm, java.security.cert.Certificate[] encryptingCertificateChain, String attachedFileName, String receiptDeliveryOption, String userName, String password, String accessToken)" ] } } },
"receipt": { "consumerOnly": true, "producerOnly": false, "description": "Receives the asynchronous AS2-MDN that is requested by the sender of an AS2 message", "methods": { "receive": { "description": "", "signatures": [ "void receive(String requestUriPattern, org.apache.hc.core5.http.io.HttpRequestHandler handler)" ] } } },
"server": { "consumerOnly": true, "producerOnly": false, "description": "Receives EDI Messages over HTTP", "methods": { "listen": { "description": "", "signatures": [ "void listen(String requestUriPattern, org.apache.hc.core5.http.io.HttpRequestHandler handler)" ] } } }
},
"apiProperties": {
- "client": { "methods": { "send": { "properties": { "as2From": { "index": 0, "kind": "parameter", "displayName": "As2 From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of sender", "optional": false }, "as2MessageStructure": { "index": 1, "kind": "parameter", "displayName": "As2 Message Structure", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2MessageStructure", "enum": [ "PLAIN", "SIGNED", "ENCRYPTED", "SIGNED_ENCRYPTED", "PLAIN_COMPRESSED", "COMPRESSED_SIGNED", "SIGNED_COMPRESSED", "ENCRYPTED_COMPRESSED", "ENCRYPTED_COMPRESSED_SIGNED", "ENCRYPTED_SIGNED_COMPRESSED" ], "deprecated": false, "autowired": false, "secret": false, "description": "The structure of AS2 to send; see AS2MessageStructure", "optional": false }, "as2To": { "index": 2, "kind": "parameter", "displayName": "As2 To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of recipient", "optional": false }, "attachedFileName": { "index": 3, "kind": "parameter", "displayName": "Attached File Name", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The name of the attached file or null if user doesn't want to specify it", "optional": true }, "compressionAlgorithm": { "index": 4, "kind": "parameter", "displayName": "Compression Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2CompressionAlgorithm", "enum": [ "ZLIB" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to compress the message or null if sending EDI message uncompressed", "optional": true }, "dispositionNotificationTo": { "index": 5, "kind": "parameter", "displayName": "Disposition Notification To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "An RFC2822 address to request a receipt or null if no receipt requested", "optional": true }, "ediMessage": { "index": 6, "kind": "parameter", "displayName": "Edi Message", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.lang.Object", "deprecated": false, "autowired": false, "secret": false, "description": "EDI message to transport", "optional": false }, "ediMessageCharset": { "index": 7, "kind": "parameter", "displayName": "Edi Message Charset", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The charset of the EDI message", "optional": true }, "ediMessageContentType": { "index": 8, "kind": "parameter", "displayName": "Edi Message Content Type", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The content type of EDI message", "optional": false }, "ediMessageTransferEncoding": { "index": 9, "kind": "parameter", "displayName": "Edi Message Transfer Encoding", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The transfer encoding used to transport EDI message", "optional": true }, "encryptingAlgorithm": { "index": 10, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "encryptingCertificateChain": { "index": 11, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "from": { "index": 12, "kind": "parameter", "displayName": "From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "RFC2822 address of sender", "optional": false }, "receiptDeliveryOption": { "index": 13, "kind": "parameter", "displayName": "Receipt Delivery Option", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "", "optional": true }, "requestUri": { "index": 14, "kind": "parameter", "displayName": "Request Uri", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Resource location to deliver message", "optional": false }, "signedReceiptMicAlgorithms": { "index": 15, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The senders list of signing algorithms for signing receipt, in preferred order, or null if requesting an unsigned receipt.", "optional": true }, "signingAlgorithm": { "index": 16, "kind": "parameter", "displayName": "Signing Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingCertificateChain": { "index": 17, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingPrivateKey": { "index": 18, "kind": "parameter", "displayName": "Signing Private Key", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "description": "The private key used to sign EDI message", "optional": true }, "subject": { "index": 19, "kind": "parameter", "displayName": "Subject", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Message subject", "optional": false } } } } },
+ "client": { "methods": { "send": { "properties": { "accessToken": { "index": 0, "kind": "parameter", "displayName": "Access Token", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The access token that is used by the client for bearer authentication", "optional": true }, "as2From": { "index": 1, "kind": "parameter", "displayName": "As2 From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of sender", "optional": false }, "as2MessageStructure": { "index": 2, "kind": "parameter", "displayName": "As2 Message Structure", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2MessageStructure", "enum": [ "PLAIN", "SIGNED", "ENCRYPTED", "SIGNED_ENCRYPTED", "PLAIN_COMPRESSED", "COMPRESSED_SIGNED", "SIGNED_COMPRESSED", "ENCRYPTED_COMPRESSED", "ENCRYPTED_COMPRESSED_SIGNED", "ENCRYPTED_SIGNED_COMPRESSED" ], "deprecated": false, "autowired": false, "secret": false, "description": "The structure of AS2 to send; see AS2MessageStructure", "optional": false }, "as2To": { "index": 3, "kind": "parameter", "displayName": "As2 To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of recipient", "optional": false }, "attachedFileName": { "index": 4, "kind": "parameter", "displayName": "Attached File Name", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The name of the attached file or null if user doesn't want to specify it", "optional": true }, "compressionAlgorithm": { "index": 5, "kind": "parameter", "displayName": "Compression Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2CompressionAlgorithm", "enum": [ "ZLIB" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to compress the message or null if sending EDI message uncompressed", "optional": true }, "dispositionNotificationTo": { "index": 6, "kind": "parameter", "displayName": "Disposition Notification To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "An RFC2822 address to request a receipt or null if no receipt requested", "optional": true }, "ediMessage": { "index": 7, "kind": "parameter", "displayName": "Edi Message", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.lang.Object", "deprecated": false, "autowired": false, "secret": false, "description": "EDI message to transport", "optional": false }, "ediMessageCharset": { "index": 8, "kind": "parameter", "displayName": "Edi Message Charset", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The charset of the EDI message", "optional": true }, "ediMessageContentType": { "index": 9, "kind": "parameter", "displayName": "Edi Message Content Type", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The content type of EDI message", "optional": false }, "ediMessageTransferEncoding": { "index": 10, "kind": "parameter", "displayName": "Edi Message Transfer Encoding", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The transfer encoding used to transport EDI message", "optional": true }, "encryptingAlgorithm": { "index": 11, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "encryptingCertificateChain": { "index": 12, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "from": { "index": 13, "kind": "parameter", "displayName": "From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "RFC2822 address of sender", "optional": false }, "password": { "index": 14, "kind": "parameter", "displayName": "Password", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The password that is used by the client for basic authentication", "optional": true }, "receiptDeliveryOption": { "index": 15, "kind": "parameter", "displayName": "Receipt Delivery Option", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The return URL that the message receiver should send an asynchronous MDN to", "optional": true }, "requestUri": { "index": 16, "kind": "parameter", "displayName": "Request Uri", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Resource location to deliver message", "optional": false }, "signedReceiptMicAlgorithms": { "index": 17, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The senders list of signing algorithms for signing receipt, in preferred order, or null if requesting an unsigned receipt.", "optional": true }, "signingAlgorithm": { "index": 18, "kind": "parameter", "displayName": "Signing Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingCertificateChain": { "index": 19, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingPrivateKey": { "index": 20, "kind": "parameter", "displayName": "Signing Private Key", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "description": "The private key used to sign EDI message", "optional": true }, "subject": { "index": 21, "kind": "parameter", "displayName": "Subject", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Message subject", "optional": false }, "userName": { "index": 22, "kind": "parameter", "displayName": "User Name", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The user-name that is used for basic authentication", "optional": true } } } } },
"receipt": { "methods": { "receive": { "properties": { "requestUriPattern": { "index": 0, "kind": "parameter", "displayName": "Request Uri Pattern", "group": "consumer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "", "optional": false } } } } },
"server": { "methods": { "listen": { "properties": { "requestUriPattern": { "index": 0, "kind": "parameter", "displayName": "Request Uri Pattern", "group": "consumer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "", "optional": false } } } } }
}
diff --git a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2AsynchronousMDNManager.java b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2AsynchronousMDNManager.java
index ff68f23afc28a..75a1b76113ab0 100644
--- a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2AsynchronousMDNManager.java
+++ b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2AsynchronousMDNManager.java
@@ -24,6 +24,7 @@
import org.apache.camel.component.as2.api.entity.MultipartMimeEntity;
import org.apache.camel.component.as2.api.protocol.RequestAsynchronousMDN;
+import org.apache.camel.component.as2.api.util.AS2HeaderUtils;
import org.apache.camel.component.as2.api.util.EntityUtils;
import org.apache.camel.util.ObjectHelper;
import org.apache.hc.client5.http.impl.io.ManagedHttpClientConnectionFactory;
@@ -89,14 +90,23 @@ public class AS2AsynchronousMDNManager {
private Certificate[] signingCertificateChain;
@SuppressWarnings("unused")
private PrivateKey signingPrivateKey;
+ private String userName;
+ private String password;
+ private String accessToken;
public AS2AsynchronousMDNManager(String as2Version,
String userAgent,
String senderFQDN,
Certificate[] signingCertificateChain,
- PrivateKey signingPrivateKey) {
+ PrivateKey signingPrivateKey,
+ String userName,
+ String password,
+ String accessToken) {
this.signingCertificateChain = signingCertificateChain;
this.signingPrivateKey = signingPrivateKey;
+ this.userName = userName;
+ this.password = password;
+ this.accessToken = accessToken;
// Build Processor
httpProcessor = HttpProcessorBuilder.create().add(new RequestAsynchronousMDN(as2Version, senderFQDN))
@@ -131,6 +141,7 @@ public HttpCoreContext send(
ClassicHttpRequest request = new BasicClassicHttpRequest("POST", uri);
request.setHeader(AS2Header.CONTENT_TYPE, contentType);
+ AS2HeaderUtils.addAuthorizationHeader(request, userName, password, accessToken);
httpContext.setAttribute(HttpCoreContext.HTTP_REQUEST, request);
multipartMimeEntity.setMainBody(true);
EntityUtils.setMessageEntity(request, multipartMimeEntity);
diff --git a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ClientManager.java b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ClientManager.java
index 7692e6e263641..0aae64f96e6b5 100644
--- a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ClientManager.java
+++ b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ClientManager.java
@@ -29,6 +29,7 @@
import org.apache.camel.component.as2.api.entity.ApplicationPkcs7MimeEnvelopedDataEntity;
import org.apache.camel.component.as2.api.entity.EntityParser;
import org.apache.camel.component.as2.api.entity.MultipartSignedEntity;
+import org.apache.camel.component.as2.api.util.AS2HeaderUtils;
import org.apache.camel.component.as2.api.util.CompressionUtils;
import org.apache.camel.component.as2.api.util.EncryptingUtils;
import org.apache.camel.component.as2.api.util.EntityUtils;
@@ -202,6 +203,10 @@ public AS2ClientManager(AS2ClientConnection as2ClientConnection) {
* if sending EDI message unencrypted
* @param attachedFileName - the name of the attached file or null
if user doesn't want to
* specify it
+ * @param receiptDeliveryOption - the return URL that the message receiver should send an asynchronous MDN to
+ * @param userName - the user-name that is used for basic authentication
+ * @param password - the password that is used by the client for basic authentication
+ * @param accessToken - the access token that is used by the client for bearer authentication
* @return {@link HttpCoreContext} containing request and response used to send EDI
* message
* @throws HttpException when things go wrong.
@@ -226,7 +231,10 @@ public HttpCoreContext send(
AS2EncryptionAlgorithm encryptingAlgorithm,
Certificate[] encryptingCertificateChain,
String attachedFileName,
- String receiptDeliveryOption)
+ String receiptDeliveryOption,
+ String userName,
+ String password,
+ String accessToken)
throws HttpException {
ObjectHelper.notNull(ediMessage, "EDI Message");
@@ -283,6 +291,8 @@ public HttpCoreContext send(
} catch (Exception e) {
throw new HttpException("Failed to create EDI message entity", e);
}
+
+ AS2HeaderUtils.addAuthorizationHeader(request, userName, password, accessToken);
switch (as2MessageStructure) {
case PLAIN: {
plain(applicationEntity, request);
diff --git a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2Header.java b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2Header.java
index bbe8a3f1d7537..9637fda79ec5e 100644
--- a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2Header.java
+++ b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2Header.java
@@ -118,5 +118,9 @@ public interface AS2Header {
* Message Header name for Disposition Notification Options
*/
String DISPOSITION_NOTIFICATION_OPTIONS = "Disposition-Notification-Options";
+ /**
+ * Message Header name for Authorization
+ */
+ String AUTHORIZATION = "Authorization";
}
diff --git a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ServerConnection.java b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ServerConnection.java
index 08976e9b122c3..88c2852511a9b 100644
--- a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ServerConnection.java
+++ b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/AS2ServerConnection.java
@@ -171,7 +171,8 @@ public void run() {
DispositionNotificationMultipartReportEntity.class);
AS2AsynchronousMDNManager asynchronousMDNManager = new AS2AsynchronousMDNManager(
as2Version,
- originServer, serverFqdn, signingCertificateChain, signingPrivateKey);
+ originServer, serverFqdn, signingCertificateChain, signingPrivateKey,
+ userName, password, accessToken);
HttpRequest request = coreContext.getAttribute(HttpCoreContext.HTTP_REQUEST, HttpRequest.class);
AS2SignedDataGenerator gen = ResponseMDN.createSigningGenerator(
@@ -224,6 +225,9 @@ public void run() {
private final PrivateKey decryptingPrivateKey;
private final Certificate[] validateSigningCertificateChain;
private final AS2SignatureAlgorithm signingAlgorithm;
+ private final String userName;
+ private final String password;
+ private final String accessToken;
public AS2ServerConnection(String as2Version,
String originServer,
@@ -235,8 +239,11 @@ public AS2ServerConnection(String as2Version,
PrivateKey decryptingPrivateKey,
String mdnMessageTemplate,
Certificate[] validateSigningCertificateChain,
- SSLContext sslContext)
- throws IOException {
+ SSLContext sslContext,
+ String userName,
+ String password,
+ String accessToken)
+ throws IOException {
this.as2Version = ObjectHelper.notNull(as2Version, "as2Version");
this.originServer = ObjectHelper.notNull(originServer, "userAgent");
this.serverFqdn = ObjectHelper.notNull(serverFqdn, "serverFqdn");
@@ -245,6 +252,9 @@ public AS2ServerConnection(String as2Version,
this.signingPrivateKey = signingPrivateKey;
this.decryptingPrivateKey = decryptingPrivateKey;
this.validateSigningCertificateChain = validateSigningCertificateChain;
+ this.userName = userName;
+ this.password = password;
+ this.accessToken = accessToken;
this.signingAlgorithm = signingAlgorithm;
listenerThread = new RequestListenerThread(
diff --git a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/util/AS2HeaderUtils.java b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/util/AS2HeaderUtils.java
index 93342dc3739b9..0c88ed9e65dc7 100644
--- a/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/util/AS2HeaderUtils.java
+++ b/components/camel-as2/camel-as2-api/src/main/java/org/apache/camel/component/as2/api/util/AS2HeaderUtils.java
@@ -20,10 +20,12 @@
import java.util.BitSet;
import java.util.List;
+import org.apache.camel.component.as2.api.AS2Header;
import org.apache.camel.component.as2.api.entity.Importance;
import org.apache.camel.util.ObjectHelper;
import org.apache.hc.core5.http.Header;
import org.apache.hc.core5.http.HeaderElement;
+import org.apache.hc.core5.http.HttpMessage;
import org.apache.hc.core5.http.NameValuePair;
import org.apache.hc.core5.http.message.BasicHeader;
import org.apache.hc.core5.http.message.MessageSupport;
@@ -162,4 +164,12 @@ public static String getParameterValue(Header[] headers, String headerName, Stri
return null;
}
+ public static void addAuthorizationHeader(HttpMessage message, String userName, String password, String accessToken) {
+ if (userName != null && password != null) {
+ message.addHeader(AS2Header.AUTHORIZATION,
+ ("Basic " + java.util.Base64.getEncoder().encodeToString((userName + ":" + password).getBytes())));
+ } else if (accessToken != null) {
+ message.addHeader(AS2Header.AUTHORIZATION, "Bearer " + accessToken);
+ }
+ }
}
diff --git a/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2MessageTest.java b/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2MessageTest.java
index 8a0678b90da62..b221c6240acdf 100644
--- a/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2MessageTest.java
+++ b/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2MessageTest.java
@@ -98,7 +98,7 @@ public static void setUpOnce() throws Exception {
testServer = new AS2ServerConnection(
AS2_VERSION, "MyServer-HTTP/1.1", SERVER_FQDN, TARGET_PORT, AS2SignatureAlgorithm.SHA256WITHRSA,
certList.toArray(new Certificate[0]), signingKP.getPrivate(), decryptingKP.getPrivate(), MDN_MESSAGE_TEMPLATE,
- VALIDATE_SIGNING_CERTIFICATE_CHAIN, null);
+ VALIDATE_SIGNING_CERTIFICATE_CHAIN, null, null, null, null);
testServer.listen("*", new HttpRequestHandler() {
@Override
public void handle(ClassicHttpRequest request, ClassicHttpResponse response, HttpContext context)
@@ -171,7 +171,8 @@ public void multipartSignedMessageRequestTest() throws Exception {
HttpCoreContext httpContext = clientManager.send(EDI_MESSAGE, REQUEST_URI, SUBJECT, FROM, AS2_NAME, AS2_NAME,
AS2MessageStructure.SIGNED, AS2MediaType.APPLICATION_EDIFACT, null,
null, AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
- null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, "file.txt", null);
+ null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -326,7 +327,8 @@ public void envelopedMessageTest(AS2EncryptionAlgorithm encryptionAlgorithm) thr
AS2MediaType.APPLICATION_EDIFACT, null, null,
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(), null,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, encryptionAlgorithm,
- certList.toArray(new Certificate[0]), "file.txt", null);
+ certList.toArray(new Certificate[0]), "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -383,7 +385,8 @@ public void envelopedAndSignedMessageTest(AS2EncryptionAlgorithm encryptionAlgor
AS2MediaType.APPLICATION_EDIFACT, null, null,
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(), null,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, encryptionAlgorithm,
- certList.toArray(new Certificate[0]), "file.txt", null);
+ certList.toArray(new Certificate[0]), "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -446,7 +449,8 @@ public void signatureVerificationTest() throws Exception {
HttpCoreContext httpContext = clientManager.send(EDI_MESSAGE, REQUEST_URI, SUBJECT, FROM, AS2_NAME, AS2_NAME,
AS2MessageStructure.SIGNED, AS2MediaType.APPLICATION_EDIFACT, null,
null, AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
- null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, "file.txt", null);
+ null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertTrue(request instanceof ClassicHttpRequest, "Request does not contain entity");
@@ -471,7 +475,7 @@ public void asynchronousMdnMessageTest() throws Exception {
AS2AsynchronousMDNManager mdnManager = new AS2AsynchronousMDNManager(
AS2_VERSION, USER_AGENT, CLIENT_FQDN,
- certList.toArray(new X509Certificate[0]), signingKP.getPrivate());
+ certList.toArray(new X509Certificate[0]), signingKP.getPrivate(), null, null, null);
// Create plain edi request message to acknowledge
ApplicationEntity ediEntity = EntityUtils.createEDIEntity(EDI_MESSAGE.getBytes(StandardCharsets.US_ASCII),
@@ -559,7 +563,8 @@ private void signedAndCompressedMessage(Object msg) throws Exception {
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
AS2CompressionAlgorithm.ZLIB,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null,
- null, "file.txt", null);
+ null, "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -632,7 +637,8 @@ private void envelopedAndCompressedMessage(Object msg) throws Exception {
AS2MessageStructure.ENCRYPTED_COMPRESSED,
AS2MediaType.APPLICATION_EDIFACT, null, "base64", null, null, null,
AS2CompressionAlgorithm.ZLIB, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS,
- AS2EncryptionAlgorithm.AES128_CBC, certList.toArray(new Certificate[0]), "file.txt", null);
+ AS2EncryptionAlgorithm.AES128_CBC, certList.toArray(new Certificate[0]), "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -703,7 +709,8 @@ private void compressedAndSignedMessage(Object msg) throws Exception {
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
AS2CompressionAlgorithm.ZLIB,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null,
- null, "file.txt", null);
+ null, "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
verifyRequest(request);
@@ -738,7 +745,8 @@ private void envelopedSignedAndCompressedMessage(Object msg) throws Exception {
AS2MediaType.APPLICATION_EDIFACT, null, null,
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
AS2CompressionAlgorithm.ZLIB, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS,
- AS2EncryptionAlgorithm.AES128_CBC, certList.toArray(new Certificate[0]), "file.txt", null);
+ AS2EncryptionAlgorithm.AES128_CBC, certList.toArray(new Certificate[0]), "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
verifyRequest(request);
@@ -783,7 +791,8 @@ private void envelopedCompressedAndSignedMessage(Object msg) throws Exception {
AS2MediaType.APPLICATION_EDIFACT, null, null,
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
AS2CompressionAlgorithm.ZLIB, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS,
- AS2EncryptionAlgorithm.AES128_CBC, certList.toArray(new Certificate[0]), "file.txt", null);
+ AS2EncryptionAlgorithm.AES128_CBC, certList.toArray(new Certificate[0]), "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
diff --git a/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2UnencryptedMessageTest.java b/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2UnencryptedMessageTest.java
index 0f4e5917d0fc8..127ad285894c7 100644
--- a/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2UnencryptedMessageTest.java
+++ b/components/camel-as2/camel-as2-api/src/test/java/org/apache/camel/component/as2/api/AS2UnencryptedMessageTest.java
@@ -61,7 +61,7 @@ public static void setUpOnce() throws Exception {
testServer = new AS2ServerConnection(
AS2_VERSION, "MyServer-HTTP/1.1", SERVER_FQDN, TARGET_PORT, AS2SignatureAlgorithm.SHA256WITHRSA,
certList.toArray(new Certificate[0]), signingKP.getPrivate(), null, MDN_MESSAGE_TEMPLATE,
- null, null);
+ null, null, null, null, null);
testServer.listen("*", new HttpRequestHandler() {
@Override
public void handle(ClassicHttpRequest request, ClassicHttpResponse response, HttpContext context)
@@ -87,7 +87,7 @@ public void plainEDIMessageRequestTest() throws Exception {
AS2MessageStructure.PLAIN, AS2MediaType.APPLICATION_EDIFACT, null,
null, null, null, null, null,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null,
- "file.txt", null);
+ "file.txt", null, null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -128,7 +128,8 @@ public void compressedMessageRequestTest() throws Exception {
AS2MediaType.APPLICATION_EDIFACT, null, null,
null, null, null, AS2CompressionAlgorithm.ZLIB,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null,
- null, "file.txt", null);
+ null, "file.txt", null,
+ null, null, null);
HttpRequest request = httpContext.getRequest();
assertEquals(METHOD, request.getMethod(), "Unexpected method value");
@@ -175,7 +176,7 @@ public void mdnMessageTest() throws Exception {
AS2MessageStructure.PLAIN, AS2MediaType.APPLICATION_EDIFACT, null,
null, null, null, null, null,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null,
- "file.txt", null);
+ "file.txt", null, null, null, null);
HttpResponse response = httpContext.getResponse();
assertEquals(HttpVersion.HTTP_1_1, response.getVersion(), "Unexpected method value");
diff --git a/components/camel-as2/camel-as2-component/pom.xml b/components/camel-as2/camel-as2-component/pom.xml
index e250c4be8f84b..9beb59bc08819 100644
--- a/components/camel-as2/camel-as2-component/pom.xml
+++ b/components/camel-as2/camel-as2-component/pom.xml
@@ -126,6 +126,9 @@
attachedFileName
receiptDeliveryOption
ediMessageCharset
+ userName
+ password
+ accessToken
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerEndpointConfigurationConfigurer.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerEndpointConfigurationConfigurer.java
index 52e9ee4d83c69..214852589959e 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerEndpointConfigurationConfigurer.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerEndpointConfigurationConfigurer.java
@@ -22,6 +22,7 @@ public class AS2AsyncMDNServerManagerEndpointConfigurationConfigurer extends org
private static final Map ALL_OPTIONS;
static {
Map map = new CaseInsensitiveMap();
+ map.put("AccessToken", java.lang.String.class);
map.put("ApiName", org.apache.camel.component.as2.internal.AS2ApiName.class);
map.put("As2From", java.lang.String.class);
map.put("As2MessageStructure", org.apache.camel.component.as2.api.AS2MessageStructure.class);
@@ -44,8 +45,12 @@ public class AS2AsyncMDNServerManagerEndpointConfigurationConfigurer extends org
map.put("HttpConnectionPoolTtl", java.time.Duration.class);
map.put("HttpConnectionTimeout", java.time.Duration.class);
map.put("HttpSocketTimeout", java.time.Duration.class);
+ map.put("MdnAccessToken", java.lang.String.class);
map.put("MdnMessageTemplate", java.lang.String.class);
+ map.put("MdnPassword", java.lang.String.class);
+ map.put("MdnUserName", java.lang.String.class);
map.put("MethodName", java.lang.String.class);
+ map.put("Password", java.lang.String.class);
map.put("ReceiptDeliveryOption", java.lang.String.class);
map.put("RequestUri", java.lang.String.class);
map.put("RequestUriPattern", java.lang.String.class);
@@ -61,6 +66,7 @@ public class AS2AsyncMDNServerManagerEndpointConfigurationConfigurer extends org
map.put("TargetHostname", java.lang.String.class);
map.put("TargetPortNumber", java.lang.Integer.class);
map.put("UserAgent", java.lang.String.class);
+ map.put("UserName", java.lang.String.class);
map.put("ValidateSigningCertificateChain", java.security.cert.Certificate[].class);
ALL_OPTIONS = map;
}
@@ -69,6 +75,8 @@ public class AS2AsyncMDNServerManagerEndpointConfigurationConfigurer extends org
public boolean configure(CamelContext camelContext, Object obj, String name, Object value, boolean ignoreCase) {
org.apache.camel.component.as2.AS2AsyncMDNServerManagerEndpointConfiguration target = (org.apache.camel.component.as2.AS2AsyncMDNServerManagerEndpointConfiguration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": target.setAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "apiname":
case "apiName": target.setApiName(property(camelContext, org.apache.camel.component.as2.internal.AS2ApiName.class, value)); return true;
case "as2from":
@@ -112,10 +120,17 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "httpConnectionTimeout": target.setHttpConnectionTimeout(property(camelContext, java.time.Duration.class, value)); return true;
case "httpsockettimeout":
case "httpSocketTimeout": target.setHttpSocketTimeout(property(camelContext, java.time.Duration.class, value)); return true;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": target.setMdnAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "mdnmessagetemplate":
case "mdnMessageTemplate": target.setMdnMessageTemplate(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnpassword":
+ case "mdnPassword": target.setMdnPassword(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnusername":
+ case "mdnUserName": target.setMdnUserName(property(camelContext, java.lang.String.class, value)); return true;
case "methodname":
case "methodName": target.setMethodName(property(camelContext, java.lang.String.class, value)); return true;
+ case "password": target.setPassword(property(camelContext, java.lang.String.class, value)); return true;
case "receiptdeliveryoption":
case "receiptDeliveryOption": target.setReceiptDeliveryOption(property(camelContext, java.lang.String.class, value)); return true;
case "requesturi":
@@ -144,6 +159,8 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "targetPortNumber": target.setTargetPortNumber(property(camelContext, java.lang.Integer.class, value)); return true;
case "useragent":
case "userAgent": target.setUserAgent(property(camelContext, java.lang.String.class, value)); return true;
+ case "username":
+ case "userName": target.setUserName(property(camelContext, java.lang.String.class, value)); return true;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": target.setValidateSigningCertificateChain(property(camelContext, java.security.cert.Certificate[].class, value)); return true;
default: return false;
@@ -158,6 +175,8 @@ public Map getAllOptions(Object target) {
@Override
public Class> getOptionType(String name, boolean ignoreCase) {
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return java.lang.String.class;
case "apiname":
case "apiName": return org.apache.camel.component.as2.internal.AS2ApiName.class;
case "as2from":
@@ -201,10 +220,17 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "httpConnectionTimeout": return java.time.Duration.class;
case "httpsockettimeout":
case "httpSocketTimeout": return java.time.Duration.class;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return java.lang.String.class;
case "mdnmessagetemplate":
case "mdnMessageTemplate": return java.lang.String.class;
+ case "mdnpassword":
+ case "mdnPassword": return java.lang.String.class;
+ case "mdnusername":
+ case "mdnUserName": return java.lang.String.class;
case "methodname":
case "methodName": return java.lang.String.class;
+ case "password": return java.lang.String.class;
case "receiptdeliveryoption":
case "receiptDeliveryOption": return java.lang.String.class;
case "requesturi":
@@ -233,6 +259,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "targetPortNumber": return java.lang.Integer.class;
case "useragent":
case "userAgent": return java.lang.String.class;
+ case "username":
+ case "userName": return java.lang.String.class;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return java.security.cert.Certificate[].class;
default: return null;
@@ -243,6 +271,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
org.apache.camel.component.as2.AS2AsyncMDNServerManagerEndpointConfiguration target = (org.apache.camel.component.as2.AS2AsyncMDNServerManagerEndpointConfiguration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return target.getAccessToken();
case "apiname":
case "apiName": return target.getApiName();
case "as2from":
@@ -286,10 +316,17 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "httpConnectionTimeout": return target.getHttpConnectionTimeout();
case "httpsockettimeout":
case "httpSocketTimeout": return target.getHttpSocketTimeout();
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return target.getMdnAccessToken();
case "mdnmessagetemplate":
case "mdnMessageTemplate": return target.getMdnMessageTemplate();
+ case "mdnpassword":
+ case "mdnPassword": return target.getMdnPassword();
+ case "mdnusername":
+ case "mdnUserName": return target.getMdnUserName();
case "methodname":
case "methodName": return target.getMethodName();
+ case "password": return target.getPassword();
case "receiptdeliveryoption":
case "receiptDeliveryOption": return target.getReceiptDeliveryOption();
case "requesturi":
@@ -318,6 +355,8 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "targetPortNumber": return target.getTargetPortNumber();
case "useragent":
case "userAgent": return target.getUserAgent();
+ case "username":
+ case "userName": return target.getUserName();
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return target.getValidateSigningCertificateChain();
default: return null;
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfiguration.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfiguration.java
index 757aa6152d4f7..a773a306f4584 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfiguration.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfiguration.java
@@ -15,10 +15,13 @@
*/
@ApiParams(apiName = "client", producerOnly = true,
description = "Sends EDI Messages over HTTP",
- apiMethods = {@ApiMethod(methodName = "send", description="Send ediMessage to trading partner", signatures={"org.apache.hc.core5.http.protocol.HttpCoreContext send(Object ediMessage, String requestUri, String subject, String from, String as2From, String as2To, org.apache.camel.component.as2.api.AS2MessageStructure as2MessageStructure, String ediMessageContentType, String ediMessageCharset, String ediMessageTransferEncoding, org.apache.camel.component.as2.api.AS2SignatureAlgorithm signingAlgorithm, java.security.cert.Certificate[] signingCertificateChain, java.security.PrivateKey signingPrivateKey, org.apache.camel.component.as2.api.AS2CompressionAlgorithm compressionAlgorithm, String dispositionNotificationTo, String signedReceiptMicAlgorithms, org.apache.camel.component.as2.api.AS2EncryptionAlgorithm encryptingAlgorithm, java.security.cert.Certificate[] encryptingCertificateChain, String attachedFileName, String receiptDeliveryOption)"})}, aliases = {})
+ apiMethods = {@ApiMethod(methodName = "send", description="Send ediMessage to trading partner", signatures={"org.apache.hc.core5.http.protocol.HttpCoreContext send(Object ediMessage, String requestUri, String subject, String from, String as2From, String as2To, org.apache.camel.component.as2.api.AS2MessageStructure as2MessageStructure, String ediMessageContentType, String ediMessageCharset, String ediMessageTransferEncoding, org.apache.camel.component.as2.api.AS2SignatureAlgorithm signingAlgorithm, java.security.cert.Certificate[] signingCertificateChain, java.security.PrivateKey signingPrivateKey, org.apache.camel.component.as2.api.AS2CompressionAlgorithm compressionAlgorithm, String dispositionNotificationTo, String signedReceiptMicAlgorithms, org.apache.camel.component.as2.api.AS2EncryptionAlgorithm encryptingAlgorithm, java.security.cert.Certificate[] encryptingCertificateChain, String attachedFileName, String receiptDeliveryOption, String userName, String password, String accessToken)"})}, aliases = {})
@UriParams
@Configurer(extended = true)
public final class AS2ClientManagerEndpointConfiguration extends AS2Configuration {
+ @UriParam
+ @ApiParam(optional = true, apiMethods = {@ApiMethod(methodName = "send", description="The access token that is used by the client for bearer authentication")})
+ private String accessToken;
@UriParam
@ApiParam(optional = false, apiMethods = {@ApiMethod(methodName = "send", description="AS2 name of sender")})
private String as2From;
@@ -59,7 +62,10 @@ public final class AS2ClientManagerEndpointConfiguration extends AS2Configuratio
@ApiParam(optional = false, apiMethods = {@ApiMethod(methodName = "send", description="RFC2822 address of sender")})
private String from;
@UriParam
- @ApiParam(optional = true, apiMethods = {@ApiMethod(methodName = "send")})
+ @ApiParam(optional = true, apiMethods = {@ApiMethod(methodName = "send", description="The password that is used by the client for basic authentication")})
+ private String password;
+ @UriParam
+ @ApiParam(optional = true, apiMethods = {@ApiMethod(methodName = "send", description="The return URL that the message receiver should send an asynchronous MDN to")})
private String receiptDeliveryOption;
@UriParam
@ApiParam(optional = false, apiMethods = {@ApiMethod(methodName = "send", description="Resource location to deliver message")})
@@ -79,6 +85,17 @@ public final class AS2ClientManagerEndpointConfiguration extends AS2Configuratio
@UriParam
@ApiParam(optional = false, apiMethods = {@ApiMethod(methodName = "send", description="Message subject")})
private String subject;
+ @UriParam
+ @ApiParam(optional = true, apiMethods = {@ApiMethod(methodName = "send", description="The user-name that is used for basic authentication")})
+ private String userName;
+
+ public String getAccessToken() {
+ return accessToken;
+ }
+
+ public void setAccessToken(String accessToken) {
+ this.accessToken = accessToken;
+ }
public String getAs2From() {
return as2From;
@@ -184,6 +201,14 @@ public void setFrom(String from) {
this.from = from;
}
+ public String getPassword() {
+ return password;
+ }
+
+ public void setPassword(String password) {
+ this.password = password;
+ }
+
public String getReceiptDeliveryOption() {
return receiptDeliveryOption;
}
@@ -239,4 +264,12 @@ public String getSubject() {
public void setSubject(String subject) {
this.subject = subject;
}
+
+ public String getUserName() {
+ return userName;
+ }
+
+ public void setUserName(String userName) {
+ this.userName = userName;
+ }
}
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfigurationConfigurer.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfigurationConfigurer.java
index 9d9e685ea0ffb..f24e86349b8d7 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfigurationConfigurer.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ClientManagerEndpointConfigurationConfigurer.java
@@ -22,6 +22,7 @@ public class AS2ClientManagerEndpointConfigurationConfigurer extends org.apache.
private static final Map ALL_OPTIONS;
static {
Map map = new CaseInsensitiveMap();
+ map.put("AccessToken", java.lang.String.class);
map.put("ApiName", org.apache.camel.component.as2.internal.AS2ApiName.class);
map.put("As2From", java.lang.String.class);
map.put("As2MessageStructure", org.apache.camel.component.as2.api.AS2MessageStructure.class);
@@ -46,8 +47,12 @@ public class AS2ClientManagerEndpointConfigurationConfigurer extends org.apache.
map.put("HttpConnectionPoolTtl", java.time.Duration.class);
map.put("HttpConnectionTimeout", java.time.Duration.class);
map.put("HttpSocketTimeout", java.time.Duration.class);
+ map.put("MdnAccessToken", java.lang.String.class);
map.put("MdnMessageTemplate", java.lang.String.class);
+ map.put("MdnPassword", java.lang.String.class);
+ map.put("MdnUserName", java.lang.String.class);
map.put("MethodName", java.lang.String.class);
+ map.put("Password", java.lang.String.class);
map.put("ReceiptDeliveryOption", java.lang.String.class);
map.put("RequestUri", java.lang.String.class);
map.put("Server", java.lang.String.class);
@@ -62,6 +67,7 @@ public class AS2ClientManagerEndpointConfigurationConfigurer extends org.apache.
map.put("TargetHostname", java.lang.String.class);
map.put("TargetPortNumber", java.lang.Integer.class);
map.put("UserAgent", java.lang.String.class);
+ map.put("UserName", java.lang.String.class);
map.put("ValidateSigningCertificateChain", java.security.cert.Certificate[].class);
ALL_OPTIONS = map;
}
@@ -70,6 +76,8 @@ public class AS2ClientManagerEndpointConfigurationConfigurer extends org.apache.
public boolean configure(CamelContext camelContext, Object obj, String name, Object value, boolean ignoreCase) {
org.apache.camel.component.as2.AS2ClientManagerEndpointConfiguration target = (org.apache.camel.component.as2.AS2ClientManagerEndpointConfiguration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": target.setAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "apiname":
case "apiName": target.setApiName(property(camelContext, org.apache.camel.component.as2.internal.AS2ApiName.class, value)); return true;
case "as2from":
@@ -117,10 +125,17 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "httpConnectionTimeout": target.setHttpConnectionTimeout(property(camelContext, java.time.Duration.class, value)); return true;
case "httpsockettimeout":
case "httpSocketTimeout": target.setHttpSocketTimeout(property(camelContext, java.time.Duration.class, value)); return true;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": target.setMdnAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "mdnmessagetemplate":
case "mdnMessageTemplate": target.setMdnMessageTemplate(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnpassword":
+ case "mdnPassword": target.setMdnPassword(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnusername":
+ case "mdnUserName": target.setMdnUserName(property(camelContext, java.lang.String.class, value)); return true;
case "methodname":
case "methodName": target.setMethodName(property(camelContext, java.lang.String.class, value)); return true;
+ case "password": target.setPassword(property(camelContext, java.lang.String.class, value)); return true;
case "receiptdeliveryoption":
case "receiptDeliveryOption": target.setReceiptDeliveryOption(property(camelContext, java.lang.String.class, value)); return true;
case "requesturi":
@@ -147,6 +162,8 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "targetPortNumber": target.setTargetPortNumber(property(camelContext, java.lang.Integer.class, value)); return true;
case "useragent":
case "userAgent": target.setUserAgent(property(camelContext, java.lang.String.class, value)); return true;
+ case "username":
+ case "userName": target.setUserName(property(camelContext, java.lang.String.class, value)); return true;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": target.setValidateSigningCertificateChain(property(camelContext, java.security.cert.Certificate[].class, value)); return true;
default: return false;
@@ -161,6 +178,8 @@ public Map getAllOptions(Object target) {
@Override
public Class> getOptionType(String name, boolean ignoreCase) {
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return java.lang.String.class;
case "apiname":
case "apiName": return org.apache.camel.component.as2.internal.AS2ApiName.class;
case "as2from":
@@ -208,10 +227,17 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "httpConnectionTimeout": return java.time.Duration.class;
case "httpsockettimeout":
case "httpSocketTimeout": return java.time.Duration.class;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return java.lang.String.class;
case "mdnmessagetemplate":
case "mdnMessageTemplate": return java.lang.String.class;
+ case "mdnpassword":
+ case "mdnPassword": return java.lang.String.class;
+ case "mdnusername":
+ case "mdnUserName": return java.lang.String.class;
case "methodname":
case "methodName": return java.lang.String.class;
+ case "password": return java.lang.String.class;
case "receiptdeliveryoption":
case "receiptDeliveryOption": return java.lang.String.class;
case "requesturi":
@@ -238,6 +264,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "targetPortNumber": return java.lang.Integer.class;
case "useragent":
case "userAgent": return java.lang.String.class;
+ case "username":
+ case "userName": return java.lang.String.class;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return java.security.cert.Certificate[].class;
default: return null;
@@ -248,6 +276,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
org.apache.camel.component.as2.AS2ClientManagerEndpointConfiguration target = (org.apache.camel.component.as2.AS2ClientManagerEndpointConfiguration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return target.getAccessToken();
case "apiname":
case "apiName": return target.getApiName();
case "as2from":
@@ -295,10 +325,17 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "httpConnectionTimeout": return target.getHttpConnectionTimeout();
case "httpsockettimeout":
case "httpSocketTimeout": return target.getHttpSocketTimeout();
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return target.getMdnAccessToken();
case "mdnmessagetemplate":
case "mdnMessageTemplate": return target.getMdnMessageTemplate();
+ case "mdnpassword":
+ case "mdnPassword": return target.getMdnPassword();
+ case "mdnusername":
+ case "mdnUserName": return target.getMdnUserName();
case "methodname":
case "methodName": return target.getMethodName();
+ case "password": return target.getPassword();
case "receiptdeliveryoption":
case "receiptDeliveryOption": return target.getReceiptDeliveryOption();
case "requesturi":
@@ -325,6 +362,8 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "targetPortNumber": return target.getTargetPortNumber();
case "useragent":
case "userAgent": return target.getUserAgent();
+ case "username":
+ case "userName": return target.getUserName();
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return target.getValidateSigningCertificateChain();
default: return null;
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ConfigurationConfigurer.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ConfigurationConfigurer.java
index 30974b46b6d5d..ae58d63e54039 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ConfigurationConfigurer.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ConfigurationConfigurer.java
@@ -22,6 +22,7 @@ public class AS2ConfigurationConfigurer extends org.apache.camel.support.compone
private static final Map ALL_OPTIONS;
static {
Map map = new CaseInsensitiveMap();
+ map.put("AccessToken", java.lang.String.class);
map.put("ApiName", org.apache.camel.component.as2.internal.AS2ApiName.class);
map.put("As2From", java.lang.String.class);
map.put("As2MessageStructure", org.apache.camel.component.as2.api.AS2MessageStructure.class);
@@ -44,8 +45,12 @@ public class AS2ConfigurationConfigurer extends org.apache.camel.support.compone
map.put("HttpConnectionPoolTtl", java.time.Duration.class);
map.put("HttpConnectionTimeout", java.time.Duration.class);
map.put("HttpSocketTimeout", java.time.Duration.class);
+ map.put("MdnAccessToken", java.lang.String.class);
map.put("MdnMessageTemplate", java.lang.String.class);
+ map.put("MdnPassword", java.lang.String.class);
+ map.put("MdnUserName", java.lang.String.class);
map.put("MethodName", java.lang.String.class);
+ map.put("Password", java.lang.String.class);
map.put("ReceiptDeliveryOption", java.lang.String.class);
map.put("RequestUri", java.lang.String.class);
map.put("Server", java.lang.String.class);
@@ -60,6 +65,7 @@ public class AS2ConfigurationConfigurer extends org.apache.camel.support.compone
map.put("TargetHostname", java.lang.String.class);
map.put("TargetPortNumber", java.lang.Integer.class);
map.put("UserAgent", java.lang.String.class);
+ map.put("UserName", java.lang.String.class);
map.put("ValidateSigningCertificateChain", java.security.cert.Certificate[].class);
ALL_OPTIONS = map;
}
@@ -68,6 +74,8 @@ public class AS2ConfigurationConfigurer extends org.apache.camel.support.compone
public boolean configure(CamelContext camelContext, Object obj, String name, Object value, boolean ignoreCase) {
org.apache.camel.component.as2.AS2Configuration target = (org.apache.camel.component.as2.AS2Configuration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": target.setAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "apiname":
case "apiName": target.setApiName(property(camelContext, org.apache.camel.component.as2.internal.AS2ApiName.class, value)); return true;
case "as2from":
@@ -111,10 +119,17 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "httpConnectionTimeout": target.setHttpConnectionTimeout(property(camelContext, java.time.Duration.class, value)); return true;
case "httpsockettimeout":
case "httpSocketTimeout": target.setHttpSocketTimeout(property(camelContext, java.time.Duration.class, value)); return true;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": target.setMdnAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "mdnmessagetemplate":
case "mdnMessageTemplate": target.setMdnMessageTemplate(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnpassword":
+ case "mdnPassword": target.setMdnPassword(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnusername":
+ case "mdnUserName": target.setMdnUserName(property(camelContext, java.lang.String.class, value)); return true;
case "methodname":
case "methodName": target.setMethodName(property(camelContext, java.lang.String.class, value)); return true;
+ case "password": target.setPassword(property(camelContext, java.lang.String.class, value)); return true;
case "receiptdeliveryoption":
case "receiptDeliveryOption": target.setReceiptDeliveryOption(property(camelContext, java.lang.String.class, value)); return true;
case "requesturi":
@@ -141,6 +156,8 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "targetPortNumber": target.setTargetPortNumber(property(camelContext, java.lang.Integer.class, value)); return true;
case "useragent":
case "userAgent": target.setUserAgent(property(camelContext, java.lang.String.class, value)); return true;
+ case "username":
+ case "userName": target.setUserName(property(camelContext, java.lang.String.class, value)); return true;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": target.setValidateSigningCertificateChain(property(camelContext, java.security.cert.Certificate[].class, value)); return true;
default: return false;
@@ -155,6 +172,8 @@ public Map getAllOptions(Object target) {
@Override
public Class> getOptionType(String name, boolean ignoreCase) {
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return java.lang.String.class;
case "apiname":
case "apiName": return org.apache.camel.component.as2.internal.AS2ApiName.class;
case "as2from":
@@ -198,10 +217,17 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "httpConnectionTimeout": return java.time.Duration.class;
case "httpsockettimeout":
case "httpSocketTimeout": return java.time.Duration.class;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return java.lang.String.class;
case "mdnmessagetemplate":
case "mdnMessageTemplate": return java.lang.String.class;
+ case "mdnpassword":
+ case "mdnPassword": return java.lang.String.class;
+ case "mdnusername":
+ case "mdnUserName": return java.lang.String.class;
case "methodname":
case "methodName": return java.lang.String.class;
+ case "password": return java.lang.String.class;
case "receiptdeliveryoption":
case "receiptDeliveryOption": return java.lang.String.class;
case "requesturi":
@@ -228,6 +254,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "targetPortNumber": return java.lang.Integer.class;
case "useragent":
case "userAgent": return java.lang.String.class;
+ case "username":
+ case "userName": return java.lang.String.class;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return java.security.cert.Certificate[].class;
default: return null;
@@ -238,6 +266,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
org.apache.camel.component.as2.AS2Configuration target = (org.apache.camel.component.as2.AS2Configuration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return target.getAccessToken();
case "apiname":
case "apiName": return target.getApiName();
case "as2from":
@@ -281,10 +311,17 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "httpConnectionTimeout": return target.getHttpConnectionTimeout();
case "httpsockettimeout":
case "httpSocketTimeout": return target.getHttpSocketTimeout();
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return target.getMdnAccessToken();
case "mdnmessagetemplate":
case "mdnMessageTemplate": return target.getMdnMessageTemplate();
+ case "mdnpassword":
+ case "mdnPassword": return target.getMdnPassword();
+ case "mdnusername":
+ case "mdnUserName": return target.getMdnUserName();
case "methodname":
case "methodName": return target.getMethodName();
+ case "password": return target.getPassword();
case "receiptdeliveryoption":
case "receiptDeliveryOption": return target.getReceiptDeliveryOption();
case "requesturi":
@@ -311,6 +348,8 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "targetPortNumber": return target.getTargetPortNumber();
case "useragent":
case "userAgent": return target.getUserAgent();
+ case "username":
+ case "userName": return target.getUserName();
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return target.getValidateSigningCertificateChain();
default: return null;
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointConfigurer.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointConfigurer.java
index 7b387b269a312..4de2c44bd7070 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointConfigurer.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointConfigurer.java
@@ -55,15 +55,21 @@ public class AS2EndpointConfigurer extends PropertyConfigurerSupport implements
map.put("ExceptionHandler", org.apache.camel.spi.ExceptionHandler.class);
map.put("ExchangePattern", org.apache.camel.ExchangePattern.class);
map.put("LazyStartProducer", boolean.class);
+ map.put("AccessToken", java.lang.String.class);
map.put("DecryptingPrivateKey", java.security.PrivateKey.class);
map.put("EncryptingAlgorithm", org.apache.camel.component.as2.api.AS2EncryptionAlgorithm.class);
map.put("EncryptingCertificateChain", java.security.cert.Certificate[].class);
map.put("HostnameVerifier", javax.net.ssl.HostnameVerifier.class);
+ map.put("MdnAccessToken", java.lang.String.class);
+ map.put("MdnPassword", java.lang.String.class);
+ map.put("MdnUserName", java.lang.String.class);
+ map.put("Password", java.lang.String.class);
map.put("SignedReceiptMicAlgorithms", java.lang.String.class);
map.put("SigningAlgorithm", org.apache.camel.component.as2.api.AS2SignatureAlgorithm.class);
map.put("SigningCertificateChain", java.security.cert.Certificate[].class);
map.put("SigningPrivateKey", java.security.PrivateKey.class);
map.put("SslContext", javax.net.ssl.SSLContext.class);
+ map.put("UserName", java.lang.String.class);
map.put("ValidateSigningCertificateChain", java.security.cert.Certificate[].class);
ALL_OPTIONS = map;
}
@@ -72,6 +78,8 @@ public class AS2EndpointConfigurer extends PropertyConfigurerSupport implements
public boolean configure(CamelContext camelContext, Object obj, String name, Object value, boolean ignoreCase) {
AS2Endpoint target = (AS2Endpoint) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": target.getConfiguration().setAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "as2from":
case "as2From": target.getConfiguration().setAs2From(property(camelContext, java.lang.String.class, value)); return true;
case "as2messagestructure":
@@ -121,8 +129,15 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "inBody": target.setInBody(property(camelContext, java.lang.String.class, value)); return true;
case "lazystartproducer":
case "lazyStartProducer": target.setLazyStartProducer(property(camelContext, boolean.class, value)); return true;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": target.getConfiguration().setMdnAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "mdnmessagetemplate":
case "mdnMessageTemplate": target.getConfiguration().setMdnMessageTemplate(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnpassword":
+ case "mdnPassword": target.getConfiguration().setMdnPassword(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnusername":
+ case "mdnUserName": target.getConfiguration().setMdnUserName(property(camelContext, java.lang.String.class, value)); return true;
+ case "password": target.getConfiguration().setPassword(property(camelContext, java.lang.String.class, value)); return true;
case "receiptdeliveryoption":
case "receiptDeliveryOption": target.getConfiguration().setReceiptDeliveryOption(property(camelContext, java.lang.String.class, value)); return true;
case "requesturi":
@@ -149,6 +164,8 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "targetPortNumber": target.getConfiguration().setTargetPortNumber(property(camelContext, java.lang.Integer.class, value)); return true;
case "useragent":
case "userAgent": target.getConfiguration().setUserAgent(property(camelContext, java.lang.String.class, value)); return true;
+ case "username":
+ case "userName": target.getConfiguration().setUserName(property(camelContext, java.lang.String.class, value)); return true;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": target.getConfiguration().setValidateSigningCertificateChain(property(camelContext, java.security.cert.Certificate[].class, value)); return true;
default: return false;
@@ -163,6 +180,8 @@ public Map getAllOptions(Object target) {
@Override
public Class> getOptionType(String name, boolean ignoreCase) {
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return java.lang.String.class;
case "as2from":
case "as2From": return java.lang.String.class;
case "as2messagestructure":
@@ -212,8 +231,15 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "inBody": return java.lang.String.class;
case "lazystartproducer":
case "lazyStartProducer": return boolean.class;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return java.lang.String.class;
case "mdnmessagetemplate":
case "mdnMessageTemplate": return java.lang.String.class;
+ case "mdnpassword":
+ case "mdnPassword": return java.lang.String.class;
+ case "mdnusername":
+ case "mdnUserName": return java.lang.String.class;
+ case "password": return java.lang.String.class;
case "receiptdeliveryoption":
case "receiptDeliveryOption": return java.lang.String.class;
case "requesturi":
@@ -240,6 +266,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "targetPortNumber": return java.lang.Integer.class;
case "useragent":
case "userAgent": return java.lang.String.class;
+ case "username":
+ case "userName": return java.lang.String.class;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return java.security.cert.Certificate[].class;
default: return null;
@@ -250,6 +278,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
AS2Endpoint target = (AS2Endpoint) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return target.getConfiguration().getAccessToken();
case "as2from":
case "as2From": return target.getConfiguration().getAs2From();
case "as2messagestructure":
@@ -299,8 +329,15 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "inBody": return target.getInBody();
case "lazystartproducer":
case "lazyStartProducer": return target.isLazyStartProducer();
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return target.getConfiguration().getMdnAccessToken();
case "mdnmessagetemplate":
case "mdnMessageTemplate": return target.getConfiguration().getMdnMessageTemplate();
+ case "mdnpassword":
+ case "mdnPassword": return target.getConfiguration().getMdnPassword();
+ case "mdnusername":
+ case "mdnUserName": return target.getConfiguration().getMdnUserName();
+ case "password": return target.getConfiguration().getPassword();
case "receiptdeliveryoption":
case "receiptDeliveryOption": return target.getConfiguration().getReceiptDeliveryOption();
case "requesturi":
@@ -327,6 +364,8 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "targetPortNumber": return target.getConfiguration().getTargetPortNumber();
case "useragent":
case "userAgent": return target.getConfiguration().getUserAgent();
+ case "username":
+ case "userName": return target.getConfiguration().getUserName();
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return target.getConfiguration().getValidateSigningCertificateChain();
default: return null;
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointUriFactory.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointUriFactory.java
index e259008f3f8f4..6bee8aaa3a0f6 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointUriFactory.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2EndpointUriFactory.java
@@ -23,7 +23,8 @@ public class AS2EndpointUriFactory extends org.apache.camel.support.component.En
private static final Set SECRET_PROPERTY_NAMES;
private static final Set MULTI_VALUE_PREFIXES;
static {
- Set props = new HashSet<>(46);
+ Set props = new HashSet<>(52);
+ props.add("accessToken");
props.add("apiName");
props.add("as2From");
props.add("as2MessageStructure");
@@ -52,8 +53,12 @@ public class AS2EndpointUriFactory extends org.apache.camel.support.component.En
props.add("httpSocketTimeout");
props.add("inBody");
props.add("lazyStartProducer");
+ props.add("mdnAccessToken");
props.add("mdnMessageTemplate");
+ props.add("mdnPassword");
+ props.add("mdnUserName");
props.add("methodName");
+ props.add("password");
props.add("receiptDeliveryOption");
props.add("requestUri");
props.add("requestUriPattern");
@@ -69,9 +74,17 @@ public class AS2EndpointUriFactory extends org.apache.camel.support.component.En
props.add("targetHostname");
props.add("targetPortNumber");
props.add("userAgent");
+ props.add("userName");
props.add("validateSigningCertificateChain");
PROPERTY_NAMES = Collections.unmodifiableSet(props);
- SECRET_PROPERTY_NAMES = Collections.emptySet();
+ Set secretProps = new HashSet<>(6);
+ secretProps.add("accessToken");
+ secretProps.add("mdnAccessToken");
+ secretProps.add("mdnPassword");
+ secretProps.add("mdnUserName");
+ secretProps.add("password");
+ secretProps.add("userName");
+ SECRET_PROPERTY_NAMES = Collections.unmodifiableSet(secretProps);
MULTI_VALUE_PREFIXES = Collections.emptySet();
}
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ServerManagerEndpointConfigurationConfigurer.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ServerManagerEndpointConfigurationConfigurer.java
index 468d0c0526054..dafc031b29862 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ServerManagerEndpointConfigurationConfigurer.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/AS2ServerManagerEndpointConfigurationConfigurer.java
@@ -22,6 +22,7 @@ public class AS2ServerManagerEndpointConfigurationConfigurer extends org.apache.
private static final Map ALL_OPTIONS;
static {
Map map = new CaseInsensitiveMap();
+ map.put("AccessToken", java.lang.String.class);
map.put("ApiName", org.apache.camel.component.as2.internal.AS2ApiName.class);
map.put("As2From", java.lang.String.class);
map.put("As2MessageStructure", org.apache.camel.component.as2.api.AS2MessageStructure.class);
@@ -44,8 +45,12 @@ public class AS2ServerManagerEndpointConfigurationConfigurer extends org.apache.
map.put("HttpConnectionPoolTtl", java.time.Duration.class);
map.put("HttpConnectionTimeout", java.time.Duration.class);
map.put("HttpSocketTimeout", java.time.Duration.class);
+ map.put("MdnAccessToken", java.lang.String.class);
map.put("MdnMessageTemplate", java.lang.String.class);
+ map.put("MdnPassword", java.lang.String.class);
+ map.put("MdnUserName", java.lang.String.class);
map.put("MethodName", java.lang.String.class);
+ map.put("Password", java.lang.String.class);
map.put("ReceiptDeliveryOption", java.lang.String.class);
map.put("RequestUri", java.lang.String.class);
map.put("RequestUriPattern", java.lang.String.class);
@@ -61,6 +66,7 @@ public class AS2ServerManagerEndpointConfigurationConfigurer extends org.apache.
map.put("TargetHostname", java.lang.String.class);
map.put("TargetPortNumber", java.lang.Integer.class);
map.put("UserAgent", java.lang.String.class);
+ map.put("UserName", java.lang.String.class);
map.put("ValidateSigningCertificateChain", java.security.cert.Certificate[].class);
ALL_OPTIONS = map;
}
@@ -69,6 +75,8 @@ public class AS2ServerManagerEndpointConfigurationConfigurer extends org.apache.
public boolean configure(CamelContext camelContext, Object obj, String name, Object value, boolean ignoreCase) {
org.apache.camel.component.as2.AS2ServerManagerEndpointConfiguration target = (org.apache.camel.component.as2.AS2ServerManagerEndpointConfiguration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": target.setAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "apiname":
case "apiName": target.setApiName(property(camelContext, org.apache.camel.component.as2.internal.AS2ApiName.class, value)); return true;
case "as2from":
@@ -112,10 +120,17 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "httpConnectionTimeout": target.setHttpConnectionTimeout(property(camelContext, java.time.Duration.class, value)); return true;
case "httpsockettimeout":
case "httpSocketTimeout": target.setHttpSocketTimeout(property(camelContext, java.time.Duration.class, value)); return true;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": target.setMdnAccessToken(property(camelContext, java.lang.String.class, value)); return true;
case "mdnmessagetemplate":
case "mdnMessageTemplate": target.setMdnMessageTemplate(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnpassword":
+ case "mdnPassword": target.setMdnPassword(property(camelContext, java.lang.String.class, value)); return true;
+ case "mdnusername":
+ case "mdnUserName": target.setMdnUserName(property(camelContext, java.lang.String.class, value)); return true;
case "methodname":
case "methodName": target.setMethodName(property(camelContext, java.lang.String.class, value)); return true;
+ case "password": target.setPassword(property(camelContext, java.lang.String.class, value)); return true;
case "receiptdeliveryoption":
case "receiptDeliveryOption": target.setReceiptDeliveryOption(property(camelContext, java.lang.String.class, value)); return true;
case "requesturi":
@@ -144,6 +159,8 @@ public boolean configure(CamelContext camelContext, Object obj, String name, Obj
case "targetPortNumber": target.setTargetPortNumber(property(camelContext, java.lang.Integer.class, value)); return true;
case "useragent":
case "userAgent": target.setUserAgent(property(camelContext, java.lang.String.class, value)); return true;
+ case "username":
+ case "userName": target.setUserName(property(camelContext, java.lang.String.class, value)); return true;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": target.setValidateSigningCertificateChain(property(camelContext, java.security.cert.Certificate[].class, value)); return true;
default: return false;
@@ -158,6 +175,8 @@ public Map getAllOptions(Object target) {
@Override
public Class> getOptionType(String name, boolean ignoreCase) {
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return java.lang.String.class;
case "apiname":
case "apiName": return org.apache.camel.component.as2.internal.AS2ApiName.class;
case "as2from":
@@ -201,10 +220,17 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "httpConnectionTimeout": return java.time.Duration.class;
case "httpsockettimeout":
case "httpSocketTimeout": return java.time.Duration.class;
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return java.lang.String.class;
case "mdnmessagetemplate":
case "mdnMessageTemplate": return java.lang.String.class;
+ case "mdnpassword":
+ case "mdnPassword": return java.lang.String.class;
+ case "mdnusername":
+ case "mdnUserName": return java.lang.String.class;
case "methodname":
case "methodName": return java.lang.String.class;
+ case "password": return java.lang.String.class;
case "receiptdeliveryoption":
case "receiptDeliveryOption": return java.lang.String.class;
case "requesturi":
@@ -233,6 +259,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
case "targetPortNumber": return java.lang.Integer.class;
case "useragent":
case "userAgent": return java.lang.String.class;
+ case "username":
+ case "userName": return java.lang.String.class;
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return java.security.cert.Certificate[].class;
default: return null;
@@ -243,6 +271,8 @@ public Class> getOptionType(String name, boolean ignoreCase) {
public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
org.apache.camel.component.as2.AS2ServerManagerEndpointConfiguration target = (org.apache.camel.component.as2.AS2ServerManagerEndpointConfiguration) obj;
switch (ignoreCase ? name.toLowerCase() : name) {
+ case "accesstoken":
+ case "accessToken": return target.getAccessToken();
case "apiname":
case "apiName": return target.getApiName();
case "as2from":
@@ -286,10 +316,17 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "httpConnectionTimeout": return target.getHttpConnectionTimeout();
case "httpsockettimeout":
case "httpSocketTimeout": return target.getHttpSocketTimeout();
+ case "mdnaccesstoken":
+ case "mdnAccessToken": return target.getMdnAccessToken();
case "mdnmessagetemplate":
case "mdnMessageTemplate": return target.getMdnMessageTemplate();
+ case "mdnpassword":
+ case "mdnPassword": return target.getMdnPassword();
+ case "mdnusername":
+ case "mdnUserName": return target.getMdnUserName();
case "methodname":
case "methodName": return target.getMethodName();
+ case "password": return target.getPassword();
case "receiptdeliveryoption":
case "receiptDeliveryOption": return target.getReceiptDeliveryOption();
case "requesturi":
@@ -318,6 +355,8 @@ public Object getOptionValue(Object obj, String name, boolean ignoreCase) {
case "targetPortNumber": return target.getTargetPortNumber();
case "useragent":
case "userAgent": return target.getUserAgent();
+ case "username":
+ case "userName": return target.getUserName();
case "validatesigningcertificatechain":
case "validateSigningCertificateChain": return target.getValidateSigningCertificateChain();
default: return null;
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ApiCollection.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ApiCollection.java
index d42a82271366d..111165c1c2d71 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ApiCollection.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ApiCollection.java
@@ -31,7 +31,7 @@ private AS2ApiCollection() {
List nullableArgs;
aliases.clear();
- nullableArgs = Arrays.asList("ediMessageTransferEncoding", "signingAlgorithm", "signingCertificateChain", "signingPrivateKey", "compressionAlgorithm", "dispositionNotificationTo", "signedReceiptMicAlgorithms", "encryptingAlgorithm", "encryptingCertificateChain", "attachedFileName", "receiptDeliveryOption", "ediMessageCharset");
+ nullableArgs = Arrays.asList("ediMessageTransferEncoding", "signingAlgorithm", "signingCertificateChain", "signingPrivateKey", "compressionAlgorithm", "dispositionNotificationTo", "signedReceiptMicAlgorithms", "encryptingAlgorithm", "encryptingCertificateChain", "attachedFileName", "receiptDeliveryOption", "ediMessageCharset", "userName", "password", "accessToken");
apiHelpers.put(AS2ApiName.CLIENT, new ApiMethodHelper<>(AS2ClientManagerApiMethod.class, aliases, nullableArgs));
apiMethods.put(AS2ClientManagerApiMethod.class, AS2ApiName.CLIENT);
diff --git a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ClientManagerApiMethod.java b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ClientManagerApiMethod.java
index 0ddbb18794db5..5bf0414b7c34e 100644
--- a/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ClientManagerApiMethod.java
+++ b/components/camel-as2/camel-as2-component/src/generated/java/org/apache/camel/component/as2/internal/AS2ClientManagerApiMethod.java
@@ -41,7 +41,10 @@ public enum AS2ClientManagerApiMethod implements ApiMethod {
arg("encryptingAlgorithm", org.apache.camel.component.as2.api.AS2EncryptionAlgorithm.class),
arg("encryptingCertificateChain", new java.security.cert.Certificate[0].getClass()),
arg("attachedFileName", String.class),
- arg("receiptDeliveryOption", String.class));
+ arg("receiptDeliveryOption", String.class),
+ arg("userName", String.class),
+ arg("password", String.class),
+ arg("accessToken", String.class));
private final ApiMethod apiMethod;
diff --git a/components/camel-as2/camel-as2-component/src/generated/resources/META-INF/org/apache/camel/component/as2/as2.json b/components/camel-as2/camel-as2-component/src/generated/resources/META-INF/org/apache/camel/component/as2/as2.json
index 0988917f675f5..e3408145423d7 100644
--- a/components/camel-as2/camel-as2-component/src/generated/resources/META-INF/org/apache/camel/component/as2/as2.json
+++ b/components/camel-as2/camel-as2-component/src/generated/resources/META-INF/org/apache/camel/component/as2/as2.json
@@ -66,24 +66,30 @@
"exceptionHandler": { "index": 30, "kind": "parameter", "displayName": "Exception Handler", "group": "consumer (advanced)", "label": "consumer,advanced", "required": false, "type": "object", "javaType": "org.apache.camel.spi.ExceptionHandler", "optionalPrefix": "consumer.", "deprecated": false, "autowired": false, "secret": false, "description": "To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored." },
"exchangePattern": { "index": 31, "kind": "parameter", "displayName": "Exchange Pattern", "group": "consumer (advanced)", "label": "consumer,advanced", "required": false, "type": "object", "javaType": "org.apache.camel.ExchangePattern", "enum": [ "InOnly", "InOut" ], "deprecated": false, "autowired": false, "secret": false, "description": "Sets the exchange pattern when the consumer creates an exchange." },
"lazyStartProducer": { "index": 32, "kind": "parameter", "displayName": "Lazy Start Producer", "group": "producer (advanced)", "label": "producer,advanced", "required": false, "type": "boolean", "javaType": "boolean", "deprecated": false, "autowired": false, "secret": false, "defaultValue": false, "description": "Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing." },
- "decryptingPrivateKey": { "index": 33, "kind": "parameter", "displayName": "Decrypting Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to encrypt the EDI message." },
- "encryptingAlgorithm": { "index": 34, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to encrypt EDI message." },
- "encryptingCertificateChain": { "index": 35, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to encrypt EDI message." },
- "hostnameVerifier": { "index": 36, "kind": "parameter", "displayName": "Hostname Verifier", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.HostnameVerifier", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set hostname verifier for SSL session." },
- "signedReceiptMicAlgorithms": { "index": 37, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The list of algorithms, in order of preference, requested to generate a message integrity check (MIC) returned in message disposition notification (MDN). Multiple algorithms can be separated by comma." },
- "signingAlgorithm": { "index": 38, "kind": "parameter", "displayName": "Signing Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to sign EDI message." },
- "signingCertificateChain": { "index": 39, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to sign EDI message." },
- "signingPrivateKey": { "index": 40, "kind": "parameter", "displayName": "Signing Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to sign the EDI message." },
- "sslContext": { "index": 41, "kind": "parameter", "displayName": "Ssl Context", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.SSLContext", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set SSL context for connection to remote server." },
- "validateSigningCertificateChain": { "index": 42, "kind": "parameter", "displayName": "Validate Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Certificates to validate the message's signature against. If not supplied, validation will not take place. Server: validates the received message. Client: not yet implemented, should validate the MDN" }
+ "accessToken": { "index": 33, "kind": "parameter", "displayName": "Access Token", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The access token that is used by the client for bearer authentication." },
+ "decryptingPrivateKey": { "index": 34, "kind": "parameter", "displayName": "Decrypting Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to encrypt the EDI message." },
+ "encryptingAlgorithm": { "index": 35, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to encrypt EDI message." },
+ "encryptingCertificateChain": { "index": 36, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to encrypt EDI message." },
+ "hostnameVerifier": { "index": 37, "kind": "parameter", "displayName": "Hostname Verifier", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.HostnameVerifier", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set hostname verifier for SSL session." },
+ "mdnAccessToken": { "index": 38, "kind": "parameter", "displayName": "Mdn Access Token", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The access token that is used by the server when it sends an async MDN." },
+ "mdnPassword": { "index": 39, "kind": "parameter", "displayName": "Mdn Password", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The password that is used by the server for basic authentication when it sends an async MDN." },
+ "mdnUserName": { "index": 40, "kind": "parameter", "displayName": "Mdn User Name", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The user-name that is used by the server for basic authentication when it sends an async MDN. If options for basic authentication and bearer authentication are both set then basic authentication takes precedence." },
+ "password": { "index": 41, "kind": "parameter", "displayName": "Password", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The password that is used by the client for basic authentication." },
+ "signedReceiptMicAlgorithms": { "index": 42, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The list of algorithms, in order of preference, requested to generate a message integrity check (MIC) returned in message disposition notification (MDN). Multiple algorithms can be separated by comma." },
+ "signingAlgorithm": { "index": 43, "kind": "parameter", "displayName": "Signing Algorithm", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The algorithm used to sign EDI message." },
+ "signingCertificateChain": { "index": 44, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The chain of certificates used to sign EDI message." },
+ "signingPrivateKey": { "index": 45, "kind": "parameter", "displayName": "Signing Private Key", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The key used to sign the EDI message." },
+ "sslContext": { "index": 46, "kind": "parameter", "displayName": "Ssl Context", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "javax.net.ssl.SSLContext", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Set SSL context for connection to remote server." },
+ "userName": { "index": 47, "kind": "parameter", "displayName": "User Name", "group": "security", "label": "security", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": true, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "The user-name that is used by the client for basic authentication. If options for basic authentication and bearer authentication are both set then basic authentication takes precedence." },
+ "validateSigningCertificateChain": { "index": 48, "kind": "parameter", "displayName": "Validate Signing Certificate Chain", "group": "security", "label": "security", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "configurationClass": "org.apache.camel.component.as2.AS2Configuration", "configurationField": "configuration", "description": "Certificates to validate the message's signature against. If not supplied, validation will not take place. Server: validates the received message. Client: not yet implemented, should validate the MDN" }
},
"apis": {
- "client": { "consumerOnly": false, "producerOnly": true, "description": "Sends EDI Messages over HTTP", "methods": { "send": { "description": "Send ediMessage to trading partner", "signatures": [ "org.apache.hc.core5.http.protocol.HttpCoreContext send(Object ediMessage, String requestUri, String subject, String from, String as2From, String as2To, org.apache.camel.component.as2.api.AS2MessageStructure as2MessageStructure, String ediMessageContentType, String ediMessageCharset, String ediMessageTransferEncoding, org.apache.camel.component.as2.api.AS2SignatureAlgorithm signingAlgorithm, java.security.cert.Certificate[] signingCertificateChain, java.security.PrivateKey signingPrivateKey, org.apache.camel.component.as2.api.AS2CompressionAlgorithm compressionAlgorithm, String dispositionNotificationTo, String signedReceiptMicAlgorithms, org.apache.camel.component.as2.api.AS2EncryptionAlgorithm encryptingAlgorithm, java.security.cert.Certificate[] encryptingCertificateChain, String attachedFileName, String receiptDeliveryOption)" ] } } },
+ "client": { "consumerOnly": false, "producerOnly": true, "description": "Sends EDI Messages over HTTP", "methods": { "send": { "description": "Send ediMessage to trading partner", "signatures": [ "org.apache.hc.core5.http.protocol.HttpCoreContext send(Object ediMessage, String requestUri, String subject, String from, String as2From, String as2To, org.apache.camel.component.as2.api.AS2MessageStructure as2MessageStructure, String ediMessageContentType, String ediMessageCharset, String ediMessageTransferEncoding, org.apache.camel.component.as2.api.AS2SignatureAlgorithm signingAlgorithm, java.security.cert.Certificate[] signingCertificateChain, java.security.PrivateKey signingPrivateKey, org.apache.camel.component.as2.api.AS2CompressionAlgorithm compressionAlgorithm, String dispositionNotificationTo, String signedReceiptMicAlgorithms, org.apache.camel.component.as2.api.AS2EncryptionAlgorithm encryptingAlgorithm, java.security.cert.Certificate[] encryptingCertificateChain, String attachedFileName, String receiptDeliveryOption, String userName, String password, String accessToken)" ] } } },
"receipt": { "consumerOnly": true, "producerOnly": false, "description": "Receives the asynchronous AS2-MDN that is requested by the sender of an AS2 message", "methods": { "receive": { "description": "", "signatures": [ "void receive(String requestUriPattern, org.apache.hc.core5.http.io.HttpRequestHandler handler)" ] } } },
"server": { "consumerOnly": true, "producerOnly": false, "description": "Receives EDI Messages over HTTP", "methods": { "listen": { "description": "", "signatures": [ "void listen(String requestUriPattern, org.apache.hc.core5.http.io.HttpRequestHandler handler)" ] } } }
},
"apiProperties": {
- "client": { "methods": { "send": { "properties": { "as2From": { "index": 0, "kind": "parameter", "displayName": "As2 From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of sender", "optional": false }, "as2MessageStructure": { "index": 1, "kind": "parameter", "displayName": "As2 Message Structure", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2MessageStructure", "enum": [ "PLAIN", "SIGNED", "ENCRYPTED", "SIGNED_ENCRYPTED", "PLAIN_COMPRESSED", "COMPRESSED_SIGNED", "SIGNED_COMPRESSED", "ENCRYPTED_COMPRESSED", "ENCRYPTED_COMPRESSED_SIGNED", "ENCRYPTED_SIGNED_COMPRESSED" ], "deprecated": false, "autowired": false, "secret": false, "description": "The structure of AS2 to send; see AS2MessageStructure", "optional": false }, "as2To": { "index": 2, "kind": "parameter", "displayName": "As2 To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of recipient", "optional": false }, "attachedFileName": { "index": 3, "kind": "parameter", "displayName": "Attached File Name", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The name of the attached file or null if user doesn't want to specify it", "optional": true }, "compressionAlgorithm": { "index": 4, "kind": "parameter", "displayName": "Compression Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2CompressionAlgorithm", "enum": [ "ZLIB" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to compress the message or null if sending EDI message uncompressed", "optional": true }, "dispositionNotificationTo": { "index": 5, "kind": "parameter", "displayName": "Disposition Notification To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "An RFC2822 address to request a receipt or null if no receipt requested", "optional": true }, "ediMessage": { "index": 6, "kind": "parameter", "displayName": "Edi Message", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.lang.Object", "deprecated": false, "autowired": false, "secret": false, "description": "EDI message to transport", "optional": false }, "ediMessageCharset": { "index": 7, "kind": "parameter", "displayName": "Edi Message Charset", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The charset of the EDI message", "optional": true }, "ediMessageContentType": { "index": 8, "kind": "parameter", "displayName": "Edi Message Content Type", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The content type of EDI message", "optional": false }, "ediMessageTransferEncoding": { "index": 9, "kind": "parameter", "displayName": "Edi Message Transfer Encoding", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The transfer encoding used to transport EDI message", "optional": true }, "encryptingAlgorithm": { "index": 10, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "encryptingCertificateChain": { "index": 11, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "from": { "index": 12, "kind": "parameter", "displayName": "From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "RFC2822 address of sender", "optional": false }, "receiptDeliveryOption": { "index": 13, "kind": "parameter", "displayName": "Receipt Delivery Option", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "", "optional": true }, "requestUri": { "index": 14, "kind": "parameter", "displayName": "Request Uri", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Resource location to deliver message", "optional": false }, "signedReceiptMicAlgorithms": { "index": 15, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The senders list of signing algorithms for signing receipt, in preferred order, or null if requesting an unsigned receipt.", "optional": true }, "signingAlgorithm": { "index": 16, "kind": "parameter", "displayName": "Signing Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingCertificateChain": { "index": 17, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingPrivateKey": { "index": 18, "kind": "parameter", "displayName": "Signing Private Key", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "description": "The private key used to sign EDI message", "optional": true }, "subject": { "index": 19, "kind": "parameter", "displayName": "Subject", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Message subject", "optional": false } } } } },
+ "client": { "methods": { "send": { "properties": { "accessToken": { "index": 0, "kind": "parameter", "displayName": "Access Token", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The access token that is used by the client for bearer authentication", "optional": true }, "as2From": { "index": 1, "kind": "parameter", "displayName": "As2 From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of sender", "optional": false }, "as2MessageStructure": { "index": 2, "kind": "parameter", "displayName": "As2 Message Structure", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2MessageStructure", "enum": [ "PLAIN", "SIGNED", "ENCRYPTED", "SIGNED_ENCRYPTED", "PLAIN_COMPRESSED", "COMPRESSED_SIGNED", "SIGNED_COMPRESSED", "ENCRYPTED_COMPRESSED", "ENCRYPTED_COMPRESSED_SIGNED", "ENCRYPTED_SIGNED_COMPRESSED" ], "deprecated": false, "autowired": false, "secret": false, "description": "The structure of AS2 to send; see AS2MessageStructure", "optional": false }, "as2To": { "index": 3, "kind": "parameter", "displayName": "As2 To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "AS2 name of recipient", "optional": false }, "attachedFileName": { "index": 4, "kind": "parameter", "displayName": "Attached File Name", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The name of the attached file or null if user doesn't want to specify it", "optional": true }, "compressionAlgorithm": { "index": 5, "kind": "parameter", "displayName": "Compression Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2CompressionAlgorithm", "enum": [ "ZLIB" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to compress the message or null if sending EDI message uncompressed", "optional": true }, "dispositionNotificationTo": { "index": 6, "kind": "parameter", "displayName": "Disposition Notification To", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "An RFC2822 address to request a receipt or null if no receipt requested", "optional": true }, "ediMessage": { "index": 7, "kind": "parameter", "displayName": "Edi Message", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.lang.Object", "deprecated": false, "autowired": false, "secret": false, "description": "EDI message to transport", "optional": false }, "ediMessageCharset": { "index": 8, "kind": "parameter", "displayName": "Edi Message Charset", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The charset of the EDI message", "optional": true }, "ediMessageContentType": { "index": 9, "kind": "parameter", "displayName": "Edi Message Content Type", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The content type of EDI message", "optional": false }, "ediMessageTransferEncoding": { "index": 10, "kind": "parameter", "displayName": "Edi Message Transfer Encoding", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The transfer encoding used to transport EDI message", "optional": true }, "encryptingAlgorithm": { "index": 11, "kind": "parameter", "displayName": "Encrypting Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2EncryptionAlgorithm", "enum": [ "AES128_CBC", "AES192_CBC", "AES256_CBC", "AES128_CCM", "AES192_CCM", "AES256_CCM", "AES128_GCM", "AES192_GCM", "AES256_GCM", "CAMELLIA128_CBC", "CAMELLIA192_CBC", "CAMELLIA256_CBC", "CAST5_CBC", "DES_CBC", "DES_EDE3_CBC", "GOST28147_GCFB", "IDEA_CBC", "RC2_CBC", "RC4", "SEED_CBC" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "encryptingCertificateChain": { "index": 12, "kind": "parameter", "displayName": "Encrypting Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to encrypt the message or null if sending EDI message unencrypted", "optional": true }, "from": { "index": 13, "kind": "parameter", "displayName": "From", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "RFC2822 address of sender", "optional": false }, "password": { "index": 14, "kind": "parameter", "displayName": "Password", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The password that is used by the client for basic authentication", "optional": true }, "receiptDeliveryOption": { "index": 15, "kind": "parameter", "displayName": "Receipt Delivery Option", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The return URL that the message receiver should send an asynchronous MDN to", "optional": true }, "requestUri": { "index": 16, "kind": "parameter", "displayName": "Request Uri", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Resource location to deliver message", "optional": false }, "signedReceiptMicAlgorithms": { "index": 17, "kind": "parameter", "displayName": "Signed Receipt Mic Algorithms", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The senders list of signing algorithms for signing receipt, in preferred order, or null if requesting an unsigned receipt.", "optional": true }, "signingAlgorithm": { "index": 18, "kind": "parameter", "displayName": "Signing Algorithm", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "org.apache.camel.component.as2.api.AS2SignatureAlgorithm", "enum": [ "SHA3_224WITHRSA", "SHA3_256WITHRSA", "SHA3_384withRSA", "SHA3_512WITHRSA", "MD5WITHRSA", "SHA1WITHRSA", "MD2WITHRSA", "SHA224WITHRSA", "SHA256WITHRSA", "SHA384WITHRSA", "SHA512WITHRSA", "RIPEMD128WITHRSA", "RIPEMD160WITHRSA", "RIPEMD256WITHRSA", "SHA224WITHDSA", "SHA256WITHDSA", "SHA384WITHDSA", "SHA512WITHDSA", "SHA3_224WITHDSA", "SHA3_256WITHDSA", "SHA3_384WITHDSA", "SHA3_512WITHDSA", "SHA1WITHDSA", "SHA3_224WITHECDSA", "SHA3_256WITHECDSA", "SHA3_384WITHECDSA", "SHA3_512WITHECDSA", "SHA1WITHECDSA", "SHA224WITHECDSA", "SHA256WITHECDSA", "SHA384WITHECDSA", "SHA512WITHECDSA", "SHA1WITHPLAIN_ECDSA", "SHA224WITHPLAIN_ECDSA", "SHA256WITHPLAIN_ECDSA", "SHA384WITHPLAIN_ECDSA", "SHA512WITHPLAIN_ECDSA", "RIPEMD160WITHPLAIN_ECDSA", "SHA1WITHRSAANDMGF1", "SHA224WITHRSAANDMGF1", "SHA256WITHRSAANDMGF1", "SHA384WITHRSAANDMGF1", "SHA512WITHRSAANDMGF1", "SHA3_224WITHRSAANDMGF1", "SHA3_256WITHRSAANDMGF1", "SHA3_384WITHRSAANDMGF1", "SHA3_512WITHRSAANDMGF1" ], "deprecated": false, "autowired": false, "secret": false, "description": "The algorithm used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingCertificateChain": { "index": 19, "kind": "parameter", "displayName": "Signing Certificate Chain", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.cert.Certificate[]", "deprecated": false, "autowired": false, "secret": false, "description": "The chain of certificates used to sign the message or null if sending EDI message unsigned", "optional": true }, "signingPrivateKey": { "index": 20, "kind": "parameter", "displayName": "Signing Private Key", "group": "producer", "label": "", "required": false, "type": "object", "javaType": "java.security.PrivateKey", "deprecated": false, "autowired": false, "secret": false, "description": "The private key used to sign EDI message", "optional": true }, "subject": { "index": 21, "kind": "parameter", "displayName": "Subject", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "Message subject", "optional": false }, "userName": { "index": 22, "kind": "parameter", "displayName": "User Name", "group": "producer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "The user-name that is used for basic authentication", "optional": true } } } } },
"receipt": { "methods": { "receive": { "properties": { "requestUriPattern": { "index": 0, "kind": "parameter", "displayName": "Request Uri Pattern", "group": "consumer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "", "optional": false } } } } },
"server": { "methods": { "listen": { "properties": { "requestUriPattern": { "index": 0, "kind": "parameter", "displayName": "Request Uri Pattern", "group": "consumer", "label": "", "required": false, "type": "string", "javaType": "java.lang.String", "deprecated": false, "autowired": false, "secret": false, "description": "", "optional": false } } } } }
}
diff --git a/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/AS2Configuration.java b/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/AS2Configuration.java
index e71fd31846133..1baa79db7eda7 100644
--- a/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/AS2Configuration.java
+++ b/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/AS2Configuration.java
@@ -123,6 +123,18 @@ public class AS2Configuration {
private Integer asyncMdnPortNumber;
@UriParam
private String receiptDeliveryOption;
+ @UriParam(label = "security", secret = true)
+ private String userName;
+ @UriParam(label = "security", secret = true)
+ private String password;
+ @UriParam(label = "security", secret = true)
+ private String accessToken;
+ @UriParam(label = "security", secret = true)
+ private String mdnUserName;
+ @UriParam(label = "security", secret = true)
+ private String mdnPassword;
+ @UriParam(label = "security", secret = true)
+ private String mdnAccessToken;
public AS2ApiName getApiName() {
return apiName;
@@ -573,4 +585,72 @@ public String getReceiptDeliveryOption() {
public void setReceiptDeliveryOption(String receiptDeliveryOption) {
this.receiptDeliveryOption = receiptDeliveryOption;
}
+
+ public String getUserName() {
+ return userName;
+ }
+
+ /**
+ * The user-name that is used by the client for basic authentication. If options for basic authentication and bearer
+ * authentication are both set then basic authentication takes precedence.
+ */
+ public void setUserName(String userName) {
+ this.userName = userName;
+ }
+
+ public String getPassword() {
+ return password;
+ }
+
+ /**
+ * The password that is used by the client for basic authentication.
+ */
+ public void setPassword(String password) {
+ this.password = password;
+ }
+
+ public String getAccessToken() {
+ return accessToken;
+ }
+
+ /**
+ * The access token that is used by the client for bearer authentication.
+ */
+ public void setAccessToken(String accessToken) {
+ this.accessToken = accessToken;
+ }
+
+ public String getMdnUserName() {
+ return mdnUserName;
+ }
+
+ /**
+ * The user-name that is used by the server for basic authentication when it sends an async MDN. If options for
+ * basic authentication and bearer authentication are both set then basic authentication takes precedence.
+ */
+ public void setMdnUserName(String mdnUserName) {
+ this.mdnUserName = mdnUserName;
+ }
+
+ public String getMdnPassword() {
+ return mdnPassword;
+ }
+
+ /**
+ * The password that is used by the server for basic authentication when it sends an async MDN.
+ */
+ public void setMdnPassword(String mdnPassword) {
+ this.mdnPassword = mdnPassword;
+ }
+
+ public String getMdnAccessToken() {
+ return mdnAccessToken;
+ }
+
+ /**
+ * The access token that is used by the server when it sends an async MDN.
+ */
+ public void setMdnAccessToken(String accessToken) {
+ this.mdnAccessToken = accessToken;
+ }
}
diff --git a/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/internal/AS2ConnectionHelper.java b/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/internal/AS2ConnectionHelper.java
index c43297fa924f7..3342da15bd952 100644
--- a/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/internal/AS2ConnectionHelper.java
+++ b/components/camel-as2/camel-as2-component/src/main/java/org/apache/camel/component/as2/internal/AS2ConnectionHelper.java
@@ -105,7 +105,9 @@ public static AS2ServerConnection createAS2ServerConnection(AS2Configuration con
configuration.getSigningAlgorithm(),
configuration.getSigningCertificateChain(), configuration.getSigningPrivateKey(),
configuration.getDecryptingPrivateKey(), configuration.getMdnMessageTemplate(),
- configuration.getValidateSigningCertificateChain(), configuration.getSslContext());
+ configuration.getValidateSigningCertificateChain(), configuration.getSslContext(),
+ configuration.getMdnUserName(), configuration.getMdnPassword(),
+ configuration.getMdnAccessToken());
} catch (IOException e) {
throw new UncheckedIOException(e);
}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerIT.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerIT.java
index cbbf0982edf07..87998c2d76f14 100644
--- a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerIT.java
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMDNServerManagerIT.java
@@ -436,7 +436,7 @@ private static void receiveTestMessages() throws IOException {
AS2_VERSION, ORIGIN_SERVER_NAME,
SERVER_FQDN, PARTNER_TARGET_PORT, AS2SignatureAlgorithm.SHA256WITHRSA,
new Certificate[] { serverCert }, serverKP.getPrivate(), null,
- MDN_MESSAGE_TEMPLATE, new Certificate[] { clientCert }, null);
+ MDN_MESSAGE_TEMPLATE, new Certificate[] { clientCert }, null, null, null, null);
requestHandler = new RequestHandler();
serverConnection.listen("/", requestHandler);
}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMdnBasicAuthHeaderTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMdnBasicAuthHeaderTest.java
new file mode 100644
index 0000000000000..515188088e3ac
--- /dev/null
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMdnBasicAuthHeaderTest.java
@@ -0,0 +1,193 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.as2;
+
+import java.io.IOException;
+import java.nio.charset.StandardCharsets;
+import java.util.Base64;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.Exchange;
+import org.apache.camel.Message;
+import org.apache.camel.Processor;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.as2.api.*;
+import org.apache.camel.component.as2.api.entity.DispositionNotificationMultipartReportEntity;
+import org.apache.camel.component.as2.api.entity.MimeEntity;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.http.common.HttpMessage;
+import org.apache.camel.test.AvailablePortFinder;
+import org.apache.hc.core5.http.ContentType;
+import org.junit.jupiter.api.AfterAll;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.Test;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertFalse;
+import static org.junit.jupiter.api.Assertions.assertNotNull;
+import static org.junit.jupiter.api.Assertions.assertTrue;
+
+/**
+ * Verify that the authorization header is added to the Async AS2 MDN request sent by the server for Basic Auth.
+ */
+public class AS2AsyncMdnBasicAuthHeaderTest extends AbstractAS2ITSupport {
+
+ // Basic Auth takes precedence when auth token also provided
+ private static final String MDN_USER_NAME = "camel";
+ private static final String MDN_PASSWORD = "rider";
+ private static final String MDN_ACCESS_TOKEN = "MTQ0NjJkZmQ5OTM2NDE1ZTZjNGZmZjI3";
+ private static final int RECEIPT_SERVER_PORT = AvailablePortFinder.getNextAvailable();
+ private static final int JETTY_PORT = AvailablePortFinder.getNextAvailable();
+ private static final String EDI_MESSAGE = "UNB+UNOA:1+005435656:1+006415160:1+060515:1434+00000000000778'\n"
+ + "UNH+00000000000117+INVOIC:D:97B:UN'\n"
+ + "BGM+380+342459+9'\n"
+ + "DTM+3:20060515:102'\n"
+ + "RFF+ON:521052'\n"
+ + "NAD+BY+792820524::16++CUMMINS MID-RANGE ENGINE PLANT'\n"
+ + "NAD+SE+005435656::16++GENERAL WIDGET COMPANY'\n"
+ + "CUX+1:USD'\n"
+ + "LIN+1++157870:IN'\n"
+ + "IMD+F++:::WIDGET'\n"
+ + "QTY+47:1020:EA'\n"
+ + "ALI+US'\n"
+ + "MOA+203:1202.58'\n"
+ + "PRI+INV:1.179'\n"
+ + "LIN+2++157871:IN'\n"
+ + "IMD+F++:::DIFFERENT WIDGET'\n"
+ + "QTY+47:20:EA'\n"
+ + "ALI+JP'\n"
+ + "MOA+203:410'\n"
+ + "PRI+INV:20.5'\n"
+ + "UNS+S'\n"
+ + "MOA+39:2137.58'\n"
+ + "ALC+C+ABG'\n"
+ + "MOA+8:525'\n"
+ + "UNT+23+00000000000117'\n"
+ + "UNZ+1+00000000000778'\n";
+
+ private static AS2ServerConnection serverConnection;
+
+ @BeforeAll
+ public static void setupTest() throws Exception {
+ receiveTestMessages();
+ }
+
+ @AfterAll
+ public static void tearDownTest() {
+ if (serverConnection != null) {
+ serverConnection.close();
+ }
+ }
+
+ @Test
+ public void asyncMdnHasBasicAuthHeader() throws Exception {
+ requestBodyAndHeaders("direct://SEND", EDI_MESSAGE,
+ getAS2Headers("http://localhost:" + JETTY_PORT + "/handle-receipts"));
+
+ MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvRcptMsgs");
+ mockEndpoint.expectedMinimumMessageCount(1);
+ mockEndpoint.setResultWaitTime(TimeUnit.MILLISECONDS.convert(5, TimeUnit.SECONDS));
+ mockEndpoint.assertIsSatisfied();
+ }
+
+ // regression
+ @Test
+ public void asyncMdnHasExpectedParts() throws Exception {
+ requestBodyAndHeaders("direct://SEND", EDI_MESSAGE,
+ getAS2Headers("http://localhost:" + RECEIPT_SERVER_PORT + "/handle-receipts"));
+
+ MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvRcptMsgs2");
+ mockEndpoint.expectedMinimumMessageCount(1);
+ mockEndpoint.setResultWaitTime(TimeUnit.MILLISECONDS.convert(5, TimeUnit.SECONDS));
+ mockEndpoint.assertIsSatisfied();
+
+ List exchanges = mockEndpoint.getExchanges();
+ assertNotNull(exchanges);
+ assertFalse(exchanges.isEmpty());
+
+ Message message = exchanges.get(0).getIn();
+ assertNotNull(message);
+ assertTrue(message.getBody() instanceof DispositionNotificationMultipartReportEntity);
+
+ DispositionNotificationMultipartReportEntity mdn = (DispositionNotificationMultipartReportEntity) message.getBody();
+ assertEquals(2, mdn.getPartCount(), "Unexpected number of body parts in report");
+
+ MimeEntity reportPartOne = mdn.getPart(0);
+ assertEquals(ContentType.create(AS2MimeType.TEXT_PLAIN, StandardCharsets.US_ASCII).toString(),
+ reportPartOne.getContentType());
+
+ MimeEntity reportPartTwo = mdn.getPart(1);
+ assertEquals(ContentType.create(AS2MimeType.MESSAGE_DISPOSITION_NOTIFICATION).toString(),
+ reportPartTwo.getContentType());
+ }
+
+ private Map getAS2Headers(String asyncMdnDeliveryAddress) {
+ Map headers = new HashMap<>();
+ headers.put("CamelAs2.requestUri", "/");
+ headers.put("CamelAs2.subject", "Test Case");
+ headers.put("CamelAs2.from", "mrAS@example.org");
+ headers.put("CamelAs2.as2From", "878051556");
+ headers.put("CamelAs2.as2To", "878051556");
+ headers.put("CamelAs2.as2MessageStructure", AS2MessageStructure.PLAIN);
+ headers.put("CamelAs2.ediMessageContentType", AS2MediaType.APPLICATION_EDIFACT);
+ headers.put("CamelAs2.ediMessageTransferEncoding", "7bit");
+ headers.put("CamelAs2.dispositionNotificationTo", "mrAS2@example.com");
+ headers.put("CamelAs2.receiptDeliveryOption", asyncMdnDeliveryAddress);
+ return headers;
+ }
+
+ @Override
+ protected RouteBuilder createRouteBuilder() {
+ return new RouteBuilder() {
+ public void configure() {
+ Processor proc = exchange -> {
+ HttpMessage message = exchange.getIn(HttpMessage.class);
+
+ assertNotNull(message.getHeader("Authorization"));
+ String encoded = Base64.getEncoder().encodeToString((MDN_USER_NAME + ":" + MDN_PASSWORD).getBytes());
+ assertEquals("Basic " + encoded, message.getHeader("Authorization"));
+ };
+
+ from("direct://SEND")
+ .to("as2://client/send?inBody=ediMessage&httpSocketTimeout=5m&httpConnectionTimeout=5m");
+
+ from("jetty:http://localhost:" + JETTY_PORT + "/handle-receipts")
+ .process(proc)
+ .to("mock:as2RcvRcptMsgs");
+
+ fromF("as2://receipt/receive?requestUriPattern=/handle-receipts&asyncMdnPortNumber=%s",
+ RECEIPT_SERVER_PORT)
+ .to("mock:as2RcvRcptMsgs2");
+ }
+ };
+ }
+
+ // AS2 server adds Authorization header to MDN returned asynchronously
+ private static void receiveTestMessages() throws IOException {
+ serverConnection = new AS2ServerConnection(
+ "1.1", "AS2ClientManagerIntegrationTest Server",
+ "server.example.com", 8888, AS2SignatureAlgorithm.SHA256WITHRSA,
+ null, null, null,
+ "TBD", null, null,
+ // server authorization config
+ MDN_USER_NAME, MDN_PASSWORD, MDN_ACCESS_TOKEN);
+ serverConnection.listen("/", new AS2AsyncMDNServerManagerIT.RequestHandler());
+ }
+}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMdnTokenAuthHeaderTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMdnTokenAuthHeaderTest.java
new file mode 100644
index 0000000000000..19f9cd176b625
--- /dev/null
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2AsyncMdnTokenAuthHeaderTest.java
@@ -0,0 +1,145 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.as2;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.Processor;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.as2.api.AS2MediaType;
+import org.apache.camel.component.as2.api.AS2MessageStructure;
+import org.apache.camel.component.as2.api.AS2ServerConnection;
+import org.apache.camel.component.as2.api.AS2SignatureAlgorithm;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.http.common.HttpMessage;
+import org.apache.camel.test.AvailablePortFinder;
+import org.junit.jupiter.api.AfterAll;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.Test;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertNotNull;
+
+/**
+ * Verify that the authorization header is added to the Async AS2 MDN request sent by the server for Bearer Auth.
+ */
+public class AS2AsyncMdnTokenAuthHeaderTest extends AbstractAS2ITSupport {
+
+ private static final String MDN_ACCESS_TOKEN = "MTQ0NjJkZmQ5OTM2NDE1ZTZjNGZmZjI3";
+ private static final int RECEIPT_SERVER_PORT = AvailablePortFinder.getNextAvailable();
+ private static final String EDI_MESSAGE = "UNB+UNOA:1+005435656:1+006415160:1+060515:1434+00000000000778'\n"
+ + "UNH+00000000000117+INVOIC:D:97B:UN'\n"
+ + "BGM+380+342459+9'\n"
+ + "DTM+3:20060515:102'\n"
+ + "RFF+ON:521052'\n"
+ + "NAD+BY+792820524::16++CUMMINS MID-RANGE ENGINE PLANT'\n"
+ + "NAD+SE+005435656::16++GENERAL WIDGET COMPANY'\n"
+ + "CUX+1:USD'\n"
+ + "LIN+1++157870:IN'\n"
+ + "IMD+F++:::WIDGET'\n"
+ + "QTY+47:1020:EA'\n"
+ + "ALI+US'\n"
+ + "MOA+203:1202.58'\n"
+ + "PRI+INV:1.179'\n"
+ + "LIN+2++157871:IN'\n"
+ + "IMD+F++:::DIFFERENT WIDGET'\n"
+ + "QTY+47:20:EA'\n"
+ + "ALI+JP'\n"
+ + "MOA+203:410'\n"
+ + "PRI+INV:20.5'\n"
+ + "UNS+S'\n"
+ + "MOA+39:2137.58'\n"
+ + "ALC+C+ABG'\n"
+ + "MOA+8:525'\n"
+ + "UNT+23+00000000000117'\n"
+ + "UNZ+1+00000000000778'\n";
+
+ private static AS2ServerConnection serverConnection;
+
+ @BeforeAll
+ public static void setupTest() throws Exception {
+ receiveTestMessages();
+ }
+
+ @AfterAll
+ public static void tearDownTest() {
+ if (serverConnection != null) {
+ serverConnection.close();
+ }
+ }
+
+ @Test
+ public void asyncMdnHasTokenAuthHeader() throws Exception {
+ requestBodyAndHeaders("direct://SEND", EDI_MESSAGE,
+ getAS2Headers("http://localhost:" + RECEIPT_SERVER_PORT + "/handle-receipts"));
+
+ MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvRcptMsgs");
+ mockEndpoint.expectedMinimumMessageCount(1);
+ mockEndpoint.setResultWaitTime(TimeUnit.MILLISECONDS.convert(5, TimeUnit.SECONDS));
+ mockEndpoint.assertIsSatisfied();
+ }
+
+ private Map getAS2Headers(String asyncMdnDeliveryAddress) {
+ Map headers = new HashMap<>();
+ headers.put("CamelAs2.requestUri", "/");
+ headers.put("CamelAs2.subject", "Test Case");
+ headers.put("CamelAs2.from", "mrAS@example.org");
+ headers.put("CamelAs2.as2From", "878051556");
+ headers.put("CamelAs2.as2To", "878051556");
+ headers.put("CamelAs2.as2MessageStructure", AS2MessageStructure.PLAIN);
+ headers.put("CamelAs2.ediMessageContentType", AS2MediaType.APPLICATION_EDIFACT);
+ headers.put("CamelAs2.ediMessageTransferEncoding", "7bit");
+ headers.put("CamelAs2.dispositionNotificationTo", "mrAS2@example.com");
+ headers.put("CamelAs2.receiptDeliveryOption", asyncMdnDeliveryAddress);
+ return headers;
+ }
+
+ @Override
+ protected RouteBuilder createRouteBuilder() {
+ return new RouteBuilder() {
+ public void configure() {
+ Processor proc = exchange -> {
+ HttpMessage message = exchange.getIn(HttpMessage.class);
+
+ assertNotNull(message.getHeader("Authorization"));
+ assertEquals("Bearer " + MDN_ACCESS_TOKEN, message.getHeader("Authorization"));
+ };
+
+ from("direct://SEND")
+ .to("as2://client/send?inBody=ediMessage&httpSocketTimeout=5m&httpConnectionTimeout=5m");
+
+ from("jetty:http://localhost:" + RECEIPT_SERVER_PORT + "/handle-receipts").process(proc)
+ .to("mock:as2RcvRcptMsgs");
+ }
+ };
+ }
+
+ // AS2 server adds Authorization header to MDN returned asynchronously
+ private static void receiveTestMessages() throws IOException {
+ serverConnection = new AS2ServerConnection(
+ "1.1", "AS2ClientManagerIntegrationTest Server",
+ "server.example.com", 8888, AS2SignatureAlgorithm.SHA256WITHRSA,
+ null, null, null,
+ "TBD", null, null,
+ // server authorization config
+ null, null, MDN_ACCESS_TOKEN);
+ serverConnection.listen("/", new AS2AsyncMDNServerManagerIT.RequestHandler());
+ }
+}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2BasicAuthHeaderTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2BasicAuthHeaderTest.java
new file mode 100644
index 0000000000000..803490cb7e9d7
--- /dev/null
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2BasicAuthHeaderTest.java
@@ -0,0 +1,199 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.as2;
+
+import java.io.IOException;
+import java.nio.charset.StandardCharsets;
+import java.util.Base64;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.as2.api.*;
+import org.apache.camel.component.as2.api.entity.ApplicationEntity;
+import org.apache.camel.component.as2.api.entity.DispositionNotificationMultipartReportEntity;
+import org.apache.camel.component.as2.api.entity.MimeEntity;
+import org.apache.hc.core5.http.ClassicHttpRequest;
+import org.apache.hc.core5.http.ContentType;
+import org.apache.hc.core5.http.HttpEntity;
+import org.apache.hc.core5.http.HttpRequest;
+import org.junit.jupiter.api.AfterAll;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.Test;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertInstanceOf;
+import static org.junit.jupiter.api.Assertions.assertNotNull;
+
+/**
+ * Verify that the authorization header is added to the request sent to the AS2 server for Basic Auth.
+ */
+public class AS2BasicAuthHeaderTest extends AbstractAS2ITSupport {
+
+ // Basic Auth takes precedence when auth token also provided
+ private static final String USER_NAME = "camel";
+ private static final String PASSWORD = "rider";
+ private static final String ACCESS_TOKEN = "MTQ0NjJkZmQ5OTM2NDE1ZTZjNGZmZjI3";
+ private static final String EDI_MESSAGE = "UNB+UNOA:1+005435656:1+006415160:1+060515:1434+00000000000778'\n"
+ + "UNH+00000000000117+INVOIC:D:97B:UN'\n"
+ + "BGM+380+342459+9'\n"
+ + "DTM+3:20060515:102'\n"
+ + "RFF+ON:521052'\n"
+ + "NAD+BY+792820524::16++CUMMINS MID-RANGE ENGINE PLANT'\n"
+ + "NAD+SE+005435656::16++GENERAL WIDGET COMPANY'\n"
+ + "CUX+1:USD'\n"
+ + "LIN+1++157870:IN'\n"
+ + "IMD+F++:::WIDGET'\n"
+ + "QTY+47:1020:EA'\n"
+ + "ALI+US'\n"
+ + "MOA+203:1202.58'\n"
+ + "PRI+INV:1.179'\n"
+ + "LIN+2++157871:IN'\n"
+ + "IMD+F++:::DIFFERENT WIDGET'\n"
+ + "QTY+47:20:EA'\n"
+ + "ALI+JP'\n"
+ + "MOA+203:410'\n"
+ + "PRI+INV:20.5'\n"
+ + "UNS+S'\n"
+ + "MOA+39:2137.58'\n"
+ + "ALC+C+ABG'\n"
+ + "MOA+8:525'\n"
+ + "UNT+23+00000000000117'\n"
+ + "UNZ+1+00000000000778'\n";
+
+ private static AS2ServerConnection serverConnection;
+ private static AS2ClientManagerIT.RequestHandler requestHandler;
+
+ @BeforeAll
+ public static void setupTest() throws Exception {
+ receiveTestMessages();
+ }
+
+ @AfterAll
+ public static void tearDownTest() {
+ if (serverConnection != null) {
+ serverConnection.close();
+ }
+ }
+
+ @Test
+ public void clientSendsBasicAuthHeader() throws Exception {
+ Map headers = configureNonAuthHeaders();
+ headers.put("CamelAs2.userName", USER_NAME);
+ headers.put("CamelAs2.password", PASSWORD);
+ headers.put("CamelAs2.accessToken", ACCESS_TOKEN);
+ requestBodyAndHeaders("direct://SEND", EDI_MESSAGE, headers);
+
+ HttpRequest request = requestHandler.getRequest();
+ assertNotNull(request);
+ assertNotNull(request.getHeader("Authorization"));
+
+ String encodedCreds = Base64.getEncoder().encodeToString((USER_NAME + ":" + PASSWORD).getBytes());
+ assertEquals("Basic " + encodedCreds, request.getHeader("Authorization").getValue());
+ }
+
+ @Test
+ public void clientSendsBasicAuthHeaderRouteConfig() throws Exception {
+ requestBodyAndHeaders("direct://SEND2", EDI_MESSAGE, configureNonAuthHeaders());
+
+ HttpRequest request = requestHandler.getRequest();
+ assertNotNull(request);
+ assertNotNull(request.getHeader("Authorization"));
+
+ String encodedCreds = Base64.getEncoder().encodeToString((USER_NAME + ":" + PASSWORD).getBytes());
+ assertEquals("Basic " + encodedCreds, request.getHeader("Authorization").getValue());
+ }
+
+ // regression
+ @Test
+ public void clientSendsRequestMessage() {
+ requestBodyAndHeaders("direct://SEND2", EDI_MESSAGE, configureNonAuthHeaders());
+
+ HttpRequest request = requestHandler.getRequest();
+ assertNotNull(request);
+ assertInstanceOf(ClassicHttpRequest.class, request);
+
+ HttpEntity entity = ((ClassicHttpRequest) request).getEntity();
+ assertNotNull(entity);
+ assertInstanceOf(ApplicationEntity.class, entity);
+
+ ApplicationEntity appEntity = (ApplicationEntity) entity;
+ assertInstanceOf(String.class, appEntity.getEdiMessage());
+ String ediMessage = (String) appEntity.getEdiMessage();
+ assertEquals(EDI_MESSAGE, ediMessage.replaceAll("\r", ""));
+ }
+
+ // regression, verify that the returned mdn holds the expected entity parts
+ @Test
+ public void serverSendsMdnResponse() {
+ HttpEntity responseEntity = requestBodyAndHeaders("direct://SEND2", EDI_MESSAGE, configureNonAuthHeaders());
+ assertNotNull(responseEntity);
+ assertInstanceOf(DispositionNotificationMultipartReportEntity.class, responseEntity);
+
+ DispositionNotificationMultipartReportEntity reportEntity
+ = (DispositionNotificationMultipartReportEntity) responseEntity;
+ assertEquals(2, reportEntity.getPartCount());
+
+ MimeEntity firstPart = reportEntity.getPart(0);
+ assertEquals(ContentType.create(AS2MimeType.TEXT_PLAIN, StandardCharsets.US_ASCII).toString(),
+ firstPart.getContentType());
+
+ MimeEntity secondPart = reportEntity.getPart(1);
+ assertEquals(ContentType.create(AS2MimeType.MESSAGE_DISPOSITION_NOTIFICATION).toString(), secondPart.getContentType());
+ }
+
+ private Map configureNonAuthHeaders() {
+ final Map headers = new HashMap<>();
+ headers.put("CamelAs2.requestUri", "/");
+ headers.put("CamelAs2.subject", "Test Case");
+ headers.put("CamelAs2.from", "mrAS@example.org");
+ headers.put("CamelAs2.as2From", "878051556");
+ headers.put("CamelAs2.as2To", "878051556");
+ headers.put("CamelAs2.as2MessageStructure", AS2MessageStructure.PLAIN);
+ headers.put("CamelAs2.ediMessageContentType", AS2MediaType.APPLICATION_EDIFACT);
+ headers.put("CamelAs2.ediMessageTransferEncoding", "7bit");
+ headers.put("CamelAs2.dispositionNotificationTo", "mrAS2@example.com");
+ headers.put("CamelAs2.attachedFileName", "");
+
+ return headers;
+ }
+
+ @Override
+ protected RouteBuilder createRouteBuilder() {
+ return new RouteBuilder() {
+ public void configure() {
+ from("direct://SEND")
+ .to("as2://client/send?inBody=ediMessage&httpSocketTimeout=5m&httpConnectionTimeout=5m");
+
+ from("direct://SEND2")
+ .toF("as2://client/send?userName=%s&password=%s&accessToken=%s" +
+ "&inBody=ediMessage&httpSocketTimeout=5m&httpConnectionTimeout=5m",
+ USER_NAME, PASSWORD, ACCESS_TOKEN);
+ }
+ };
+ }
+
+ private static void receiveTestMessages() throws IOException {
+ serverConnection = new AS2ServerConnection(
+ "1.1", "AS2ClientManagerIntegrationTest Server",
+ "server.example.com", 8888, AS2SignatureAlgorithm.SHA256WITHRSA,
+ null, null, null,
+ "TBD", null, null, null, null, null);
+ requestHandler = new AS2ClientManagerIT.RequestHandler();
+ serverConnection.listen("/", requestHandler);
+ }
+}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ClientManagerIT.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ClientManagerIT.java
index 7a87f7f7d57a3..574e791e1138c 100644
--- a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ClientManagerIT.java
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ClientManagerIT.java
@@ -844,7 +844,7 @@ public void asyncMDNTest() {
private void runAsyncMDNTest() throws CamelException, HttpException {
AS2AsynchronousMDNManager mdnManager = new AS2AsynchronousMDNManager(
AS2_VERSION, ORIGIN_SERVER_NAME, SERVER_FQDN,
- new Certificate[] { clientCert }, clientKeyPair.getPrivate());
+ new Certificate[] { clientCert }, clientKeyPair.getPrivate(), null, null, null);
// Create plain edi request message to acknowledge
ApplicationEntity ediEntity = EntityUtils
@@ -994,7 +994,7 @@ private static void receiveTestMessages() throws IOException {
AS2_VERSION, ORIGIN_SERVER_NAME,
SERVER_FQDN, PARTNER_TARGET_PORT, AS2SignatureAlgorithm.SHA256WITHRSA,
new Certificate[] { serverCert }, serverKP.getPrivate(), null,
- MDN_MESSAGE_TEMPLATE, null, null);
+ MDN_MESSAGE_TEMPLATE, null, null, null, null, null);
requestHandler = new RequestHandler();
serverConnection.listen("/", requestHandler);
}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerBasicAuthHeaderTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerBasicAuthHeaderTest.java
new file mode 100644
index 0000000000000..e3a3eef0f8495
--- /dev/null
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerBasicAuthHeaderTest.java
@@ -0,0 +1,121 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.as2;
+
+import java.io.IOException;
+import java.time.Duration;
+import java.util.Base64;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.Processor;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.as2.api.AS2ClientConnection;
+import org.apache.camel.component.as2.api.AS2ClientManager;
+import org.apache.camel.component.as2.api.AS2MediaType;
+import org.apache.camel.component.as2.api.AS2MessageStructure;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.http.common.HttpMessage;
+import org.apache.camel.test.AvailablePortFinder;
+import org.junit.jupiter.api.Test;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertNotNull;
+
+/**
+ * Test that the server adds a Basic Auth authorization header when sending an async MDN.
+ */
+public class AS2ServerBasicAuthHeaderTest extends AbstractAS2ITSupport {
+
+ private static final String MDN_USER_NAME = "camel";
+ private static final String MDN_PASSWORD = "rider";
+ private static final int JETTY_PORT = AvailablePortFinder.getNextAvailable();
+ private static final String EDI_MESSAGE = "UNB+UNOA:1+005435656:1+006415160:1+060515:1434+00000000000778'\n"
+ + "UNH+00000000000117+INVOIC:D:97B:UN'\n"
+ + "BGM+380+342459+9'\n"
+ + "DTM+3:20060515:102'\n"
+ + "RFF+ON:521052'\n"
+ + "NAD+BY+792820524::16++CUMMINS MID-RANGE ENGINE PLANT'\n"
+ + "NAD+SE+005435656::16++GENERAL WIDGET COMPANY'\n"
+ + "CUX+1:USD'\n"
+ + "LIN+1++157870:IN'\n"
+ + "IMD+F++:::WIDGET'\n"
+ + "QTY+47:1020:EA'\n"
+ + "ALI+US'\n"
+ + "MOA+203:1202.58'\n"
+ + "PRI+INV:1.179'\n"
+ + "LIN+2++157871:IN'\n"
+ + "IMD+F++:::DIFFERENT WIDGET'\n"
+ + "QTY+47:20:EA'\n"
+ + "ALI+JP'\n"
+ + "MOA+203:410'\n"
+ + "PRI+INV:20.5'\n"
+ + "UNS+S'\n"
+ + "MOA+39:2137.58'\n"
+ + "ALC+C+ABG'\n"
+ + "MOA+8:525'\n"
+ + "UNT+23+00000000000117'\n"
+ + "UNZ+1+00000000000778'\n";
+
+ // verify that the jetty server receives a Basic Auth header
+ @Test
+ public void serverRouteWithBasicAuthConfig() throws Exception {
+ clientSend("/basic", "http://localhost:" + JETTY_PORT + "/receiptsWithBasicAuth");
+
+ MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvRcptMsgs");
+ mockEndpoint.expectedMinimumMessageCount(1);
+ mockEndpoint.setResultWaitTime(TimeUnit.MILLISECONDS.convert(5, TimeUnit.SECONDS));
+ mockEndpoint.assertIsSatisfied();
+ }
+
+ @Override
+ protected RouteBuilder createRouteBuilder() {
+ return new RouteBuilder() {
+ public void configure() {
+
+ Processor basicHeaderProc = exchange -> {
+ HttpMessage message = exchange.getIn(HttpMessage.class);
+ assertNotNull(message.getHeader("Authorization"));
+ String encoded = Base64.getEncoder().encodeToString((MDN_USER_NAME + ":" + MDN_PASSWORD).getBytes());
+ assertEquals("Basic " + encoded, message.getHeader("Authorization"));
+ };
+
+ from(String.format("as2://server/listen?requestUriPattern=/basic&mdnUserName=%s&mdnPassword=%s",
+ MDN_USER_NAME, MDN_PASSWORD))
+ .to("mock:as2RcvMsgs");
+
+ from("jetty:http://localhost:" + JETTY_PORT + "/receiptsWithBasicAuth")
+ .process(basicHeaderProc)
+ .to("mock:as2RcvRcptMsgs");
+ }
+ };
+ }
+
+ private void clientSend(String requestUri, String receiptDeliveryOption) throws Exception {
+ AS2ClientConnection clientConnection = getAs2ClientConnection();
+ new AS2ClientManager(clientConnection).send(EDI_MESSAGE, requestUri, "Test Case", "mrAS@example.org", "878051556",
+ "878051556", AS2MessageStructure.PLAIN,
+ AS2MediaType.APPLICATION_EDIFACT, null, null, null, null, null,
+ null, "mrAS@example.org", "sha1,md5", null, null, null, receiptDeliveryOption,
+ null, null, null);
+ }
+
+ private AS2ClientConnection getAs2ClientConnection() throws IOException {
+ return new AS2ClientConnection(
+ "1.1", "Camel AS2 Endpoint", "example.org", "localhost", 8888, Duration.ofSeconds(5),
+ Duration.ofSeconds(5), 5, Duration.ofMinutes(15), null, null);
+ }
+}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerBearerAuthHeaderTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerBearerAuthHeaderTest.java
new file mode 100644
index 0000000000000..d9b3577387130
--- /dev/null
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerBearerAuthHeaderTest.java
@@ -0,0 +1,118 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.as2;
+
+import java.io.IOException;
+import java.time.Duration;
+import java.util.concurrent.TimeUnit;
+
+import org.apache.camel.Processor;
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.as2.api.AS2ClientConnection;
+import org.apache.camel.component.as2.api.AS2ClientManager;
+import org.apache.camel.component.as2.api.AS2MediaType;
+import org.apache.camel.component.as2.api.AS2MessageStructure;
+import org.apache.camel.component.mock.MockEndpoint;
+import org.apache.camel.http.common.HttpMessage;
+import org.apache.camel.test.AvailablePortFinder;
+import org.junit.jupiter.api.Test;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertNotNull;
+
+/**
+ * Test that the server adds a Bearer Auth authorization header when sending an async MDN.
+ */
+public class AS2ServerBearerAuthHeaderTest extends AbstractAS2ITSupport {
+
+ private static final String MDN_ACCESS_TOKEN = "MTQ0NjJkZmQ5OTM2NDE1ZTZjNGZmZjI3";
+ private static final int JETTY_PORT = AvailablePortFinder.getNextAvailable();
+ private static final String EDI_MESSAGE = "UNB+UNOA:1+005435656:1+006415160:1+060515:1434+00000000000778'\n"
+ + "UNH+00000000000117+INVOIC:D:97B:UN'\n"
+ + "BGM+380+342459+9'\n"
+ + "DTM+3:20060515:102'\n"
+ + "RFF+ON:521052'\n"
+ + "NAD+BY+792820524::16++CUMMINS MID-RANGE ENGINE PLANT'\n"
+ + "NAD+SE+005435656::16++GENERAL WIDGET COMPANY'\n"
+ + "CUX+1:USD'\n"
+ + "LIN+1++157870:IN'\n"
+ + "IMD+F++:::WIDGET'\n"
+ + "QTY+47:1020:EA'\n"
+ + "ALI+US'\n"
+ + "MOA+203:1202.58'\n"
+ + "PRI+INV:1.179'\n"
+ + "LIN+2++157871:IN'\n"
+ + "IMD+F++:::DIFFERENT WIDGET'\n"
+ + "QTY+47:20:EA'\n"
+ + "ALI+JP'\n"
+ + "MOA+203:410'\n"
+ + "PRI+INV:20.5'\n"
+ + "UNS+S'\n"
+ + "MOA+39:2137.58'\n"
+ + "ALC+C+ABG'\n"
+ + "MOA+8:525'\n"
+ + "UNT+23+00000000000117'\n"
+ + "UNZ+1+00000000000778'\n";
+
+ // verify that the jetty server receives a Bearer Auth header
+ @Test
+ public void serverRouteWithBearerAuthConfig() throws Exception {
+ clientSend("/bearer", "http://localhost:" + JETTY_PORT + "/receiptsWithBearerAuth");
+
+ MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvRcptMsgs2");
+ mockEndpoint.expectedMinimumMessageCount(1);
+ mockEndpoint.setResultWaitTime(TimeUnit.MILLISECONDS.convert(5, TimeUnit.SECONDS));
+ mockEndpoint.assertIsSatisfied();
+ }
+
+ @Override
+ protected RouteBuilder createRouteBuilder() {
+ return new RouteBuilder() {
+ public void configure() {
+
+ Processor tokenHeaderProc = exchange -> {
+ HttpMessage message = exchange.getIn(HttpMessage.class);
+ assertNotNull(message.getHeader("Authorization"));
+ assertEquals("Bearer " + MDN_ACCESS_TOKEN, message.getHeader("Authorization"));
+ };
+
+ from(String.format("as2://server/listen?requestUriPattern=/bearer&mdnAccessToken=%s",
+ MDN_ACCESS_TOKEN))
+ .to("mock:as2RcvMsgs");
+
+ from("jetty:http://localhost:" + JETTY_PORT + "/receiptsWithBearerAuth")
+ .process(tokenHeaderProc)
+ .to("mock:as2RcvRcptMsgs2");
+ }
+ };
+ }
+
+ private void clientSend(String requestUri, String receiptDeliveryOption) throws Exception {
+ AS2ClientConnection clientConnection = getAs2ClientConnection();
+ new AS2ClientManager(clientConnection).send(EDI_MESSAGE, requestUri, "Test Case", "mrAS@example.org", "878051556",
+ "878051556", AS2MessageStructure.PLAIN,
+ AS2MediaType.APPLICATION_EDIFACT, null, null, null, null, null,
+ null, "mrAS@example.org", "sha1,md5", null, null, null, receiptDeliveryOption,
+ null, null, null);
+ }
+
+ private AS2ClientConnection getAs2ClientConnection() throws IOException {
+ return new AS2ClientConnection(
+ "1.1", "Camel AS2 Endpoint", "example.org", "localhost", 8888, Duration.ofSeconds(5),
+ Duration.ofSeconds(5), 5, Duration.ofMinutes(15), null, null);
+ }
+}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerEncryptedIT.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerEncryptedIT.java
index 7edecac479ebd..53806e9297127 100644
--- a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerEncryptedIT.java
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerEncryptedIT.java
@@ -68,7 +68,7 @@ public void receiveEnvelopedMessageTest() throws Exception {
clientManager.send(EDI_MESSAGE, REQUEST_URI, SUBJECT, FROM, AS2_NAME, AS2_NAME, AS2MessageStructure.ENCRYPTED,
AS2MediaType.APPLICATION_EDIFACT, null, null, null, null, null,
null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, AS2EncryptionAlgorithm.AES128_CBC,
- certList.toArray(new Certificate[0]), null, null);
+ certList.toArray(new Certificate[0]), null, null, null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
mockEndpoint.expectedMinimumMessageCount(1);
@@ -144,7 +144,8 @@ public void receiveEnvelopedCompressedAndSignedMessageTest() throws Exception {
AS2SignatureAlgorithm.SHA256WITHRSA, certList.toArray(new Certificate[0]), signingKP.getPrivate(),
AS2CompressionAlgorithm.ZLIB, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS,
AS2EncryptionAlgorithm.AES128_CBC,
- certList.toArray(new Certificate[0]), null, null);
+ certList.toArray(new Certificate[0]), null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
verifyMock(mockEndpoint);
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerIT.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerIT.java
index 2112fbfcdd184..5793928696a80 100644
--- a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerIT.java
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerManagerIT.java
@@ -91,7 +91,8 @@ private void receivePlainEDIMessage(Object msg, String encoding) throws Exceptio
clientManager.send(msg, REQUEST_URI, SUBJECT, FROM, AS2_NAME, AS2_NAME, AS2MessageStructure.PLAIN,
AS2MediaType.APPLICATION_EDIFACT, null, encoding, null, null, null,
- null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
mockEndpoint.expectedMinimumMessageCount(1);
@@ -187,7 +188,8 @@ private void receiveMultipartSignedMessage(Object msg, String encoding) throws E
AS2MediaType.APPLICATION_EDIFACT, null, encoding,
AS2SignatureAlgorithm.SHA256WITHRSA,
certList.toArray(new Certificate[0]), signingKP.getPrivate(), null, DISPOSITION_NOTIFICATION_TO,
- SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
mockEndpoint.expectedMinimumMessageCount(1);
@@ -265,7 +267,8 @@ public void receiveMultipartSignedXMLMessageTest() throws Exception {
AS2MediaType.APPLICATION_XML, null, null, // this line is the difference
AS2SignatureAlgorithm.SHA256WITHRSA,
certList.toArray(new Certificate[0]), signingKP.getPrivate(), null, DISPOSITION_NOTIFICATION_TO,
- SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
mockEndpoint.expectedMinimumMessageCount(1);
@@ -355,7 +358,8 @@ public void receiveMultipartInvalidSignedMessageTest() throws Exception {
AS2MediaType.APPLICATION_EDIFACT, null, null,
AS2SignatureAlgorithm.SHA256WITHRSA,
new Certificate[] { hackerSigningCert }, hackerSigningKP.getPrivate(), null, DISPOSITION_NOTIFICATION_TO,
- SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
mockEndpoint.expectedMinimumMessageCount(1);
@@ -451,7 +455,8 @@ private void receiveMultipartCompressedAndSignedMessage(Object msg, String encod
AS2SignatureAlgorithm.SHA256WITHRSA,
certList.toArray(new Certificate[0]), signingKP.getPrivate(), AS2CompressionAlgorithm.ZLIB,
DISPOSITION_NOTIFICATION_TO,
- SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
verifyMock(mockEndpoint);
@@ -485,7 +490,8 @@ public void sendEditMessageToFailingProcessorTest() throws Exception {
HttpCoreContext context = clientManager.send(EDI_MESSAGE, "/process_error", SUBJECT, FROM, AS2_NAME, AS2_NAME,
AS2MessageStructure.PLAIN,
AS2MediaType.APPLICATION_EDIFACT, null, null, null, null, null,
- null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
MockEndpoint mockEndpoint = getMockEndpoint("mock:as2RcvMsgs");
mockEndpoint.expectedMinimumMessageCount(0);
@@ -510,7 +516,8 @@ public void checkMDNTest() throws Exception {
HttpCoreContext response
= clientManager.send(EDI_MESSAGE, REQUEST_URI, SUBJECT, FROM, AS2_NAME, AS2_NAME, AS2MessageStructure.PLAIN,
AS2MediaType.APPLICATION_EDIFACT, null, null, null, null, null,
- null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
assertEquals(new AS2Configuration().getServer(), response.getResponse().getFirstHeader(AS2Header.FROM).getValue(),
"Default value for From header not set");
@@ -521,7 +528,8 @@ public void checkMDNTest() throws Exception {
response = clientManager.send(EDI_MESSAGE, REQUEST_URI + "mdnTest", SUBJECT, FROM, AS2_NAME, AS2_NAME,
AS2MessageStructure.PLAIN,
AS2MediaType.APPLICATION_EDIFACT, null, null, null, null, null,
- null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null);
+ null, DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, null, null, null, null,
+ null, null, null);
assertEquals("MdnTestFrom", response.getResponse().getFirstHeader(AS2Header.FROM).getValue(),
"Configured value for From header not set");
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerSecTestBase.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerSecTestBase.java
index 42e1b55f5e864..ac0cc368e2521 100644
--- a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerSecTestBase.java
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2ServerSecTestBase.java
@@ -219,7 +219,7 @@ protected HttpCoreContext send(
AS2MediaType.APPLICATION_EDIFACT, null, null,
signingAlgorithm, signingCertificate, signingPrivateKey, compressionAlgorithm,
DISPOSITION_NOTIFICATION_TO, SIGNED_RECEIPT_MIC_ALGORITHMS, encryptionAlgorithm,
- encryptingCertificate, null, null);
+ encryptingCertificate, null, null, null, null, null);
}
protected AS2ClientManager clientConnection() throws IOException {
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2TokenAuthHeaderTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2TokenAuthHeaderTest.java
new file mode 100644
index 0000000000000..94d64de25985f
--- /dev/null
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/AS2TokenAuthHeaderTest.java
@@ -0,0 +1,145 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.component.as2;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.camel.builder.RouteBuilder;
+import org.apache.camel.component.as2.api.AS2MediaType;
+import org.apache.camel.component.as2.api.AS2MessageStructure;
+import org.apache.camel.component.as2.api.AS2ServerConnection;
+import org.apache.camel.component.as2.api.AS2SignatureAlgorithm;
+import org.apache.hc.core5.http.HttpRequest;
+import org.junit.jupiter.api.AfterAll;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.Test;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertNotNull;
+
+/**
+ * Verify that the authorization header is added to the request sent to the AS2 server for Bearer Auth.
+ */
+public class AS2TokenAuthHeaderTest extends AbstractAS2ITSupport {
+
+ private static final String ACCESS_TOKEN = "MTQ0NjJkZmQ5OTM2NDE1ZTZjNGZmZjI3";
+ private static final String EDI_MESSAGE = "UNB+UNOA:1+005435656:1+006415160:1+060515:1434+00000000000778'\n"
+ + "UNH+00000000000117+INVOIC:D:97B:UN'\n"
+ + "BGM+380+342459+9'\n"
+ + "DTM+3:20060515:102'\n"
+ + "RFF+ON:521052'\n"
+ + "NAD+BY+792820524::16++CUMMINS MID-RANGE ENGINE PLANT'\n"
+ + "NAD+SE+005435656::16++GENERAL WIDGET COMPANY'\n"
+ + "CUX+1:USD'\n"
+ + "LIN+1++157870:IN'\n"
+ + "IMD+F++:::WIDGET'\n"
+ + "QTY+47:1020:EA'\n"
+ + "ALI+US'\n"
+ + "MOA+203:1202.58'\n"
+ + "PRI+INV:1.179'\n"
+ + "LIN+2++157871:IN'\n"
+ + "IMD+F++:::DIFFERENT WIDGET'\n"
+ + "QTY+47:20:EA'\n"
+ + "ALI+JP'\n"
+ + "MOA+203:410'\n"
+ + "PRI+INV:20.5'\n"
+ + "UNS+S'\n"
+ + "MOA+39:2137.58'\n"
+ + "ALC+C+ABG'\n"
+ + "MOA+8:525'\n"
+ + "UNT+23+00000000000117'\n"
+ + "UNZ+1+00000000000778'\n";
+
+ private static AS2ServerConnection serverConnection;
+ private static AS2ClientManagerIT.RequestHandler requestHandler;
+
+ @BeforeAll
+ public static void setupTest() throws Exception {
+ receiveTestMessages();
+ }
+
+ @AfterAll
+ public static void tearDownTest() {
+ if (serverConnection != null) {
+ serverConnection.close();
+ }
+ }
+
+ @Test
+ public void clientSendsBasicAuthHeader() throws Exception {
+ Map headers = configureNonAuthHeaders();
+ headers.put("CamelAs2.accessToken", ACCESS_TOKEN);
+ requestBodyAndHeaders("direct://SEND", EDI_MESSAGE, headers);
+
+ HttpRequest request = requestHandler.getRequest();
+ assertNotNull(request);
+ assertNotNull(request.getHeader("Authorization"));
+ assertEquals("Bearer " + ACCESS_TOKEN, request.getHeader("Authorization").getValue());
+ }
+
+ @Test
+ public void clientSendsBasicAuthHeaderRouteConfig() throws Exception {
+ requestBodyAndHeaders("direct://SEND2", EDI_MESSAGE, configureNonAuthHeaders());
+
+ HttpRequest request = requestHandler.getRequest();
+ assertNotNull(request);
+ assertNotNull(request.getHeader("Authorization"));
+ assertEquals("Bearer " + ACCESS_TOKEN, request.getHeader("Authorization").getValue());
+ }
+
+ private Map configureNonAuthHeaders() {
+ final Map headers = new HashMap<>();
+ headers.put("CamelAs2.requestUri", "/");
+ headers.put("CamelAs2.subject", "Test Case");
+ headers.put("CamelAs2.from", "mrAS@example.org");
+ headers.put("CamelAs2.as2From", "878051556");
+ headers.put("CamelAs2.as2To", "878051556");
+ headers.put("CamelAs2.as2MessageStructure", AS2MessageStructure.PLAIN);
+ headers.put("CamelAs2.ediMessageContentType", AS2MediaType.APPLICATION_EDIFACT);
+ headers.put("CamelAs2.ediMessageTransferEncoding", "7bit");
+ headers.put("CamelAs2.dispositionNotificationTo", "mrAS2@example.com");
+ headers.put("CamelAs2.attachedFileName", "");
+
+ return headers;
+ }
+
+ @Override
+ protected RouteBuilder createRouteBuilder() {
+ return new RouteBuilder() {
+ public void configure() {
+ from("direct://SEND")
+ .to("as2://client/send?inBody=ediMessage&httpSocketTimeout=5m&httpConnectionTimeout=5m");
+
+ from("direct://SEND2")
+ .toF("as2://client/send?accessToken=%s" +
+ "&inBody=ediMessage&httpSocketTimeout=5m&httpConnectionTimeout=5m", ACCESS_TOKEN);
+ }
+ };
+ }
+
+ private static void receiveTestMessages() throws IOException {
+ serverConnection = new AS2ServerConnection(
+ "1.1", "AS2ClientManagerIntegrationTest Server",
+ "server.example.com", 8888, AS2SignatureAlgorithm.SHA256WITHRSA,
+ null, null, null,
+ "TBD", null, null, null, null, null);
+ requestHandler = new AS2ClientManagerIT.RequestHandler();
+ serverConnection.listen("/", requestHandler);
+ }
+}
diff --git a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/CreateEndpointManualIssueTest.java b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/CreateEndpointManualIssueTest.java
index 7bf89fae99543..b94ef528f8dc8 100644
--- a/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/CreateEndpointManualIssueTest.java
+++ b/components/camel-as2/camel-as2-component/src/test/java/org/apache/camel/component/as2/CreateEndpointManualIssueTest.java
@@ -72,7 +72,7 @@ public void testCreateEndpoint() throws Exception {
Throwable cause = out.getException();
Assertions.assertNotNull(cause);
- Assertions.assertTrue(cause.getMessage().contains("Missing properties for send, need one or more from (11 args)"));
+ Assertions.assertTrue(cause.getMessage().contains("Missing properties for send, need one or more from (14 args)"));
Assertions.assertFalse(cause.getMessage().contains("ediMessageType"));
}
}
diff --git a/docs/user-manual/modules/ROOT/pages/camel-4x-upgrade-guide-4_12.adoc b/docs/user-manual/modules/ROOT/pages/camel-4x-upgrade-guide-4_12.adoc
new file mode 100644
index 0000000000000..0db3d8f98cc10
--- /dev/null
+++ b/docs/user-manual/modules/ROOT/pages/camel-4x-upgrade-guide-4_12.adoc
@@ -0,0 +1,12 @@
+= Apache Camel 4.x Upgrade Guide
+
+This document is for helping you upgrade your Apache Camel application
+from Camel 4.x to 4.y. For example, if you are upgrading Camel 4.0 to 4.2, then you should follow the guides
+from both 4.0 to 4.1 and 4.1 to 4.2.
+
+== Upgrading Camel 4.11 to 4.12
+
+=== camel-as2
+
+Add options allowing the addition of an `Authorization` header for Basic or Bearer authentication to client and
+asynchronous MDN requests.
diff --git a/dsl/camel-endpointdsl/src/generated/java/org/apache/camel/builder/endpoint/dsl/AS2EndpointBuilderFactory.java b/dsl/camel-endpointdsl/src/generated/java/org/apache/camel/builder/endpoint/dsl/AS2EndpointBuilderFactory.java
index a02244e0e260d..4cc6029c10707 100644
--- a/dsl/camel-endpointdsl/src/generated/java/org/apache/camel/builder/endpoint/dsl/AS2EndpointBuilderFactory.java
+++ b/dsl/camel-endpointdsl/src/generated/java/org/apache/camel/builder/endpoint/dsl/AS2EndpointBuilderFactory.java
@@ -607,6 +607,21 @@ default AS2EndpointConsumerBuilder userAgent(String userAgent) {
doSetProperty("userAgent", userAgent);
return this;
}
+ /**
+ * The access token that is used by the client for bearer
+ * authentication.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param accessToken the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointConsumerBuilder accessToken(String accessToken) {
+ doSetProperty("accessToken", accessToken);
+ return this;
+ }
/**
* The key used to encrypt the EDI message.
*
@@ -724,6 +739,67 @@ default AS2EndpointConsumerBuilder hostnameVerifier(String hostnameVerifier) {
doSetProperty("hostnameVerifier", hostnameVerifier);
return this;
}
+ /**
+ * The access token that is used by the server when it sends an async
+ * MDN.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnAccessToken the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointConsumerBuilder mdnAccessToken(String mdnAccessToken) {
+ doSetProperty("mdnAccessToken", mdnAccessToken);
+ return this;
+ }
+ /**
+ * The password that is used by the server for basic authentication when
+ * it sends an async MDN.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnPassword the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointConsumerBuilder mdnPassword(String mdnPassword) {
+ doSetProperty("mdnPassword", mdnPassword);
+ return this;
+ }
+ /**
+ * The user-name that is used by the server for basic authentication
+ * when it sends an async MDN. If options for basic authentication and
+ * bearer authentication are both set then basic authentication takes
+ * precedence.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnUserName the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointConsumerBuilder mdnUserName(String mdnUserName) {
+ doSetProperty("mdnUserName", mdnUserName);
+ return this;
+ }
+ /**
+ * The password that is used by the client for basic authentication.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param password the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointConsumerBuilder password(String password) {
+ doSetProperty("password", password);
+ return this;
+ }
/**
* The list of algorithms, in order of preference, requested to generate
* a message integrity check (MIC) returned in message disposition
@@ -859,6 +935,22 @@ default AS2EndpointConsumerBuilder sslContext(String sslContext) {
doSetProperty("sslContext", sslContext);
return this;
}
+ /**
+ * The user-name that is used by the client for basic authentication. If
+ * options for basic authentication and bearer authentication are both
+ * set then basic authentication takes precedence.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param userName the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointConsumerBuilder userName(String userName) {
+ doSetProperty("userName", userName);
+ return this;
+ }
/**
* Certificates to validate the message's signature against. If not
* supplied, validation will not take place. Server: validates the
@@ -1546,6 +1638,21 @@ default AS2EndpointProducerBuilder userAgent(String userAgent) {
doSetProperty("userAgent", userAgent);
return this;
}
+ /**
+ * The access token that is used by the client for bearer
+ * authentication.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param accessToken the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointProducerBuilder accessToken(String accessToken) {
+ doSetProperty("accessToken", accessToken);
+ return this;
+ }
/**
* The key used to encrypt the EDI message.
*
@@ -1663,6 +1770,67 @@ default AS2EndpointProducerBuilder hostnameVerifier(String hostnameVerifier) {
doSetProperty("hostnameVerifier", hostnameVerifier);
return this;
}
+ /**
+ * The access token that is used by the server when it sends an async
+ * MDN.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnAccessToken the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointProducerBuilder mdnAccessToken(String mdnAccessToken) {
+ doSetProperty("mdnAccessToken", mdnAccessToken);
+ return this;
+ }
+ /**
+ * The password that is used by the server for basic authentication when
+ * it sends an async MDN.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnPassword the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointProducerBuilder mdnPassword(String mdnPassword) {
+ doSetProperty("mdnPassword", mdnPassword);
+ return this;
+ }
+ /**
+ * The user-name that is used by the server for basic authentication
+ * when it sends an async MDN. If options for basic authentication and
+ * bearer authentication are both set then basic authentication takes
+ * precedence.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnUserName the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointProducerBuilder mdnUserName(String mdnUserName) {
+ doSetProperty("mdnUserName", mdnUserName);
+ return this;
+ }
+ /**
+ * The password that is used by the client for basic authentication.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param password the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointProducerBuilder password(String password) {
+ doSetProperty("password", password);
+ return this;
+ }
/**
* The list of algorithms, in order of preference, requested to generate
* a message integrity check (MIC) returned in message disposition
@@ -1798,6 +1966,22 @@ default AS2EndpointProducerBuilder sslContext(String sslContext) {
doSetProperty("sslContext", sslContext);
return this;
}
+ /**
+ * The user-name that is used by the client for basic authentication. If
+ * options for basic authentication and bearer authentication are both
+ * set then basic authentication takes precedence.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param userName the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointProducerBuilder userName(String userName) {
+ doSetProperty("userName", userName);
+ return this;
+ }
/**
* Certificates to validate the message's signature against. If not
* supplied, validation will not take place. Server: validates the
@@ -2466,6 +2650,21 @@ default AS2EndpointBuilder userAgent(String userAgent) {
doSetProperty("userAgent", userAgent);
return this;
}
+ /**
+ * The access token that is used by the client for bearer
+ * authentication.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param accessToken the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointBuilder accessToken(String accessToken) {
+ doSetProperty("accessToken", accessToken);
+ return this;
+ }
/**
* The key used to encrypt the EDI message.
*
@@ -2583,6 +2782,67 @@ default AS2EndpointBuilder hostnameVerifier(String hostnameVerifier) {
doSetProperty("hostnameVerifier", hostnameVerifier);
return this;
}
+ /**
+ * The access token that is used by the server when it sends an async
+ * MDN.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnAccessToken the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointBuilder mdnAccessToken(String mdnAccessToken) {
+ doSetProperty("mdnAccessToken", mdnAccessToken);
+ return this;
+ }
+ /**
+ * The password that is used by the server for basic authentication when
+ * it sends an async MDN.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnPassword the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointBuilder mdnPassword(String mdnPassword) {
+ doSetProperty("mdnPassword", mdnPassword);
+ return this;
+ }
+ /**
+ * The user-name that is used by the server for basic authentication
+ * when it sends an async MDN. If options for basic authentication and
+ * bearer authentication are both set then basic authentication takes
+ * precedence.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param mdnUserName the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointBuilder mdnUserName(String mdnUserName) {
+ doSetProperty("mdnUserName", mdnUserName);
+ return this;
+ }
+ /**
+ * The password that is used by the client for basic authentication.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param password the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointBuilder password(String password) {
+ doSetProperty("password", password);
+ return this;
+ }
/**
* The list of algorithms, in order of preference, requested to generate
* a message integrity check (MIC) returned in message disposition
@@ -2718,6 +2978,22 @@ default AS2EndpointBuilder sslContext(String sslContext) {
doSetProperty("sslContext", sslContext);
return this;
}
+ /**
+ * The user-name that is used by the client for basic authentication. If
+ * options for basic authentication and bearer authentication are both
+ * set then basic authentication takes precedence.
+ *
+ * The option is a: java.lang.String
type.
+ *
+ * Group: security
+ *
+ * @param userName the value to set
+ * @return the dsl builder
+ */
+ default AS2EndpointBuilder userName(String userName) {
+ doSetProperty("userName", userName);
+ return this;
+ }
/**
* Certificates to validate the message's signature against. If not
* supplied, validation will not take place. Server: validates the