82 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| # Shows help
 | |
| default:
 | |
|     @just --list --justfile {{ justfile() }}
 | |
| 
 | |
| # Pulls external Ansible roles
 | |
| roles:
 | |
|     #!/usr/bin/env sh
 | |
|     echo "[NOTE] This command just updates the roles, but if you want to update everything at once (playbook, roles, etc.) - use 'just update'"
 | |
|     if [ -x "$(command -v agru)" ]; then
 | |
|     	agru
 | |
|     else
 | |
|     	rm -rf roles/galaxy
 | |
|     	ansible-galaxy install -r requirements.yml -p roles/galaxy/ --force
 | |
|     fi
 | |
| 
 | |
| # Updates the playbook and installs the necessary Ansible roles pinned in requirements.yml. If a -u flag is passed, also updates the requirements.yml file with new role versions (if available)
 | |
| update *flags: update-playbook-only
 | |
|     #!/usr/bin/env sh
 | |
|     if [ -x "$(command -v agru)" ]; then
 | |
|         echo {{ if flags == "" { "Installing roles pinned in requirements.yml…" } else if flags == "-u" { "Updating roles and pinning new versions in requirements.yml…" } else { "Unknown flags passed" } }}
 | |
|         agru {{ flags }}
 | |
|     else
 | |
|         echo "[NOTE] You are using the standard ansible-galaxy tool to install roles, which is slow and lacks other features. We recommend installing the 'agru' tool to speed up the process: https://github.com/etkecc/agru#where-to-get"
 | |
|         echo "Installing roles…"
 | |
|         rm -rf roles/galaxy
 | |
|         ansible-galaxy install -r requirements.yml -p roles/galaxy/ --force
 | |
|     fi
 | |
| 
 | |
| # Updates the playbook without installing/updating Ansible roles
 | |
| update-playbook-only:
 | |
|     @echo "Updating playbook…"
 | |
|     @git stash -q
 | |
|     @git pull -q
 | |
|     @-git stash pop -q
 | |
| 
 | |
| # Runs ansible-lint against all roles in the playbook
 | |
| lint:
 | |
|     ansible-lint
 | |
| 
 | |
| # Runs the playbook with --tags=install-all,ensure-matrix-users-created,start and optional arguments
 | |
| install-all *extra_args: (run-tags "install-all,ensure-matrix-users-created,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,ensure-matrix-users-created,start and optional arguments
 | |
| setup-all *extra_args: (run-tags "setup-all,ensure-matrix-users-created,start" extra_args)
 | |
| 
 | |
| # Runs the playbook with the given list of arguments
 | |
| run +extra_args:
 | |
|     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 }}
 | |
| 
 | |
| # Runs the playbook in user-registration mode
 | |
| register-user username password admin_yes_or_no *extra_args:
 | |
|     ansible-playbook -i inventory/hosts setup.yml --tags=register-user --extra-vars="username={{ username }} password={{ password }} admin={{ admin_yes_or_no }}" {{ 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 }}
 | |
| 
 | |
| # Rebuilds the mautrix-meta-instagram Ansible role using the mautrix-meta-messenger role as a source
 | |
| rebuild-mautrix-meta-instagram:
 | |
|     /bin/bash {{ justfile_directory() }}/bin/rebuild-mautrix-meta-instagram.sh {{ justfile_directory() }}/roles/custom
 |