kamelets/dropbox-sink.kamelet.yaml (77 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/v1 kind: Kamelet metadata: name: dropbox-sink annotations: camel.apache.org/kamelet.support.level: "Stable" camel.apache.org/catalog.version: "4.12.0-SNAPSHOT" camel.apache.org/kamelet.icon: "" camel.apache.org/provider: "Apache Software Foundation" camel.apache.org/kamelet.group: "Dropbox" camel.apache.org/kamelet.namespace: "Cloud" labels: camel.apache.org/kamelet.type: "sink" spec: definition: title: "Dropbox Sink" description: |- Upload Files to Dropbox. The Kamelet expects the following headers to be set: - `file` / `ce-file`: as the file name to upload If the header won't be set the exchange ID will be used as file name. required: - accessToken - clientIdentifier - remotePath - uploadMode type: object properties: accessToken: title: Dropbox Access Token description: The access Token to use to access Dropbox type: string format: password x-descriptors: - urn:camel:group:credentials clientIdentifier: title: Client Identifier description: Dropbox App client Identifier type: string x-descriptors: - urn:camel:group:credentials remotePath: title: Remote Path description: Original file or folder to work with type: string uploadMode: title: Upload Mode description: Which mode to upload. in case of add the new file will be renamed if a file with the same name already exists on dropbox. in case of force if a file with the same name already exists on dropbox, this will be overwritten. The value can be one of add, force. type: string default: add dependencies: - "camel:core" - "camel:dropbox" - "camel:kamelet" template: from: uri: "kamelet:source" steps: - choice: when: - simple: "${header[file]}" steps: - setHeader: name: CamelDropboxPutFileName simple: "${header[file]}" - simple: "${header[ce-file]}" steps: - setHeader: name: CamelDropboxPutFileName simple: "${header[ce-file]}" - to: uri: 'dropbox:put' parameters: accessToken: '{{accessToken}}' remotePath: '{{remotePath}}' clientIdentifier: '{{clientIdentifier}}' uploadMode: '{{uploadMode}}'