mirror of
https://gitlab.archlinux.org/archlinux/infrastructure.git
synced 2025-01-18 08:06:16 +01:00
ansible-lint 6.19.0 started complaining about this: schema[tasks]: 'become_method' must be one of the currently available values: ansible.builtin.runas, ansible.builtin.su, ansible.builtin.sudo, ansible.netcommon.enable, community.general.doas, community.general.dzdo, community.general.ksu, community.general.machinectl, community.general.pbrun, community.general.pfexec, community.general.pmrun, community.general.sesu, community.general.sudosu, containers.podman.podman_unshare
85 lines
2.9 KiB
YAML
85 lines
2.9 KiB
YAML
- name: Create postgres subvolume
|
|
command: btrfs subvol create /var/lib/postgres
|
|
args:
|
|
creates: /var/lib/postgres
|
|
when: filesystem == "btrfs"
|
|
|
|
- name: Install postgres
|
|
pacman: name=postgresql,python-psycopg2 state=present
|
|
|
|
- name: Create nocow database directory
|
|
file:
|
|
state: directory
|
|
owner: postgres
|
|
group: postgres
|
|
attributes: "+C"
|
|
path: /var/lib/postgres/data
|
|
mode: '0700'
|
|
when: filesystem == "btrfs"
|
|
|
|
- name: Initialize postgres
|
|
become: true
|
|
become_user: postgres
|
|
become_method: ansible.builtin.su
|
|
command: initdb --locale C.UTF-8 -E UTF8 -D '/var/lib/postgres/data'
|
|
args:
|
|
chdir: /var/lib/postgres
|
|
creates: /var/lib/postgres/data/postgresql.conf
|
|
notify:
|
|
- Restart postgres
|
|
|
|
- name: Configure postgres
|
|
template: src={{ item }}.j2 dest=/var/lib/postgres/data/{{ item }} owner=postgres group=postgres mode=0600
|
|
with_items:
|
|
- postgresql.conf
|
|
- pg_hba.conf
|
|
notify:
|
|
- Restart postgres
|
|
|
|
- name: Install postgres certificate
|
|
copy: src=/etc/letsencrypt/live/{{ inventory_hostname }}/fullchain.pem dest={{ postgres_ssl_cert_file }}
|
|
remote_src=true owner=postgres group=postgres mode=0400
|
|
when: postgres_ssl == 'on'
|
|
|
|
- name: Install postgres private key
|
|
copy: src=/etc/letsencrypt/live/{{ inventory_hostname }}/privkey.pem dest={{ postgres_ssl_key_file }}
|
|
remote_src=true owner=postgres group=postgres mode=0400
|
|
when: postgres_ssl == 'on'
|
|
|
|
- name: Install postgres ca
|
|
copy: src=/etc/letsencrypt/live/{{ inventory_hostname }}/chain.pem dest={{ postgres_ssl_ca_file }}
|
|
remote_src=true owner=postgres group=postgres mode=0400
|
|
when: postgres_ssl == 'on'
|
|
|
|
- name: Start and enable postgres
|
|
service: name=postgresql enabled=yes state=started
|
|
|
|
- name: Set postgres user password
|
|
postgresql_user: name=postgres password={{ vault_postgres_users.postgres }} encrypted=yes
|
|
become: true
|
|
become_user: postgres
|
|
become_method: ansible.builtin.su
|
|
|
|
- name: Install postgres cert renewal hook
|
|
template: src=letsencrypt.hook.d.j2 dest=/etc/letsencrypt/hook.d/postgres owner=root group=root mode=0755
|
|
when: postgres_ssl == 'on'
|
|
|
|
- name: Open firewall holes to known postgresql ipv4 clients
|
|
ansible.posix.firewalld: zone={{ postgres_firewalld_zone }} permanent=true state=enabled immediate=yes
|
|
rich_rule="rule family=ipv4 source address={{ item }} port protocol=tcp port=5432 accept"
|
|
with_items: "{{ postgres_hosts4 + postgres_ssl_hosts4 }}"
|
|
when: configure_firewall
|
|
tags:
|
|
- firewall
|
|
|
|
- name: Open firewall holes to known postgresql ipv6 clients
|
|
ansible.posix.firewalld: zone={{ postgres_firewalld_zone }} permanent=true state=enabled immediate=yes
|
|
rich_rule="rule family=ipv6 source address={{ item }} port protocol=tcp port=5432 accept"
|
|
with_items: "{{ postgres_hosts6 + postgres_ssl_hosts6 }}"
|
|
when: configure_firewall
|
|
tags:
|
|
- firewall
|
|
|
|
- name: Copy postgresql upgrade script
|
|
copy: src=upgrade_pg.sh dest=/usr/local/bin/upgrade_pg.sh mode=0755 owner=root group=root
|