mirror of
				https://github.com/kevinveenbirkenbach/computer-playbook.git
				synced 2025-11-04 12:18:17 +00:00 
			
		
		
		
	- Remove stray spaces after include_role: across many roles to ensure clean YAML and
  consistent linting/formatting.
- Listmonk:
  - Introduce LISTMONK_CONFIG_HOST = [ docker_compose.directories.config, 'config.toml' ] | path_join
  - Use that var in the template task (dest) and the docker-compose volume mount
- Matrix:
  - Build MATRIX_SYNAPSE_CONFIG_PATH_HOST, MATRIX_SYNAPSE_LOG_PATH_HOST, and
    MATRIX_ELEMENT_CONFIG_PATH_HOST via path_join
- Mobilizon:
  - Build mobilizon_host_conf_exs_file via path_join
  - Keep get_app_conf strictness unchanged (defaults to True in our filter), so behavior
    remains strict even though the explicit third arg was dropped
- Simpleicons:
  - Build server.js and package.json host paths via path_join
- Numerous web-app roles (Confluence, Discourse, EspoCRM, Friendica, Funkwhale, Gitea,
  GitLab, Jenkins, Joomla, Listmonk, Mailu, Mastodon, Matomo, Matrix, MediaWiki,
  Mobilizon, Moodle, Nextcloud, OpenProject, Peertube, Pixelfed, Pretix, Roulette Wheel,
  Snipe-IT, Syncope, Taiga, WordPress, XWiki, Yourls) and web-svc roles (coturn,
  libretranslate, simpleicons) updated for consistent include_role formatting
Why:
- path_join avoids double slashes and missing separators across different config roots
- Consistent include_role: formatting improves readability and prevents linter noise
Ref:
- Conversation: https://chatgpt.com/share/68d14711-727c-800f-b454-7dc4c3c1f4cb
		
	
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
- name: Ensure MAILU_HOSTNAMES is a list with max 1 entry
 | 
						|
  ansible.builtin.assert:
 | 
						|
    that:
 | 
						|
      - MAILU_HOSTNAMES is iterable
 | 
						|
      - MAILU_HOSTNAMES is sequence
 | 
						|
      - MAILU_HOSTNAMES | length <= 1
 | 
						|
    fail_msg: "MAILU_HOSTNAMES must be a list with at most one entry (only one host is supported). You can set the other ones as alias."
 | 
						|
    success_msg: "MAILU_HOSTNAMES is valid."
 | 
						|
  when: MODE_ASSERT | bool
 | 
						|
 | 
						|
- name: "load variables from {{ DOCKER_VARS_FILE }}"
 | 
						|
  include_vars: "{{ DOCKER_VARS_FILE }}"
 | 
						|
 | 
						|
- name: Ensure Rspamd overrides directory exists (host)
 | 
						|
  file:
 | 
						|
    path: "{{ MAILU_RSPAMD_HOST_DIR }}"
 | 
						|
    state: directory
 | 
						|
    mode: "0755"
 | 
						|
 | 
						|
- name: Render ratelimit.conf
 | 
						|
  template:
 | 
						|
    src: ratelimit.conf.j2
 | 
						|
    dest: "{{ MAILU_RSPAMD_HOST_FILE }}"
 | 
						|
    mode: "0644"
 | 
						|
 | 
						|
- name: "Mailu Docker and Webserver Setup"
 | 
						|
  block:
 | 
						|
  - name: "load docker, db and proxy for {{ application_id }}"
 | 
						|
    include_role:
 | 
						|
      name: sys-stk-full-stateful
 | 
						|
    vars:
 | 
						|
      docker_compose_flush_handlers: true
 | 
						|
 | 
						|
  - name: "Include Cert deploy service for '{{ role_name }}'"
 | 
						|
    include_role:
 | 
						|
      name: sys-ctl-mtn-cert-deploy
 | 
						|
  vars:
 | 
						|
    domain: "{{ MAILU_HOSTNAME }}"
 | 
						|
 | 
						|
- name: Flush docker service handlers
 | 
						|
  meta: flush_handlers
 | 
						|
 | 
						|
- name: "Create Mailu accounts"
 | 
						|
  include_tasks: 02_create-user.yml
 | 
						|
  vars:
 | 
						|
    MAILU_DOCKER_DIR:        "{{ docker_compose.directories.instance }}"
 | 
						|
    mailu_api_base_url:       "http://127.0.0.1:8080/api/v1"
 | 
						|
    mailu_action: >-
 | 
						|
      {{
 | 
						|
        (
 | 
						|
          'administrator' in (item.value.get('roles', []))
 | 
						|
        )
 | 
						|
        | ternary('admin','user')
 | 
						|
      }}
 | 
						|
    mailu_user_key:           "{{ item.key }}"
 | 
						|
    mailu_user_name:          "{{ item.value.username }}"
 | 
						|
    mailu_password:           "{{ item.value.password }}"
 | 
						|
    mailu_token_ip:           "{{ item.value.ip | default('') }}"
 | 
						|
  loop:                       "{{ users | dict2items }}"
 | 
						|
  loop_control:
 | 
						|
    loop_var: item
 | 
						|
  no_log: "{{ MASK_CREDENTIALS_IN_LOGS | bool }}"
 | 
						|
 | 
						|
- name: Generate DKIM public key
 | 
						|
  include_tasks: 04_generate-and-read-dkim.yml
 | 
						|
 | 
						|
- name: Set Mailu DNS records
 | 
						|
  include_tasks: 05_dns-records.yml
 |