mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-26 10:03:25 +00:00 
			
		
		
		
	Etherpad role
This commit is contained in:
		| @@ -757,7 +757,30 @@ matrix_dimension_database_password: "{{ matrix_synapse_macaroon_secret_key | pas | ||||
| # | ||||
| ###################################################################### | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # matrix-etherpad | ||||
| # | ||||
| ###################################################################### | ||||
|  | ||||
| matrix_etherpad_enabled: false | ||||
|  | ||||
| matrix_etherpad_systemd_required_services_list: | | ||||
|   {{ | ||||
|     ['docker.service'] | ||||
|     + | ||||
|     (['matrix-postgres.service'] if matrix_postgres_enabled else []) | ||||
|   }} | ||||
|  | ||||
| # Postgres is the default, except if not using `matrix_postgres` (internal postgres) | ||||
| matrix_etherpad_database_engine: "{{ 'postgres' if matrix_postgres_enabled else 'sqlite' }}" | ||||
| matrix_etherpad_database_password: "{{ matrix_synapse_macaroon_secret_key | password_hash('sha512', 'etherpad.db') | to_uuid }}" | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # /matrix-etherpad | ||||
| # | ||||
| ###################################################################### | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| @@ -1146,6 +1169,12 @@ matrix_postgres_additional_databases: | | ||||
|       'username': matrix_dimension_database_username, | ||||
|       'password': matrix_dimension_database_password, | ||||
|     }] if (matrix_dimension_enabled and matrix_dimension_database_engine == 'postgres' and matrix_dimension_database_hostname == 'matrix-postgres') else []) | ||||
|     + | ||||
|     ([{ | ||||
|       'name': matrix_etherpad_database_name, | ||||
|       'username': matrix_etherpad_database_username, | ||||
|       'password': matrix_etherpad_database_password, | ||||
|     }] if (matrix_etherpad_enabled and matrix_etherpad_database_engine == 'postgres' and matrix_etherpad_database_hostname == 'matrix-postgres') else []) | ||||
|    }} | ||||
|  | ||||
| matrix_postgres_import_roles_to_ignore: | | ||||
|   | ||||
							
								
								
									
										93
									
								
								roles/matrix-etherpad/defaults/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								roles/matrix-etherpad/defaults/main.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| matrix_etherpad_enabled: false | ||||
|  | ||||
| matrix_etherpad_base_path: "{{ matrix_base_data_path }}/etherpad" | ||||
|  | ||||
| matrix_etherpad_docker_image: "docker.io/etherpad/etherpad:latest" | ||||
| matrix_etherpad_docker_image_force_pull: "{{ matrix_etherpad_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| # List of systemd services that matrix-etherpad.service depends on. | ||||
| matrix_etherpad_systemd_required_services_list: ['docker.service'] | ||||
|  | ||||
| # List of systemd services that matrix-etherpad.service wants | ||||
| matrix_etherpad_systemd_wanted_services_list: [] | ||||
|  | ||||
| # Container user has to be able to write to the source file directories until this bug is fixed: | ||||
| # https://github.com/ether/etherpad-lite/issues/2683 | ||||
| matrix_etherpad_user_uid: '5001' | ||||
| matrix_etherpad_user_gid: '5001' | ||||
|  | ||||
| # Controls whether the matrix-etherpad container exposes its HTTP port (tcp/9001 in the container). | ||||
| # | ||||
| # Takes an "<ip>:<port>" or "<port>" value (e.g. "127.0.0.1:9001"), or empty string to not expose. | ||||
| matrix_etherpad_container_http_host_bind_port: '9001' | ||||
|  | ||||
| # A list of extra arguments to pass to the container | ||||
| matrix_etherpad_container_extra_arguments: [] | ||||
|  | ||||
| matrix_etherpad_public_endpoint: '/etherpad' | ||||
|  | ||||
| # By default, the Etherpad app can be accessed within the Dimension domain | ||||
| matrix_etherpad_base_url: "https://{{ matrix_server_fqn_dimension }}{{ matrix_etherpad_public_endpoint }}" | ||||
|  | ||||
| # Database-related configuration fields. | ||||
| # | ||||
| # Etherpad recommends using a dedicated database, and supports Sqliite only for development | ||||
| # | ||||
| # To use Postgres: | ||||
| # - change the engine (`matrix_etherpad_database_engine: 'postgres'`) | ||||
| # - adjust your database credentials via the `matrix_etherpad_postgres_*` variables | ||||
| matrix_etherpad_database_engine: 'sqlite' | ||||
|  | ||||
| matrix_etherpad_sqlite_database_path_local: "{{ matrix_etherpad_base_path }}/etherpad.db" | ||||
| matrix_etherpad_sqlite_database_path_in_container: "/data/etherpad.db" | ||||
|  | ||||
| matrix_etherpad_database_username: 'matrix_etherpad' | ||||
| matrix_etherpad_database_password: 'some-password' | ||||
| matrix_etherpad_database_hostname: 'matrix-postgres' | ||||
| matrix_etherpad_database_port: 5432 | ||||
| matrix_etherpad_database_name: 'matrix_etherpad' | ||||
|  | ||||
| matrix_etherpad_database_connection_string: 'postgres://{{ matrix_etherpad_database_username }}:{{ matrix_etherpad_database_password }}@{{ matrix_etherpad_database_hostname }}:{{ matrix_etherpad_database_port }}/{{ matrix_etherpad_database_name }}' | ||||
|  | ||||
| # Variables configuring the etherpad | ||||
| matrix_etherpad_title: 'Etherpad' | ||||
| matrix_etherpad_default_pad_text: | | ||||
|   Welcome to Etherpad! | ||||
|    | ||||
|   This pad text is synchronized as you type, so that everyone viewing this page sees the same text. This allows you to collaborate seamlessly on documents! | ||||
|    | ||||
|   Get involved with Etherpad at https://etherpad.org | ||||
|  | ||||
| # Default Etherpad configuration template which covers the generic use case. | ||||
| # You can customize it by controlling the various variables inside it. | ||||
| # | ||||
| # For a more advanced customization, you can extend the default (see `matrix_etherpad_configuration_extension_json`) | ||||
| # or completely replace this variable with your own template. | ||||
| matrix_etherpad_configuration_default: "{{ lookup('template', 'templates/settings.json.j2') }}" | ||||
|  | ||||
| # Your custom JSON configuration for Etherpad goes here. | ||||
| # This configuration extends the default starting configuration (`matrix_etherpad_configuration_json`). | ||||
| # | ||||
| # You can override individual variables from the default configuration, or introduce new ones. | ||||
| # | ||||
| # If you need something more special, you can take full control by | ||||
| # completely redefining `matrix_etherpad_configuration_json`. | ||||
| # | ||||
| # Example configuration extension follows: | ||||
| # | ||||
| # matrix_etherpad_configuration_extension_json: | | ||||
| #  { | ||||
| #   "loadTest": true, | ||||
| #   "commitRateLimiting": { | ||||
| #     "duration": 1, | ||||
| #     "points": 10 | ||||
| #   } | ||||
| #  } | ||||
| # | ||||
| matrix_etherpad_configuration_extension_json: '{}' | ||||
|  | ||||
| matrix_etherpad_configuration_extension: "{{ matrix_etherpad_configuration_extension_json|from_json if matrix_etherpad_configuration_extension_json|from_json is mapping else {} }}" | ||||
|  | ||||
| # Holds the final Etherpad configuration (a combination of the default and its extension). | ||||
| # You most likely don't need to touch this variable. Instead, see `matrix_etherpad_configuration_json`. | ||||
| matrix_etherpad_configuration: "{{ matrix_etherpad_configuration_default|combine(matrix_etherpad_configuration_extension, recursive=True) }}" | ||||
							
								
								
									
										3
									
								
								roles/matrix-etherpad/tasks/init.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								roles/matrix-etherpad/tasks/init.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| - set_fact: | ||||
