This is an automated email from the ASF dual-hosted git repository.

davsclaus pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/camel-spring-boot.git


The following commit(s) were added to refs/heads/main by this push:
     new 4b1a91e  Add camel-huaweicloud-iam-starter and regen
4b1a91e is described below

commit 4b1a91e8e8b5ff49d67511a41e33bda8f6805041
Author: Claus Ibsen <[email protected]>
AuthorDate: Mon Jun 14 21:23:50 2021 +0200

    Add camel-huaweicloud-iam-starter and regen
---
 .../camel/springboot/catalog/components.properties |   1 +
 .../{kamelet-reify.json => hwcloud-iam.json}       |  36 ++--
 .../catalog/components/kamelet-reify.json          |   2 +-
 .../springboot/catalog/components/mongodb.json     |  14 +-
 .../springboot/catalog/components/rabbitmq.json    |   2 +
 components-starter/README.adoc                     |   6 +-
 .../camel-huaweicloud-iam-starter/pom.xml          |  48 +++++
 .../src/main/docs/huaweicloud-iam-starter.adoc     |  34 ++++
 .../springboot/IAMComponentAutoConfiguration.java  |  79 ++++++++
 .../iam/springboot/IAMComponentConfiguration.java  |  92 ++++++++++
 .../src/main/resources/META-INF/LICENSE.txt        | 203 +++++++++++++++++++++
 .../src/main/resources/META-INF/NOTICE.txt         |  11 ++
 .../src/main/resources/META-INF/spring.factories   |  19 ++
 .../src/main/resources/META-INF/spring.provides    |  17 ++
 .../src/main/docs/rabbitmq-starter.adoc            |   3 +-
 .../springboot/RabbitMQComponentConfiguration.java |  18 ++
 components-starter/pom.xml                         |   1 +
 .../ROOT/pages/huaweicloud-iam-starter.adoc        |  34 ++++
 docs/modules/ROOT/pages/list.adoc                  |   6 +-
 docs/modules/ROOT/pages/rabbitmq-starter.adoc      |   3 +-
 tooling/camel-spring-boot-bom/pom.xml              |   5 +
 tooling/camel-spring-boot-dependencies/pom.xml     |  12 +-
 22 files changed, 619 insertions(+), 27 deletions(-)

diff --git 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components.properties
 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components.properties
index 25f0a62..1ad7371 100644
--- 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components.properties
+++ 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components.properties
@@ -147,6 +147,7 @@ hdfs
 http
 https
 hwcloud-functiongraph
+hwcloud-iam
 hwcloud-smn
 iec60870-client
 iec60870-server
