Official GitHub Action to create a CI/CD pipeline that deploys Flows or Namespace Files to your Kestra server.
This action should be used within a workflow that runs only on your main
branch.
Only one namespace can be specified in each Kestra Deploy Action
so you may need to
reuse the action for each namespace. Here is an example:
- name: deploy-prod
uses: kestra-io/deploy-action@master
with:
namespace: prod
directory: ./flows
- name: deploy-prod-marketing
uses: kestra-io/deploy-action@master
with:
namespace: prod.marketing
directory: ./flows/marketing
Also, note that this GitHub Action supports flows built with Kestra v0.6.1+.
It takes a directory
as an input argument, indicating the directory within your repository where your Flow
or Template
YAML files are stored.
For each resource, the following outcomes are possible:
- Create a flow or a template resource, if the resource does not exist.
- Update a flow or a template resource, if the resource exists.
- Delete a flow or a template resource, if the resource exists, but the file does not exist anymore (i.e. the flow or template file got deleted).
- You can disable the deletion of a given resource by setting
delete: false
in the action, as shown in the full example below.
- You can disable the deletion of a given resource by setting
The action logs all these outcomes by specifying which resources got updated, added or deleted.
Note that the action can NOT update multiple namespaces at the same time. We recommend grouping your Flows
and
Templates
into subdirectories indicating a specific namespace. For the example shown above, your directory structure could look as follows:
.
├── flows
│ ├── flow1.yml
│ ├── flow2.yml
│ └── flow3.yml
├── marketing
│ ├── marketing__flow1.yml
│ ├── marketing__flow2.yml
│ └── marketing__flow3.yml
Also, you should always deploy your Templates
before your Flows
, to avoid running before their
templates are created.
Namespace files should also be deployed before the flows to prevent a flow depending on one of these files before the file exists.
Note that when using the namespace_files
resource type, you can add a special file called .kestraignore
to ignore some files and folders using regular expression patterns that follow the .gitignore syntax.
Example of a .kestraignore
file (which works exactly the same way as .gitignore
):
flows/
Dockerfile
docker-compose.yml
*.md
Inputs | Required | Default | Description |
---|---|---|---|
namespace |
✔️ | Namespace containing your flows and templates | |
directory |
✔️ | Folder containing your resources | |
resource |
✔️ | Resource you want to update in your namespace, can be either flow ,template or namespace_files |
|
server |
✔️ | URL of your Kestra server | |
user |
❌ | User name of your Kestra server | |
password |
❌ | Password of your Kestra server | |
delete |
❌ | true | Flows found in Kestra server, but no longer existing in a specified directory, will be deleted by default. Set this to false if you want to avoid that behavior |
tenant |
❌ | Tenant identifier (EE only, when multi-tenancy is enabled) | |
to |
❌ | Remote path indicating where to upload namespace files to |
Depending on your Kestra edition, you may need to include a user
and password
to authenticate the action with your Kestra server.
Example with Flows
resources:
- name: flow update namespace action
uses: kestra-io/deploy-action@master
with:
namespace: io.kestra.namespace
resource: flow
directory: ./flows/namespace_dedicated_folder
server: https:/kestra.io
Example with namespace_file
resources:
- name: template update namespace action
uses: kestra-io/deploy-action@master
with:
namespace: io.kestra.namespace
resource: namespace_file
directory: ./files/namespace_dedicated_folder
server: https:/kestra.io
Example with Templates
resources (deprecated):
- name: template update namespace action
uses: kestra-io/deploy-action@master
with:
namespace: io.kestra.namespace
resource: template
directory: ./templates/namespace_dedicated_folder
server: https:/kestra.io
Assuming that you store all your flow YAML files in the flows
directory and that all flows belong to the namespace prod
, you can configure a GitHub Action workflow by creating the following file (you can store the file as .github/workflows/main.yml
):
name: Kestra CI/CD
on:
workflow_dispatch:
jobs:
kestra:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: deploy
uses: kestra-io/deploy-action@master
with:
namespace: prod
directory: ./flows
resource: flow
server: ${{secrets.KESTRA_HOST}}
user: ${{secrets.KESTRA_USER}}
password: ${{secrets.KESTRA_PASSWORD}}
delete: false
This setup also assumes that you stored the host name, user name and password as Actions secrets.
Finally, instead of only running this workflow manually, you can configure it to be triggered upon push to the main branch:
name: Kestra CI/CD
on:
push:
branches:
- main
jobs:
...
Read more in the documentation here.