Compare commits
31 Commits
Author | SHA1 | Date | |
---|---|---|---|
caf82b43be
|
|||
ba3581fec2
|
|||
dabf804bb0
|
|||
473d4aa38c
|
|||
425a3d18e0
|
|||
4a33321f0e
|
|||
1ca530f337
|
|||
5df510b266
|
|||
aa8cb40c34
|
|||
18389388ab
|
|||
e76cf67277
|
|||
8764acb3c3
|
|||
87d7e8285f
|
|||
eea141b844
|
|||
4969faeb70
|
|||
00fa76be14
|
|||
23f70c9f26
|
|||
4f7cd41d72
|
|||
bb0e1f3ad5
|
|||
12ac351254
|
|||
dbb6fe15ce
|
|||
3616ad5f45
|
|||
0a3b32c823
|
|||
e2e8d84c13
|
|||
6027db3f5f
|
|||
8eae295b83
|
|||
f759064c1e
|
|||
38246ea585
|
|||
ff312f8214
|
|||
31f326016b
|
|||
6640ba726e
|
@ -1,14 +1,18 @@
|
||||
namespace: finallycoffee
|
||||
name: nextcloud
|
||||
version: 0.7.0
|
||||
version: "0.8.0"
|
||||
readme: README.md
|
||||
authors:
|
||||
- transcaffeine <transcaffeine@finally.coffee>
|
||||
description: Installing and configuring nextcloud (and related apps/services) using docker
|
||||
dependencies:
|
||||
"community.docker": "^3.0.0"
|
||||
"community.docker": "^4.0.0"
|
||||
license_file: LICENSE.md
|
||||
build_ignore:
|
||||
- '*.tar.gz'
|
||||
repository: https://git.finally.coffee/finallycoffee/nextcloud
|
||||
issues: https://codeberg.org/finallycoffee/ansible-collection-nextcloud/issues
|
||||
tags:
|
||||
- nextcloud
|
||||
- nextcloud_apps
|
||||
- docker
|
||||
|
6
playbooks/onlyoffice_documentserver.yml
Normal file
6
playbooks/onlyoffice_documentserver.yml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: Deploy onlyoffice documentserver
|
||||
hosts: "{{ onlyoffice_documentserver_hosts | default('onlyoffice_documentserver') }}"
|
||||
become: "{{ onlyoffice_documentserver_become | default(false, true) }}"
|
||||
roles:
|
||||
- role: finallycoffee.nextcloud.onlyoffice_documentserver
|
12
roles/apps/meta/main.yml
Normal file
12
roles/apps/meta/main.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: apps
|
||||
description: Install Nextcloud apps using ansible
|
||||
galaxy_tags:
|
||||
- nextcloud
|
||||
- owncloud
|
||||
- apps
|
||||
- nextcloud-apps
|
||||
- docker
|
@ -1,4 +1,12 @@
|
||||
---
|
||||
|
||||
collections:
|
||||
- community.docker
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: ldap_user_backend
|
||||
description: Configure a nextcloud ldap user backend using ansible
|
||||
galaxy_tags:
|
||||
- nextcloud
|
||||
- owncloud
|
||||
- ldap
|
||||
- authentication
|
||||
- docker
|
||||
|
@ -12,9 +12,12 @@ nc_ldap_config_keys:
|
||||
ldapBackupHost: "{{ nc_ldap_config_backup_host }}"
|
||||
ldapBackupPort: "{{ nc_ldap_config_backup_port }}"
|
||||
ldapOverrideMainServer: "{{ nc_ldap_config_override_main_server }}"
|
||||
ldapBase: "{{ nc_ldap_config_base_dn }}"
|
||||
ldapBaseUsers: "{{ nc_ldap_config_base_dn_users }}"
|
||||
ldapBaseGroups: "{{ nc_ldap_config_base_dn_groups }}"
|
||||
ldapBase:
|
||||
- "{{ nc_ldap_config_base_dn }}"
|
||||
ldapBaseUsers:
|
||||
- "{{ nc_ldap_config_base_dn_users }}"
|
||||
ldapBaseGroups:
|
||||
- "{{ nc_ldap_config_base_dn_groups }}"
|
||||
ldapAgentName: "{{ nc_ldap_config_agent_name }}"
|
||||
ldapAgentPassword: "{{ nc_ldap_config_agent_password }}"
|
||||
ldapTLS: "{{ nc_ldap_config_tls }}"
|
||||
@ -30,8 +33,10 @@ nc_ldap_config_keys:
|
||||
ldapAttributesForUserSearch: "{{ nc_ldap_config_attributes_for_user_search }}"
|
||||
ldapGroupFilter: "{{ nc_ldap_config_group_filter }}"
|
||||
ldapGroupFilterMode: "{{ nc_ldap_config_group_filter_mode }}"
|
||||
ldapGroupFilterObjectclass: "{{ nc_ldap_config_group_filter_objectclass }}"
|
||||
ldapGroupFilterGroups: "{{ nc_ldap_config_group_filter_groups }}"
|
||||
ldapGroupFilterObjectclass:
|
||||
- "{{ nc_ldap_config_group_filter_objectclass }}"
|
||||
ldapGroupFilterGroups:
|
||||
- "{{ nc_ldap_config_group_filter_groups }}"
|
||||
ldapGroupMemberAssocAttr: "{{ nc_ldap_config_group_member_assoc_attr }}"
|
||||
ldapGroupDisplayName: "{{ nc_ldap_config_group_displayname }}"
|
||||
ldapAttributesForGroupSearch: "{{ nc_ldap_config_attributes_for_group_search }}"
|
||||
|
@ -1,6 +1,5 @@
|
||||
---
|
||||
|
||||
nextcloud_nginx_version: "1.25.3"
|
||||
nextcloud_nginx_version: "1.28.0"
|
||||
nextcloud_nginx_basepath: /opt/nextcloud-nginx
|
||||
nextcloud_nginx_config: "{{ nextcloud_nginx_basepath }}/nextcloud.conf"
|
||||
nextcloud_nginx_servernames: ~
|
||||
|
12
roles/nginx_fpm_proxy/meta/main.yml
Normal file
12
roles/nginx_fpm_proxy/meta/main.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: nginx_fpm_proxy
|
||||
description: Configure nginx as a FPM proxy for nextcloud
|
||||
galaxy_tags:
|
||||
- nextcloud
|
||||
- owncloud
|
||||
- nginx
|
||||
- fpm
|
||||
- docker
|
@ -29,9 +29,9 @@
|
||||
env: "{{ nextcloud_nginx_container_env }}"
|
||||
name: "{{ nextcloud_nginx_container_name }}"
|
||||
image: "{{ nextcloud_nginx_container_image_ref }}"
|
||||
ports: "{{ nextcloud_nginx_container_ports }}"
|
||||
ports: "{{ nextcloud_nginx_container_ports | default(omit, true) }}"
|
||||
volumes: "{{ nextcloud_nginx_container_volumes }}"
|
||||
labels: "{{ nextcloud_nginx_container_labels }}"
|
||||
networks: "{{ nextcloud_nginx_container_networks | default(omit) }}"
|
||||
labels: "{{ nextcloud_nginx_container_labels | default(omit, true) }}"
|
||||
networks: "{{ nextcloud_nginx_container_networks | default(omit, true) }}"
|
||||
restart_policy: "{{ nextcloud_nginx_container_restart_policy }}"
|
||||
state: started
|
||||
|
12
roles/oidc_user_backend/meta/main.yml
Normal file
12
roles/oidc_user_backend/meta/main.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: oidc_user_backend
|
||||
description: Configure a nextcloud oidc user backend using ansible
|
||||
galaxy_tags:
|
||||
- nextcloud
|
||||
- owncloud
|
||||
- oidc
|
||||
- authentication
|
||||
- docker
|
4
roles/onlyoffice_documentserver/README.md
Normal file
4
roles/onlyoffice_documentserver/README.md
Normal file
@ -0,0 +1,4 @@
|
||||
# `finallycoffee.nextcloud.onlyoffice_documentserver` ansible role
|
||||
|
||||
Ansible role to deploy [ONLYOFFICE](https://www.onlyoffice.com)'s
|
||||
document editing server using docker.
|
44
roles/onlyoffice_documentserver/defaults/main/container.yml
Normal file
44
roles/onlyoffice_documentserver/defaults/main/container.yml
Normal file
@ -0,0 +1,44 @@
|
||||
---
|
||||
onlyoffice_documentserver_container_name: "onlyoffice-documentserver"
|
||||
onlyoffice_documentserver_container_image: >-2
|
||||
{{
|
||||
[
|
||||
onlyoffice_documentserver_container_image_repository,
|
||||
onlyoffice_documentserver_container_image_tag
|
||||
| default(onlyoffice_documentserver_version, true)
|
||||
] | join(':')
|
||||
}}
|
||||
onlyoffice_documentserver_container_image_registry: docker.io
|
||||
onlyoffice_documentserver_container_image_namespace: "onlyoffice"
|
||||
onlyoffice_documentserver_container_image_name: "documentserver"
|
||||
onlyoffice_documentserver_container_image_repository: >-2
|
||||
{{ onlyoffice_documentserver_container_image_registry
|
||||
+ (('/' + onlyoffice_documentserver_container_image_namespace)
|
||||
if onlyoffice_documentserver_container_image_namespace else '')
|
||||
+ '/' + onlyoffice_documentserver_container_image_name }}
|
||||
onlyoffice_documentserver_container_image_tag: ~
|
||||
onlyoffice_documentserver_container_image_source: pull
|
||||
onlyoffice_documentserver_container_image_force_source: >-2
|
||||
{{ onlyoffice_documentserver_container_image_tag | default(false, true) }}
|
||||
onlyoffice_documentserver_container_env: {}
|
||||
onlyoffice_documentserver_container_ports: ~
|
||||
onlyoffice_documentserver_container_labels: ~
|
||||
onlyoffice_documentserver_container_ulimits: ~
|
||||
onlyoffice_documentserver_container_networks: ~
|
||||
onlyoffice_documentserver_container_dns_servers: ~
|
||||
onlyoffice_documentserver_container_etc_hosts: ~
|
||||
onlyoffice_documentserver_container_memory: ~
|
||||
onlyoffice_documentserver_container_memory_reservation: ~
|
||||
onlyoffice_documentserver_container_memory_swap: ~
|
||||
|
||||
onlyoffice_documentserver_container_state: >-2
|
||||
{{ (onlyoffice_documentserver_state == 'present')
|
||||
| ternary('started', 'absent') }}
|
||||
onlyoffice_documentserver_container_restart_policy: "on-failure"
|
||||
|
||||
onlyoffice_documentserver_default_volumes:
|
||||
- "/var/log/onlyoffice:/var/log/onlyoffice:rw"
|
||||
onlyoffice_documentserver_volumes: ~
|
||||
onlyoffice_documentserver_all_volumes: >-2
|
||||
{{ onlyoffice_documentserver_default_volumes | default([], true)
|
||||
+ onlyoffice_documentserver_volumes | default([], true) }}
|
6
roles/onlyoffice_documentserver/defaults/main/main.yml
Normal file
6
roles/onlyoffice_documentserver/defaults/main/main.yml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
onlyoffice_documentserver_user: "onlyoffice"
|
||||
onlyoffice_documentserver_version: "8.3.3"
|
||||
|
||||
onlyoffice_documentserver_state: present
|
||||
onlyoffice_documentserver_deployment_method: docker
|
25
roles/onlyoffice_documentserver/tasks/deploy-docker.yml
Normal file
25
roles/onlyoffice_documentserver/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,25 @@
|
||||
---
|
||||
- name: Ensure container image '{{ onlyoffice_documentserver_container_image }}' is {{ onlyoffice_documentserver_state }}
|
||||
community.docker.docker_image:
|
||||
name: "{{ onlyoffice_documentserver_container_image }}"
|
||||
state: "{{ onlyoffice_documentserver_state }}"
|
||||
source: "{{ onlyoffice_documentserver_container_image_source }}"
|
||||
force_source: "{{ onlyoffice_documentserver_container_image_force_source }}"
|
||||
|
||||
- name: Ensure container '{{ onlyoffice_documentserver_container_name }}' is {{ onlyoffice_documentserver_container_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ onlyoffice_documentserver_container_name }}"
|
||||
image: "{{ onlyoffice_documentserver_container_image }}"
|
||||
env: "{{ onlyoffice_documentserver_container_env | default(omit, true) }}"
|
||||
ports: "{{ onlyoffice_documentserver_container_ports | default(omit, true) }}"
|
||||
labels: "{{ onlyoffice_documentserver_container_labels | default(omit, true) }}"
|
||||
volumes: "{{ onlyoffice_documentserver_all_volumes }}"
|
||||
ulimits: "{{ onlyoffice_documentserver_container_ulimits | default(omit, true) }}"
|
||||
networks: "{{ onlyoffice_documentserver_container_networks | default(omit, true) }}"
|
||||
dns_servers: "{{ onlyoffice_documentserver_container_dns_servers | default(omit, true) }}"
|
||||
etc_hosts: "{{ onlyoffice_documentserver_container_etc_hosts | default(omit, true) }}"
|
||||
memory: "{{ onlyoffice_documentserver_container_memory | default(omit, true) }}"
|
||||
memory_reservation: "{{ onlyoffice_documentserver_container_memory_reservation | default(omit, true) }}"
|
||||
memory_swap: "{{ onlyoffice_documentserver_container_memory_swap | default(omit, true) }}"
|
||||
restart_policy: "{{ onlyoffice_documentserver_container_restart_policy }}"
|
||||
state: "{{ onlyoffice_documentserver_container_state }}"
|
18
roles/onlyoffice_documentserver/tasks/main.yml
Normal file
18
roles/onlyoffice_documentserver/tasks/main.yml
Normal file
@ -0,0 +1,18 @@
|
||||
---
|
||||
- name: Ensure 'onlyoffice_documentserver_state' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported state '{{ onlyoffice_documentserver_state }}'.
|
||||
Supported states are {{ onlyoffice_documentserver_states | join(', ') }}.
|
||||
when: onlyoffice_documentserver_state not in onlyoffice_documentserver_states
|
||||
|
||||
- name: Ensure 'onlyoffice_documentserver_deployment_method' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported deployment method '{{ onlyoffice_documentserver_deployment_method }}'.
|
||||
Supported deployment methods are {{ onlyoffice_documentserver_deployment_methods | join(', ') }}.
|
||||
when: onlyoffice_documentserver_deployment_method not in onlyoffice_documentserver_deployment_methods
|
||||
|
||||
- name: Deploy using {{ onlyoffice_documentserver_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ onlyoffice_documentserver_deployment_method }}.yml"
|
6
roles/onlyoffice_documentserver/vars/main.yml
Normal file
6
roles/onlyoffice_documentserver/vars/main.yml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
onlyoffice_documentserver_states:
|
||||
- present
|
||||
- absent
|
||||
onlyoffice_documentserver_deployment_methods:
|
||||
- docker
|
@ -1,6 +1,5 @@
|
||||
---
|
||||
|
||||
nextcloud_version: 30.0.0
|
||||
nextcloud_version: "31.0.6"
|
||||
nextcloud_user: nextcloud
|
||||
nextcloud_basepath: /opt/nextcloud
|
||||
nextcloud_config_path: "{{ nextcloud_basepath }}/config"
|
||||
@ -20,9 +19,20 @@ nextcloud_database_pass: ~
|
||||
nextcloud_database_host: localhost
|
||||
|
||||
nextcloud_container_name: nextcloud
|
||||
nextcloud_container_image: docker.io/library/nextcloud
|
||||
nextcloud_container_image_server: docker.io
|
||||
nextcloud_container_image_namespace: library
|
||||
nextcloud_container_image_name: nextcloud
|
||||
nextcloud_container_image: >-2
|
||||
{{
|
||||
[
|
||||
nextcloud_container_image_server,
|
||||
nextcloud_container_image_namespace,
|
||||
nextcloud_container_image_name,
|
||||
] | join('/')
|
||||
}}
|
||||
nextcloud_container_image_variant: "-fpm-alpine"
|
||||
nextcloud_container_image_ref: "{{ nextcloud_container_name }}:{{ nextcloud_version }}{{ nextcloud_container_image_variant }}"
|
||||
nextcloud_container_image_ref: >-2
|
||||
{{ nextcloud_container_image }}:{{ nextcloud_version }}{{ nextcloud_container_image_variant }}
|
||||
nextcloud_container_image_force_source: false
|
||||
nextcloud_container_restart_policy: "unless-stopped"
|
||||
|
||||
@ -41,7 +51,6 @@ nextcloud_container_extra_labels: {}
|
||||
nextcloud_container_extra_environment: {}
|
||||
|
||||
nextcloud_container_networks: ~
|
||||
nextcloud_container_purge_other_networks: true
|
||||
|
||||
nextcloud_paths:
|
||||
- path: "{{ nextcloud_config_path }}"
|
||||
|
10
roles/server/meta/main.yml
Normal file
10
roles/server/meta/main.yml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: server
|
||||
description: Deploy nextcloud server, the self-hosted nextcloud
|
||||
galaxy_tags:
|
||||
- nextcloud
|
||||
- owncloud
|
||||
- docker
|
@ -9,6 +9,9 @@
|
||||
user: "{{ nextcloud_user_info.uid }}"
|
||||
tty: yes
|
||||
register: nextcloud_current_config_entry
|
||||
until: nextcloud_current_config_entry is success
|
||||
retries: 30
|
||||
delay: 10
|
||||
check_mode: false
|
||||
changed_when: false
|
||||
|
||||
@ -25,9 +28,9 @@
|
||||
value_type: >-
|
||||
{% if value is boolean %}
|
||||
boolean
|
||||
{% elsif value is integer %}
|
||||
{% elif value is integer %}
|
||||
integer
|
||||
{% elsif value is float %}
|
||||
{% elif value is float %}
|
||||
float
|
||||
{% else %}
|
||||
string
|
||||
|
@ -29,7 +29,7 @@
|
||||
group: "{{ item.group }}"
|
||||
loop: "{{ nextcloud_paths }}"
|
||||
|
||||
- name: Ensure docker container for nextcloud is pulled
|
||||
- name: Ensure docker container image '{{ nextcloud_container_image_ref }}' for nextcloud is pulled
|
||||
community.docker.docker_image:
|
||||
name: "{{ nextcloud_container_image_ref }}"
|
||||
state: present
|
||||
@ -118,8 +118,8 @@
|
||||
volumes: "{{ nextcloud_container_volumes }}"
|
||||
labels: "{{ nextcloud_container_labels }}"
|
||||
env: "{{ nextcloud_container_env }}"
|
||||
etc_hosts: "{{ nextcloud_container_etc_hosts | default(omit, true) }}"
|
||||
networks: "{{ nextcloud_container_networks | default(omit, true) }}"
|
||||
purge_networks: "{{ nextcloud_container_purge_other_networks }}"
|
||||
restart_policy: "{{ nextcloud_container_restart_policy }}"
|
||||
state: started
|
||||
|
||||
|
Reference in New Issue
Block a user