diff --git 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/hwcloud-iam.json
similarity index 52%
copy from 
catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
copy to 
catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/hwcloud-iam.json
index 900c39f..0d904a0 100644
--- 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
+++ 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/hwcloud-iam.json
@@ -1,25 +1,25 @@
 {
   "component": {
     "kind": "component",
-    "name": "kamelet-reify",
-    "title": "Kamelet Reify",
-    "description": "To call Kamelets (indirectly)",
+    "name": "hwcloud-iam",
+    "title": "IAM",
+    "description": "To securely manage users on Huawei Cloud",
     "deprecated": false,
-    "firstVersion": "3.6.0",
-    "label": "core",
-    "javaType": 
"org.apache.camel.component.kameletreify.KameletReifyComponent",
-    "supportLevel": "Stable",
+    "firstVersion": "3.11.0",
+    "label": "cloud",
+    "javaType": "org.apache.camel.component.huaweicloud.iam.IAMComponent",
+    "supportLevel": "Preview",
     "groupId": "org.apache.camel.springboot",
-    "artifactId": "camel-kamelet-reify-starter",
+    "artifactId": "camel-huaweicloud-iam-starter",
     "version": "3.11.0-SNAPSHOT",
-    "scheme": "kamelet-reify",
+    "scheme": "hwcloud-iam",
     "extendsScheme": "",
-    "syntax": "kamelet-reify:delegateUri",
+    "syntax": "hwcloud-iam:operation",
     "async": false,
     "api": false,
     "consumerOnly": false,
     "producerOnly": false,
-    "lenientProperties": true
+    "lenientProperties": false
   },
   "componentProperties": {
     "bridgeErrorHandler": { "kind": "property", "displayName": "Bridge Error 
Handler", "group": "consumer", "label": "consumer", "required": false, "type": 
"boolean", "javaType": "boolean", "deprecated": false, "autowired": false, 
"secret": false, "defaultValue": false, "description": "Allows for bridging the 
consumer to the Camel routing Error Handler, which mean any exceptions occurred 
while the consumer is trying to pickup incoming messages, or the likes, will 
now be processed as a me [...]
@@ -27,7 +27,19 @@
     "autowiredEnabled": { "kind": "property", "displayName": "Autowired 
Enabled", "group": "advanced", "label": "advanced", "required": false, "type": 
"boolean", "javaType": "boolean", "deprecated": false, "autowired": false, 
"secret": false, "defaultValue": true, "description": "Whether autowiring is 
enabled. This is used for automatic autowiring options (the option must be 
marked as autowired) by looking up in the registry to find if there is a single 
instance of matching type, which t [...]
   },
   "properties": {
-    "delegateUri": { "kind": "path", "displayName": "Delegate Uri", "group": 
"common", "label": "", "required": true, "type": "string", "javaType": 
"java.lang.String", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": false, "description": "The delegated uri" },
+    "operation": { "kind": "path", "displayName": "Operation", "group": 
"producer", "label": "producer", "required": true, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "deprecationNote": "", 
"autowired": false, "secret": false, "description": "Operation to be performed" 
},
+    "authenticationKey": { "kind": "parameter", "displayName": "API 
authentication key (AK)", "group": "common", "label": "", "required": true, 
"type": "string", "javaType": "java.lang.String", "deprecated": false, 
"deprecationNote": "", "autowired": false, "secret": true, "description": 
"Authentication key for the cloud user" },
+    "endpoint": { "kind": "parameter", "displayName": "Service endpoint", 
"group": "common", "label": "", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "deprecationNote": "", 
"autowired": false, "secret": false, "description": "IAM endpoint url. Carries 
higher precedence than region parameter based client initialization" },
+    "groupId": { "kind": "parameter", "displayName": "Group ID", "group": 
"common", "label": "", "required": false, "type": "string", "javaType": 
"java.lang.String", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": true, "description": "Group ID to perform operation with" },
+    "ignoreSslVerification": { "kind": "parameter", "displayName": "SSL 
Verification Ignored", "group": "common", "label": "", "required": false, 
"type": "boolean", "javaType": "boolean", "deprecated": false, 
"deprecationNote": "", "autowired": false, "secret": false, "defaultValue": 
false, "description": "Ignore SSL verification" },
+    "proxyHost": { "kind": "parameter", "displayName": "Proxy server host", 
"group": "common", "label": "", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "deprecationNote": "", 
"autowired": false, "secret": false, "description": "Proxy server ip\/hostname" 
},
+    "proxyPassword": { "kind": "parameter", "displayName": "Proxy password", 
"group": "common", "label": "", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "deprecationNote": "", 
"autowired": false, "secret": true, "description": "Proxy authentication 
password" },
+    "proxyPort": { "kind": "parameter", "displayName": "Proxy server port", 
"group": "common", "label": "", "required": false, "type": "integer", 
"javaType": "int", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": false, "description": "Proxy server port" },
+    "proxyUser": { "kind": "parameter", "displayName": "Proxy user", "group": 
"common", "label": "", "required": false, "type": "string", "javaType": 
"java.lang.String", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": true, "description": "Proxy authentication user" },
+    "region": { "kind": "parameter", "displayName": "Service region", "group": 
"common", "label": "", "required": true, "type": "string", "javaType": 
"java.lang.String", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": false, "description": "IAM service region. This is lower 
precedence than endpoint based configuration" },
+    "secretKey": { "kind": "parameter", "displayName": "API secret key (SK)", 
"group": "common", "label": "", "required": true, "type": "string", "javaType": 
"java.lang.String", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": true, "description": "Secret key for the cloud user" },
+    "serviceKeys": { "kind": "parameter", "displayName": "Service 
Configuration", "group": "common", "label": "", "required": false, "type": 
"object", "javaType": 
"org.apache.camel.component.huaweicloud.iam.models.ServiceKeys", "deprecated": 
false, "deprecationNote": "", "autowired": false, "secret": true, 
"description": "Configuration object for cloud service authentication" },
+    "userId": { "kind": "parameter", "displayName": "User ID", "group": 
"common", "label": "", "required": false, "type": "string", "javaType": 
"java.lang.String", "deprecated": false, "deprecationNote": "", "autowired": 
false, "secret": true, "description": "User ID to perform operation with" },
     "bridgeErrorHandler": { "kind": "parameter", "displayName": "Bridge Error 
Handler", "group": "consumer", "label": "consumer", "required": false, "type": 
"boolean", "javaType": "boolean", "deprecated": false, "autowired": false, 
"secret": false, "defaultValue": false, "description": "Allows for bridging the 
consumer to the Camel routing Error Handler, which mean any exceptions occurred 
while the consumer is trying to pickup incoming messages, or the likes, will 
now be processed as a m [...]
     "exceptionHandler": { "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 
con [...]
     "exchangePattern": { "kind": "parameter", "displayName": "Exchange 
Pattern", "group": "consumer (advanced)", "label": "consumer,advanced", 
"required": false, "type": "object", "javaType": 
"org.apache.camel.ExchangePattern", "enum": [ "InOnly", "InOut", 
"InOptionalOut" ], "deprecated": false, "autowired": false, "secret": false, 
"description": "Sets the exchange pattern when the consumer creates an 
exchange." },
diff --git 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
index 900c39f..be94a72 100644
--- 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
+++ 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/kamelet-reify.json
@@ -4,7 +4,7 @@
     "name": "kamelet-reify",
     "title": "Kamelet Reify",
     "description": "To call Kamelets (indirectly)",
-    "deprecated": false,
+    "deprecated": true,
     "firstVersion": "3.6.0",
     "label": "core",
     "javaType": 
"org.apache.camel.component.kameletreify.KameletReifyComponent",
diff --git 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/mongodb.json
 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/mongodb.json
index 09215e6..e2b47fa 100644
--- 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/mongodb.json
+++ 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/mongodb.json
@@ -47,14 +47,14 @@
     "readPreference": { "kind": "parameter", "displayName": "Read Preference", 
"group": "advanced", "label": "advanced", "required": false, "type": "string", 
"javaType": "java.lang.String", "enum": [ "PRIMARY", "PRIMARY_PREFERRED", 
"SECONDARY", "SECONDARY_PREFERRED", "NEAREST" ], "deprecated": false, 
"autowired": false, "secret": false, "defaultValue": "PRIMARY", "description": 
"Configure how MongoDB clients route read operations to the members of a 
replica set. Possible values are PRIMA [...]
     "writeConcern": { "kind": "parameter", "displayName": "Write Concern", 
"group": "advanced", "label": "advanced", "required": false, "type": "string", 
"javaType": "java.lang.String", "enum": [ "ACKNOWLEDGED", "W1", "W2", "W3", 
"UNACKNOWLEDGED", "JOURNALED", "MAJORITY" ], "deprecated": false, "autowired": 
false, "secret": false, "defaultValue": "ACKNOWLEDGED", "description": 
"Configure the connection bean with the level of acknowledgment requested from 
MongoDB for write operations to a [...]
     "writeResultAsHeader": { "kind": "parameter", "displayName": "Write Result 
As Header", "group": "advanced", "label": "advanced", "required": false, 
"type": "boolean", "javaType": "boolean", "deprecated": false, "autowired": 
false, "secret": false, "defaultValue": false, "description": "In write 
operations, it determines whether instead of returning WriteResult as the body 
of the OUT message, we transfer the IN message to the OUT and attach the 
WriteResult as a header." },
-    "streamFilter": { "kind": "parameter", "displayName": "Stream Filter", 
"group": "changeStream", "label": "changeStream", "required": false, "type": 
"string", "javaType": "java.lang.String", "deprecated": false, "autowired": 
false, "secret": false, "description": "Filter condition for change streams 
consumer." },
+    "streamFilter": { "kind": "parameter", "displayName": "Stream Filter", 
"group": "changeStream", "label": "consumer,changeStream", "required": false, 
"type": "string", "javaType": "java.lang.String", "deprecated": false, 
"autowired": false, "secret": false, "description": "Filter condition for 
change streams consumer." },
     "password": { "kind": "parameter", "displayName": "Password", "group": 
"security", "label": "security", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": true, "description": "User password for mongodb connection" },
     "username": { "kind": "parameter", "displayName": "Username", "group": 
"security", "label": "security", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": true, "description": "Username for mongodb connection" },
-    "persistentId": { "kind": "parameter", "displayName": "Persistent Id", 
"group": "tail", "label": "tail", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": false, "description": "One tail tracking collection can host many 
trackers for several tailable consumers. To keep them separate, each tracker 
should have its own unique persistentId." },
-    "persistentTailTracking": { "kind": "parameter", "displayName": 
"Persistent Tail Tracking", "group": "tail", "label": "tail", "required": 
false, "type": "boolean", "javaType": "boolean", "deprecated": false, 
"autowired": false, "secret": false, "defaultValue": false, "description": 
"Enable persistent tail tracking, which is a mechanism to keep track of the 
last consumed message across system restarts. The next time the system is up, 
the endpoint will recover the cursor from the point [...]
-    "tailTrackCollection": { "kind": "parameter", "displayName": "Tail Track 
Collection", "group": "tail", "label": "tail", "required": false, "type": 
"string", "javaType": "java.lang.String", "deprecated": false, "autowired": 
false, "secret": false, "description": "Collection where tail tracking 
information will be persisted. If not specified, 
MongoDbTailTrackingConfig#DEFAULT_COLLECTION will be used by default." },
-    "tailTrackDb": { "kind": "parameter", "displayName": "Tail Track Db", 
"group": "tail", "label": "tail", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": false, "description": "Indicates what database the tail tracking 
mechanism will persist to. If not specified, the current database will be 
picked by default. Dynamicity will not be taken into account even if enabled, 
i.e. the tail tracking database will not vary p [...]
-    "tailTrackField": { "kind": "parameter", "displayName": "Tail Track 
Field", "group": "tail", "label": "tail", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": false, "description": "Field where the last tracked value will be 
placed. If not specified, MongoDbTailTrackingConfig#DEFAULT_FIELD will be used 
by default." },
-    "tailTrackIncreasingField": { "kind": "parameter", "displayName": "Tail 
Track Increasing Field", "group": "tail", "label": "tail", "required": false, 
"type": "string", "javaType": "java.lang.String", "deprecated": false, 
"autowired": false, "secret": false, "description": "Correlation field in the 
incoming record which is of increasing nature and will be used to position the 
tailing cursor every time it is generated. The cursor will be (re)created with 
a query of type: tailTrackIncre [...]
+    "persistentId": { "kind": "parameter", "displayName": "Persistent Id", 
"group": "tail", "label": "consumer,tail", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": false, "description": "One tail tracking collection can host many 
trackers for several tailable consumers. To keep them separate, each tracker 
should have its own unique persistentId." },
+    "persistentTailTracking": { "kind": "parameter", "displayName": 
"Persistent Tail Tracking", "group": "tail", "label": "consumer,tail", 
"required": false, "type": "boolean", "javaType": "boolean", "deprecated": 
false, "autowired": false, "secret": false, "defaultValue": false, 
"description": "Enable persistent tail tracking, which is a mechanism to keep 
track of the last consumed message across system restarts. The next time the 
system is up, the endpoint will recover the cursor from  [...]
+    "tailTrackCollection": { "kind": "parameter", "displayName": "Tail Track 
Collection", "group": "tail", "label": "consumer,tail", "required": false, 
"type": "string", "javaType": "java.lang.String", "deprecated": false, 
"autowired": false, "secret": false, "description": "Collection where tail 
tracking information will be persisted. If not specified, 
MongoDbTailTrackingConfig#DEFAULT_COLLECTION will be used by default." },
+    "tailTrackDb": { "kind": "parameter", "displayName": "Tail Track Db", 
"group": "tail", "label": "consumer,tail", "required": false, "type": "string", 
"javaType": "java.lang.String", "deprecated": false, "autowired": false, 
"secret": false, "description": "Indicates what database the tail tracking 
mechanism will persist to. If not specified, the current database will be 
picked by default. Dynamicity will not be taken into account even if enabled, 
i.e. the tail tracking database will n [...]
+    "tailTrackField": { "kind": "parameter", "displayName": "Tail Track 
Field", "group": "tail", "label": "consumer,tail", "required": false, "type": 
"string", "javaType": "java.lang.String", "deprecated": false, "autowired": 
false, "secret": false, "description": "Field where the last tracked value will 
be placed. If not specified, MongoDbTailTrackingConfig#DEFAULT_FIELD will be 
used by default." },
+    "tailTrackIncreasingField": { "kind": "parameter", "displayName": "Tail 
Track Increasing Field", "group": "tail", "label": "consumer,tail", "required": 
false, "type": "string", "javaType": "java.lang.String", "deprecated": false, 
"autowired": false, "secret": false, "description": "Correlation field in the 
incoming record which is of increasing nature and will be used to position the 
tailing cursor every time it is generated. The cursor will be (re)created with 
a query of type: tailT [...]
   }
 }
diff --git 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/rabbitmq.json
 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/rabbitmq.json
index 3c5e9ad..c7a7603 100644
--- 
a/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/rabbitmq.json
+++ 
b/catalog/camel-catalog-provider-springboot/src/main/resources/org/apache/camel/springboot/catalog/components/rabbitmq.json
@@ -46,6 +46,7 @@
     "prefetchEnabled": { "kind": "property", "displayName": "Prefetch 
Enabled", "group": "consumer", "label": "consumer", "required": false, "type": 
"boolean", "javaType": "boolean", "deprecated": false, "autowired": false, 
"secret": false, "defaultValue": false, "description": "Enables the quality of 
service on the RabbitMQConsumer side. You need to specify the option of 
prefetchSize, prefetchCount, prefetchGlobal at the same time" },
     "prefetchGlobal": { "kind": "property", "displayName": "Prefetch Global", 
"group": "consumer", "label": "consumer", "required": false, "type": "boolean", 
"javaType": "boolean", "deprecated": false, "autowired": false, "secret": 
false, "defaultValue": false, "description": "If the settings should be applied 
to the entire channel rather than each consumer You need to specify the option 
of prefetchSize, prefetchCount, prefetchGlobal at the same time" },
     "prefetchSize": { "kind": "property", "displayName": "Prefetch Size", 
"group": "consumer", "label": "consumer", "required": false, "type": "integer", 
"javaType": "int", "deprecated": false, "autowired": false, "secret": false, 
"description": "The maximum amount of content (measured in octets) that the 
server will deliver, 0 if unlimited. You need to specify the option of 
prefetchSize, prefetchCount, prefetchGlobal at the same time" },
+    "recoverFromDeclareException": { "kind": "property", "displayName": 
"Recover From Declare Exception", "group": "consumer", "label": "consumer", 
"required": false, "type": "boolean", "javaType": "boolean", "deprecated": 
false, "autowired": false, "secret": false, "defaultValue": false, 
"description": "Decides whether an exception during declaration of exchanges or 
queues is recoverable or not. If the option is false, camel will throw an 
exception when starting the consumer, which will [...]
     "threadPoolSize": { "kind": "property", "displayName": "Thread Pool Size", 
"group": "consumer (advanced)", "label": "consumer,advanced", "required": 
false, "type": "integer", "javaType": "int", "deprecated": false, "autowired": 
false, "secret": false, "defaultValue": 10, "description": "The consumer uses a 
Thread Pool Executor with a fixed number of threads. This setting allows you to 
set that number of threads." },
     "additionalHeaders": { "kind": "property", "displayName": "Additional 
Headers", "group": "producer", "label": "producer", "required": false, "type": 
"object", "javaType": "java.util.Map<java.lang.String, java.lang.Object>", 
"deprecated": false, "autowired": false, "secret": false, "description": "Map 
of additional headers. These headers will be set only when the 
'allowCustomHeaders' is set to true" },
     "additionalProperties": { "kind": "property", "displayName": "Additional 
Properties", "group": "producer", "label": "producer", "required": false, 
"type": "object", "javaType": "java.util.Map<java.lang.String, 
java.lang.Object>", "deprecated": false, "autowired": false, "secret": false, 
"description": "Map of additional properties. These are standard RabbitMQ 
properties as defined in com.rabbitmq.client.AMQP.BasicProperties The map keys 
should be from org.apache.camel.component.rabbi [...]
@@ -111,6 +112,7 @@
     "prefetchEnabled": { "kind": "parameter", "displayName": "Prefetch 
Enabled", "group": "consumer", "label": "consumer", "required": false, "type": 
"boolean", "javaType": "boolean", "deprecated": false, "autowired": false, 
"secret": false, "defaultValue": false, "description": "Enables the quality of 
service on the RabbitMQConsumer side. You need to specify the option of 
prefetchSize, prefetchCount, prefetchGlobal at the same time" },
     "prefetchGlobal": { "kind": "parameter", "displayName": "Prefetch Global", 
"group": "consumer", "label": "consumer", "required": false, "type": "boolean", 
"javaType": "boolean", "deprecated": false, "autowired": false, "secret": 
false, "defaultValue": false, "description": "If the settings should be applied 
to the entire channel rather than each consumer You need to specify the option 
of prefetchSize, prefetchCount, prefetchGlobal at the same time" },
     "prefetchSize": { "kind": "parameter", "displayName": "Prefetch Size", 
"group": "consumer", "label": "consumer", "required": false, "type": "integer", 
"javaType": "int", "deprecated": false, "autowired": false, "secret": false, 
"description": "The maximum amount of content (measured in octets) that the 
server will deliver, 0 if unlimited. You need to specify the option of 
prefetchSize, prefetchCount, prefetchGlobal at the same time" },
+    "recoverFromDeclareException": { "kind": "parameter", "displayName": 
"Recover From Declare Exception", "group": "consumer", "label": "consumer", 
"required": false, "type": "boolean", "javaType": "boolean", "deprecated": 
false, "autowired": false, "secret": false, "defaultValue": true, 
"description": "Decides whether an exception during declaration of exchanges or 
queues is recoverable or not. If the option is false, camel will throw an 
exception when starting the consumer, which will [...]
     "reQueue": { "kind": "parameter", "displayName": "Re Queue", "group": 
"consumer", "label": "consumer", "required": false, "type": "boolean", 
"javaType": "boolean", "deprecated": false, "autowired": false, "secret": 
false, "defaultValue": false, "description": "This is used by the consumer to 
control rejection of the message. When the consumer is complete processing the 
exchange, and if the exchange failed, then the consumer is going to reject the 
message from the RabbitMQ broker. If  [...]
     "exceptionHandler": { "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 
con [...]
     "exchangePattern": { "kind": "parameter", "displayName": "Exchange 
Pattern", "group": "consumer (advanced)", "label": "consumer,advanced", 
"required": false, "type": "object", "javaType": 
"org.apache.camel.ExchangePattern", "enum": [ "InOnly", "InOut", 
"InOptionalOut" ], "deprecated": false, "autowired": false, "secret": false, 
"description": "Sets the exchange pattern when the consumer creates an 
exchange." },
diff --git a/components-starter/README.adoc b/components-starter/README.adoc
index 1b10120..8dd2db2 100644
--- a/components-starter/README.adoc
+++ b/components-starter/README.adoc
@@ -5,7 +5,7 @@ Apache Camel Spring Boot supports the following Camel artifacts 
as Spring Boot S
 == Camel Components
 
 // components: START
-Number of Camel components: 332 in 268 JAR artifacts (0 deprecated)
+Number of Camel components: 333 in 269 JAR artifacts (1 deprecated)
 
 [width="100%",cols="4,3,3,3,6",options="header"]
 |===
@@ -293,6 +293,8 @@ Number of Camel components: 332 in 268 JAR artifacts (0 
deprecated)
 
 | xref:latest@components::http-component.adoc[HTTP] | camel-http-starter | 
Stable | 2.3 | Send requests to external HTTP servers using Apache HTTP Client 
4.x.
 
+| xref:latest@components::hwcloud-iam-component.adoc[IAM] | 
camel-huaweicloud-iam-starter | Preview | 3.11 | To securely manage users on 
Huawei Cloud
+
 | xref:latest@components::iec60870-client-component.adoc[IEC 60870 Client] | 
camel-iec60870-starter | Stable | 2.20 | IEC 60870 supervisory control and data 
acquisition (SCADA) client using NeoSCADA implementation.
 
 | xref:latest@components::iec60870-server-component.adoc[IEC 60870 Server] | 
camel-iec60870-starter | Stable | 2.20 | IEC 60870 supervisory control and data 
acquisition (SCADA) server using NeoSCADA implementation.
@@ -371,7 +373,7 @@ Number of Camel components: 332 in 268 JAR artifacts (0 
deprecated)
 
 | xref:latest@components::kamelet-component.adoc[Kamelet] | 
camel-kamelet-starter | Stable | 3.8 | To call Kamelets
 
-| xref:latest@components::kamelet-reify-component.adoc[Kamelet Reify] | 
camel-kamelet-reify-starter | Stable | 3.6 | To call Kamelets (indirectly)
+| xref:latest@components::kamelet-reify-component.adoc[Kamelet Reify] | 
camel-kamelet-reify-starter | Stable | 3.6 | *deprecated* To call Kamelets 
(indirectly)
 
 | xref:latest@components::kubernetes-config-maps-component.adoc[Kubernetes 
ConfigMap] | camel-kubernetes-starter | Stable | 2.17 | Perform operations on 
Kubernetes ConfigMaps and get notified on ConfigMaps changes.
 
diff --git a/components-starter/camel-huaweicloud-iam-starter/pom.xml 
b/components-starter/camel-huaweicloud-iam-starter/pom.xml
new file mode 100644
index 0000000..e9a6c68
--- /dev/null
+++ b/components-starter/camel-huaweicloud-iam-starter/pom.xml
@@ -0,0 +1,48 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+
+    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.
+
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0"; 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"; 
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
http://maven.apache.org/maven-v4_0_0.xsd";>
+  <modelVersion>4.0.0</modelVersion>
+  <parent>
+    <groupId>org.apache.camel.springboot</groupId>
+    <artifactId>components-starter</artifactId>
+    <version>3.11.0-SNAPSHOT</version>
+  </parent>
+  <artifactId>camel-huaweicloud-iam-starter</artifactId>
+  <packaging>jar</packaging>
+  <name>Camel SB Starters :: Huawei Cloud IAM</name>
+  <dependencies>
+    <dependency>
+      <groupId>org.springframework.boot</groupId>
+      <artifactId>spring-boot-starter</artifactId>
+      <version>${spring-boot-version}</version>
+    </dependency>
+    <dependency>
+      <groupId>org.apache.camel</groupId>
+      <artifactId>camel-huaweicloud-iam</artifactId>
+      <version>${camel-version}</version>
+    </dependency>
+    <!--START OF GENERATED CODE-->
+    <dependency>
+      <groupId>org.apache.camel.springboot</groupId>
+      <artifactId>camel-core-starter</artifactId>
+    </dependency>
+    <!--END OF GENERATED CODE-->
+  </dependencies>
+</project>
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/docs/huaweicloud-iam-starter.adoc
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/docs/huaweicloud-iam-starter.adoc
new file mode 100644
index 0000000..d3dfa0f
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/docs/huaweicloud-iam-starter.adoc
@@ -0,0 +1,34 @@
+// spring-boot-auto-configure options: START
+:page-partial:
+:doctitle: Camel Spring Boot Starter for huaweicloud-iam
+
+== Spring Boot Auto-Configuration
+
+When using huaweicloud-iam with Spring Boot make sure to use the following 
Maven dependency to have support for auto configuration:
+
+[source,xml]
+----
+<dependency>
+  <groupId>org.apache.camel.springboot</groupId>
+  <artifactId>camel-huaweicloud-iam-starter</artifactId>
+  <version>x.x.x</version>
+  <!-- use the same version as your Camel core version -->
+</dependency>
+----
+
+
+The component supports 4 options, which are listed below.
+
+
+
+[width="100%",cols="2,5,^1,2",options="header"]
+|===
+| Name | Description | Default | Type
+| *camel.component.hwcloud-iam.autowired-enabled* | Whether autowiring is 
enabled. This is used for automatic autowiring options (the option must be 
marked as autowired) by looking up in the registry to find if there is a single 
instance of matching type, which then gets configured on the component. This 
can be used for automatic configuring JDBC data sources, JMS connection 
factories, AWS Clients, etc. | true | Boolean
+| *camel.component.hwcloud-iam.bridge-error-handler* | Allows for bridging the 
consumer to the Camel routing Error Handler, which mean any exceptions occurred 
while the consumer is trying to pickup incoming messages, or the likes, will 
now be processed as a message and handled by the routing Error Handler. By 
default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal 
with exceptions, that will be logged at WARN or ERROR level and ignored. | 
false | Boolean
+| *camel.component.hwcloud-iam.enabled* | Whether to enable auto configuration 
of the hwcloud-iam component. This is enabled by default. |  | Boolean
+| *camel.component.hwcloud-iam.lazy-start-producer* | 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 processe [...]
+|===
+
+
+// spring-boot-auto-configure options: END
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/java/org/apache/camel/component/huaweicloud/iam/springboot/IAMComponentAutoConfiguration.java
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/java/org/apache/camel/component/huaweicloud/iam/springboot/IAMComponentAutoConfiguration.java
new file mode 100644
index 0000000..60bfb0e
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/java/org/apache/camel/component/huaweicloud/iam/springboot/IAMComponentAutoConfiguration.java
@@ -0,0 +1,79 @@
+/*
+ * 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.huaweicloud.iam.springboot;
+
+import javax.annotation.Generated;
+import org.apache.camel.CamelContext;
+import org.apache.camel.Component;
+import org.apache.camel.component.huaweicloud.iam.IAMComponent;
+import org.apache.camel.spi.ComponentCustomizer;
+import org.apache.camel.spring.boot.CamelAutoConfiguration;
+import org.apache.camel.spring.boot.ComponentConfigurationProperties;
+import org.apache.camel.spring.boot.util.CamelPropertiesHelper;
+import 
org.apache.camel.spring.boot.util.ConditionalOnCamelContextAndAutoConfigurationBeans;
+import org.apache.camel.spring.boot.util.ConditionalOnHierarchicalProperties;
+import org.apache.camel.spring.boot.util.HierarchicalPropertiesEvaluator;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.AutoConfigureAfter;
+import 
org.springframework.boot.context.properties.EnableConfigurationProperties;
+import org.springframework.context.ApplicationContext;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Conditional;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.context.annotation.Lazy;
+
+/**
+ * Generated by camel-package-maven-plugin - do not edit this file!
+ */
+@Generated("org.apache.camel.springboot.maven.SpringBootAutoConfigurationMojo")
+@Configuration(proxyBeanMethods = false)
+@Conditional(ConditionalOnCamelContextAndAutoConfigurationBeans.class)
+@EnableConfigurationProperties({ComponentConfigurationProperties.class,IAMComponentConfiguration.class})
+@ConditionalOnHierarchicalProperties({"camel.component", 
"camel.component.hwcloud-iam"})
+@AutoConfigureAfter(CamelAutoConfiguration.class)
+public class IAMComponentAutoConfiguration {
+
+    @Autowired
+    private ApplicationContext applicationContext;
+    private final CamelContext camelContext;
+    @Autowired
+    private IAMComponentConfiguration configuration;
+
+    public IAMComponentAutoConfiguration(
+            org.apache.camel.CamelContext camelContext) {
+        this.camelContext = camelContext;
+    }
+
+    @Lazy
+    @Bean
+    public ComponentCustomizer configureIAMComponent() {
+        return new ComponentCustomizer() {
+            @Override
+            public void configure(String name, Component target) {
+                CamelPropertiesHelper.copyProperties(camelContext, 
configuration, target);
+            }
+            @Override
+            public boolean isEnabled(String name, Component target) {
+                return HierarchicalPropertiesEvaluator.evaluate(
+                        applicationContext,
+                        "camel.component.customizer",
+                        "camel.component.hwcloud-iam.customizer")
+                    && target instanceof IAMComponent;
+            }
+        };
+    }
+}
\ No newline at end of file
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/java/org/apache/camel/component/huaweicloud/iam/springboot/IAMComponentConfiguration.java
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/java/org/apache/camel/component/huaweicloud/iam/springboot/IAMComponentConfiguration.java
new file mode 100644
index 0000000..058a80c
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/java/org/apache/camel/component/huaweicloud/iam/springboot/IAMComponentConfiguration.java
@@ -0,0 +1,92 @@
+/*
+ * 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.huaweicloud.iam.springboot;
+
+import javax.annotation.Generated;
+import org.apache.camel.spring.boot.ComponentConfigurationPropertiesCommon;
+import org.springframework.boot.context.properties.ConfigurationProperties;
+
+/**
+ * To securely manage users on Huawei Cloud
+ * 
+ * Generated by camel-package-maven-plugin - do not edit this file!
+ */
+@Generated("org.apache.camel.springboot.maven.SpringBootAutoConfigurationMojo")
+@ConfigurationProperties(prefix = "camel.component.hwcloud-iam")
+public class IAMComponentConfiguration
+        extends
+            ComponentConfigurationPropertiesCommon {
+
+    /**
+     * Whether to enable auto configuration of the hwcloud-iam component. This
+     * is enabled by default.
+     */
+    private Boolean enabled;
+    /**
+     * Allows for bridging the consumer to the Camel routing Error Handler,
+     * which mean any exceptions occurred while the consumer is trying to 
pickup
+     * incoming messages, or the likes, will now be processed as a message and
+     * handled by the routing Error Handler. By default the consumer will use
+     * the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that
+     * will be logged at WARN or ERROR level and ignored.
+     */
+    private Boolean bridgeErrorHandler = false;
+    /**
+     * 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.
+     */
+    private Boolean lazyStartProducer = false;
+    /**
+     * Whether autowiring is enabled. This is used for automatic autowiring
+     * options (the option must be marked as autowired) by looking up in the
+     * registry to find if there is a single instance of matching type, which
+     * then gets configured on the component. This can be used for automatic
+     * configuring JDBC data sources, JMS connection factories, AWS Clients,
+     * etc.
+     */
+    private Boolean autowiredEnabled = true;
+
+    public Boolean getBridgeErrorHandler() {
+        return bridgeErrorHandler;
+    }
+
+    public void setBridgeErrorHandler(Boolean bridgeErrorHandler) {
+        this.bridgeErrorHandler = bridgeErrorHandler;
+    }
+
+    public Boolean getLazyStartProducer() {
+        return lazyStartProducer;
+    }
+
+    public void setLazyStartProducer(Boolean lazyStartProducer) {
+        this.lazyStartProducer = lazyStartProducer;
+    }
+
+    public Boolean getAutowiredEnabled() {
+        return autowiredEnabled;
+    }
+
+    public void setAutowiredEnabled(Boolean autowiredEnabled) {
+        this.autowiredEnabled = autowiredEnabled;
+    }
+}
\ No newline at end of file
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/LICENSE.txt
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/LICENSE.txt
new file mode 100644
index 0000000..6b0b127
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/LICENSE.txt
@@ -0,0 +1,203 @@
+
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed 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.
+
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/NOTICE.txt
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/NOTICE.txt
new file mode 100644
index 0000000..2e215bf
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/NOTICE.txt
@@ -0,0 +1,11 @@
+   =========================================================================
+   ==  NOTICE file corresponding to the section 4 d of                    ==
+   ==  the Apache License, Version 2.0,                                   ==
+   ==  in this case for the Apache Camel distribution.                    ==
+   =========================================================================
+
+   This product includes software developed by
+   The Apache Software Foundation (http://www.apache.org/).
+
+   Please read the different LICENSE files present in the licenses directory of
+   this distribution.
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/spring.factories
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/spring.factories
new file mode 100644
index 0000000..ed4069e
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/spring.factories
@@ -0,0 +1,19 @@
+## ---------------------------------------------------------------------------
+## 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.
+## ---------------------------------------------------------------------------
+
+org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
+org.apache.camel.component.huaweicloud.iam.springboot.IAMComponentAutoConfiguration
diff --git 
a/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/spring.provides
 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/spring.provides
new file mode 100644
index 0000000..b2dd727
--- /dev/null
+++ 
b/components-starter/camel-huaweicloud-iam-starter/src/main/resources/META-INF/spring.provides
@@ -0,0 +1,17 @@
+## ---------------------------------------------------------------------------
+## 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.
+## ---------------------------------------------------------------------------
+provides: camel-huaweicloud-iam
diff --git 
a/components-starter/camel-rabbitmq-starter/src/main/docs/rabbitmq-starter.adoc 
b/components-starter/camel-rabbitmq-starter/src/main/docs/rabbitmq-starter.adoc
index 91b9cf9..49cefb6 100644
--- 
a/components-starter/camel-rabbitmq-starter/src/main/docs/rabbitmq-starter.adoc
+++ 
b/components-starter/camel-rabbitmq-starter/src/main/docs/rabbitmq-starter.adoc
@@ -17,7 +17,7 @@ When using rabbitmq with Spring Boot make sure to use the 
following Maven depend
 ----
 
 
-The component supports 56 options, which are listed below.
+The component supports 57 options, which are listed below.
 
 
 
@@ -65,6 +65,7 @@ The component supports 56 options, which are listed below.
 | *camel.component.rabbitmq.prefetch-size* | The maximum amount of content 
(measured in octets) that the server will deliver, 0 if unlimited. You need to 
specify the option of prefetchSize, prefetchCount, prefetchGlobal at the same 
time |  | Integer
 | *camel.component.rabbitmq.publisher-acknowledgements* | When true, the 
message will be published with publisher acknowledgements turned on | false | 
Boolean
 | *camel.component.rabbitmq.publisher-acknowledgements-timeout* | The amount 
of time in milliseconds to wait for a basic.ack response from RabbitMQ server | 
 | Long
+| *camel.component.rabbitmq.recover-from-declare-exception* | Decides whether 
an exception during declaration of exchanges or queues is recoverable or not. 
If the option is false, camel will throw an exception when starting the 
consumer, which will interrupt application startup (e.g. in the case when the 
exchange / queue is already declared in RabbitMQ and has incompatible 
configuration). If set to true, the consumer will try to reconnect 
periodically. | false | Boolean
 | *camel.component.rabbitmq.request-timeout* | Set timeout for waiting for a 
reply when using the InOut Exchange Pattern (in milliseconds) | 20000 | Long
 | *camel.component.rabbitmq.request-timeout-checker-interval* | Set 
requestTimeoutCheckerInterval for inOut exchange | 1000 | Long
 | *camel.component.rabbitmq.requested-channel-max* | Connection requested 
channel max (max number of channels offered) | 2047 | Integer
diff --git 
a/components-starter/camel-rabbitmq-starter/src/main/java/org/apache/camel/component/rabbitmq/springboot/RabbitMQComponentConfiguration.java
 
b/components-starter/camel-rabbitmq-starter/src/main/java/org/apache/camel/component/rabbitmq/springboot/RabbitMQComponentConfiguration.java
index 919c37fd..9c35279 100644
--- 
a/components-starter/camel-rabbitmq-starter/src/main/java/org/apache/camel/component/rabbitmq/springboot/RabbitMQComponentConfiguration.java
+++ 
b/components-starter/camel-rabbitmq-starter/src/main/java/org/apache/camel/component/rabbitmq/springboot/RabbitMQComponentConfiguration.java
@@ -161,6 +161,15 @@ public class RabbitMQComponentConfiguration
      */
     private Integer prefetchSize;
     /**
+     * Decides whether an exception during declaration of exchanges or queues 
is
+     * recoverable or not. If the option is false, camel will throw an 
exception
+     * when starting the consumer, which will interrupt application startup
+     * (e.g. in the case when the exchange / queue is already declared in
+     * RabbitMQ and has incompatible configuration). If set to true, the
+     * consumer will try to reconnect periodically.
+     */
+    private Boolean recoverFromDeclareException = false;
+    /**
      * The consumer uses a Thread Pool Executor with a fixed number of threads.
      * This setting allows you to set that number of threads.
      */
@@ -527,6 +536,15 @@ public class RabbitMQComponentConfiguration
         this.prefetchSize = prefetchSize;
     }
 
+    public Boolean getRecoverFromDeclareException() {
+        return recoverFromDeclareException;
+    }
+
+    public void setRecoverFromDeclareException(
+            Boolean recoverFromDeclareException) {
+        this.recoverFromDeclareException = recoverFromDeclareException;
+    }
+
     public Integer getThreadPoolSize() {
         return threadPoolSize;
     }
diff --git a/components-starter/pom.xml b/components-starter/pom.xml
index da4e4e0..ec180a2 100644
--- a/components-starter/pom.xml
+++ b/components-starter/pom.xml
@@ -245,6 +245,7 @@
     <module>camel-http-common-starter</module>
     <module>camel-http-starter</module>
     <module>camel-huaweicloud-functiongraph-starter</module>
+    <module>camel-huaweicloud-iam-starter</module>
     <module>camel-huaweicloud-smn-starter</module>
     <module>camel-hystrix-starter</module>
     <module>camel-ical-starter</module>
diff --git a/docs/modules/ROOT/pages/huaweicloud-iam-starter.adoc 
b/docs/modules/ROOT/pages/huaweicloud-iam-starter.adoc
new file mode 100644
index 0000000..d3dfa0f
--- /dev/null
+++ b/docs/modules/ROOT/pages/huaweicloud-iam-starter.adoc
@@ -0,0 +1,34 @@
+// spring-boot-auto-configure options: START
+:page-partial:
+:doctitle: Camel Spring Boot Starter for huaweicloud-iam
+
+== Spring Boot Auto-Configuration
+
+When using huaweicloud-iam with Spring Boot make sure to use the following 
Maven dependency to have support for auto configuration:
+
+[source,xml]
+----
+<dependency>
+  <groupId>org.apache.camel.springboot</groupId>
+  <artifactId>camel-huaweicloud-iam-starter</artifactId>
+  <version>x.x.x</version>
+  <!-- use the same version as your Camel core version -->
+</dependency>
+----
+
+
+The component supports 4 options, which are listed below.
+
+
+
+[width="100%",cols="2,5,^1,2",options="header"]
+|===
+| Name | Description | Default | Type
+| *camel.component.hwcloud-iam.autowired-enabled* | Whether autowiring is 
enabled. This is used for automatic autowiring options (the option must be 
marked as autowired) by looking up in the registry to find if there is a single 
instance of matching type, which then gets configured on the component. This 
can be used for automatic configuring JDBC data sources, JMS connection 
factories, AWS Clients, etc. | true | Boolean
+| *camel.component.hwcloud-iam.bridge-error-handler* | Allows for bridging the 
consumer to the Camel routing Error Handler, which mean any exceptions occurred 
while the consumer is trying to pickup incoming messages, or the likes, will 
now be processed as a message and handled by the routing Error Handler. By 
default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal 
with exceptions, that will be logged at WARN or ERROR level and ignored. | 
false | Boolean
+| *camel.component.hwcloud-iam.enabled* | Whether to enable auto configuration 
of the hwcloud-iam component. This is enabled by default. |  | Boolean
+| *camel.component.hwcloud-iam.lazy-start-producer* | 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 processe [...]
+|===
+
+
+// spring-boot-auto-configure options: END
diff --git a/docs/modules/ROOT/pages/list.adoc 
b/docs/modules/ROOT/pages/list.adoc
index 1b10120..8dd2db2 100644
--- a/docs/modules/ROOT/pages/list.adoc
+++ b/docs/modules/ROOT/pages/list.adoc
@@ -5,7 +5,7 @@ Apache Camel Spring Boot supports the following Camel artifacts 
as Spring Boot S
 == Camel Components
 
 // components: START
-Number of Camel components: 332 in 268 JAR artifacts (0 deprecated)
+Number of Camel components: 333 in 269 JAR artifacts (1 deprecated)
 
 [width="100%",cols="4,3,3,3,6",options="header"]
 |===
@@ -293,6 +293,8 @@ Number of Camel components: 332 in 268 JAR artifacts (0 
deprecated)
 
 | xref:latest@components::http-component.adoc[HTTP] | camel-http-starter | 
Stable | 2.3 | Send requests to external HTTP servers using Apache HTTP Client 
4.x.
 
+| xref:latest@components::hwcloud-iam-component.adoc[IAM] | 
camel-huaweicloud-iam-starter | Preview | 3.11 | To securely manage users on 
Huawei Cloud
+
 | xref:latest@components::iec60870-client-component.adoc[IEC 60870 Client] | 
camel-iec60870-starter | Stable | 2.20 | IEC 60870 supervisory control and data 
acquisition (SCADA) client using NeoSCADA implementation.
 
 | xref:latest@components::iec60870-server-component.adoc[IEC 60870 Server] | 
camel-iec60870-starter | Stable | 2.20 | IEC 60870 supervisory control and data 
acquisition (SCADA) server using NeoSCADA implementation.
@@ -371,7 +373,7 @@ Number of Camel components: 332 in 268 JAR artifacts (0 
deprecated)
 
 | xref:latest@components::kamelet-component.adoc[Kamelet] | 
camel-kamelet-starter | Stable | 3.8 | To call Kamelets
 
-| xref:latest@components::kamelet-reify-component.adoc[Kamelet Reify] | 
camel-kamelet-reify-starter | Stable | 3.6 | To call Kamelets (indirectly)
+| xref:latest@components::kamelet-reify-component.adoc[Kamelet Reify] | 
camel-kamelet-reify-starter | Stable | 3.6 | *deprecated* To call Kamelets 
(indirectly)
 
 | xref:latest@components::kubernetes-config-maps-component.adoc[Kubernetes 
ConfigMap] | camel-kubernetes-starter | Stable | 2.17 | Perform operations on 
Kubernetes ConfigMaps and get notified on ConfigMaps changes.
 
diff --git a/docs/modules/ROOT/pages/rabbitmq-starter.adoc 
b/docs/modules/ROOT/pages/rabbitmq-starter.adoc
index 91b9cf9..49cefb6 100644
--- a/docs/modules/ROOT/pages/rabbitmq-starter.adoc
+++ b/docs/modules/ROOT/pages/rabbitmq-starter.adoc
@@ -17,7 +17,7 @@ When using rabbitmq with Spring Boot make sure to use the 
following Maven depend
 ----
 
 
-The component supports 56 options, which are listed below.
+The component supports 57 options, which are listed below.
 
 
 
@@ -65,6 +65,7 @@ The component supports 56 options, which are listed below.
 | *camel.component.rabbitmq.prefetch-size* | The maximum amount of content 
(measured in octets) that the server will deliver, 0 if unlimited. You need to 
specify the option of prefetchSize, prefetchCount, prefetchGlobal at the same 
time |  | Integer
 | *camel.component.rabbitmq.publisher-acknowledgements* | When true, the 
message will be published with publisher acknowledgements turned on | false | 
Boolean
 | *camel.component.rabbitmq.publisher-acknowledgements-timeout* | The amount 
of time in milliseconds to wait for a basic.ack response from RabbitMQ server | 
 | Long
+| *camel.component.rabbitmq.recover-from-declare-exception* | Decides whether 
an exception during declaration of exchanges or queues is recoverable or not. 
If the option is false, camel will throw an exception when starting the 
consumer, which will interrupt application startup (e.g. in the case when the 
exchange / queue is already declared in RabbitMQ and has incompatible 
configuration). If set to true, the consumer will try to reconnect 
periodically. | false | Boolean
 | *camel.component.rabbitmq.request-timeout* | Set timeout for waiting for a 
reply when using the InOut Exchange Pattern (in milliseconds) | 20000 | Long
 | *camel.component.rabbitmq.request-timeout-checker-interval* | Set 
requestTimeoutCheckerInterval for inOut exchange | 1000 | Long
 | *camel.component.rabbitmq.requested-channel-max* | Connection requested 
channel max (max number of channels offered) | 2047 | Integer
diff --git a/tooling/camel-spring-boot-bom/pom.xml 
b/tooling/camel-spring-boot-bom/pom.xml
index b33a493..3b974c5 100644
--- a/tooling/camel-spring-boot-bom/pom.xml
+++ b/tooling/camel-spring-boot-bom/pom.xml
@@ -715,6 +715,11 @@
       </dependency>
       <dependency>
         <groupId>org.apache.camel.springboot</groupId>
+        <artifactId>camel-huaweicloud-iam-starter</artifactId>
+        <version>${project.version}</version>
+      </dependency>
+      <dependency>
+        <groupId>org.apache.camel.springboot</groupId>
         <artifactId>camel-huaweicloud-smn-starter</artifactId>
         <version>${project.version}</version>
       </dependency>
diff --git a/tooling/camel-spring-boot-dependencies/pom.xml 
b/tooling/camel-spring-boot-dependencies/pom.xml
index e4767e7..ab417e1 100644
--- a/tooling/camel-spring-boot-dependencies/pom.xml
+++ b/tooling/camel-spring-boot-dependencies/pom.xml
@@ -329,7 +329,7 @@
       <dependency>
         <groupId>commons-io</groupId>
         <artifactId>commons-io</artifactId>
-        <version>2.8.0</version>
+        <version>2.10.0</version>
       </dependency>
       <dependency>
         <groupId>commons-logging</groupId>
@@ -1118,6 +1118,11 @@
       </dependency>
       <dependency>
         <groupId>org.apache.camel.springboot</groupId>
+        <artifactId>camel-huaweicloud-iam-starter</artifactId>
+        <version>${project.version}</version>
+      </dependency>
+      <dependency>
+        <groupId>org.apache.camel.springboot</groupId>
         <artifactId>camel-huaweicloud-smn-starter</artifactId>
         <version>${project.version}</version>
       </dependency>
@@ -3059,6 +3064,11 @@
       </dependency>
       <dependency>
         <groupId>org.apache.camel</groupId>
+        <artifactId>camel-huaweicloud-iam</artifactId>
+        <version>3.11.0-SNAPSHOT</version>
+      </dependency>
+      <dependency>
+        <groupId>org.apache.camel</groupId>
         <artifactId>camel-huaweicloud-smn</artifactId>
         <version>3.11.0-SNAPSHOT</version>
       </dependency>

Reply via email to