mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-09-09 03:37:37 +02:00
Introduce sys-svc-cdn (cdn_paths/cdn_urls/cdn_dirs) and ensure CDN directories + latest symlink. Rename sys-srv-web-inj-* → sys-front-inj-*; update includes/templates; serve shared/per-app CSS & JS via CDN. Add lookup_plugins/local_mtime_qs.py for mtime-based cache busting; split CSS into default.css/bootstrap.css + optional per-app style.css. CSP: use style-src-elem; drop unsafe-inline for styles. Services: fix SYS_SERVICE_ALL_ENABLED bool and controlled flush. BREAKING CHANGE: role names changed; replace includes and references accordingly. Conversation: https://chatgpt.com/share/68b55494-9ec4-800f-b559-44707029141d
36 lines
947 B
Django/Jinja
36 lines
947 B
Django/Jinja
map $http_upgrade $connection_upgrade {
|
|
default upgrade;
|
|
'' close;
|
|
}
|
|
|
|
server {
|
|
server_name {{ domain }};
|
|
|
|
{% include 'roles/srv-letsencrypt/templates/ssl_header.j2' %}
|
|
|
|
{% include 'roles/sys-front-inj-all/templates/server.conf.j2' %}
|
|
|
|
client_max_body_size {{ client_max_body_size | default('100m') }};
|
|
keepalive_timeout 70;
|
|
sendfile on;
|
|
|
|
gzip on;
|
|
gzip_disable "msie6";
|
|
gzip_vary on;
|
|
gzip_proxied any;
|
|
gzip_comp_level 6;
|
|
gzip_buffers 16 8k;
|
|
gzip_http_version 1.1;
|
|
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
|
|
|
|
add_header Strict-Transport-Security "max-age=31536000";
|
|
|
|
{% include 'roles/srv-proxy-core/templates/location/html.conf.j2' %}
|
|
|
|
{% if location_ws is defined %}
|
|
{% include 'roles/srv-proxy-core/templates/location/ws.conf.j2' %}
|
|
{% endif %}
|
|
|
|
error_page 500 501 502 503 504 /500.html;
|
|
}
|