kamelets.azure-cosmosdb-sink.kamelet.yaml Maven / Gradle / Ivy
The newest version!
# ---------------------------------------------------------------------------
# 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.
# ---------------------------------------------------------------------------
apiVersion: camel.apache.org/v1
kind: Kamelet
metadata:
name: azure-cosmosdb-sink
annotations:
camel.apache.org/kamelet.support.level: "Stable"
camel.apache.org/catalog.version: "4.8.0"
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Apache Software Foundation"
camel.apache.org/kamelet.group: "Azure CosmosDB"
camel.apache.org/kamelet.namespace: "Azure"
labels:
camel.apache.org/kamelet.type: "sink"
spec:
definition:
title: "Azure CosmosDB Sink"
description: |-
Send Data to an Azure CosmosDB instance
In the headers, you can optionally set the `itemPartitionKey` / `ce-itemPartitionKey` property to specify the partition key for a specific item.
If you do not set the property in the header, you'll need to use the static property itemPartitonKey.
There are two different mechanism of authentication `SHARED_ACCOUNT_KEY` and `AZURE_IDENTITY`, you could specify with credentialType property. If you're using `SHARED_ACCOUNT_KEY` accountKey property will be needed.
In case of `AZURE_IDENTITY` selection, the DefaultAzureCredential will attempt to authenticate via the following mechanisms in the following order enviroment, Workload Identity, Managed Identity, Azure Developer CLI, IntelliJ, Azure CLI and Azure Powershell.
required:
- databaseName
- containerName
- databaseEndpoint
type: object
properties:
databaseName:
title: Database Name
description: The Azure Cosmos database name.
type: string
containerName:
title: Container Name
description: The Azure Cosmos container name.
type: string
accountKey:
title: Account Key
description: The Azure Cosmos account Key.
type: string
format: password
x-descriptors:
- urn:camel:group:credentials
databaseEndpoint:
title: Database Endpoint
description: Sets the Azure Cosmos database endpoint the component will connect to.
type: string
itemPartitionKey:
title: Item Partition Key
description: Represents a partition key value in the Azure Cosmos DB database service. A partition key identifies the partition where the item is stored in.
type: string
credentialType:
title: Credential Type
description: Determines the credential strategy to adopt.
type: string
enum: ["SHARED_ACCOUNT_KEY", "AZURE_IDENTITY"]
default: "SHARED_ACCOUNT_KEY"
types:
in:
mediaType: application/json
dependencies:
- "camel:azure-cosmosdb"
- "camel:kamelet"
- "camel:jackson"
- "camel:core"
template:
from:
uri: "kamelet:source"
steps:
- choice:
precondition: true
when:
- simple: '${propertiesExist:!itemPartitionKey}'
steps:
- choice:
when:
- simple: "${header[itemPartitionKey]}"
steps:
- setHeader:
name: CamelAzureCosmosDbItemPartitionKey
simple: "${header[itemPartitionKey]}"
- simple: "${header[ce-itemPartitionKey]}"
steps:
- setHeader:
name: CamelAzureCosmosDbItemPartitionKey
simple: "${header[ce-itemPartitionKey]}"
- unmarshal:
json:
library: Jackson
- to:
uri: "azure-cosmosdb:{{databaseName}}/{{containerName}}"
parameters:
accountKey: "{{?accountKey}}"
databaseEndpoint: "{{databaseEndpoint}}"
itemPartitionKey: "{{?itemPartitionKey}}"
operation: createItem
credentialType: "{{credentialType}}"