Compare commits
	
		
			1 Commits
		
	
	
		
			server-28.
			...
			e9b5475a39
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e9b5475a39 | 
| @@ -13,11 +13,6 @@ and managing nextcloud installations | |||||||
| - [`roles/apps`](roles/apps/README.md): | - [`roles/apps`](roles/apps/README.md): | ||||||
|   For managing nextcloud apps in an already installed nextcloud |   For managing nextcloud apps in an already installed nextcloud | ||||||
|   server instance. Can install, remove, enable/disable and update apps. |   server instance. Can install, remove, enable/disable and update apps. | ||||||
| - [`roles/ldap-user-backend`](roles/ldap-user-backend/README.md): |  | ||||||
|   Manages LDAP authentication sources in installed nextcloud instances. |  | ||||||
| - [`roles/nginx-fpm-proxy`](roles/nginx-fpm-proxy/README.md): |  | ||||||
|   Reverse proxy role which connects to nextcloud using FPM |  | ||||||
|   and serves static content. |  | ||||||
|  |  | ||||||
| ## License | ## License | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								galaxy.yml
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								galaxy.yml
									
									
									
									
									
								
							| @@ -1,14 +1,15 @@ | |||||||
| namespace: finallycoffee | namespace: finallycoffee | ||||||
| name: nextcloud | name: nextcloud | ||||||
| version: 0.5.1 | version: 0.3.0 | ||||||
| readme: README.md | readme: README.md | ||||||
| authors: | authors: | ||||||
| - transcaffeine <transcaffeine@finally.coffee> | - Johanna Dorothea Reichmann <transcaffeine@finallycoffee.eu> | ||||||
| description: Installing and configuring nextcloud (and related apps/services) using docker | description: Installing and configuring nextcloud (and related apps/services) using docker | ||||||
| dependencies: | dependencies: | ||||||
|   "community.docker": "^1.10.0" |   "community.docker": "^1.10.0" | ||||||
| license_file: LICENSE.md | license: | ||||||
|  | - CNPLv7+ | ||||||
| build_ignore: | build_ignore: | ||||||
| - '*.tar.gz' | - '*.tar.gz' | ||||||
| repository: https://git.finally.coffee/finallycoffee/nextcloud | repository: https://git.finallycoffee.eu/finallycoffee.eu/nextcloud | ||||||
| issues: https://git.finally.coffee/finallycoffee/nextcloud/issues | issues: https://git.finallycoffee.eu/finallycoffee.eu/nextcloud/issues | ||||||
|   | |||||||
| @@ -1,3 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| requires_ansible: ">=2.12" |  | ||||||
| @@ -25,13 +25,3 @@ nextcloud app installed. For starting a nextcloud instance, see the | |||||||
|   the URL to the nextcloud server, including protocol (and port, if |   the URL to the nextcloud server, including protocol (and port, if | ||||||
|   non-standard), and `nc_ldap_api_basic_auth_[user|password]` contain the |   non-standard), and `nc_ldap_api_basic_auth_[user|password]` contain the | ||||||
|   credentials of an admin user with the rights to edit the LDAP settings. |   credentials of an admin user with the rights to edit the LDAP settings. | ||||||
| 
 |  | ||||||
| - Set `nc_ldap_test_configuration` to `true`/`false` to have the role issue a |  | ||||||
|   nextcloud-provided test of the configured LDAP configuration, this corresponds |  | ||||||
|   to a `occ ldap:test-config <id>`. |  | ||||||
| 
 |  | ||||||
