blob: c263ce75c415f3209918f03a2e0b88da342c2b8b [file] [log] [blame]
apiVersion: camel.apache.org/v1alpha1
kind: Kamelet
metadata:
name: azure-cosmosdb-source
annotations:
camel.apache.org/kamelet.support.level: "Preview"
camel.apache.org/catalog.version: "main-SNAPSHOT"
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Apache Software Foundation"
camel.apache.org/kamelet.group: "Azure CosmosDB"
labels:
camel.apache.org/kamelet.type: "source"
spec:
definition:
title: "Azure CosmosDB Source"
description: |-
Consume Changes from a CosmosDB instance
required:
- databaseName
- containerName
- accountKey
- 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:alm:descriptor:com.tectonic.ui:password
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
x-descriptors:
- 'urn:alm:descriptor:com.tectonic.ui:checkbox'
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
x-descriptors:
- 'urn:alm:descriptor:com.tectonic.ui:checkbox'
default: false
databaseEndpoint:
title: Database Endpoint
description: Sets the Azure Cosmos database endpoint the component will connect to.
type: string
types:
out:
mediaType: application/json
dependencies:
- "camel:azure-cosmosdb"
- "camel:kamelet"
- "camel:jackson"
flow:
from:
uri: "azure-cosmosdb:{{databaseName}}/{{containerName}}"
parameters:
leaseDatabaseName: "{{?leaseDatabaseName}}"
leaseContainerName: "{{?leaseContainerName}}"
accountKey: "{{accountKey}}"
createLeaseDatabaseIfNotExists: "{{createLeaseDatabaseIfNotExists}}"
createLeaseContainerIfNotExists: "{{createLeaseContainerIfNotExists}}"
databaseEndpoint: "{{databaseEndpoint}}"
steps:
- marshal:
json: {}
- to: "kamelet:sink"