blob: 32f9e6ccab844e3b208d36d231f522bfabebe6ca [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: slack-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: "Slack"
camel.apache.org/kamelet.namespace: "Social"
labels:
camel.apache.org/kamelet.type: "source"
spec:
definition:
title: "Slack Source"
description: |-
Receive messages from a Slack channel.
required:
- channel
- token
type: object
properties:
channel:
title: Channel
description: The Slack channel to receive messages from.
type: string
example: "#myroom"
token:
title: Token
description: "The Bot User OAuth Access Token to access Slack. A Slack app that has the following permissions is required: `channels:history`, `groups:history`, `im:history`, `mpim:history`, `channels:read`, `groups:read`, `im:read`, and `mpim:read`."
type: string
format: password
x-descriptors:
- urn:camel:group:credentials
delay:
title: Delay
description: The delay between polls. If no unit provided, miliseconds is the default.
type: string
default: "60000"
example: "60s or 6000 or 1m"
naturalOrder:
title: Natural Order
description: Create exchanges in natural order (oldest to newest) or not.
type: boolean
default: false
dataTypes:
out:
default: json
headers:
types:
json:
format: "application-json"
description: Json mapping of a Slack API Message
mediaType: application/json
cloudevents:
format: "slack:application-cloudevents"
description: |-
Output data type represents Azure Storage Blob get blob response as CloudEvent V1. The data type sets Camel specific CloudEvent headers on the exchange with
respective data from the Azure container and its derived object.
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.slack.consume"
type: string
CamelCloudEventSource:
title: CloudEvent Source
description: The event source. By default, the Slack App Id with prefix "slack.".
type: string
CamelCloudEventSubject:
title: CloudEvent Subject
description: The event subject. The Slack Channel name.
type: string
CamelCloudEventTime:
title: CloudEvent Time
description: The exchange creation timestamp as event time.
type: string
types:
out:
mediaType: application/json
dependencies:
- "camel:gson"
- "camel:slack"
- "camel:kamelet"
template:
from:
uri: "slack:{{channel}}"
parameters:
token: "{{token}}"
delay: "{{delay}}"
naturalOrder: "{{naturalOrder}}"
steps:
- marshal:
json:
library: "Gson"
- to: "kamelet:sink"