monica: add docker compose-based config
parent
df463ed7cb
commit
363eaecc07
|
@ -1,2 +1,6 @@
|
||||||
t5_uuid: 'b3b60b45-0bd2-42ac-a8d8-35a44fbd2529'
|
t5_uuid: 'b3b60b45-0bd2-42ac-a8d8-35a44fbd2529'
|
||||||
elements_uuid: '5D19-E5D1'
|
elements_uuid: '5D19-E5D1'
|
||||||
|
|
||||||
|
monica_app_key: "{{ vault_monica_app_key }}"
|
||||||
|
monica_hash_salt: "{{ vault_monica_hash_salt }}"
|
||||||
|
monica_mariadb_root_pass: "{{ vault_monica_mariadb_root_pass }}"
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
$ANSIBLE_VAULT;1.1;AES256
|
||||||
|
66333462323334613232666338303230343263613330363538653765656466353032313330663435
|
||||||
|
3561393631386465316261353633663234383133343439380a393063326132656630623961656365
|
||||||
|
63353866313961333233333837666438373764373534616161333565323831316665393230633364
|
||||||
|
3134353339636637340a633561316162656237386261373432373337373739623239643131633636
|
||||||
|
34346162633336336162613639303435623936356563333664323237626466393865623536353437
|
||||||
|
63666661366532666637643433336233323138633130353331626364643334616636636131373735
|
||||||
|
31393533313436343732633761656261306434363165323161383034333166353737623138343364
|
||||||
|
66346562653266393665336339343466333635396532613937396539306335396566313466303662
|
||||||
|
62356262653835653335303566393035366431636439323664356433303633666563333136623861
|
||||||
|
39396464393631613865326437336231353136653366383937306138633432373062626666623561
|
||||||
|
64343831376264616661393030366163663666383035663633346232663233346537353337356436
|
||||||
|
62333738316633613030376664373136353031653033356334383963373461626133386139376165
|
||||||
|
3938
|
|
@ -14,3 +14,6 @@
|
||||||
# Miniflux server host
|
# Miniflux server host
|
||||||
[miniflux]
|
[miniflux]
|
||||||
192.168.0.2 static_ip=192.168.0.2
|
192.168.0.2 static_ip=192.168.0.2
|
||||||
|
|
||||||
|
[monica]
|
||||||
|
192.168.0.2 static_ip=192.168.0.2
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
---
|
||||||
|
dependencies:
|
||||||
|
- role: caddy
|
|
@ -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
|
|
@ -0,0 +1,3 @@
|
||||||
|
prm.roosens.me {
|
||||||
|
reverse_proxy {{ groups['monica'][0] }}:8001
|
||||||
|
}
|
|
@ -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'
|
|
@ -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'
|
6
ruby.yml
6
ruby.yml
|
@ -26,3 +26,9 @@
|
||||||
roles:
|
roles:
|
||||||
- restic
|
- restic
|
||||||
tags: restic
|
tags: restic
|
||||||
|
|
||||||
|
- hosts: ruby
|
||||||
|
become: yes
|
||||||
|
roles:
|
||||||
|
- monica
|
||||||
|
tags: monica
|
||||||
|
|
Loading…
Reference in New Issue