| For most of the options, see the |  | ||||||
| [nextcloud manual on configuration keys](https://docs.nextcloud.com/server/latest/admin_manual/configuration_user/user_auth_ldap_api.html#configuration-keys), |  | ||||||
| the config keys are mapped 1:1 with a prefix of `nc_ldap_config_` and |  | ||||||
| the so-called "snake-case" (`ldap_backup_host`), so `ldapUserFilterMode` becomes |  | ||||||
| `nc_ldap_config_ldap_user_filter_mode`. |  | ||||||
| @@ -1,7 +1,6 @@ | |||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| nc_ldap_api_method: occ | nc_ldap_api_method: occ | ||||||
| nc_ldap_test_configuration: true |  | ||||||
| 
 | 
 | ||||||
| nc_ldap_api_instance_url: http://localhost | nc_ldap_api_instance_url: http://localhost | ||||||
| nc_ldap_api_basic_auth_user: | nc_ldap_api_basic_auth_user: | ||||||
							
								
								
									
										81
									
								
								roles/ldap-user-backend/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										81
									
								
								roles/ldap-user-backend/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,81 @@ | |||||||
|  | --- | ||||||
|  |  | ||||||
|  | - name: Set default api parameters for HTTP | ||||||
|  |   meta: noop | ||||||
|  |   vars: &api_defaults | ||||||
|  |     http_agent: "{{ nc_ldap_meta_http_agent }}" | ||||||
|  |     headers: "{{ nc_ldap_api_headers }}" | ||||||
|  |     url_username: "{{ nc_ldap_api_basic_auth_user }}" | ||||||
|  |     url_password: "{{ nc_ldap_api_basic_auth_password }}" | ||||||
|  |     force_basic_auth: yes | ||||||
|  |     force: yes | ||||||
|  |   when: nc_ldap_api_method == 'http' | ||||||
|  |  | ||||||
|  | - name: Check if configuration with given config ID already exists (occ) | ||||||
|  |   docker_container_exec: | ||||||
|  |     container: "{{ nc_ldap_container }}" | ||||||
|  |     command: "{{ nc_ldap_occ_command }} ldap:show-config --output json {{ '--show-password' if nc_ldap_config_agent_password else '' }} {{ nc_ldap_config_id }}" | ||||||
|  |     user: "{{ nc_ldap_occ_user }}" | ||||||
|  |     tty: yes | ||||||
|  |   when: nc_ldap_api_method == 'occ' | ||||||
|  |   changed_when: false | ||||||
|  |   check_mode: false | ||||||
|  |   register: nc_ldap_existing_config_occ | ||||||
|  |  | ||||||
|  | - name: Check if configuration with given config ID already exists (http) | ||||||
|  |   uri: | ||||||
|  |     <<: *api_defaults | ||||||
|  |     url: "{{ nc_ldap_api_path }}/{{ nc_ldap_config_id }}{{ query_params }}" | ||||||
|  |     method: GET | ||||||
|  |   vars: | ||||||
|  |     query_params: "?showPassword={{ '1' if nc_ldap_config_agent_password else '0' }}&format={{nc_ldap_api_parameter_format }}" | ||||||
|  |   when: nc_ldap_api_method == 'http' | ||||||
|  |   register: nc_ldap_existing_config_api | ||||||
|  |  | ||||||
|  | # TODO: Can we force an ID on POST? | ||||||
|  | - name: Create ldap configuration with id={{ nc_ldap_config_id }} (http) | ||||||
|  |   uri: | ||||||
|  |     <<: *api_defaults | ||||||
|  |     url: "{{ nc_ldap_api_path }}" | ||||||
|  |     method: POST | ||||||
|  |   when: nc_ldap_api_method == 'http' and nc_ldap_existing_config_api.status != 200 | ||||||
|  |  | ||||||
|  | - name: Create ldap configuration with id={{ nc_ldap_config_id }} (occ) | ||||||
|  |   docker_container_exec: | ||||||
|  |     container: "{{ nc_ldap_container }}" | ||||||
|  |     command: "{{ nc_ldap_occ_command }} ldap:create-empty-config --output json {{ nc_ldap_config_id }}" | ||||||
|  |     user: "{{ nc_ldap_occ_user }}" | ||||||
|  |     tty: yes | ||||||
|  |   when: nc_ldap_api_method == 'occ' and nc_ldap_existing_config_occ.rc != 0 and nc_ldap_config_id not in (nc_ldap_existing_config_occ.stdout | from_json).keys() | ||||||
|  |  | ||||||
|  | - name: Parse output of query command to dict | ||||||
|  |   set_fact: | ||||||
|  |     nc_ldap_existing_config: "{{ nc_ldap_existing_config_occ.stdout | from_json }}" | ||||||
|  |   changed_when: false | ||||||
|  |  | ||||||
|  | - name: Create changeset | ||||||
|  |   set_fact: | ||||||
|  |     nc_ldap_config_changeset: "{{ nc_ldap_config_changeset | combine(changed_entry) }}" | ||||||
|  |   vars: | ||||||
|  |     changed_entry: "{{ { item : nc_ldap_config_keys[item] } }}" | ||||||
|  |   loop: "{{ nc_ldap_config_keys.keys() }}" | ||||||
|  |   when: nc_ldap_config_keys[item] is defined and nc_ldap_config_keys[item] and nc_ldap_config_keys[item] != nc_ldap_existing_config[nc_ldap_config_id][item] | ||||||
|  |  | ||||||
|  | - name: Ensure ldap configuration is in sync (http) | ||||||
|  |   uri: | ||||||
|  |     <<: *api_defaults | ||||||
|  |     url: | ||||||
|  |     method: PUT | ||||||
|  |     body: | ||||||
|  |     body_format: "form-urlencoded" | ||||||
|  |   loop: "{{ nc_ldap_config_changeset | dict2items }}" | ||||||
|  |   when: nc_ldap_api_method == 'http' | ||||||
|  |  | ||||||
|  | - name: Ensure ldap configuration is in sync (occ) | ||||||
|  |   docker_container_exec: | ||||||
|  |     container: "{{ nc_ldap_container }}" | ||||||
|  |     command: "{{ nc_ldap_occ_command }} ldap:set-config \"{{ nc_ldap_config_id }}\" \"{{ item.key }}\" \"{{ item.value }}\"" | ||||||
|  |     user: "{{ nc_ldap_occ_user }}" | ||||||
|  |     tty: yes | ||||||
|  |   loop: "{{ nc_ldap_config_changeset | dict2items }}" | ||||||
|  |   when: nc_ldap_api_method == 'occ' | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| - name: Set default api parameters for HTTP |  | ||||||
|   meta: noop |  | ||||||
|   vars: &api_defaults |  | ||||||
|     http_agent: "{{ nc_ldap_meta_http_agent }}" |  | ||||||
|     headers: "{{ nc_ldap_api_headers }}" |  | ||||||
|     url_username: "{{ nc_ldap_api_basic_auth_user }}" |  | ||||||
|     url_password: "{{ nc_ldap_api_basic_auth_password }}" |  | ||||||
|     force_basic_auth: yes |  | ||||||
|     force: yes |  | ||||||
|  |  | ||||||
| - name: Check if configuration with given config ID already exists |  | ||||||
|   uri: |  | ||||||
|     <<: *api_defaults |  | ||||||
|     url: "{{ nc_ldap_api_path }}/{{ nc_ldap_config_id }}{{ query_params }}" |  | ||||||
|     method: GET |  | ||||||
|   vars: |  | ||||||
|     query_params: "?showPassword={{ '1' if nc_ldap_config_agent_password else '0' }}&format={{nc_ldap_api_parameter_format }}" |  | ||||||
|   register: nc_ldap_existing_config_api |  | ||||||
|  |  | ||||||
| # TODO: Can we force an ID on POST? |  | ||||||
| - name: Create ldap configuration with id={{ nc_ldap_config_id }} |  | ||||||
|   uri: |  | ||||||
|     <<: *api_defaults |  | ||||||
|     url: "{{ nc_ldap_api_path }}" |  | ||||||
|     method: POST |  | ||||||
|   when: nc_ldap_existing_config_api.status != 200 |  | ||||||
|  |  | ||||||
| - name: Parse output of query command to dict |  | ||||||
|   set_fact: |  | ||||||
|     nc_ldap_existing_config: "{{ nc_ldap_existing_config_api.stdout | from_json }}" |  | ||||||
|   changed_when: false |  | ||||||
|  |  | ||||||
| - name: Create changeset |  | ||||||
|   set_fact: |  | ||||||
|     nc_ldap_config_changeset: "{{ nc_ldap_config_changeset | combine(changed_entry) }}" |  | ||||||
|   vars: |  | ||||||
|     changed_entry: "{{ { item : nc_ldap_config_keys[item] } }}" |  | ||||||
|   loop: "{{ nc_ldap_config_keys.keys() }}" |  | ||||||
|   when: nc_ldap_config_keys[item] is defined and nc_ldap_config_keys[item] and nc_ldap_config_keys[item] != nc_ldap_existing_config[nc_ldap_config_id][item] |  | ||||||
|  |  | ||||||
| - name: Ensure ldap configuration is in sync (http) |  | ||||||
|   uri: |  | ||||||
|     <<: *api_defaults |  | ||||||
|     url: "{{ nc_lap_api_path }}/{{ nc_ldap_config_id }}" |  | ||||||
|     method: PUT |  | ||||||
|     body: "{{ { 'configData': nc_ldap_config_changeset } }}" |  | ||||||
|     body_format: "form-urlencoded" |  | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| - name: Check if configuration with given config ID already exists |  | ||||||
|   docker_container_exec: |  | ||||||
|     container: "{{ nc_ldap_container }}" |  | ||||||
|     command: "{{ nc_ldap_occ_command }} ldap:show-config --output json {{ '--show-password' if nc_ldap_config_agent_password else '' }} {{ nc_ldap_config_id }}" |  | ||||||
|     user: "{{ nc_ldap_occ_user }}" |  | ||||||
|     tty: yes |  | ||||||
|   changed_when: false |  | ||||||
|   check_mode: false |  | ||||||
|   register: nc_ldap_existing_config_occ |  | ||||||
|  |  | ||||||
| - name: Create ldap configuration with id={{ nc_ldap_config_id }} |  | ||||||
|   docker_container_exec: |  | ||||||
|     container: "{{ nc_ldap_container }}" |  | ||||||
|     command: "{{ nc_ldap_occ_command }} ldap:create-empty-config --output json {{ nc_ldap_config_id }}" |  | ||||||
|     user: "{{ nc_ldap_occ_user }}" |  | ||||||
|     tty: yes |  | ||||||
|   when: nc_ldap_existing_config_occ.rc != 0 and nc_ldap_config_id not in (nc_ldap_existing_config_occ.stdout | from_json).keys() |  | ||||||
|  |  | ||||||
| - name: Parse output of query command to dict |  | ||||||
|   set_fact: |  | ||||||
|     nc_ldap_existing_config: "{{ nc_ldap_existing_config_occ.stdout | from_json }}" |  | ||||||
|   changed_when: false |  | ||||||
|  |  | ||||||
| - name: Create changeset |  | ||||||
|   set_fact: |  | ||||||
|     nc_ldap_config_changeset: "{{ nc_ldap_config_changeset | combine(changed_entry) }}" |  | ||||||
|   vars: |  | ||||||
|     changed_entry: "{{ { item : nc_ldap_config_keys[item] } }}" |  | ||||||
|   loop: "{{ nc_ldap_config_keys.keys() }}" |  | ||||||
|   when: nc_ldap_config_keys[item] is defined and nc_ldap_config_keys[item] and nc_ldap_config_keys[item] != nc_ldap_existing_config[nc_ldap_config_id][item] |  | ||||||
|  |  | ||||||
| - name: Ensure ldap configuration is in sync |  | ||||||
|   docker_container_exec: |  | ||||||
|     container: "{{ nc_ldap_container }}" |  | ||||||
|     command: "{{ nc_ldap_occ_command }} ldap:set-config \"{{ nc_ldap_config_id }}\" \"{{ item.key }}\" \"{{ item.value }}\"" |  | ||||||
|     user: "{{ nc_ldap_occ_user }}" |  | ||||||
|     tty: yes |  | ||||||
|   loop: "{{ nc_ldap_config_changeset | dict2items }}" |  | ||||||
|  |  | ||||||
| - name: Ensure ldap configuration is working |  | ||||||
|   docker_container_exec: |  | ||||||
|     container: "{{ nc_ldap_container }}" |  | ||||||
|     command: "{{ nc_ldap_occ_command }} ldap:test-config {{ nc_ldap_config_id }}" |  | ||||||
|     user: "{{ nc_ldap_occ_user }}" |  | ||||||
|     tty: yes |  | ||||||
|   changed_when: false |  | ||||||
|   when: nc_ldap_test_configuration |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| - name: Load config {{ nc_ldap_config_id }} (and create if not exists) when running mode is http |  | ||||||
|   include_tasks: load_config_http.yml |  | ||||||
|   when: nc_ldap_api_method == 'http' |  | ||||||
|  |  | ||||||
| - name: Load config {{ nc_ldap_config_id }} (and create if not exists) when running mode is occ |  | ||||||
|   include_tasks: load_config_occ.yml |  | ||||||
|   when: nc_ldap_api_method == 'occ' |  | ||||||
|  |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| # `finallycoffee.nextcloud.nginx-fpm-proxy` ansible role |  | ||||||
|  |  | ||||||
| Ansible role for serving nextcloud static content and connecting to dynamic content via PHP-FPM. |  | ||||||
|  |  | ||||||
| ## Prerequisites |  | ||||||
|  |  | ||||||
| A running nextcloud instance with FPM available either via IP+port or a unix socket. |  | ||||||
|  |  | ||||||
| ## Configuration |  | ||||||
|  |  | ||||||
| - Set `nextcloud_nginx_data_path` to the data directory of the nextcloud instance, |  | ||||||
|   from where static content etc is served from. |  | ||||||
|  |  | ||||||
| - `nextcloud_nginx_storage_path` needs to be set to the storage path of the nextcloud |  | ||||||
|   instance, where user data is stored. Usually this is `{{ nextcloud_nginx_data_path }}/data`. |  | ||||||
|  |  | ||||||
| - Set `nextcloud_nginx_fpm_socket_dir` to the directory containing the FPM socket, |  | ||||||
|   called `nextcloud.sock` by default. This can be overridden in `nextcloud_nginx_fpm_socket_path`. |  | ||||||
|  |  | ||||||
| - If FPM is not used via a unix socket, set `nextcloud_nginx_fpm_server_ip` and |  | ||||||
|   `nextcloud_nginx_fpm_server_port` accordingly. Note that the IP must be reachable |  | ||||||
|   from inside the nginx container. |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| nextcloud_nginx_version: "1.23.3" |  | ||||||
| nextcloud_nginx_basepath: /opt/nextcloud-nginx |  | ||||||
| nextcloud_nginx_config: "{{ nextcloud_nginx_basepath }}/nextcloud.conf" |  | ||||||
| nextcloud_nginx_servernames: ~ |  | ||||||
|  |  | ||||||
| nextcloud_nginx_container_name: nextcloud_nginx |  | ||||||
| nextcloud_nginx_container_image: "docker.io/library/nginx" |  | ||||||
| nextcloud_nginx_container_image_flavor: "alpine" |  | ||||||
| nextcloud_nginx_container_image_ref: "{{ nextcloud_nginx_container_image }}:{{ nextcloud_nginx_version }}{{ '-' + nextcloud_nginx_container_image_flavor if nextcloud_nginx_container_image_flavor else ''}}" |  | ||||||
| nextcloud_nginx_container_image_force_pull: false |  | ||||||
| nextcloud_nginx_container_extra_volumes: [] |  | ||||||
| nextcloud_nginx_container_extra_labels: {} |  | ||||||
| nextcloud_nginx_container_extra_env: {} |  | ||||||
| nextcloud_nginx_container_restart_policy: unless-stopped |  | ||||||
|  |  | ||||||
| nextcloud_nginx_fpm_server_ip: ~ |  | ||||||
| nextcloud_nginx_fpm_server_port: 9000 |  | ||||||
| nextcloud_nginx_fpm_socket_dir: ~ |  | ||||||
| nextcloud_nginx_fpm_socket_path: "{{ nextcloud_nginx_fpm_socket_dir }}/nextcloud.sock" |  | ||||||
| nextcloud_nginx_data_path: ~ |  | ||||||
| nextcloud_nginx_storage_path: ~ |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| - name: Restart nextcloud nginx fpm proxy container |  | ||||||
|   listen: restart-nextcloud-nginx |  | ||||||
|   docker_container: |  | ||||||
|     name: "{{ nextcloud_nginx_container_name }}" |  | ||||||
|     state: started |  | ||||||
|     restart: yes |  | ||||||
| @@ -1,36 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| - name: Create directory for nginx config |  | ||||||
|   file: |  | ||||||
|     path: "{{ nextcloud_nginx_basepath }}" |  | ||||||
|     state: directory |  | ||||||
|     mode: 0750 |  | ||||||
|  |  | ||||||
| - name: Template nginx reverse proxy config for nextcloud |  | ||||||
|   template: |  | ||||||
|     src: nextcloud-nginx.conf.j2 |  | ||||||
|     dest: "{{ nextcloud_nginx_config }}" |  | ||||||
|   vars: |  | ||||||
|     fpm_server: "{{ nextcloud_nginx_fpm_server_ip }}" |  | ||||||
|     fpm_server_port: "{{ nextcloud_nginx_fpm_server_port }}" |  | ||||||
|     fpm_socket: "{{ nextcloud_nginx_fpm_socket_path }}" |  | ||||||
|     domain: "{{ nextcloud_nginx_servernames }}" |  | ||||||
|   notify: restart-nextcloud-nginx |  | ||||||
|  |  | ||||||
| - name: Ensure nginx docker image is pulled |  | ||||||
|   docker_image: |  | ||||||
|     name: "{{ nextcloud_nginx_container_image_ref }}" |  | ||||||
|     state: present |  | ||||||
|     source: pull |  | ||||||
|     force_source: "{{ nextcloud_nginx_container_image_force_pull }}" |  | ||||||
|  |  | ||||||
| - name: Ensure nginx is running for FPM and static file serving |  | ||||||
|   docker_container: |  | ||||||
|     name: "{{ nextcloud_nginx_container_name }}" |  | ||||||
|     image: "{{ nextcloud_nginx_container_image_ref }}" |  | ||||||
|     volumes: "{{ nextcloud_nginx_container_volumes }}" |  | ||||||
|     labels: "{{ nextcloud_nginx_container_labels }}" |  | ||||||
|     env: "{{ nextcloud_nginx_container_env }}" |  | ||||||
|     networks: "{{ nextcloud_nginx_container_networks | default(omit) }}" |  | ||||||
|     restart_policy: "{{ nextcloud_nginx_container_restart_policy }}" |  | ||||||
|     state: started |  | ||||||
| @@ -1,180 +0,0 @@ | |||||||
| upstream php-handler { |  | ||||||
| {% if fpm_socket %} |  | ||||||
| {% if fpm_socket is not string %} |  | ||||||
| {% for upstream in fpm_socket %} |  | ||||||
|     server unix:{{ upstream }}; |  | ||||||
| {% endfor %} |  | ||||||
| {% else %} |  | ||||||
|     server unix:{{ fpm_socket }}; |  | ||||||
| {% endif %} |  | ||||||
| {% else %} |  | ||||||
|     server {{ fpm_server }}:{{ fpm_server_port }}; |  | ||||||
| {% endif %} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| server { |  | ||||||
|     listen 80; |  | ||||||
|     listen [::]:80; |  | ||||||
|     server_name {{ domain | join(' ') }}; |  | ||||||
|  |  | ||||||
|     # Add headers to serve security related headers |  | ||||||
|     # Before enabling Strict-Transport-Security headers please read into this |  | ||||||
|     # topic first. |  | ||||||
|     add_header Strict-Transport-Security "max-age=15768000; includeSubDomains; preload;" always; |  | ||||||
|     # |  | ||||||
|     # WARNING: Only add the preload option once you read about |  | ||||||
|     # the consequences in https://hstspreload.org/. This option |  | ||||||
|     # will add the domain to a hardcoded list that is shipped |  | ||||||
|     # in all major browsers and getting removed from this list |  | ||||||
|     # could take several months. |  | ||||||
|     add_header Referrer-Policy "no-referrer" always; |  | ||||||
|     add_header X-Content-Type-Options "nosniff" always; |  | ||||||
|     add_header X-Download-Options "noopen" always; |  | ||||||
|     add_header X-Frame-Options "SAMEORIGIN" always; |  | ||||||
|     add_header X-Permitted-Cross-Domain-Policies "none" always; |  | ||||||
|     add_header X-Robots-Tag "none" always; |  | ||||||
|     add_header X-XSS-Protection "1; mode=block" always; |  | ||||||
|  |  | ||||||
|     # Remove X-Powered-By, which is an information leak |  | ||||||
|     fastcgi_hide_header X-Powered-By; |  | ||||||
|  |  | ||||||
|     # Path to the root of your installation |  | ||||||
|     root /var/www/nextcloud; |  | ||||||
|  |  | ||||||
|     location = /robots.txt { |  | ||||||
|         allow all; |  | ||||||
|         log_not_found off; |  | ||||||
|         access_log off; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     # Make a regex exception for `/.well-known` so that clients can still |  | ||||||
|     # access it despite the existence of the regex rule |  | ||||||
|     # `location ~ /(\.|autotest|...)` which would otherwise handle requests |  | ||||||
|     # for `/.well-known`. |  | ||||||
|     location ^~ /.well-known { |  | ||||||
|         # The rules in this block are an adaptation of the rules |  | ||||||
|         # in `.htaccess` that concern `/.well-known`. |  | ||||||
|  |  | ||||||
|         location = /.well-known/carddav { return 301 https://$host/remote.php/dav/; } |  | ||||||
|         location = /.well-known/caldav  { return 301 https://$host/remote.php/dav/; } |  | ||||||
|  |  | ||||||
|         # The following rule is only needed for the Social app. |  | ||||||
|         # Uncomment it if you're planning to use this app. |  | ||||||
|         location = /.well-known/webfinger	{ return 301 https://$host/public.php?service=webfinger; } |  | ||||||
|  |  | ||||||
|         # The following 2 rules are only needed for the user_webfinger app. |  | ||||||
|         # Uncomment it if you're planning to use this app. |  | ||||||
|         location = /.well-known/host-meta	{ return 301 https://$host/public.php?service=host-meta; } |  | ||||||
|         location = /.well-known/host-meta.json	{ return 301 https://$host/public.php?service=host-meta-json; } |  | ||||||
|  |  | ||||||
|         location /.well-known/acme-challenge    { try_files $uri $uri/ =404; } |  | ||||||
|         location /.well-known/pki-validation    { try_files $uri $uri/ =404; } |  | ||||||
|  |  | ||||||
|         # Let Nextcloud's API for `/.well-known` URIs handle all other |  | ||||||
|         # requests by passing them to the front-end controller. |  | ||||||
|         return 301 https://$host/index.php$request_uri; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     # set max upload size |  | ||||||
|     client_max_body_size {{ nextcloud_php_upload_limit }}; |  | ||||||
|     fastcgi_buffers 128 4K; |  | ||||||
|  |  | ||||||
|     # Enable gzip but do not remove ETag headers |  | ||||||
|     gzip on; |  | ||||||
|     gzip_vary on; |  | ||||||
|     gzip_comp_level 4; |  | ||||||
|     gzip_min_length 256; |  | ||||||
|     gzip_proxied expired no-cache no-store private no_last_modified no_etag auth; |  | ||||||
|     gzip_types application/atom+xml application/javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy; |  | ||||||
|  |  | ||||||
|     # Uncomment if your server is build with the ngx_pagespeed module |  | ||||||
|     # This module is currently not supported. |  | ||||||
|     #pagespeed off; |  | ||||||
|  |  | ||||||
|     location / { |  | ||||||
|         rewrite ^ /index.php; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     location ~ ^\/(?:build|tests|config|lib|3rdparty|templates|data)\/ { |  | ||||||
|         deny all; |  | ||||||
|     } |  | ||||||
|     location ~ ^\/(?:\.|autotest|occ|issue|indie|db_|console) { |  | ||||||
|         deny all; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     location ~ ^\/(?:index|remote|public|cron|core\/ajax\/update|status|ocs\/v[12]|updater\/.+|oc[ms]-provider\/.+|.+\/richdocumentscode\/proxy)\.php(?:$|\/) { |  | ||||||
|         fastcgi_split_path_info ^(.+?\.php)(\/.*|)$; |  | ||||||
|         set $path_info $fastcgi_path_info; |  | ||||||
|         try_files $fastcgi_script_name =404; |  | ||||||
|         fastcgi_param SCRIPT_FILENAME /var/www/html$fastcgi_script_name; |  | ||||||
|         fastcgi_param SCRIPT_NAME $fastcgi_script_name; |  | ||||||
|         fastcgi_param PATH_INFO $path_info; |  | ||||||
|         fastcgi_param HTTPS $https; |  | ||||||
|         fastcgi_param HTTP_PROXY ""; |  | ||||||
|         fastcgi_param REMOTE_ADDR $remote_addr; |  | ||||||
|         # Avoid sending the security headers twice |  | ||||||
|         fastcgi_param modHeadersAvailable true; |  | ||||||
|         # Enable pretty urls |  | ||||||
|         fastcgi_param front_controller_active true; |  | ||||||
|         fastcgi_pass php-handler; |  | ||||||
|         include fastcgi_params; |  | ||||||
|         fastcgi_intercept_errors on; |  | ||||||
|         fastcgi_request_buffering off; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     location ~ ^\/(?:updater|oc[ms]-provider)(?:$|\/) { |  | ||||||
|         try_files $uri/ =404; |  | ||||||
|         index index.php; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     # Adding the cache control header for js, css and map files |  | ||||||
|     # Make sure it is BELOW the PHP block |  | ||||||
|     location ~ \.(?:css|js|woff2?|svg|gif|map)$ { |  | ||||||
|         expires 1d; |  | ||||||
|         # How `sendfile`, `tcp_nopush` and `tcp_nodelay` interact |  | ||||||
|         # https://thoughts.t37.net/nginx-optimization-understanding-sendfile-tcp-nodelay-and-tcp-nopush-c55cdd276765?gi=f11af534b564 |  | ||||||
|         sendfile on; # use `sendfile` syscall, which is a DMA (zero-copy) call |  | ||||||
|         tcp_nopush on; # wait until the file is fully "read" |  | ||||||
|         tcp_nodelay on; # always immediately flush, never wait for a full packet worth of data (default wait interval = 200ms) |  | ||||||
|         aio on; #async IO for files |  | ||||||
|         open_file_cache max=10000; # cache metadata for up to 10000 files |  | ||||||
|         open_file_cache_valid 3600s; # previous cache is valid for 1h |  | ||||||
|         open_file_cache_errors off; # except if there was an error, that is not cached |  | ||||||
|         try_files $uri /index.php$request_uri; |  | ||||||
|         add_header Cache-Control "public, max-age=15778463"; |  | ||||||
|         # Add headers to serve security related headers (It is intended to |  | ||||||
|         # have those duplicated to the ones above) |  | ||||||
|         # Before enabling Strict-Transport-Security headers please read into |  | ||||||
|         # this topic first. |  | ||||||
|         #add_header Strict-Transport-Security "max-age=15768000; includeSubDomains; preload;" always; |  | ||||||
|         # |  | ||||||
|         # WARNING: Only add the preload option once you read about |  | ||||||
|         # the consequences in https://hstspreload.org/. This option |  | ||||||
|         # will add the domain to a hardcoded list that is shipped |  | ||||||
|         # in all major browsers and getting removed from this list |  | ||||||
|         # could take several months. |  | ||||||
|         add_header Referrer-Policy "no-referrer" always; |  | ||||||
|         add_header X-Content-Type-Options "nosniff" always; |  | ||||||
|         add_header X-Download-Options "noopen" always; |  | ||||||
|         add_header X-Frame-Options "SAMEORIGIN" always; |  | ||||||
|         add_header X-Permitted-Cross-Domain-Policies "none" always; |  | ||||||
|         add_header X-Robots-Tag "none" always; |  | ||||||
|         add_header X-XSS-Protection "1; mode=block" always; |  | ||||||
|  |  | ||||||
|         # Optional: Don't log access to assets |  | ||||||
|         access_log off; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     location ~ \.(?:png|html|ttf|ico|jpg|jpeg|bcmap|mp4|webm)$ { |  | ||||||
|         expires 1d; |  | ||||||
|         sendfile on; |  | ||||||
|         tcp_nopush on; |  | ||||||
|         tcp_nodelay on; |  | ||||||
|         open_file_cache max=10000; |  | ||||||
|         open_file_cache_valid 3600s; |  | ||||||
|         open_file_cache_errors off; |  | ||||||
|         try_files $uri /index.php$request_uri; |  | ||||||
|         # Optional: Don't log access to other assets |  | ||||||
|         access_log off; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,18 +0,0 @@ | |||||||
| --- |  | ||||||
|  |  | ||||||
| nextcloud_nginx_container_volumes_base: >-2 |  | ||||||
|   {{ |  | ||||||
|     [ |  | ||||||
|       nextcloud_nginx_config + ':/etc/nginx/conf.d/nextcloud.conf:ro', |  | ||||||
|       nextcloud_nginx_data_path + ':/var/www/nextcloud:ro', |  | ||||||
|       nextcloud_nginx_storage_path + ':/var/www/nextcloud/data:rw' |  | ||||||
|     ] |  | ||||||
|     + ([nextcloud_nginx_fpm_socket_dir + ':' + nextcloud_nginx_fpm_socket_dir + ':rw'] if nextcloud_nginx_fpm_socket_dir else []) |  | ||||||
|   }} |  | ||||||
| nextcloud_nginx_container_labels_base: |  | ||||||
|   version: "{{ nextcloud_nginx_version }}" |  | ||||||
| nextcloud_nginx_container_env_base: {} |  | ||||||
|  |  | ||||||
| nextcloud_nginx_container_volumes: "{{ nextcloud_nginx_container_volumes_base + nextcloud_nginx_container_extra_volumes }}" |  | ||||||
| nextcloud_nginx_container_labels: "{{ nextcloud_nginx_container_labels_base | combine(nextcloud_nginx_container_extra_labels) }}" |  | ||||||
| nextcloud_nginx_container_env: "{{ nextcloud_nginx_container_env_base | combine(nextcloud_nginx_container_extra_env) }}" |  | ||||||
| @@ -12,10 +12,3 @@ so the host file permissions remain comprehensible. | |||||||
| - `nextcloud_socket_path`: Setting this (to, for example, `{{ nextcloud_basepath }}/socket`), | - `nextcloud_socket_path`: Setting this (to, for example, `{{ nextcloud_basepath }}/socket`), | ||||||
|   will make FPM listen on `{{ nextcloud_socket_path }}/nextcloud.sock` on the host, enabling |   will make FPM listen on `{{ nextcloud_socket_path }}/nextcloud.sock` on the host, enabling | ||||||
|   you to use FPM to interface with nextcloud. |   you to use FPM to interface with nextcloud. | ||||||
|  |  | ||||||
| ### Redis over UNIX-Socket |  | ||||||
|  |  | ||||||
| Set `REDIS_HOST` to a path in the container where the socket is mapped using |  | ||||||
| `nextcloud_container_extra_environment`. Also set `REDIS_HOST_PORT` to 0 |  | ||||||
| explicitely, as `redis.config.php` will set it to `null` otherwise, resulting |  | ||||||
| in an exception. Set your redis password in `REDIS_HOST_PASSWORD`. |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
|  |  | ||||||
| nextcloud_version: 28.0.2 | nextcloud_version: 22.2.0 | ||||||
| nextcloud_user: nextcloud | nextcloud_user: nextcloud | ||||||
| nextcloud_basepath: /opt/nextcloud | nextcloud_basepath: /opt/nextcloud | ||||||
| nextcloud_config_path: "{{ nextcloud_basepath }}/config" | nextcloud_config_path: "{{ nextcloud_basepath }}/config" | ||||||
| @@ -46,19 +46,19 @@ nextcloud_container_purge_other_networks: true | |||||||
| nextcloud_paths: | nextcloud_paths: | ||||||
|   - path: "{{ nextcloud_config_path }}" |   - path: "{{ nextcloud_config_path }}" | ||||||
|     mode: "0755" |     mode: "0755" | ||||||
|     owner: "{{ nextcloud_user_info.uid | default(nextcloud_user) }}" |     owner: "{{ nextcloud_user_info.uid|default(nextcloud_user) }}" | ||||||
|     group: root |     group: "root" | ||||||
|   - path: "{{ nextcloud_data_path }}" |   - path: "{{ nextcloud_data_path }}" | ||||||
|     mode: "0755" |     mode: "0755" | ||||||
|     owner: "{{ nextcloud_user_info.uid | default(nextcloud_user) }}" |     owner: "{{ nextcloud_user_info.uid|default(nextcloud_user) }}" | ||||||
|     group: "{{ nextcloud_user_info.group | default(nextcloud_user) }}" |     group: "{{ nextcloud_user_info.uid|default(nextcloud_user) }}" | ||||||
|   - path: "{{ nextcloud_fpm_config_path }}" |   - path: "{{ nextcloud_fpm_config_path }}" | ||||||
|     mode: "0750" |     mode: "0750" | ||||||
|     owner: root |     owner: root | ||||||
|     group: root |     group: root | ||||||
|   - path: "{{ nextcloud_storage_path }}" |   - path: "{{ nextcloud_storage_path }}" | ||||||
|     mode: "0770" |     mode: "0770" | ||||||
|     owner: "{{ nextcloud_user_info.uid | default(nextcloud_user) }}" |     owner: "{{ nextcloud_user_info.uid|default(nextcloud_user) }}" | ||||||
|     group: "root" |     group: "root" | ||||||
|  |  | ||||||
| # PHP OpCache tuning | # PHP OpCache tuning | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
|  |  | ||||||
| - name: Ensure {{ key }} is set to {{ '***' if ['pass', 'secret', 'key']|select('in', key) else value }} | - name: Ensure {{ key }} is set to {{ value }} | ||||||
|   block: |   block: | ||||||
|     - name: Check value of {{ key }} |     - name: Check value of {{ key }} | ||||||
|       community.docker.docker_container_exec: |       community.docker.docker_container_exec: | ||||||
| @@ -9,10 +9,9 @@ | |||||||
|         user: "{{ nextcloud_user_info.uid }}" |         user: "{{ nextcloud_user_info.uid }}" | ||||||
|         tty: yes |         tty: yes | ||||||
|       register: nextcloud_current_config_entry |       register: nextcloud_current_config_entry | ||||||
|       check_mode: false |  | ||||||
|       changed_when: false |       changed_when: false | ||||||
|  |  | ||||||
|     - name: Set {{ key }} to {{ '***' if (['pass', 'secret', 'key']|select('in', key)) else value }} |     - name: Set {{ key }} to {{ value }} | ||||||
|       community.docker.docker_container_exec: |       community.docker.docker_container_exec: | ||||||
|         container: "{{ nextcloud_container_name }}" |         container: "{{ nextcloud_container_name }}" | ||||||
|         command: "{{ nextcloud_occ_command }} config:{{ type }}:set {{ scope }} {{ entry }} --type={{ value_type }} --value={{ value }} -n" |         command: "{{ nextcloud_occ_command }} config:{{ type }}:set {{ scope }} {{ entry }} --type={{ value_type }} --value={{ value }} -n" | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ user = www-data | |||||||
| group = www-data | group = www-data | ||||||
|  |  | ||||||
| {% if nextcloud_socket_path is defined and nextcloud_socket_path is string %} | {% if nextcloud_socket_path is defined and nextcloud_socket_path is string %} | ||||||
| listen = {{ nextcloud_container_php_socket_path }}/{{ nextcloud_container_name }}.sock | listen = {{ nextcloud_container_php_socket_path }}/nextcloud.sock | ||||||
| listen.owner = www-data | listen.owner = www-data | ||||||
| listen.group = www-data | listen.group = www-data | ||||||
| listen.mode = 0666 | listen.mode = 0666 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user