type: "io.kestra.plugin.core.namespace.UploadFiles"
Upload one or multiple files to a specific namespace.
Use a regex glob pattern or a file path to upload files as Namespace Files. When using a map with the desired file name as key and file path as value, you can also rename or relocate files.
Examples
Upload files generated by a previous task using the filesMap
property.
id: upload_files_from_git
namespace: company.team
tasks:
- id: download
type: io.kestra.plugin.core.http.Download
uri: https://github.com/kestra-io/scripts/archive/refs/heads/main.zip
- id: unzip
type: io.kestra.plugin.compress.ArchiveDecompress
from: "{{ outputs.download.uri }}"
algorithm: ZIP
- id: upload
type: io.kestra.plugin.core.namespace.UploadFiles
filesMap: "{{ outputs.unzip.files }}"
namespace: "{{ flow.namespace }}"
Upload a folder using a glob pattern. Note that the Regex syntax requires a glob
pattern inspired by Apache Ant patterns. Make sure that your pattern starts with glob:
, followed by the pattern. For example, use glob:**/dbt/**
to upload the entire dbt
folder (with all files and subdirectories) regardless of that folder's location in the directory structure.
id: upload_dbt_project
namespace: company.team
tasks:
- id: wdir
type: io.kestra.plugin.core.flow.WorkingDirectory
tasks:
- id: git_clone
type: io.kestra.plugin.git.Clone
url: https://github.com/kestra-io/dbt-example
branch: master
- id: upload
type: io.kestra.plugin.core.namespace.UploadFiles
files:
- "glob:**/dbt/**"
namespace: "{{ flow.namespace }}"
Upload a specific file and rename it.
id: upload_a_file
namespace: company.team
tasks:
- id: download
type: io.kestra.plugin.core.http.Download
uri: https://github.com/kestra-io/scripts/archive/refs/heads/main.zip
- id: unzip
type: io.kestra.plugin.compress.ArchiveDecompress
from: "{{ outputs.download.uri }}"
algorithm: ZIP
- id: upload
type: io.kestra.plugin.core.namespace.UploadFiles
filesMap:
LICENCE: "{{ outputs.unzip.files['scripts-main/LICENSE'] }}"
namespace: "{{ flow.namespace }}"
Properties
namespace
- Type: string
- Dynamic: ✔️
- Required: ✔️
The namespace to which the files will be uploaded.
conflict
- Type: string
- Dynamic: ❌
- Required: ❌
- Default:
OVERWRITE
- Possible Values:
OVERWRITE
ERROR
SKIP
Which action to take when uploading a file that already exists.
Can be one of the following options: OVERWRITE, ERROR or SKIP. Default is OVERWRITE.
destination
- Type: string
- Dynamic: ✔️
- Required: ❌
- Default:
/
The destination folder.
Required when providing a list of files.
files
- Type: array
- SubType: string
- Dynamic: ✔️
- Required: ❌
A list of Regex that match files in the current directory.
This should be a list of Regex matching the Apache Ant patterns.It's primarily intended to be used with the
WorkingDirectory
task
filesMap
- Type:
- object
- string
- Dynamic: ✔️
- Required: ❌
A map of key-value pairs where the key is the filename and the value is the URI of the file to upload.
This should be a map of URI, with the key being the filename that will be upload, and the key the URI.This one is intended to be used with output files of other tasks. Many Kestra tasks, incl. all Downloads tasks, output a map of files so that you can directly pass the output property to this task e.g. outputFiles in the S3 Downloads task or the files in the Archive Decompress task.
Outputs
files
- Type: object
- SubType: string
- Required: ❌