mirror of
https://github.com/cookiecutter/cookiecutter-django.git
synced 2024-11-23 18:14:01 +03:00
9cf47898f4
Instead of checking for `.co.XX` on best effort basis, we only check for the single dot in the domain_name indicating no subdomain usage.
99 lines
2.4 KiB
YAML
99 lines
2.4 KiB
YAML
log:
|
|
level: INFO
|
|
|
|
entryPoints:
|
|
web:
|
|
# http
|
|
address: ":80"
|
|
|
|
web-secure:
|
|
# https
|
|
address: ":443"
|
|
{%- if cookiecutter.use_celery == 'y' %}
|
|
|
|
flower:
|
|
address: ":5555"
|
|
{%- endif %}
|
|
|
|
certificatesResolvers:
|
|
letsencrypt:
|
|
# https://docs.traefik.io/master/https/acme/#lets-encrypt
|
|
acme:
|
|
email: "{{ cookiecutter.email }}"
|
|
storage: /etc/traefik/acme/acme.json
|
|
# https://docs.traefik.io/master/https/acme/#httpchallenge
|
|
httpChallenge:
|
|
entryPoint: web
|
|
|
|
http:
|
|
routers:
|
|
web-router:
|
|
{%- if cookiecutter.domain_name.count('.') == 1 %}
|
|
rule: "Host(`{{ cookiecutter.domain_name }}`) || Host(`www.{{ cookiecutter.domain_name }}`)"
|
|
{% else %}
|
|
rule: "Host(`{{ cookiecutter.domain_name }}`)"
|
|
{%- endif %}
|
|
entryPoints:
|
|
- web
|
|
middlewares:
|
|
- redirect
|
|
- csrf
|
|
service: django
|
|
|
|
web-secure-router:
|
|
{%- if cookiecutter.domain_name.count('.') == 1 %}
|
|
rule: "Host(`{{ cookiecutter.domain_name }}`) || Host(`www.{{ cookiecutter.domain_name }}`)"
|
|
{% else %}
|
|
rule: "Host(`{{ cookiecutter.domain_name }}`)"
|
|
{%- endif %}
|
|
entryPoints:
|
|
- web-secure
|
|
middlewares:
|
|
- csrf
|
|
service: django
|
|
tls:
|
|
# https://docs.traefik.io/master/routing/routers/#certresolver
|
|
certResolver: letsencrypt
|
|
{%- if cookiecutter.use_celery == 'y' %}
|
|
|
|
flower-secure-router:
|
|
rule: "Host(`{{ cookiecutter.domain_name }}`)"
|
|
entryPoints:
|
|
- flower
|
|
service: flower
|
|
tls:
|
|
# https://docs.traefik.io/master/routing/routers/#certresolver
|
|
certResolver: letsencrypt
|
|
{%- endif %}
|
|
|
|
middlewares:
|
|
redirect:
|
|
# https://docs.traefik.io/master/middlewares/redirectscheme/
|
|
redirectScheme:
|
|
scheme: https
|
|
permanent: true
|
|
csrf:
|
|
# https://docs.traefik.io/master/middlewares/headers/#hostsproxyheaders
|
|
# https://docs.djangoproject.com/en/dev/ref/csrf/#ajax
|
|
headers:
|
|
hostsProxyHeaders: ["X-CSRFToken"]
|
|
|
|
services:
|
|
django:
|
|
loadBalancer:
|
|
servers:
|
|
- url: http://django:5000
|
|
{%- if cookiecutter.use_celery == 'y' %}
|
|
|
|
flower:
|
|
loadBalancer:
|
|
servers:
|
|
- url: http://flower:5555
|
|
{%- endif %}
|
|
|
|
providers:
|
|
# https://docs.traefik.io/master/providers/file/
|
|
file:
|
|
filename: /etc/traefik/traefik.yml
|
|
watch: true
|