Skip to content

Commit

Permalink
Add support for pretix maintenance mode, using variable. (#484)
Browse files Browse the repository at this point in the history
* Add support for pretix maintenance mode, using variable.

* Fix lints
  • Loading branch information
TobiasDeBruijn authored Dec 28, 2024
1 parent e9aacfc commit 60edb12
Show file tree
Hide file tree
Showing 5 changed files with 118 additions and 5 deletions.
1 change: 1 addition & 0 deletions ansible/group_vars/production/vars.yml
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ secret_pretix:
# To change, generate a new secret using something like `pwgen 128 1`and
# re-deploy. Changing this value will invalidate all pretix sessions.
django_secret: "{{ vault_secret_pretix.django_secret }}"
pretix_maintenance_mode: true

secret_static_sticky:
contentful_space_id: "{{ vault_secret_static_sticky.contentful_space_id }}"
Expand Down
1 change: 1 addition & 0 deletions ansible/group_vars/staging/vars.yml
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ secret_pretix:
# To change, generate a new secret using something like `pwgen 128 1`and
# re-deploy. Changing this value will invalidate all pretix sessions.
django_secret: "{{ vault_secret_pretix.django_secret }}"
pretix_maintenance_mode: true

secret_static_sticky:
contentful_space_id: "{{ vault_secret_static_sticky.contentful_space_id }}"
Expand Down
57 changes: 52 additions & 5 deletions ansible/roles/pretix/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -62,13 +62,19 @@

- name: "create virtualenv if not exists, update pip and tools"
ansible.builtin.pip:
name:
- "pip"
- "setuptools"
- "wheel"
state: "latest"
name: "{{ item.name }}"
version: "{{ item.version }}"
virtualenv: "/var/www/pretix/venv"
virtualenv_python: "python3.8"
state: "present"
with_items:
# Change in pip's dependency resolver after 24.0 causes installation of pretix to fail
- name: pip
version: "24.0"
- name: "setuptools"
version: "latest"
- name: "wheel"
version: "latest"
become: true
become_user: "pretix"

Expand All @@ -92,6 +98,7 @@
state: "present"
virtualenv: "/var/www/pretix/venv"
virtualenv_python: "python3.9"

with_items:
- name: "gunicorn"
version: "20.1.0"
Expand Down Expand Up @@ -126,14 +133,54 @@
- "pretix-worker.service"
- "pretix-runperiodic.timer"

# Maintenance directory, create if maintenance mode
- name: "ensure pretix maintenance mode directory is present"
when: secret_pretix.pretix_maintenance_mode
ansible.builtin.file:
path: "/var/www/pretix-maintenance"
state: "directory"
owner: "pretix"
group: "pretix"

# Maintenance directory, remove if not maintenance mode
- name: "ensure pretix maintenance mode directory is present"
when: not secret_pretix.pretix_maintenance_mode
ansible.builtin.file:
path: "/var/www/pretix-maintenance"
state: "absent"
owner: "pretix"
group: "pretix"

# Maintenance mode page
- name: "Place Maintenance page if maintenance mode is enabled"
when: secret_pretix.pretix_maintenance_mode
ansible.builtin.template:
owner: "pretix"
group: "pretix"
src: "pretix_maintenance.html.j2"
dest: "/var/www/pretix-maintenance/pretix-maintenance.html"

# Maintenance nginx configuration
- name: "place pretix's maintenace nginx configuration"
when: secret_pretix.pretix_maintenance_mode
ansible.builtin.template:
src: "pretix_maintenance.conf.j2"
dest: "/etc/nginx/sites-available/{{ dest_filename }}"
vars:
dest_filename: "pretix.{{ canonical_hostname }}.conf"
notify: "reload nginx"

# Regular nginx configuration
- name: "place pretix's nginx configuration"
when: not secret_pretix.pretix_maintenance_mode
ansible.builtin.template:
src: "pretix.conf.j2"
dest: "/etc/nginx/sites-available/{{ dest_filename }}"
vars:
dest_filename: "pretix.{{ canonical_hostname }}.conf"
notify: "reload nginx"

# Does either maintenance mode or regular mode
- name: "enable pretix's nginx configuration"
ansible.builtin.file:
src: "/etc/nginx/sites-available/{{ filename }}"
Expand Down
21 changes: 21 additions & 0 deletions ansible/roles/pretix/templates/pretix_maintenance.conf.j2
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# {{ ansible_managed }}

server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name ~^(pretix|tickets)\.{{ canonical_hostname }};

ssl_certificate /etc/letsencrypt/live/pretix.{{ canonical_hostname }}/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/pretix.{{ canonical_hostname }}/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/pretix.{{ canonical_hostname }}/chain.pem;

include includes/block-cert-validation-path.conf;
add_header Referrer-Policy same-origin;
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains";
# Security header file not included because frames

root /var/www/pretix-maintenance;
index pretix-maintenance.html;
}
43 changes: 43 additions & 0 deletions ansible/roles/pretix/templates/pretix_maintenance.html.j2
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Pretix Maintenance</title>
<style>
body {
font-family: Arial, sans-serif;
background-color: #f4f4f9;
text-align: center;
padding: 50px;
}
header {
margin-bottom: 50px;
}
img.banner {
max-width: 600px;
height: auto;
}
h1 {
color: #333;
font-size: 2.5em;
margin-top: 30px;
}
p {
color: #666;
font-size: 1.2em;
}
</style>
</head>
<body>

<header>
<img class="banner" src="https://public.svsticky.nl/logos/logo_outline_kleur.svg" alt="Logo">
</header>

<h1>Pretix is currently under maintenance</h1>
<p>Purchasing tickets is currently not possible.</p>
<p>Het kopen van tickets is op dit moment niet mogelijk.</p>
</body>
</html>

0 comments on commit 60edb12

Please sign in to comment.