9be4276676
deployment notes: - compare to Affine, maybe outline + memos can be substituted for affine
74 lines
2.5 KiB
YAML
74 lines
2.5 KiB
YAML
---
|
|
- name: Create memos directory
|
|
ansible.builtin.file:
|
|
path: "{{ node['home_path'] }}/{{ item }}"
|
|
state: "directory"
|
|
owner: "{{ services['memos']['subuid'] }}"
|
|
group: "svadmins"
|
|
mode: "0770"
|
|
loop:
|
|
- "data/containers/memos"
|
|
- "data/containers/memos/data"
|
|
- "containers/memos"
|
|
- "containers/memos/ssl"
|
|
become: true
|
|
|
|
- name: Deploy root certificate
|
|
ansible.builtin.copy:
|
|
content: |
|
|
{{ hostvars['console']['ca']['root']['crt'] }}
|
|
dest: "{{ node['home_path'] }}/containers/memos/ssl/{{ root_cert_filename }}"
|
|
owner: "{{ services['memos']['subuid'] }}"
|
|
group: "svadmins"
|
|
mode: "0440"
|
|
become: true
|
|
notify: "notification_restart_memos"
|
|
no_log: true
|
|
|
|
- name: Register secret value to podman secret
|
|
containers.podman.podman_secret:
|
|
name: "MEMOS_DSN"
|
|
data: "postgresql://memos:{{ hostvars['console']['postgresql']['password']['memos'] | urlencode | replace('/', '%2F') }}\
|
|
@{{ services['postgresql']['domain'] }}.{{ domain['internal'] }}/memos_db?sslmode=verify-full&\
|
|
sslrootcert=/etc/ssl/memos/{{ root_cert_filename }}"
|
|
state: "present"
|
|
force: true
|
|
notify: "notification_restart_memos"
|
|
|
|
- name: Deploy memos.container file
|
|
ansible.builtin.template:
|
|
src: "{{ hostvars['console']['node']['config_path'] }}/services/containers/app/memos/memos.container.j2"
|
|
dest: "{{ node['home_path'] }}/.config/containers/systemd/memos.container"
|
|
owner: "{{ ansible_user }}"
|
|
group: "svadmins"
|
|
mode: "0644"
|
|
notify: "notification_restart_memos"
|
|
|
|
- name: Enable memos.service
|
|
ansible.builtin.systemd:
|
|
name: "memos.service"
|
|
state: "started"
|
|
enabled: true
|
|
daemon_reload: true
|
|
scope: "user"
|
|
|
|
- name: Check container archive images
|
|
ansible.builtin.stat:
|
|
path: "{{ node['home_path'] }}/archives/containers/docker.io_neosmemo_memos_{{ version['containers']['memos'] }}.tar"
|
|
register: container_archive_images
|
|
|
|
- name: Save container archive images
|
|
containers.podman.podman_save:
|
|
image:
|
|
- "docker.io/neosmemo/memos:{{ version['containers']['memos'] }}"
|
|
dest: "{{ node['home_path'] }}/archives/containers/docker.io_neosmemo_memos_{{ version['containers']['memos'] }}.tar"
|
|
format: "oci-archive"
|
|
force: false
|
|
when: not container_archive_images.stat.exists
|
|
|
|
- name: Fetch container archive images
|
|
ansible.builtin.fetch:
|
|
src: "{{ node['home_path'] }}/archives/containers/docker.io_neosmemo_memos_{{ version['containers']['memos'] }}.tar"
|
|
dest: "{{ hostvars['console']['node']['data_path'] }}/images/containers/"
|
|
flat: true
|