Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bodsch/ansible-nextcloud
Ansible role to install and configure nextcloud
https://github.com/bodsch/ansible-nextcloud
ansible ansible-role automation nextcloud nextcloud-server
Last synced: 3 months ago
JSON representation
Ansible role to install and configure nextcloud
- Host: GitHub
- URL: https://github.com/bodsch/ansible-nextcloud
- Owner: bodsch
- License: apache-2.0
- Created: 2023-08-09T11:02:07.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-28T12:37:25.000Z (4 months ago)
- Last Synced: 2024-10-16T22:42:26.143Z (3 months ago)
- Topics: ansible, ansible-role, automation, nextcloud, nextcloud-server
- Language: Python
- Homepage:
- Size: 151 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Ansible Role: `nextcloud`Ansible role to install and configure nextcloud.
[![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/bodsch/ansible-nextcloud/main.yml?branch=main)][ci]
[![GitHub issues](https://img.shields.io/github/issues/bodsch/ansible-nextcloud)][issues]
[![GitHub release (latest by date)](https://img.shields.io/github/v/release/bodsch/ansible-nextcloud)][releases]
[![Ansible Downloads](https://img.shields.io/ansible/role/d/bodsch/nextcloud?logo=ansible)][galaxy][ci]: https://github.com/bodsch/ansible-nextcloud/actions
[issues]: https://github.com/bodsch/ansible-nextcloud/issues?q=is%3Aopen+is%3Aissue
[releases]: https://github.com/bodsch/ansible-nextcloud/releases
[galaxy]: https://galaxy.ansible.com/ui/standalone/roles/bodsch/nextcloud/## Requirements & Dependencies
Ansible Collections
- [bodsch.core](https://github.com/bodsch/ansible-collection-core)
```bash
ansible-galaxy collection install bodsch.core
```
or
```bash
ansible-galaxy collection install --requirements-file collections.yml
```## usage
```yaml
nextcloud_version: 26.0.5# switch between
# releases : https://download.nextcloud.com/server/releases/nextcloud-28.0.1.zip
# prereleases : https://download.nextcloud.com/server/prereleases/nextcloud-28.0.2rc1.zip
# daily : https://download.nextcloud.com/server/daily/nextcloud-28-daily-2024-01-18.zip
# https://download.nextcloud.com/server/daily/nextcloud-master-daily-2024-01-18.zip
# default = releases
nextcloud_release_type: releasesnextcloud_direct_download: false
nextcloud_release: {}
nextcloud_install_base_directory: /var/www
nextcloud_owner: ""
nextcloud_group: ""nextcloud_admin:
username: admin
password: adminnextcloud_instande_id: ""
nextcloud_password_salt: ""
nextcloud_data_directory: ""nextcloud_trusted_domains: []
nextcloud_database:
type: sqlite
name: nextcloud
# username: nextcloud
# password:
# hostname:
# port: 3306
# schema: nextcloud
persistent: falsenextcloud_defaults: {}
# language:
# default: en
# # force: en
# locale:
# default: en_GB
# # force: en_GB
# phone_region: DE
# defaultapps:
# - dashboard
# - files
# knowledgebase_enabled: truenextcloud_php_daemon:
restart: true
name: "{{ php_fpm_daemon }}"nextcloud_background_jobs:
type: cron # alternative: webcron | ajax and systemd
daemon: "" # "{{ 'cron' if ansible_os_family | lower == 'debian' else 'cronie' }}"
state: enabled # ['enabled', 'disabled']
cron:
minute: "" # '*/5'
hour: "" # '*'
weekday: "" # '*'
```### `nextcloud_admin`
```yaml
nextcloud_admin:
username: admin
password: admin
```### `nextcloud_trusted_domains`
```yaml
nextcloud_trusted_domains:
- nextcloud.molecule.lan
- nextcloud.molecule.local
```### `nextcloud_database`
```yaml
nextcloud_database:
type: sqlite
name: nextcloud
# username: nextcloud
# password:
# hostname:
# port: 3306
# schema: nextcloud
persistent: false
```### `nextcloud_defaults`
```yaml
nextcloud_defaults:
# language:
# default: en
# # force: en
# locale:
# default: en_GB
# # force: en_GB
# phone_region: DE
# defaultapps:
# - dashboard
# - files
# knowledgebase_enabled: true
```### `nextcloud_background_jobs`
To create the Background Job.
| Variable | default | Description |
| :--- | :---- | :---- |
| `type` | `webcron` | alternative: `cron`, `webcron`, `ajax`.
systemd User can create an system timer with `systemd` insteed `cron` |
| `daemon` | ` ` | the named cron package (Will be installed) |
| `enabled` | `false` | enable cron Background Jobs. |
| `cron.minute` | `*/5` | cron configuration: *minute* |
| `cron.hour` | `*` | cron configuration: *hour* |
| `cron.weekday` | `*` | cron configuration: *weekday* |```yaml
nextcloud_background_jobs:
type: cron
daemon: ""
enabled: false
cron:
minute: ""
hour: ""
weekday: ""
```### `nextcloud_groups`
Creates Groups in Nextcloud.
| Variable | default | Description |
| :--- | :---- | :---- |
| `name` | `webcron` | Group name |
| `display_name` | ` ` | Group name used in the web UI (can contain any characters) |
| `state` | `present` | State of the Group (`present` or `absent`) |```yaml
nextcloud_groups:
- name: test
display_name: "Testing with spaces"
state: present
- name: test2
state: absent
```### `nextcloud_users`
Creates Users in Nextcloud.
| Variable | default | Description |
| :--- | :---- | :---- |
| `name` | ` ` | User name |
| `state` | `present` | State of the User (`present` or `absent`) |
| `display_name` | ` ` | User name used in the web UI (can contain any characters) |
| `password` | ` ` | User password |
| `resetpassword` | ` ` | reset the passsword (**every time the playbook is run!**) |
| `groups` | `[]` | A list of groups to which the user should be added.
Groups that do not exist are ignored. |
| `settings` | `` | *TODO* |```yaml
nextcloud_users:
- name: bodsch
password: "{{ vault__users.bodsch }}"
display_name: Bod Sch
groups:
- test
```### `nextcloud_apps`
Install Nextcloud Apps.
| Variable | default | Description |
| :--- | :---- | :---- |
| `name` | ` ` | App name |
| `state` | `present` | State of the App (`present`, `absent`, `enabled` or `disabled` ) |
| `settings` | `{}` | Dictionary of Application Settings |```yaml
nextcloud_apps:
- name: calendar
state: disabled
- name: richdocuments
state: disabled
settings:
canonical_webroot: https://office.molecule.lan
disable_certificate_verification: true
edit_groups: "admin"
public_wopi_url: https://office.molecule.lan
use_groups: "admin"
wopi_allowlist: "127.0.0.1/32"
wopi_url: https://office.molecule.lan
```---
## Contribution
Please read [Contribution](CONTRIBUTING.md)
## Development, Branches (Git Tags)
The `master` Branch is my *Working Horse* includes the "latest, hot shit" and can be complete broken!
If you want to use something stable, please use a [Tagged Version](https://github.com/bodsch/ansible-nextcloud/-/tags)!
---
## Author and License
- Bodo Schulz
## License
[Apache](LICENSE)
**FREE SOFTWARE, HELL YEAH!**