Workflowo is a tool to create simple local pipelines.
The configuration of pipelines is in a yaml file. There are Jobs located that can be executed from the cli.
Be careful when executing workflowo jobs from others. They may contain malicious code!
- resolve relative/
~
paths for file transfer - default for inputs
- parallel execution task
- exit codes for bash and cmd task
- improve error display
cargo install --git https://github.com/JL710/workflowo
Cargo/Rust needs to be installed => https://www.rust-lang.org/tools/install
Jobs are the largest abstraction layer. A Job has children. These children are Tasks. When a Job gets executed all of its children get executed in order.
example_job:
- child1
- child2
note that here a few placeholder values that would not be valid in a real context were used
A Task is something that can be executed. This can be a Job or other more specific tasks. For example a bash
or cmd
command.
job1:
- task1
- task2
job2:
- task3
- job1
- task4
note that here a few placeholder values that would not be valid in a real context were used
bash
and cmd
are to similar tasks. The only difference is that one will execute the command with bash and the other with cmd.
Short use:
example_job:
- cmd: 'echo "Hello World"'
Long use:
example_job:
- bash:
command: 'mkdir test'
work_dir: "/home/someUser"
exit_codes: [0, 1]
work_dir
andexit_codes
are optional
Sometimes it is needed to execute only if you are on a specific os. Therefore there is a solution.
example_job:
- on-linux:
- bash: 'echo "Hello World!"' # will only be executed if you are on Linux
- on-windows:
- cmd: 'echo "Hello World!"' # will only be executed if you are on Windows
example_job:
- ssh:
address: 192.128.114.12
username: "some_user"
password: "some_good_password"
commands:
- "mkdir newly_created_directory"
- "rmdir newly_created_directory"
If you want to specify the allowed exit codes of a command you can use this representation (the default allowed exit code is 0):
commands:
- "ls 1"
- command:
command: "ls 2"
exit_codes: [1, 2, 3]
With the scp-download
task you can download files from a remote computer via ssh onto your local.
example_job:
- scp-download:
address: 192.128.114.12
username: "some_user"
password: "some_good_password"
remote_path: "/home/some_user/remote_file.txt"
local_path: "some_local_file"
With the scp-upload
task you can upload files from a remote computer via ssh onto your local.
example_job:
- scp-upload:
address: 192.128.114.12
username: "some_user"
password: "some_good_password"
remote_path: "/home/some_user/remote_file.txt"
local_path: "some_local_file.txt"
Prints a value into the prompt.
example_job:
- print: "Hello World!"
With sftp-download
you can download files or directories from a remote computer via sftp onto your local.
example_job:
- sftp-upload:
address: 192.128.114.12
username: "some_user"
password: "some_good_password"
remote_path: "/home/some_user/remote_file.txt"
local_path: "some_local_file.txt"
With sftp-upload
you can upload files or directories to a remote computer via sftp from your local.
example_job:
- sftp-upload:
address: 192.128.114.12
username: "some_user"
password: "some_good_password"
remote_path: "/home/some_user/remote_file.txt"
local_path: "some_local_file.txt"
Sometimes you want to create content that should be ignored in the file. Therefore is the IGNORE
section.
Could be useful to define secrets(passwords etc.) once and use it anywhere.
IGNORE:
whatever_you_do_here_will_be_ignored
!StrF ["Hello ", "World!"]
Formats to:
"Hello World!"
!Input "Enter Something: "
!Input ["Enter Something: "]
!Input ["Enter Something: ", "this is the default"]
!Input {prompt: "Enter Something: "}
!Input {prompt: "Enter Something: ", default: "this is the default"}
use
!HiddenInput
to hide input
Asks via command line for an input. The input will be used as the value.
Is able to be used on !Input
Tags (on everything else as well). When using the yaml default, you have to input at every use. With !Input
once.
IGNORE:
- taken_input: &taken_input !Id ["taken_input", !Input "Input: "]
example_job:
- print: *taken_input
or
IGNORE:
- taken_input: &taken_input !Id { "id": "taken_input", "value": !Input "Input: " }
example_job:
- print: *taken_input