SyncApps
Sync Apps from Git to Kestra.
This task syncs apps from a given Git branch to Kestra. If the delete
property is set to true, any app available in kestra but not present in the gitDirectory
will be deleted, considering Git as a single source of truth for your flows.
Check the Version Control with Git documentation for more details.
type: "io.kestra.plugin.ee.git.SyncApps"
id: sync_apps_from_git
namespace: system
tasks:
- id: git
type: io.kestra.plugin.ee.git.SyncApps
delete: true # optional; by default, it's set to false to avoid destructive behavior
url: https://github.com/kestra-io/apps # required
branch: main
username: git_username
password: "{{ secret('GITHUB_ACCESS_TOKEN') }}"
dryRun: true # if true, the task will only log which flows from Git will be added/modified or deleted in kestra without making any changes in kestra backend yet
triggers:
- id: every_full_hour
type: io.kestra.plugin.core.trigger.Schedule
cron: "0 * * * *"
main
The branch from which apps will be synced to Kestra.
Whether to clone submodules.
false
Whether you want to delete apps present in kestra but not present in Git.
It’s false
by default to avoid destructive behavior. Use this property with caution because when set to true
, this task will delete all apps from the targetNamespace
and all its child namespaces that are not present in Git rather than only overwriting the changes.
false
If true
, the task will only output modifications without performing any modification to Kestra. If false
(default), all listed modifications will be applied.
_apps
Directory from which apps should be synced.
The passphrase for the privateKey
.
The password or Personal Access Token (PAT). When you authenticate the task with a PAT, any flows or files pushed to Git from Kestra will be pushed from the user associated with that PAT. This way, you don't need to configure the commit author (the authorName
and authorEmail
properties).
PEM-format private key content that is paired with a public key registered on Git.
To generate an ECDSA PEM format key from OpenSSH, use the following command: ssh-keygen -t ecdsa -b 256 -m PEM
. You can then set this property with your private key content and put your public key on Git.
The URI to clone from.
The username or organization.