blob: c0590a6348f9ac2db741051c132e7c85790c350d [file] [log] [blame]
apiVersion: camel.apache.org/v1alpha1
kind: Kamelet
metadata:
name: google-sheets-source
annotations:
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Apache Software Foundation"
labels:
camel.apache.org/kamelet.type: "source"
spec:
definition:
title: "Google Sheets Source"
description: |-
Receive data from Google Sheets.
required:
- index
- spreadsheetId
- clientId
- accessToken
- refreshToken
- clientSecret
- applicationName
properties:
index:
title: Index
description: An index for the google sheets endpoint
type: string
spreadsheetId:
title: Spreadsheet ID
description: The Spreadsheet ID to be used as events source
type: string
clientId:
title: Client Id
description: Client ID of the sheets application
type: string
x-descriptors:
- urn:alm:descriptor:com.tectonic.ui:password
clientSecret:
title: Client Secret
description: Client Secret of the sheets application
type: string
x-descriptors:
- urn:alm:descriptor:com.tectonic.ui:password
accessToken:
title: Access Token
description: OAuth 2 access token for google sheets application. This typically expires after an hour so refreshToken is recommended for long term usage.
type: string
x-descriptors:
- urn:alm:descriptor:com.tectonic.ui:password
refreshToken:
title: Refresh Token
description: OAuth 2 refresh token for google sheets 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
x-descriptors:
- urn:alm:descriptor:com.tectonic.ui:password
delay:
title: Delay
description: Milliseconds before the next poll
type: integer
default: 500
applicationName:
title: Application name
description: Google Sheets application name
type: string
splitResults:
title: Split Results
description: True if value range result should be split into rows or columns to process each of them individually.
type: boolean
x-descriptors:
- 'urn:alm:descriptor:com.tectonic.ui:checkbox'
default: true
range:
title: Consume from now
description: the range of rows and columns in a sheet to get data from.
type: boolean
x-descriptors:
- 'urn:alm:descriptor:com.tectonic.ui:checkbox'
example: "A1:B3"
types:
out:
mediaType: application/json
dependencies:
- "camel:jackson"
flow:
from:
uri: "google-sheets-stream://{{index}}"
parameters:
clientId: "{{clientId}}"
spreadsheetId: "{{spreadsheetId}}"
accessToken: "{{accessToken}}"
refreshToken: "{{refreshToken}}"
clientSecret: "{{clientSecret}}"
delay: "{{delay}}"
applicationName: "{{applicationName}}"
splitResults: "{{splitResults}}"
range: "{{range}}"
steps:
- marshal:
json: {}
- to: "kamelet:sink"