monica: add docker compose-based config
This commit is contained in:
parent
df463ed7cb
commit
363eaecc07
10 changed files with 173 additions and 0 deletions
3
roles/monica-web/meta/main.yml
Normal file
3
roles/monica-web/meta/main.yml
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
---
|
||||
dependencies:
|
||||
- role: caddy
|
||||
9
roles/monica-web/tasks/main.yml
Normal file
9
roles/monica-web/tasks/main.yml
Normal file
|
|
@ -0,0 +1,9 @@
|
|||
---
|
||||
- name: Ensure Caddyfile is present
|
||||
template:
|
||||
src: 'monica.Caddyfile.j2'
|
||||
dest: '/etc/caddy/monica.Caddyfile'
|
||||
owner: root
|
||||
group: root
|
||||
mode: '0644'
|
||||
notify: caddy-reload
|
||||
3
roles/monica-web/templates/monica.Caddyfile.j2
Normal file
3
roles/monica-web/templates/monica.Caddyfile.j2
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
prm.roosens.me {
|
||||
reverse_proxy {{ groups['monica'][0] }}:8001
|
||||
}
|
||||
45
roles/monica/tasks/main.yml
Normal file
45
roles/monica/tasks/main.yml
Normal file
|
|
@ -0,0 +1,45 @@
|
|||
---
|
||||
- name: Ensure data directory is present
|
||||
ansible.builtin.file:
|
||||
path: '/mnt/data1/monica'
|
||||
state: directory
|
||||
mode: '0755'
|
||||
owner: 'root'
|
||||
group: 'root'
|
||||
|
||||
- name: Ensure data subvolumes are present
|
||||
community.general.btrfs_subvolume:
|
||||
name: '/monica/{{ item }}'
|
||||
with_items:
|
||||
- 'monica'
|
||||
- 'mariadb'
|
||||
|
||||
# Monica runs as www-data which is 33 in the container
|
||||
- name: Ensure monica directory has correct permissions
|
||||
file:
|
||||
path: '/mnt/data1/monica/monica'
|
||||
state: directory
|
||||
mode: '0755'
|
||||
owner: 33
|
||||
group: 33
|
||||
|
||||
- name: Ensure configuration directory is present
|
||||
file:
|
||||
path: '/etc/monica'
|
||||
state: directory
|
||||
mode: '0755'
|
||||
|
||||
- name: Ensure compose file is present
|
||||
template:
|
||||
src: 'compose.yml.j2'
|
||||
dest: '/etc/monica/compose.yml'
|
||||
mode: '0644'
|
||||
owner: 'root'
|
||||
group: 'root'
|
||||
register: res
|
||||
|
||||
- name: Ensure stack is deployed
|
||||
ansible.builtin.shell:
|
||||
chdir: '/etc/monica'
|
||||
cmd: 'docker compose up -d --remove-orphans'
|
||||
when: 'res.changed'
|
||||
80
roles/monica/templates/compose.yml.j2
Normal file
80
roles/monica/templates/compose.yml.j2
Normal file
|
|
@ -0,0 +1,80 @@
|
|||
version: '3'
|
||||
|
||||
services:
|
||||
app:
|
||||
image: 'monica:3.7.0-apache'
|
||||
restart: 'always'
|
||||
|
||||
environment:
|
||||
- "APP_ENV=production"
|
||||
- "APP_DEBUG=false"
|
||||
- "APP_KEY={{ monica_app_key }}"
|
||||
- "HASH_SALT={{ monica_hash_salt }}"
|
||||
- "HASH_LENGTH=18"
|
||||
- "APP_URL=https://prm.roosens.me"
|
||||
- "APP_FORCE_URL=false"
|
||||
- "DB_CONNECTION=mysql"
|
||||
- "DB_HOST=db"
|
||||
- "DB_PORT=3306"
|
||||
- "DB_DATABASE=monica"
|
||||
- "DB_USERNAME=monica"
|
||||
- "DB_PASSWORD=monica"
|
||||
- "DB_PREFIX="
|
||||
- "DB_TEST_HOST=127.0.0.1"
|
||||
- "DB_TEST_DATABASE=monica_test"
|
||||
- "DB_TEST_USERNAME=homestead"
|
||||
- "DB_TEST_PASSWORD=secret"
|
||||
- "DB_USE_UTF8MB4=true"
|
||||
- "MAIL_MAILER=smtp"
|
||||
- "MAIL_HOST=mailtrap.io"
|
||||
- "MAIL_PORT=2525"
|
||||
- "MAIL_USERNAME="
|
||||
- "MAIL_PASSWORD="
|
||||
- "MAIL_ENCRYPTION="
|
||||
- "MAIL_FROM_ADDRESS="
|
||||
- "MAIL_FROM_NAME=Monica instance"
|
||||
- "APP_EMAIL_NEW_USERS_NOTIFICATION="
|
||||
- "APP_DISABLE_SIGNUP=true"
|
||||
- "APP_SIGNUP_DOUBLE_OPTIN=false"
|
||||
- "APP_TRUSTED_PROXIES=*"
|
||||
- "APP_TRUSTED_CLOUDFLARE=false"
|
||||
- "LOG_CHANNEL=daily"
|
||||
- "SENTRY_SUPPORT=false"
|
||||
- "SENTRY_LARAVEL_DSN="
|
||||
- "CHECK_VERSION=true"
|
||||
- "SESSION_LIFETIME=120"
|
||||
- "QUEUE_CONNECTION=sync"
|
||||
- "DEFAULT_MAX_UPLOAD_SIZE=10240"
|
||||
- "DEFAULT_MAX_STORAGE_SIZE=51200"
|
||||
- "DEFAULT_FILESYSTEM=public"
|
||||
- "AWS_KEY="
|
||||
- "AWS_SECRET="
|
||||
- "AWS_REGION=us-east-1"
|
||||
- "AWS_BUCKET="
|
||||
- "AWS_SERVER="
|
||||
- "MFA_ENABLED=true"
|
||||
- "DAV_ENABLED=true"
|
||||
- "PASSPORT_PERSONAL_ACCESS_CLIENT_ID="
|
||||
- "PASSPORT_PERSONAL_ACCESS_CLIENT_SECRET="
|
||||
- "ALLOW_STATISTICS_THROUGH_PUBLIC_API_ACCESS=false"
|
||||
- "POLICY_COMPLIANT=true"
|
||||
- "ENABLE_GEOLOCATION=false"
|
||||
- "LOCATION_IQ_API_KEY="
|
||||
- "ENABLE_WEATHER=false"
|
||||
- "DARKSKY_API_KEY="
|
||||
ports:
|
||||
- 8001:80
|
||||
volumes:
|
||||
- '/mnt/data1/monica/monica:/var/www/html/storage'
|
||||
|
||||
db:
|
||||
image: 'mariadb:10.7.1'
|
||||
restart: 'always'
|
||||
|
||||
environment:
|
||||
- 'MARIADB_ROOT_PASSWORD={{ monica_mariadb_root_pass }}'
|
||||
- 'MARIADB_USER=monica'
|
||||
- 'MARIADB_PASSWORD=monica'
|
||||
- 'MARIADB_DATABASE=monica'
|
||||
volumes:
|
||||
- '/mnt/data1/monica/mariadb:/var/lib/mysql'
|
||||
Loading…
Add table
Add a link
Reference in a new issue