|     matrix_systemd_services_list: "{{ matrix_systemd_services_list + ['matrix-etherpad.service'] }}" | ||||
|   when: matrix_etherpad_enabled|bool | ||||
							
								
								
									
										15
									
								
								roles/matrix-etherpad/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								roles/matrix-etherpad/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| - import_tasks: "{{ role_path }}/tasks/init.yml" | ||||
|   tags: | ||||
|     - always | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_install.yml" | ||||
|   when: run_setup|bool and matrix_etherpad_enabled|bool | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-etherpad | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_uninstall.yml" | ||||
|   when: run_setup|bool and not matrix_etherpad_enabled|bool | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-etherpad | ||||
							
								
								
									
										36
									
								
								roles/matrix-etherpad/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								roles/matrix-etherpad/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | ||||
| --- | ||||
|  | ||||
| - name: Ensure Etherpad base path exists | ||||
|   file: | ||||
|     path: "{{ matrix_etherpad_base_path }}" | ||||
|     state: directory | ||||
|     mode: 0770 | ||||
|     owner: "{{ matrix_etherpad_user_uid }}" | ||||
|     group: "{{ matrix_etherpad_user_gid }}" | ||||
|  | ||||
| - name: Ensure Etherpad config installed | ||||
|   copy: | ||||
|     content: "{{ matrix_etherpad_configuration|to_nice_json }}" | ||||
|     dest: "{{ matrix_etherpad_base_path }}/settings.json" | ||||
|     mode: 0640 | ||||
|     owner: "{{ matrix_etherpad_user_uid }}" | ||||
|     group: "{{ matrix_etherpad_user_gid }}" | ||||
|  | ||||
| - name: Ensure Etherpad image is pulled | ||||
|   docker_image: | ||||
|     name: "{{ matrix_etherpad_docker_image }}" | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_etherpad_docker_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}" | ||||
|     force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_etherpad_docker_image_force_pull }}" | ||||
|  | ||||
| - name: Ensure matrix-etherpad.service installed | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/systemd/matrix-etherpad.service.j2" | ||||
|     dest: "{{ matrix_systemd_path }}/matrix-etherpad.service" | ||||
|     mode: 0644 | ||||
|   register: matrix_etherpad_systemd_service_result | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-etherpad.service installation | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_etherpad_systemd_service_result.changed|bool" | ||||
							
								
								
									
										35
									
								
								roles/matrix-etherpad/tasks/setup_uninstall.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								roles/matrix-etherpad/tasks/setup_uninstall.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| --- | ||||
|  | ||||
| - name: Check existence of matrix-etherpad service | ||||
|   stat: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-etherpad.service" | ||||
|   register: matrix_etherpad_service_stat | ||||
|  | ||||
| - name: Ensure matrix-etherpad is stopped | ||||
|   service: | ||||
|     name: matrix-etherpad | ||||
|     state: stopped | ||||
|     daemon_reload: yes | ||||
|   register: stopping_result | ||||
|   when: "matrix_etherpad_service_stat.stat.exists|bool" | ||||
|  | ||||
| - name: Ensure matrix-etherpad.service doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-etherpad.service" | ||||
|     state: absent | ||||
|   when: "matrix_etherpad_service_stat.stat.exists|bool" | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-etherpad.service removal | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_etherpad_service_stat.stat.exists|bool" | ||||
|  | ||||
| - name: Ensure Etherpad base directory doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_etherpad_base_path }}" | ||||
|     state: absent | ||||
|  | ||||
| - name: Ensure Dimension Docker image doesn't exist | ||||
|   docker_image: | ||||
|     name: "{{ matrix_etherpad_docker_image }}" | ||||
|     state: absent | ||||
							
								
								
									
										7
									
								
								roles/matrix-etherpad/tasks/validate_config.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								roles/matrix-etherpad/tasks/validate_config.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| - name: Fail if required Etherpad settings not defined | ||||
