kamelets/google-mail-source.kamelet.yaml (114 lines of code) (raw):

# --------------------------------------------------------------------------- # 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: google-mail-source annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.0.0-SNAPSHOT" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Google Mail" camel.apache.org/kamelet.namespace: "GCP" labels: camel.apache.org/kamelet.type: "source" spec: definition: title: "Google Mail Source" description: |- Receive data from Google Mail. required: - index - clientId - accessToken - refreshToken - clientSecret - applicationName type: object properties: index: title: Index description: An index for the google mail endpoint type: string clientId: title: Client ID description: Client ID of the gmail application type: string format: password x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials clientSecret: title: Client Secret description: Client Secret of the gmail application type: string format: password x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials accessToken: title: Access Token description: OAuth 2 access token for google mail application. This typically expires after an hour so refreshToken is recommended for long term usage. type: string format: password x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials refreshToken: title: Refresh Token description: OAuth 2 refresh token for google mail application. Using this, the Google Calendar component can obtain a new accessToken whenever the current one expires - a necessity if the application is long-lived. type: string format: password x-descriptors: - urn:alm:descriptor:com.tectonic.ui:password - urn:camel:group:credentials delay: title: Delay description: The number of milliseconds before the next poll type: integer default: 500 applicationName: title: Application name description: Google Mail application name type: string markAsRead: title: Mark as Read description: Mark the message as read once it has been consumed type: boolean x-descriptors: - 'urn:alm:descriptor:com.tectonic.ui:checkbox' default: true labels: title: Gmail Labels description: Comma separated list of labels to take into account type: string example: "inbox" query: title: Gmail Query description: The query to execute on gmail box type: string example: "is:unread -category:(promotions OR social)" default: "is:unread" types: out: mediaType: application/json dependencies: - "camel:jackson" - "camel:kamelet" - "camel:google-mail" template: from: uri: "google-mail-stream://{{index}}" parameters: clientId: "{{clientId}}" accessToken: "{{accessToken}}" refreshToken: "{{refreshToken}}" clientSecret: "{{clientSecret}}" delay: "{{delay}}" applicationName: "{{applicationName}}" markAsRead: "{{markAsRead}}" labels: "{{labels}}" query: "{{query}}" steps: - marshal: json: {} - to: "kamelet:sink"