blob: e57b1533fbc1aa12f8f436b6d66c9f2808acf5dd [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-storage-queue-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 Storage Queue"
camel.apache.org/kamelet.namespace: "Azure"
labels:
camel.apache.org/kamelet.type: "source"
spec:
definition:
title: "Azure Storage Queue Source"
description: |-
Receive events from Azure Storage queues.
One header will be duplicated with different names for clarity at sink level, CamelAzureStorageQueueMessageId will be duplicated into azure.storage.queue.message.id
required:
- accountName
- queueName
- accessKey
type: object
properties:
accountName:
title: Account Name
description: The Azure Storage Queue account name.
type: string
x-descriptors:
- urn:camel:group:credentials
queueName:
title: Queue Name
description: The Azure Storage Queue container name.
type: string
accessKey:
title: Access Key
description: The Azure Storage Queue access key.
type: string
format: password
x-descriptors:
- urn:camel:group:credentials
maxMessages:
title: Maximum Messages
description: The maximum number of messages to get. You can specify a value between 1 and 32. The default is 1 (one message). If there are fewer than the maximum number of messages in the queue, then all the messages are returned.
type: integer
default: 1
credentialType:
title: Credential Type
description: Determines the credential strategy to adopt.
type: string
enum: ["SHARED_ACCOUNT_KEY", "SHARED_KEY_CREDENTIAL", "AZURE_IDENTITY"]
default: "SHARED_ACCOUNT_KEY"
dataTypes:
out:
default: text
headers:
CamelAzureStorageQueueMessageId:
title: Azure Storage Queue Message Id
description: The id of the message
type: string
CamelAzureStorageQueueInsertionTime:
title: Azure Storage Queue Message Insertion Time
description: The time the Message was inserted into the Queue.
type: OffsetDateTime
CamelAzureStorageQueueExpirationTime:
title: Azure Storage Queue Message Expiration Time
description: The time that the Message will expire and be automatically deleted.
type: OffsetDateTime
CamelAzureStorageQueuePopReceipt:
title: Pop Receipt
description: |-
Unique identifier that must match for the message to be deleted or updated. If deletion fails using this pop receipt then the message has been dequeued by another client.
type: string
CamelAzureStorageQueueTimeNextVisible:
title: Azure Storage Queue Message Time Next Visible
description: The time that the message will again become visible in the Queue.
type: OffsetDateTime
CamelAzureStorageQueueDequeueCount:
title: Dequeue Count
description: The number of times the message has been dequeued
type: long
types:
text:
format: "text-plain"
description: Default text representation of the Message dequeued from the queue.
mediaType: text/plain
cloudevents:
format: "azure-storage-queue:application-cloudevents"
description: |-
Output data type represents Azure Storage Queue receive messages operation as CloudEvent V1. The data type sets Camel
specific CloudEvent headers on the exchange.
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.storage.queue.receiveMessages"
type: string
CamelCloudEventSource:
title: CloudEvent Source
description: The event source. By default, the Message Id of the message received with prefix "azure.storage.queue.".
type: string
CamelCloudEventSubject:
title: CloudEvent Subject
description: The event subject. Usually the Pop receipt of the message dequeued.
type: string
CamelCloudEventTime:
title: CloudEvent Time
description: The exchange creation timestamp as event time.
type: string
dependencies:
- "camel:azure-storage-queue"
- "camel:kamelet"
- "mvn:org.apache.camel.kamelets:camel-kamelets-utils:4.6.0-SNAPSHOT"
- "camel:core"
template:
from:
uri: "azure-storage-queue://{{accountName}}/{{queueName}}"
parameters:
accessKey: "{{accessKey}}"
maxMessages: "{{maxMessages}}"
credentialType: "{{credentialType}}"
steps:
- to: "kamelet:sink"