|   fail: | ||||
|     msg: >- | ||||
|       You need to define a required configuration setting (`{{ item }}`) for using Etherpad. | ||||
|   with_items: | ||||
|     - | ||||
|   when: "matrix_etherpad_enabled and vars[item] == ''" | ||||
							
								
								
									
										106
									
								
								roles/matrix-etherpad/templates/settings.json.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								roles/matrix-etherpad/templates/settings.json.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,106 @@ | ||||
| { | ||||
|   "title": {{ matrix_etherpad_title|to_json }}, | ||||
|   "favicon": "favicon.ico", | ||||
|   "skinName": "colibris", | ||||
|   "skinVariants": "super-light-toolbar super-light-editor light-background", | ||||
|   "ip": "::", | ||||
|   "port": 9001, | ||||
|   "showSettingsInAdminPage": true, | ||||
|   "dbType": {{ matrix_etherpad_database_engine|to_json }}, | ||||
|   "dbSettings": { | ||||
|     {% if matrix_etherpad_database_engine == 'sqlite' %} | ||||
|       "filename": {{ matrix_etherpad_sqlite_database_path_in_container|to_json }} | ||||
|     {% elif matrix_etherpad_database_engine == 'postgres' %} | ||||
|       "database": {{ matrix_etherpad_database_name|to_json }}, | ||||
|       "host":     {{ matrix_etherpad_database_hostname|to_json }}, | ||||
|       "password": {{ matrix_etherpad_database_password|to_json }}, | ||||
|       "port":     {{ matrix_etherpad_database_port|to_json }}, | ||||
|       "user":     {{ matrix_etherpad_database_username|to_json }} | ||||
|     {% endif %} | ||||
|   }, | ||||
|   "defaultPadText" : {{ matrix_etherpad_default_pad_text|to_json }}, | ||||
|   "suppressErrorsInPadText": false, | ||||
|   "requireSession": false, | ||||
|   "editOnly": false, | ||||
|   "minify": true, | ||||
|   "maxAge": 21600, | ||||
|   "abiword": null, | ||||
|   "soffice": null, | ||||
|   "tidyHtml": null, | ||||
|   "allowUnknownFileEnds": true, | ||||
|   "requireAuthentication": false, | ||||
|   "requireAuthorization": false, | ||||
|   "trustProxy": true, | ||||
|   "cookie": { | ||||
|     "sameSite": "Lax" | ||||
|   }, | ||||
|   "disableIPlogging": true, | ||||
|   "automaticReconnectionTimeout": 0, | ||||
|   "scrollWhenFocusLineIsOutOfViewport": { | ||||
|     "percentage": { | ||||
|       "editionAboveViewport": 0, | ||||
|       "editionBelowViewport": 0 | ||||
|     }, | ||||
|     "duration": 0, | ||||
|     "scrollWhenCaretIsInTheLastLineOfViewport": false, | ||||
|     "percentageToScrollWhenUserPressesArrowUp": 0 | ||||
|   }, | ||||
|   "socketTransportProtocols" : ["xhr-polling", "jsonp-polling", "htmlfile"], | ||||
|   "loadTest": false, | ||||
|   "importExportRateLimiting": { | ||||
|     "windowMs": 90000, | ||||
|     "max": 10 | ||||
|   }, | ||||
|   "importMaxFileSize": 52428800, | ||||
|   "commitRateLimiting": { | ||||
|     "duration": 1, | ||||
|     "points": 10 | ||||
|   }, | ||||
|   "exposeVersion": false, | ||||
|   "padOptions": { | ||||
|     "noColors": false, | ||||
|     "showControls": true, | ||||
|     "showChat": false, | ||||
|     "showLineNumbers": true, | ||||
|     "useMonospaceFont": false, | ||||
|     "userName": false, | ||||
|     "userColor": false, | ||||
|     "rtl": false, | ||||
|     "alwaysShowChat": false, | ||||
|     "chatAndUsers": false, | ||||
|     "lang": "en-gb" | ||||
|   }, | ||||
|   "padShortcutEnabled" : { | ||||
|     "altF9": true, | ||||
|     "altC": true, | ||||
|     "cmdShift2": true, | ||||
|     "delete": true, | ||||
|     "return": true, | ||||
|     "esc": true, | ||||
|     "cmdS": true, | ||||
|     "tab": true, | ||||
|     "cmdZ": true, | ||||
|     "cmdY": true, | ||||
|     "cmdI": true, | ||||
|     "cmdB": true, | ||||
|     "cmdU": true, | ||||
|     "cmd5": true, | ||||
|     "cmdShiftL": true, | ||||
|     "cmdShiftN": true, | ||||
|     "cmdShift1": true, | ||||
|     "cmdShiftC": true, | ||||
|     "cmdH": true, | ||||
|     "ctrlHome": true, | ||||
|     "pageUp": true, | ||||
|     "pageDown": true | ||||
|   }, | ||||
|   "loglevel": "INFO", | ||||
|   "logconfig" : | ||||
|     { "appenders": [ | ||||
|         { "type": "console", | ||||
|           "layout": {"type": "messagePassThrough"} | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|   "customLocaleStrings": {} | ||||
| } | ||||
| @@ -0,0 +1,49 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| [Unit] | ||||
| Description=Matrix Etherpad | ||||
| {% for service in matrix_etherpad_systemd_required_services_list %} | ||||
| Requires={{ service }} | ||||
| After={{ service }} | ||||
| {% endfor %} | ||||
| {% for service in matrix_etherpad_systemd_wanted_services_list %} | ||||
| Wants={{ service }} | ||||
| {% endfor %} | ||||
| DefaultDependencies=no | ||||
|  | ||||
| [Service] | ||||
| Type=simple | ||||
| Environment="HOME={{ matrix_systemd_unit_home_path }}" | ||||
| ExecStartPre=-{{ matrix_host_command_docker }} kill matrix-etherpad | ||||
| ExecStartPre=-{{ matrix_host_command_docker }} rm matrix-etherpad | ||||
|  | ||||
| # Fixup database ownership if it got changed somehow (during a server migration, etc.) | ||||
| {% if matrix_etherpad_database_engine == 'sqlite' %} | ||||
| ExecStartPre=-{{ matrix_host_command_chown }} {{ matrix_etherpad_user_uid }} {{ matrix_etherpad_sqlite_database_path_local }} | ||||
| {% endif %} | ||||
|  | ||||
| ExecStart={{ matrix_host_command_docker }} run --rm --name matrix-etherpad \ | ||||
| 			--log-driver=none \ | ||||
| 			--user={{ matrix_etherpad_user_uid }}:{{ matrix_etherpad_user_gid }} \ | ||||
| 			--cap-drop=ALL \ | ||||
| 			--network={{ matrix_docker_network }} \ | ||||
| 			{% if matrix_etherpad_container_http_host_bind_port %} | ||||
| 			-p {{ matrix_etherpad_container_http_host_bind_port }}:9001 \ | ||||
| 			{% endif %} | ||||
| 			--mount type=bind,src={{ matrix_etherpad_base_path }},dst=/data \ | ||||
| 			{% for arg in matrix_etherpad_container_extra_arguments %} | ||||
| 			{{ arg }} \ | ||||
| 			{% endfor %} | ||||
| 			{{ matrix_etherpad_docker_image }} \ | ||||
| 			node --experimental-worker /opt/etherpad-lite/node_modules/ep_etherpad-lite/node/server.js \ | ||||
| 				--settings /data/settings.json --credentials /data/credentials.json \ | ||||
| 				--sessionkey /data/sessionkey.json --apikey /data/apijey.json | ||||
| 				 | ||||
|  | ||||
| ExecStop=-{{ matrix_host_command_docker }} kill matrix-etherpad | ||||
| ExecStop=-{{ matrix_host_command_docker }} rm matrix-etherpad | ||||
| Restart=always | ||||
| RestartSec=30 | ||||
| SyslogIdentifier=matrix-etherpad | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
		Reference in New Issue
	
	Block a user