Pretix für Hackertours
This commit is contained in:
parent
b94cb009ad
commit
f238182302
12
inventories/chaosknoten/host_vars/hackertours.yaml
Normal file
12
inventories/chaosknoten/host_vars/hackertours.yaml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
docker_compose__compose_file_content: "{{ lookup('ansible.builtin.template', 'chaosknoten/configs/hackertours/compose.yaml.j2') }}"
|
||||||
|
docker_compose__configuration_files: []
|
||||||
|
|
||||||
|
certbot__version_spec: ""
|
||||||
|
certbot__acme_account_email_address: le-admin@hamburg.ccc.de
|
||||||
|
certbot__certificate_domains:
|
||||||
|
- "hackertours.hamburg.ccc.de"
|
||||||
|
|
||||||
|
nginx__version_spec: ""
|
||||||
|
nginx__configurations:
|
||||||
|
- name: hackertours.hamburg.ccc.de
|
||||||
|
content: "{{ lookup('ansible.builtin.file', 'chaosknoten/configs/hackertours/nginx/hackertours.hamburg.ccc.de.conf') }}"
|
|
@ -6,6 +6,10 @@ all:
|
||||||
ansible_host: cloud-intern.hamburg.ccc.de
|
ansible_host: cloud-intern.hamburg.ccc.de
|
||||||
ansible_user: chaos
|
ansible_user: chaos
|
||||||
ansible_ssh_common_args: -J ssh://chaos@public-reverse-proxy.hamburg.ccc.de:42666
|
ansible_ssh_common_args: -J ssh://chaos@public-reverse-proxy.hamburg.ccc.de:42666
|
||||||
|
hackertours:
|
||||||
|
ansible_host: hackertours-intern.hamburg.ccc.de
|
||||||
|
ansible_user: chaos
|
||||||
|
ansible_ssh_common_args: -J ssh://chaos@public-reverse-proxy.hamburg.ccc.de:42666
|
||||||
keycloak:
|
keycloak:
|
||||||
ansible_host: keycloak-intern.hamburg.ccc.de
|
ansible_host: keycloak-intern.hamburg.ccc.de
|
||||||
ansible_user: chaos
|
ansible_user: chaos
|
||||||
|
@ -33,21 +37,23 @@ all:
|
||||||
ansible_ssh_common_args: -J ssh://chaos@public-reverse-proxy.hamburg.ccc.de:42666
|
ansible_ssh_common_args: -J ssh://chaos@public-reverse-proxy.hamburg.ccc.de:42666
|
||||||
docker_compose_hosts:
|
docker_compose_hosts:
|
||||||
hosts:
|
hosts:
|
||||||
pad:
|
hackertours:
|
||||||
keycloak:
|
keycloak:
|
||||||
lists:
|
lists:
|
||||||
onlyoffice:
|
onlyoffice:
|
||||||
|
pad:
|
||||||
nextcloud_hosts:
|
nextcloud_hosts:
|
||||||
hosts:
|
hosts:
|
||||||
cloud:
|
cloud:
|
||||||
nginx_hosts:
|
nginx_hosts:
|
||||||
hosts:
|
hosts:
|
||||||
pad:
|
hackertours:
|
||||||
public-reverse-proxy:
|
|
||||||
keycloak:
|
keycloak:
|
||||||
lists:
|
lists:
|
||||||
wiki:
|
|
||||||
onlyoffice:
|
onlyoffice:
|
||||||
|
pad:
|
||||||
|
public-reverse-proxy:
|
||||||
|
wiki:
|
||||||
public_reverse_proxy_hosts:
|
public_reverse_proxy_hosts:
|
||||||
hosts:
|
hosts:
|
||||||
public-reverse-proxy:
|
public-reverse-proxy:
|
||||||
|
@ -57,16 +63,18 @@ all:
|
||||||
wiki:
|
wiki:
|
||||||
certbot_hosts:
|
certbot_hosts:
|
||||||
hosts:
|
hosts:
|
||||||
pad:
|
hackertours:
|
||||||
keycloak:
|
keycloak:
|
||||||
lists:
|
lists:
|
||||||
wiki:
|
|
||||||
onlyoffice:
|
onlyoffice:
|
||||||
|
pad:
|
||||||
|
wiki:
|
||||||
infrastructure_authorized_keys_hosts:
|
infrastructure_authorized_keys_hosts:
|
||||||
hosts:
|
hosts:
|
||||||
|
hackertours:
|
||||||
cloud:
|
cloud:
|
||||||
|
keycloak:
|
||||||
|
onlyoffice:
|
||||||
pad:
|
pad:
|
||||||
public-reverse-proxy:
|
public-reverse-proxy:
|
||||||
keycloak:
|
|
||||||
wiki:
|
wiki:
|
||||||
onlyoffice:
|
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
# partly generated 2022-01-08, Mozilla Guideline v5.6, nginx 1.17.7, OpenSSL 1.1.1k, intermediate configuration
|
||||||
|
# https://ssl-config.mozilla.org/#server=nginx&version=1.17.7&config=intermediate&openssl=1.1.1k&guideline=5.6
|
||||||
|
server {
|
||||||
|
# Listen on a custom port for the proxy protocol.
|
||||||
|
listen 8443 ssl http2 proxy_protocol;
|
||||||
|
# Make use of the ngx_http_realip_module to set the $remote_addr and
|
||||||
|
# $remote_port to the client address and client port, when using proxy
|
||||||
|
# protocol.
|
||||||
|
# First set our proxy protocol proxy as trusted.
|
||||||
|
set_real_ip_from 172.31.17.140;
|
||||||
|
# Then tell the realip_module to get the addreses from the proxy protocol
|
||||||
|
# header.
|
||||||
|
real_ip_header proxy_protocol;
|
||||||
|
|
||||||
|
server_name hackertours.hamburg.ccc.de;
|
||||||
|
|
||||||
|
ssl_certificate /etc/letsencrypt/live/hackertours.hamburg.ccc.de/fullchain.pem;
|
||||||
|
ssl_certificate_key /etc/letsencrypt/live/hackertours.hamburg.ccc.de/privkey.pem;
|
||||||
|
# verify chain of trust of OCSP response using Root CA and Intermediate certs
|
||||||
|
ssl_trusted_certificate /etc/letsencrypt/live/hackertours.hamburg.ccc.de/chain.pem;
|
||||||
|
|
||||||
|
# HSTS (ngx_http_headers_module is required) (63072000 seconds)
|
||||||
|
add_header Strict-Transport-Security "max-age=63072000" always;
|
||||||
|
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_set_header X-Forwarded-Host $host;
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-Forwarded-Port 443;
|
||||||
|
# This is https in any case.
|
||||||
|
proxy_set_header X-Forwarded-Proto https;
|
||||||
|
# Hide the X-Forwarded header.
|
||||||
|
proxy_hide_header X-Forwarded;
|
||||||
|
# Assume we are the only Reverse Proxy (well using Proxy Protocol, but that
|
||||||
|
# is transparent).
|
||||||
|
# Also provide "_hidden" for by, since it's not relevant.
|
||||||
|
proxy_set_header Forwarded "for=$remote_addr;proto=https;host=$host;by=_hidden";
|
||||||
|
|
||||||
|
location / {
|
||||||
|
proxy_pass http://127.0.0.1:80/;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,55 @@
|
||||||
|
---
|
||||||
|
version: "3.6"
|
||||||
|
|
||||||
|
services:
|
||||||
|
database:
|
||||||
|
image: docker.io/library/postgres:15-alpine
|
||||||
|
environment:
|
||||||
|
- "POSTGRES_USER=pretix"
|
||||||
|
- "POSTGRES_PASSWORD={{ lookup("community.general.passwordstore", "noc/vm-secrets/chaosknoten/hackertours/DB_PASSWORD", create=false, missing="error") }}"
|
||||||
|
- "POSTGRES_DB=pretix"
|
||||||
|
volumes:
|
||||||
|
- database:/var/lib/postgresql/data
|
||||||
|
networks:
|
||||||
|
backend:
|
||||||
|
restart: always
|
||||||
|
|
||||||
|
redis:
|
||||||
|
image: docker.io/redis:7
|
||||||
|
ports:
|
||||||
|
- "6379:6379"
|
||||||
|
volumes:
|
||||||
|
- redis:/rdata
|
||||||
|
# run redis-server, save a snapshot every 60 seconds if there has been at least 1 write
|
||||||
|
command: ["redis-server", "--save", "60", "1"]
|
||||||
|
restart: always
|
||||||
|
|
||||||
|
pretix:
|
||||||
|
image: gitlab-cr.hamburg.ccc.de/ccchh/ccchh-pretix/ccchh-pretix:23.10.0
|
||||||
|
environment:
|
||||||
|
- "PRETIX_INSTANCE_NAME=CCCHH Hackertours"
|
||||||
|
- "PRETIX_URL=http://hackertours.hamburg.ccc.de"
|
||||||
|
- "DATABASE_BACKEND=postgresql"
|
||||||
|
- "DATABASE_NAME=pretix"
|
||||||
|
- "DATABASE_USER=pretix"
|
||||||
|
- "DATABASE_PASSWORD={{ lookup("community.general.passwordstore", "noc/vm-secrets/chaosknoten/hackertours/DB_PASSWORD", create=false, missing="error") }}"
|
||||||
|
- "DATABASE_HOST=database"
|
||||||
|
- "MAIL_FROM=foo@example.com"
|
||||||
|
- "MAIL_HOST=cow-intern.hamburg.ccc.de"
|
||||||
|
- "REDIS_LOCATION=redis://redis/0"
|
||||||
|
- "CELERY_BACKEND=redis://redis/0"
|
||||||
|
- "CELERY_BROKER=redis://redis/1"
|
||||||
|
volumes:
|
||||||
|
- pretix:/rdata
|
||||||
|
restart: always
|
||||||
|
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
database: {}
|
||||||
|
pretix: {}
|
||||||
|
redis: {}
|
||||||
|
|
||||||
|
networks:
|
||||||
|
backend:
|
||||||
|
internal: true
|
||||||
|
frontend:
|
Loading…
Reference in a new issue