Migrate inventory to yaml
This commit is contained in:
		
							
								
								
									
										62
									
								
								Taskfile.yml
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								Taskfile.yml
									
									
									
									
									
								
							| @@ -7,70 +7,24 @@ vars: | ||||
|     sh: 'id -u' | ||||
|   GROUP_ID: | ||||
|     sh: 'id -g' | ||||
|   HOSTS_FILE: 'ansible/hosts_prod' | ||||
|   REMOTE_USER: 'major' | ||||
|   HOSTS_FILE: 'production.yml' | ||||
|   REMOTE_USER: | ||||
|     sh: 'yq .ungrouped.hosts.server.ansible_user {{.HOSTS_FILE}}' | ||||
|   REMOTE_HOST: | ||||
|     sh: 'cat {{.HOSTS_FILE}} | xargs' | ||||
|     sh: 'yq .ungrouped.hosts.server.ansible_host {{.HOSTS_FILE}}' | ||||
|  | ||||
| tasks: | ||||
|   ssh: | ||||
|     cmds: | ||||
|       - ssh {{.REMOTE_USER}}@{{.REMOTE_HOST}} | ||||
|     - ssh {{.REMOTE_USER}}@{{.REMOTE_HOST}} | ||||
|  | ||||
|   edit-vars: | ||||
|     cmds: | ||||
|       - ansible-vault edit ansible/vars/vars.yml | ||||
|     - ansible-vault edit vars/vars.yml | ||||
|     env: | ||||
|       EDITOR: micro | ||||
|  | ||||
|   list-tags: | ||||
|     cmds: | ||||
|       - >- | ||||
|         ansible-playbook | ||||
|         --inventory="{{.HOSTS_FILE}}" | ||||
|         --list-tags | ||||
|         ansible/configuration.yml | ||||
|  | ||||
|   configure: | ||||
|     internal: true | ||||
|     vars: | ||||
|       TAGS: '{{ (empty .TAGS) | ternary "" (list "--tags=\"" .TAGS "\"" | join "") }}' | ||||
|     cmds: | ||||
|       - >-  | ||||
|         ansible-playbook | ||||
|         --become | ||||
|         --user="{{.REMOTE_USER}}" | ||||
|         --inventory="{{.HOSTS_FILE}}" | ||||
|         --extra-vars="ansible_python_interpreter=/usr/bin/python3" | ||||
|         {{.TAGS}} | ||||
|         ansible/configuration.yml | ||||
|  | ||||
|   configure-all: | ||||
|     cmds: | ||||
|       - task: configure | ||||
|  | ||||
|   configure-monitoring: | ||||
|     cmds: | ||||
|       - task: configure | ||||
|         vars: { TAGS: 'monitoring' } | ||||
|  | ||||
|   configure-apps: | ||||
|     cmds: | ||||
|       - task: configure | ||||
|         vars: { TAGS: 'webserver,apps,env' } | ||||
|  | ||||
|   configure-users: | ||||
|     cmds: | ||||
|       - task: configure | ||||
|         vars: { TAGS: 'apps,env' } | ||||
|  | ||||
|   format-py-files: | ||||
|     cmds: | ||||
|       - >- | ||||
|         docker run | ||||
|         --rm | ||||
|         -u {{.USER_ID}}:{{.GROUP_ID}} | ||||
|         -v $PWD:/app | ||||
|         -w /app | ||||
|         pyfound/black:latest_release | ||||
|         black . | ||||
|     - >- | ||||
|       docker run --rm -u {{.USER_ID}}:{{.GROUP_ID}} -v $PWD:/app -w /app pyfound/black:latest_release black . | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| 158.160.46.255 | ||||
| @@ -10,6 +10,7 @@ | ||||
|     apt_packages: | ||||
|       - acl | ||||
|       - git | ||||
|       - htop | ||||
|       - python3-pip | ||||
|  | ||||
|   tasks: | ||||
|   | ||||
							
								
								
									
										7
									
								
								production.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								production.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| --- | ||||
| ungrouped: | ||||
|   hosts: | ||||
|     server: | ||||
|       ansible_host: '158.160.46.255' | ||||
|       ansible_user: 'major' | ||||
|       ansible_become: true | ||||
							
								
								
									
										4
									
								
								tasks.py
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								tasks.py
									
									
									
									
									
								
							| @@ -53,7 +53,5 @@ def deploy(app_name: str, compose_file="docker-compose.yml", dirs=None): | ||||
|         c.run( | ||||
|             f"docker compose --project-name {shlex.quote(app_name)} --env-file=.env.prod up --detach --remove-orphans" | ||||
|         ) | ||||
|         c.run( | ||||
|             f"docker system prune --all --volumes --force" | ||||
|         ) | ||||
|         c.run(f"docker system prune --all --volumes --force") | ||||
|     print("Done.") | ||||
|   | ||||
		Reference in New Issue
	
	Block a user