diff --git a/docs/modules/ROOT/assets/images/kamelets/sftp-source.svg b/docs/modules/ROOT/assets/images/kamelets/sftp-source.svg new file mode 100644 index 000000000..4c77024ae --- /dev/null +++ b/docs/modules/ROOT/assets/images/kamelets/sftp-source.svg @@ -0,0 +1 @@ +sftp \ No newline at end of file diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index e512fe2bb..7847c8005 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -12,6 +12,7 @@ * xref:ROOT:mqtt-source.adoc[image:kamelets/mqtt-source.svg[] MQTT Source] * xref:ROOT:nats-source.adoc[image:kamelets/nats-source.svg[] NATS Source] * xref:ROOT:salesforce-source.adoc[image:kamelets/salesforce-source.svg[] Salesforce Source] +* xref:ROOT:sftp-source.adoc[image:kamelets/sftp-source.svg[] SFTP Source] * xref:ROOT:slack-source.adoc[image:kamelets/slack-source.svg[] Slack Source] * xref:ROOT:telegram-source.adoc[image:kamelets/telegram-source.svg[] Telegram Source] * xref:ROOT:timer-source.adoc[image:kamelets/timer-source.svg[] Timer Source] diff --git a/docs/modules/ROOT/pages/ftp-source.adoc b/docs/modules/ROOT/pages/ftp-source.adoc index 4b4e59f72..0792f9b65 100644 --- a/docs/modules/ROOT/pages/ftp-source.adoc +++ b/docs/modules/ROOT/pages/ftp-source.adoc @@ -11,11 +11,13 @@ The following table summarizes the configuration options available for the `ftp- [width="100%",cols="2,^2,3,^2,^2,^3",options="header"] |=== | Property| Name| Description| Type| Default| Example -| *directoryName {empty}* *| directoryName| The starting directory| string| | +| *directoryName {empty}* *| Directory Name| The starting directory| string| | | *host {empty}* *| Host| Hostname of the FTP server| string| | | *password {empty}* *| Password| The password to access the FTP server| string| | | *port {empty}* *| Port| Port of the FTP server| string| `21`| | *username {empty}* *| Username| The username to access the FTP server| string| | +| passiveMode| Passive Mode| Sets passive mode connection| boolean| `false`| +| recursive| Recursive| If a directory, will look for files in all the sub-directories as well.| boolean| `false`| |=== NOTE: Fields marked with ({empty}*) are mandatory. @@ -42,7 +44,7 @@ spec: apiVersion: camel.apache.org/v1alpha1 name: ftp-source properties: - directoryName: "The directoryName" + directoryName: "The Directory Name" host: "The Host" password: "The Password" username: "The Username" diff --git a/docs/modules/ROOT/pages/sftp-source.adoc b/docs/modules/ROOT/pages/sftp-source.adoc new file mode 100644 index 000000000..69d25fc76 --- /dev/null +++ b/docs/modules/ROOT/pages/sftp-source.adoc @@ -0,0 +1,69 @@ +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT += image:kamelets/sftp-source.svg[] SFTP Source + +*Provided by: "Apache Software Foundation"* + +Receive data from an SFTP Server. + +== Configuration Options + +The following table summarizes the configuration options available for the `sftp-source` Kamelet: +[width="100%",cols="2,^2,3,^2,^2,^3",options="header"] +|=== +| Property| Name| Description| Type| Default| Example +| *directoryName {empty}* *| Directory Name| The starting directory| string| | +| *host {empty}* *| Host| Hostname of the SFTP server| string| | +| *password {empty}* *| Password| The password to access the SFTP server| string| | +| *port {empty}* *| Port| Port of the FTP server| string| `22`| +| *username {empty}* *| Username| The username to access the SFTP server| string| | +| passiveMode| Passive Mode| Sets passive mode connection| boolean| `false`| +| recursive| Recursive| If a directory, will look for files in all the sub-directories as well.| boolean| `false`| +|=== + +NOTE: Fields marked with ({empty}*) are mandatory. + +== Usage + +This section summarizes how the `sftp-source` can be used in various contexts. + +=== Knative Source + +The `sftp-source` Kamelet can be used as Knative source by binding it to a Knative object. + +.sftp-source-binding.yaml +[source,yaml] +---- +apiVersion: camel.apache.org/v1alpha1 +kind: KameletBinding +metadata: + name: sftp-source-binding +spec: + source: + ref: + kind: Kamelet + apiVersion: camel.apache.org/v1alpha1 + name: sftp-source + properties: + directoryName: "The Directory Name" + host: "The Host" + password: "The Password" + username: "The Username" + sink: + ref: + kind: InMemoryChannel + apiVersion: messaging.knative.dev/v1 + name: mychannel + +---- + +Make sure you have xref:latest@camel-k::installation/installation.adoc[Camel K installed] into the Kubernetes cluster you're connected to. + +Save the `sftp-source-binding.yaml` file into your hard drive, then configure it according to your needs. + +You can run the source using the following command: + +[source,shell] +---- +kubectl apply -f sftp-source-binding.yaml +---- +// THIS FILE IS AUTOMATICALLY GENERATED: DO NOT EDIT diff --git a/ftp-source.kamelet.yaml b/ftp-source.kamelet.yaml index f3e23787f..18c827c91 100644 --- a/ftp-source.kamelet.yaml +++ b/ftp-source.kamelet.yaml @@ -7,6 +7,7 @@ metadata: camel.apache.org/provider: "Apache Software Foundation" labels: camel.apache.org/kamelet.type: "source" + camel.apache.org/kamelet.group: "FTP" spec: definition: title: "FTP Source" diff --git a/sftp-source.kamelet.yaml b/sftp-source.kamelet.yaml new file mode 100644 index 000000000..aa99b0328 --- /dev/null +++ b/sftp-source.kamelet.yaml @@ -0,0 +1,69 @@ +apiVersion: camel.apache.org/v1alpha1 +kind: Kamelet +metadata: + name: sftp-source + annotations: + camel.apache.org/kamelet.icon: "" + camel.apache.org/provider: "Apache Software Foundation" + labels: + camel.apache.org/kamelet.type: "source" + camel.apache.org/kamelet.group: "FTP" +spec: + definition: + title: "SFTP Source" + description: |- + Receive data from an SFTP Server. + required: + - host + - port + - username + - password + - directoryName + properties: + host: + title: Host + description: Hostname of the SFTP server + type: string + port: + title: Port + description: Port of the FTP server + type: string + default: 22 + username: + title: Username + description: The username to access the SFTP server + type: string + password: + title: Password + description: The password to access the SFTP server + type: string + x-descriptors: + - urn:alm:descriptor:com.tectonic.ui:password + directoryName: + title: Directory Name + description: The starting directory + type: string + passiveMode: + title: Passive Mode + description: Sets passive mode connection + type: boolean + default: false + recursive: + title: Recursive + description: If a directory, will look for files in all the sub-directories as well. + type: boolean + default: false + types: + out: + mediaType: application/json + flow: + from: + uri: "sftp:{{username}}@{{host}}:{{port}}/{{directoryName}}" + parameters: + password: "{{password}}" + passiveMode: "{{passiveMode}}" + recursive: "{{recursive}}" + steps: + - convert-body-to: + type: "java.lang.String" + - to: "kamelet:sink"