[add] role:authelia-for-vikunja [add] vikunja [add] vikunja-and-nginx
This commit is contained in:
parent
e89702bf75
commit
70bd2098b0
14 changed files with 349 additions and 0 deletions
5
roles/authelia-for-vikunja/defaults/main.json
Normal file
5
roles/authelia-for-vikunja/defaults/main.json
Normal file
|
@ -0,0 +1,5 @@
|
|||
{
|
||||
"var_authelia_for_vikunja_vikunja_url_base": "https://vikunja.example.org",
|
||||
"var_authelia_for_vikunja_client_id": "vikunja",
|
||||
"var_authelia_for_vikunja_client_secret": "REPLACE_ME"
|
||||
}
|
10
roles/authelia-for-vikunja/info.md
Normal file
10
roles/authelia-for-vikunja/info.md
Normal file
|
@ -0,0 +1,10 @@
|
|||
## Beschreibung
|
||||
|
||||
Um [Vikunja](../vikunja) gegen [Authelia](../authelia) authentifizieren zu lassen
|
||||
|
||||
|
||||
## Verweise
|
||||
|
||||
- [Authelia-Dokumentation | Vikunja Integration](https://www.authelia.com/integration/openid-connect/vikunja/)
|
||||
- [Vikunja-Dokumentation | OpenID](https://vikunja.io/docs/openid/)
|
||||
- [Vikunja-Dokumentation | OpenID example configurations](https://vikunja.io/docs/openid-example-configurations/)
|
25
roles/authelia-for-vikunja/tasks/main.json
Normal file
25
roles/authelia-for-vikunja/tasks/main.json
Normal file
|
@ -0,0 +1,25 @@
|
|||
[
|
||||
{
|
||||
"name": "configuration | emplace",
|
||||
"become": true,
|
||||
"ansible.builtin.template": {
|
||||
"src": "authelia-client-conf.json.j2",
|
||||
"dest": "/etc/authelia/conf.d/clients/vikunja.json"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "configuration | apply",
|
||||
"become": true,
|
||||
"ansible.builtin.command": {
|
||||
"cmd": "/usr/bin/authelia-conf-compose"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "restart service",
|
||||
"become": true,
|
||||
"ansible.builtin.systemd_service": {
|
||||
"state": "restarted",
|
||||
"name": "authelia"
|
||||
}
|
||||
}
|
||||
]
|
|
@ -0,0 +1,17 @@
|
|||
{
|
||||
"client_id": "{{var_authelia_for_vikunja_client_id}}",
|
||||
"client_secret": "{{var_authelia_for_vikunja_client_secret}}",
|
||||
"client_name": "Vikunja",
|
||||
"public": false,
|
||||
"authorization_policy": "one_factor",
|
||||
"redirect_uris": [
|
||||
"{{var_authelia_for_vikunja_vikunja_url_base}}/_vikunja/client/oidc/callback"
|
||||
],
|
||||
"scopes": [
|
||||
"openid",
|
||||
"email",
|
||||
"profile"
|
||||
],
|
||||
"userinfo_signed_response_alg": "none",
|
||||
"token_endpoint_auth_method": "client_secret_basic"
|
||||
}
|
3
roles/vikunja-and-nginx/defaults/main.json
Normal file
3
roles/vikunja-and-nginx/defaults/main.json
Normal file
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"var_vikunja_and_nginx_domain": "vikunja.example.org"
|
||||
}
|
3
roles/vikunja-and-nginx/info.md
Normal file
3
roles/vikunja-and-nginx/info.md
Normal file
|
@ -0,0 +1,3 @@
|
|||
## Verweise
|
||||
|
||||
- [Vikunja-Dokumentation](https://vikunja.io/docs/reverse-proxy/#nginx)
|
35
roles/vikunja-and-nginx/tasks/main.json
Normal file
35
roles/vikunja-and-nginx/tasks/main.json
Normal file
|
@ -0,0 +1,35 @@
|
|||
[
|
||||
{
|
||||
"name": "deactivate default site",
|
||||
"become": true,
|
||||
"ansible.builtin.file": {
|
||||
"state": "absent",
|
||||
"dest": "/etc/nginx/sites-enabled/default"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "emplace configuration | data",
|
||||
"become": true,
|
||||
"ansible.builtin.template": {
|
||||
"src": "conf.j2",
|
||||
"dest": "/etc/nginx/sites-available/{{var_vikunja_and_nginx_domain}}"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "emplace configuration | link",
|
||||
"become": true,
|
||||
"ansible.builtin.file": {
|
||||
"state": "link",
|
||||
"src": "/etc/nginx/sites-available/{{var_vikunja_and_nginx_domain}}",
|
||||
"dest": "/etc/nginx/sites-enabled/{{var_vikunja_and_nginx_domain}}"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "restart nginx",
|
||||
"become": true,
|
||||
"ansible.builtin.systemd_service": {
|
||||
"state": "restarted",
|
||||
"name": "nginx"
|
||||
}
|
||||
}
|
||||
]
|
16
roles/vikunja-and-nginx/templates/conf.j2
Normal file
16
roles/vikunja-and-nginx/templates/conf.j2
Normal file
|
@ -0,0 +1,16 @@
|
|||
server {
|
||||
listen 80;
|
||||
listen [::]:80;
|
||||
listen 443 ssl;
|
||||
listen [::]:443 ssl;
|
||||
|
||||
server_name {{var_vikunja_and_nginx_domain}};
|
||||
|
||||
ssl_certificate /etc/ssl/fullchains/{{var_vikunja_and_nginx_domain}}.pem;
|
||||
ssl_certificate_key /etc/ssl/private/{{var_vikunja_and_nginx_domain}}.pem;
|
||||
|
||||
location / {
|
||||
proxy_pass http://localhost:3456;
|
||||
client_max_body_size 20M;
|
||||
}
|
||||
}
|
20
roles/vikunja/defaults/main.json
Normal file
20
roles/vikunja/defaults/main.json
Normal file
|
@ -0,0 +1,20 @@
|
|||
{
|
||||
"var_vikunja_version": "0.23.0",
|
||||
"var_vikunja_architecture": "amd64",
|
||||
"var_vikunja_domain": "vikunja.example.org",
|
||||
"var_vikunja_directory": "/opt/vikunja",
|
||||
"var_vikunja_user": "vikunja",
|
||||
"var_vikunja_database_kind": "sqlite",
|
||||
"var_vikunja_database_data_sqlite_path": "data.sqlite",
|
||||
"var_vikunja_database_data_postgresql_host": "postgresql.example.org",
|
||||
"var_vikunja_database_data_postgresql_port": 5432,
|
||||
"var_vikunja_database_data_postgresql_username": "vikunja_user",
|
||||
"var_vikunja_database_data_postgresql_password": "REPLACE_ME",
|
||||
"var_vikunja_database_data_postgresql_schema": "vikunja",
|
||||
"var_vikunja_authentication_kind": "internal",
|
||||
"var_vikunja_authentication_data_authelia_provider_id": "authelia",
|
||||
"var_vikunja_authentication_data_authelia_provider_name": "Authelia",
|
||||
"var_vikunja_authentication_data_authelia_client_id": "vikunja",
|
||||
"var_vikunja_authentication_data_authelia_client_secret": "REPLACE_ME",
|
||||
"var_vikunja_authentication_data_authelia_url_base": "https://authelia.example.org"
|
||||
}
|
9
roles/vikunja/info.md
Normal file
9
roles/vikunja/info.md
Normal file
|
@ -0,0 +1,9 @@
|
|||
## Beschreibung
|
||||
|
||||
- Einrichtung der Aufgaben-Verwaltung [Vikunja](https://vikunja.io/)
|
||||
|
||||
|
||||
## Verweise
|
||||
|
||||
- [git-Repository](https://kolaente.dev/vikunja/vikunja)
|
||||
- [Konfiguration](https://vikunja.io/docs/config-options/)
|
64
roles/vikunja/tasks/main.json
Normal file
64
roles/vikunja/tasks/main.json
Normal file
|
@ -0,0 +1,64 @@
|
|||
[
|
||||
{
|
||||
"name": "user",
|
||||
"ansible.builtin.user": {
|
||||
"name": "{{var_vikunja_user}}",
|
||||
"create_home": true,
|
||||
"home": "{{var_vikunja_directory}}"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "download",
|
||||
"become": true,
|
||||
"become_user": "{{var_vikunja_user}}",
|
||||
"ansible.builtin.get_url": {
|
||||
"url": "https://dl.vikunja.io/vikunja/{{var_vikunja_version}}/vikunja-v{{var_vikunja_version}}-linux-{{var_vikunja_architecture}}-full.zip",
|
||||
"dest": "/tmp/vikunja.zip"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "unpack",
|
||||
"become": true,
|
||||
"become_user": "{{var_vikunja_user}}",
|
||||
"ansible.builtin.unarchive": {
|
||||
"src": "/tmp/vikunja.zip",
|
||||
"dest": "{{var_vikunja_directory}}"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "link",
|
||||
"become": true,
|
||||
"become_user": "{{var_vikunja_user}}",
|
||||
"ansible.builtin.file": {
|
||||
"state": "link",
|
||||
"src": "{{var_vikunja_directory}}/vikunja-v{{var_vikunja_version}}-{{var_vikunja_architecture}}",
|
||||
"dest": "{{var_vikunja_directory}}/vikunja"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "conf",
|
||||
"become": true,
|
||||
"become_user": "{{var_vikunja_user}}",
|
||||
"ansible.builtin.template": {
|
||||
"src": "config.json.j2",
|
||||
"dest": "{{var_vikunja_directory}}/config.json"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "systemd-unit",
|
||||
"become": true,
|
||||
"ansible.builtin.template": {
|
||||
"src": "systemd-unit.j2",
|
||||
"dest": "/etc/systemd/system/vikunja.service"
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "apply",
|
||||
"become": true,
|
||||
"ansible.builtin.systemd_service": {
|
||||
"state": "restarted",
|
||||
"enabled": true,
|
||||
"name": "vikunja"
|
||||
}
|
||||
}
|
||||
]
|
44
roles/vikunja/templates/config.json.j2
Normal file
44
roles/vikunja/templates/config.json.j2
Normal file
|
@ -0,0 +1,44 @@
|
|||
{
|
||||
"database": {
|
||||
{% if var_vikunja_database_kind == 'sqlite' %}
|
||||
"type": "sqlite",
|
||||
"path": "{{var_vikunja_database_data_sqlite_path}}"
|
||||
{% endif %}
|
||||
{% if var_vikunja_database_kind == 'postgresql' %}
|
||||
"type": "postgres",
|
||||
"host": "{{var_vikunja_database_data_postgresql_host}}",
|
||||
"port": {{var_vikunja_database_data_postgresql_port | string}},
|
||||
"user": "{{var_vikunja_database_data_postgresql_username}}",
|
||||
"password": "{{var_vikunja_database_data_postgresql_password}}",
|
||||
"database": "{{var_vikunja_database_data_postgresql_schema}}"
|
||||
{% endif %}
|
||||
},
|
||||
"auth": {
|
||||
{% if var_vikunja_authentication_kind == 'internal' %}
|
||||
"local": {
|
||||
"enabled": true
|
||||
},
|
||||
"openid": {
|
||||
"enabled": false
|
||||
}
|
||||
{% endif %}
|
||||
{% if var_vikunja_authentication_kind == 'authelia' %}
|
||||
"local": {
|
||||
"enabled": false
|
||||
},
|
||||
"openid": {
|
||||
"enabled": true,
|
||||
"redirecturl": "https://{{var_vikunja_domain}}/auth/openid/",
|
||||
"providers": [
|
||||
{
|
||||
"name": "Authelia",
|
||||
"authurl": "{{var_vikunja_authentication_data_authelia_url_base}}",
|
||||
"clientid": "{{var_vikunja_authentication_data_authelia_client_id}}",
|
||||
"clientsecret": "{{var_vikunja_authentication_data_authelia_client_secret}}",
|
||||
"scope": "openid profile email"
|
||||
}
|
||||
]
|
||||
}
|
||||
{% endif %}
|
||||
}
|
||||
}
|
16
roles/vikunja/templates/systemd-unit.j2
Normal file
16
roles/vikunja/templates/systemd-unit.j2
Normal file
|
@ -0,0 +1,16 @@
|
|||
[Unit]
|
||||
Description=Vikunja
|
||||
After=syslog.target
|
||||
After=network.target
|
||||
|
||||
[Service]
|
||||
User={{var_vikunja_user}}
|
||||
Group={{var_vikunja_user}}
|
||||
RestartSec=2s
|
||||
Type=simple
|
||||
WorkingDirectory={{var_vikunja_directory}}
|
||||
ExecStart=/usr/bin/vikunja
|
||||
Restart=always
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
82
roles/vikunja/vardef.json
Normal file
82
roles/vikunja/vardef.json
Normal file
|
@ -0,0 +1,82 @@
|
|||
{
|
||||
"version": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"architecture": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"domain": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"directory": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"user": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"database_kind": {
|
||||
"type": "string",
|
||||
"mandatory": false,
|
||||
"options": [
|
||||
"sqlite",
|
||||
"postgresql"
|
||||
]
|
||||
},
|
||||
"database_data_sqlite_path": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"database_data_postgresql_host": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"database_data_postgresql_port": {
|
||||
"type": "integer",
|
||||
"mandatory": false
|
||||
},
|
||||
"database_data_postgresql_username": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"database_data_postgresql_password": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"database_data_postgresql_schema": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"authentication_kind": {
|
||||
"type": "string",
|
||||
"mandatory": false,
|
||||
"options": [
|
||||
"internal",
|
||||
"authelia"
|
||||
]
|
||||
},
|
||||
"authentication_data_authelia_provider_id": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"authentication_data_authelia_provider_name": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"authentication_data_authelia_client_id": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"authentication_data_authelia_client_secret": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
},
|
||||
"authentication_data_authelia_url_base": {
|
||||
"type": "string",
|
||||
"mandatory": false
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue