mash-playbook/justfile
Slavi Pantaleev 7a06bd9588 Create setup.yml based on a template (setup.all.yml)
In the future, we'll also have optional optimization steps, which could
trim down `setup.yml` based on the components being used.

Related to e2132a3c51 which did the same
for the `requirements.yml` file.
2023-11-19 15:25:28 +02:00

75 lines
2.6 KiB
Makefile

# Shows help
default:
@just --list --justfile {{ justfile() }}
# Pulls external Ansible roles
roles: requirements-yml
#!/usr/bin/env sh
if [ -x "$(command -v agru)" ]; then
agru -r {{ justfile_directory() }}/requirements.yml
else
rm -rf roles/galaxy
ansible-galaxy install -r requirements.yml -p roles/galaxy/ --force
fi
# Updates requirements.yml if there are any new tags available. Requires agru
update: && opml
@agru -r {{ justfile_directory() }}/requirements.all.yml -u
# Runs ansible-lint against all roles in the playbook
lint:
ansible-lint
# dumps an OPML file with extracted git feeds for roles
opml:
@echo "generating opml..."
@python bin/feeds.py . dump
# Runs the playbook with --tags=install-all,start and optional arguments
install-all *extra_args: (run-tags "install-all,start" extra_args)
# Runs installation tasks for a single service
install-service service *extra_args:
just --justfile {{ justfile() }} run \
--tags=install-{{ service }},start-group \
--extra-vars=group={{ service }} \
--extra-vars=devture_systemd_service_manager_service_restart_mode=one-by-one {{ extra_args }}
# Runs the playbook with --tags=setup-all,start and optional arguments
setup-all *extra_args: (run-tags "setup-all,start" extra_args)
# Runs the playbook with the given list of arguments
run +extra_args: requirements-yml setup-yml
ansible-playbook -i inventory/hosts setup.yml {{ extra_args }}
# Runs the playbook with the given list of comma-separated tags and optional arguments
run-tags tags *extra_args:
just --justfile {{ justfile() }} run --tags={{ tags }} {{ extra_args }}
# Starts all services
start-all *extra_args: (run-tags "start-all" extra_args)
# Starts a specific service group
start-group group *extra_args:
@just --justfile {{ justfile() }} run-tags start-group --extra-vars="group={{ group }}" {{ extra_args }}
# Stops all services
stop-all *extra_args: (run-tags "stop-all" extra_args)
# Stops a specific service group
stop-group group *extra_args:
@just --justfile {{ justfile() }} run-tags stop-group --extra-vars="group={{ group }}" {{ extra_args }}
# Prepares the requirements.yml file
requirements-yml:
#!/usr/bin/env sh
if [ ! -f "{{ justfile_directory() }}/requirements.yml" ]; then
cp {{ justfile_directory() }}/requirements.all.yml {{ justfile_directory() }}/requirements.yml
fi
# Prepares the setup.yml file
setup-yml:
#!/usr/bin/env sh
if [ ! -f "{{ justfile_directory() }}/setup.yml" ]; then
cp {{ justfile_directory() }}/setup.all.yml {{ justfile_directory() }}/setup.yml
fi