kamelets.azure-cosmosdb-source.kamelet.yaml Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of camel-azure-cosmosdb-source-kafka-connector Show documentation
Show all versions of camel-azure-cosmosdb-source-kafka-connector Show documentation
Camel Kafka Connector for azure-cosmosdb-source
# ---------------------------------------------------------------------------
# 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/v1alpha1
kind: Kamelet
metadata:
name: azure-cosmosdb-source
annotations:
camel.apache.org/kamelet.support.level: "Preview"
camel.apache.org/catalog.version: "0.6.0"
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
- 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
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"
© 2015 - 2024 Weber Informatics LLC | Privacy Policy