Kavita: add application
This commit is contained in:
@@ -97,6 +97,14 @@ memos.vakhrushev.me {
|
|||||||
}
|
}
|
||||||
|
|
||||||
kavita.vakhrushev.me {
|
kavita.vakhrushev.me {
|
||||||
|
tls anwinged@ya.ru
|
||||||
|
|
||||||
|
reverse_proxy {
|
||||||
|
to kavita_app:5000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wanderbase.vakhrushev.me {
|
||||||
tls anwinged@ya.ru
|
tls anwinged@ya.ru
|
||||||
|
|
||||||
forward_auth authelia_app:9091 {
|
forward_auth authelia_app:9091 {
|
||||||
|
|||||||
24
files/kavita/docker-compose.template.yml
Normal file
24
files/kavita/docker-compose.template.yml
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
services:
|
||||||
|
|
||||||
|
kavita:
|
||||||
|
image: jvmilazz0/kavita:0.8.9
|
||||||
|
container_name: kavita_app
|
||||||
|
user: "{{ owner_create_result.uid }}:{{ owner_create_result.group }}"
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- "web_proxy_network"
|
||||||
|
volumes:
|
||||||
|
- "{{ books_fiction }}:/srv/books/fiction:ro"
|
||||||
|
- "{{ books_technical | path_join }}:/srv/books/technical:ro"
|
||||||
|
- "{{ books_comics | path_join }}:/srv/books/comics:ro"
|
||||||
|
- "{{ config_dir }}:/kavita/config"
|
||||||
|
environment:
|
||||||
|
- TZ=Europe/Moscow
|
||||||
|
- "PUID={{ owner_create_result.uid }}"
|
||||||
|
- "PGID={{ owner_create_result.group }}"
|
||||||
|
# ports:
|
||||||
|
# - "5000:5000"
|
||||||
|
|
||||||
|
networks:
|
||||||
|
web_proxy_network:
|
||||||
|
external: true
|
||||||
@@ -31,6 +31,9 @@
|
|||||||
- name: 'Configure wanderer'
|
- name: 'Configure wanderer'
|
||||||
ansible.builtin.import_playbook: playbook-wanderer.yml
|
ansible.builtin.import_playbook: playbook-wanderer.yml
|
||||||
|
|
||||||
|
- name: 'Configure kavita'
|
||||||
|
ansible.builtin.import_playbook: playbook-kavita.yml
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
||||||
- name: 'Configure homepage'
|
- name: 'Configure homepage'
|
||||||
|
|||||||
72
playbook-kavita.yml
Normal file
72
playbook-kavita.yml
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
---
|
||||||
|
- name: "Configure kavita application"
|
||||||
|
hosts: all
|
||||||
|
|
||||||
|
vars_files:
|
||||||
|
- vars/secrets.yml
|
||||||
|
|
||||||
|
vars:
|
||||||
|
app_name: "kavita"
|
||||||
|
app_user: "{{ app_name }}"
|
||||||
|
app_owner_uid: 1101
|
||||||
|
app_owner_gid: 1101
|
||||||
|
base_dir: "{{ (application_dir, app_name) | path_join }}"
|
||||||
|
books_dir: "{{ (base_dir, 'books') | path_join }}"
|
||||||
|
config_dir: "{{ (base_dir, 'config') | path_join }}"
|
||||||
|
|
||||||
|
books_fiction: "{{ (books_dir, 'fiction') | path_join }}"
|
||||||
|
books_technical: "{{ (books_dir, 'technical') | path_join }}"
|
||||||
|
books_comics: "{{ (books_dir, 'comics') | path_join }}"
|
||||||
|
|
||||||
|
tasks:
|
||||||
|
- name: "Create user and environment"
|
||||||
|
ansible.builtin.import_role:
|
||||||
|
name: owner
|
||||||
|
vars:
|
||||||
|
owner_name: "{{ app_user }}"
|
||||||
|
owner_uid: "{{ app_owner_uid }}"
|
||||||
|
owner_gid: "{{ app_owner_gid }}"
|
||||||
|
owner_extra_groups: ["docker"]
|
||||||
|
|
||||||
|
- name: "Create application internal directories"
|
||||||
|
ansible.builtin.file:
|
||||||
|
path: "{{ item }}"
|
||||||
|
state: "directory"
|
||||||
|
owner: "{{ app_user }}"
|
||||||
|
group: "{{ app_user }}"
|
||||||
|
mode: "0750"
|
||||||
|
loop:
|
||||||
|
- "{{ base_dir }}"
|
||||||
|
- "{{ books_dir }}"
|
||||||
|
- "{{ config_dir }}"
|
||||||
|
- "{{ books_fiction }}"
|
||||||
|
- "{{ books_technical }}"
|
||||||
|
- "{{ books_comics }}"
|
||||||
|
|
||||||
|
- name: "Create backup targets file"
|
||||||
|
ansible.builtin.lineinfile:
|
||||||
|
path: "{{ base_dir }}/backup-targets"
|
||||||
|
line: "{{ item }}"
|
||||||
|
create: true
|
||||||
|
owner: "{{ app_user }}"
|
||||||
|
group: "{{ app_user }}"
|
||||||
|
mode: "0750"
|
||||||
|
loop:
|
||||||
|
- "{{ books_dir }}"
|
||||||
|
- "{{ config_dir }}"
|
||||||
|
|
||||||
|
- name: "Copy docker compose file"
|
||||||
|
ansible.builtin.template:
|
||||||
|
src: "./files/{{ app_name }}/docker-compose.template.yml"
|
||||||
|
dest: "{{ base_dir }}/docker-compose.yml"
|
||||||
|
owner: "{{ app_user }}"
|
||||||
|
group: "{{ app_user }}"
|
||||||
|
mode: "0640"
|
||||||
|
|
||||||
|
- name: "Run application with docker compose"
|
||||||
|
community.docker.docker_compose_v2:
|
||||||
|
project_src: "{{ base_dir }}"
|
||||||
|
state: "present"
|
||||||
|
remove_orphans: true
|
||||||
|
tags:
|
||||||
|
- run-app
|
||||||
Reference in New Issue
Block a user