blob: 5c1f9fd0e9799a4e3db0606fc842f62e75cd96b8 [file] [log] [blame]
# ---------------------------------------------------------------------------
# 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-source
annotations:
camel.apache.org/kamelet.support.level: "Stable"
camel.apache.org/catalog.version: "4.6.0-SNAPSHOT"
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: "source"
spec:
definition:
title: "Azure CosmosDB Source"
description: |-
Consume Changes from a CosmosDB instance.
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
leaseDatabaseName:
title: Lease Database Name
description: Sets the lease container which acts as a state storage and coordinates processing the change feed across multiple workers.
type: string
leaseContainerName:
title: Lease Container Name
description: Sets the lease database where the leaseContainerName will be stored.
type: string
createLeaseDatabaseIfNotExists:
title: Autocreate Lease Database
description: Sets if the component should create Cosmos lease database for the consumer automatically in case it doesn’t exist in Cosmos account.
type: boolean
default: false
createLeaseContainerIfNotExists:
title: Autocreate Lease Container
description: Sets if the component should create Cosmos lease container for the consumer automatically in case it doesn’t exist in Cosmos database.
type: boolean
default: false
databaseEndpoint:
title: Database Endpoint
description: Sets the Azure Cosmos database endpoint the component will connect to.
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"
dataTypes:
out:
default: json
headers:
types:
json:
format: "application-json"
description: Json mapping of Change Feed records
mediaType: application/json
cloudevents:
format: "azure-cosmosdb:application-cloudevents"
description: |-
Data type transformer converts Azure CosmosDB Change Feed processor response to CloudEvent v1_0 data format. The data
type sets Camel specific CloudEvent headers with values extracted from Azure CosmosDB Change Feed processor response.
headers:
CamelCloudEventID:
title: CloudEvent ID
description: The Camel exchange id set as event id
type: string
CamelCloudEventType:
title: CloudEvent Type
description: The event type
default: "org.apache.camel.event.azure.cosmosdb.changes"
type: string
CamelCloudEventSource:
title: CloudEvent Source
description: The event source.
type: string
default: "org.apache.camel.event.azure.cosmosdb.changefeed"
CamelCloudEventSubject:
title: CloudEvent Subject
description: The event subject.
type: string
default: "org.apache.camel.event.azure.cosmosdb.changefeed"
CamelCloudEventTime:
title: CloudEvent Time
description: The exchange creation timestamp as event time.
type: string
dependencies:
- "camel:azure-cosmosdb"
- "camel:kamelet"
- "camel:jackson"
template:
from:
uri: "azure-cosmosdb:{{databaseName}}/{{containerName}}"
parameters:
leaseDatabaseName: "{{?leaseDatabaseName}}"
leaseContainerName: "{{?leaseContainerName}}"
accountKey: "{{?accountKey}}"
createLeaseDatabaseIfNotExists: "{{createLeaseDatabaseIfNotExists}}"
createLeaseContainerIfNotExists: "{{createLeaseContainerIfNotExists}}"
databaseEndpoint: "{{databaseEndpoint}}"
credentialType: "{{credentialType}}"
steps:
- marshal:
json: {}
- to: "kamelet:sink"