Same as homepage deploy Prepare for two-step deploy: - local build and fix local tag - deploy to remote server
56 lines
1.5 KiB
YAML
56 lines
1.5 KiB
YAML
---
|
|
- name: "Deploy transcriber application"
|
|
hosts: all
|
|
|
|
vars_files:
|
|
- vars/ports.yml
|
|
- vars/secrets.yml
|
|
- vars/transcriber.yml
|
|
- vars/transcriber.images.yml
|
|
|
|
tasks:
|
|
- name: "Create user and environment"
|
|
ansible.builtin.import_role:
|
|
name: owner
|
|
vars:
|
|
owner_name: "{{ app_user }}"
|
|
owner_extra_groups: ["docker"]
|
|
|
|
- name: "Create application internal directories"
|
|
ansible.builtin.file:
|
|
path: "{{ item }}"
|
|
state: "directory"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0750"
|
|
loop:
|
|
- "{{ config_dir }}"
|
|
- "{{ data_dir }}"
|
|
- "{{ backups_dir }}"
|
|
|
|
- name: "Copy configuration files (templates)"
|
|
ansible.builtin.copy:
|
|
src: "files/{{ app_name }}/config.secrets.toml"
|
|
dest: "{{ config_file }}"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0600"
|
|
|
|
- name: "Login to yandex docker registry."
|
|
ansible.builtin.script:
|
|
cmd: "files/yandex-docker-registry-auth.sh"
|
|
|
|
- name: "Copy docker compose file"
|
|
ansible.builtin.template:
|
|
src: "./files/{{ app_name }}/docker-compose.template.yml"
|
|
dest: "{{ base_dir }}/docker-compose.yml"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0640"
|
|
|
|
- name: "Run application with docker compose"
|
|
community.docker.docker_compose_v2:
|
|
project_src: "{{ base_dir }}"
|
|
state: "present"
|
|
remove_orphans: true
|