mirror of
				https://github.com/kevinveenbirkenbach/computer-playbook.git
				synced 2025-10-31 10:19:09 +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
 |