38 lines
1.3 KiB
YAML
38 lines
1.3 KiB
YAML
|
- name: Deploy app
|
||
|
hosts: photos
|
||
|
gather_facts: false
|
||
|
vars:
|
||
|
app: immich
|
||
|
tasks:
|
||
|
- name: Wait for connection
|
||
|
ansible.builtin.wait_for_connection:
|
||
|
timeout: 300
|
||
|
- name: Get user
|
||
|
ansible.builtin.user:
|
||
|
name: debian
|
||
|
register: user
|
||
|
- name: Docker compose down
|
||
|
ansible.builtin.command: docker compose down
|
||
|
args:
|
||
|
chdir: "{{ user.home }}/{{ app }}"
|
||
|
ignore_errors: true
|
||
|
- name: Copy project
|
||
|
ansible.builtin.copy:
|
||
|
src: "./{{ app }}"
|
||
|
dest: "{{ user.home }}"
|
||
|
mode: "0744"
|
||
|
- name: Replace Typesense secret
|
||
|
ansible.builtin.replace:
|
||
|
path: "{{ user.home }}/{{ app }}/.env"
|
||
|
regexp: "TYPESENSE_API_KEY_VALUE"
|
||
|
replace: "{{ lookup('ansible.builtin.password', user.home + '/typesense_secret', length=64, chars=['ascii_letters', 'digits']) }}"
|
||
|
- name: Replace DB secret
|
||
|
ansible.builtin.replace:
|
||
|
path: "{{ user.home }}/{{ app }}/.env"
|
||
|
regexp: "DB_PASSWORD_VALUE"
|
||
|
replace: "{{ lookup('ansible.builtin.password', user.home + '/db_secret', length=64, chars=['ascii_letters', 'digits']) }}"
|
||
|
- name: Docker compose up -d
|
||
|
ansible.builtin.command: docker compose up -d
|
||
|
args:
|
||
|
chdir: "{{ user.home }}/{{ app }}"
|