Skip to content

Commit

Permalink
🐛 Fix: Traefik www redirect (#893)
Browse files Browse the repository at this point in the history
* wip

* Add csi-s3 and have portainer use it

* Change request @Hrytsuk 1GB max portainer volume size

* Fix wrong filename

* Fix registry local deploy

* Traefik local deployment fixes

* Traefik www redirect fixes

* Remove Explicit www TLS domain

* Enhance www redirect regex @Hrytsuk

---------

Co-authored-by: Dustin Kaiser <[email protected]>
  • Loading branch information
mrnicegyu11 and mrnicegyu11 authored Dec 6, 2024
1 parent 177e82f commit 2f0279c
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 16 deletions.
1 change: 1 addition & 0 deletions services/admin-panels/jupyter_server_config.py.template
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
# pylint: skip-file
c.ServerApp.ip = '0.0.0.0'
c.ServerApp.port = 8888
c.ServerApp.open_browser = False
Expand Down
2 changes: 1 addition & 1 deletion services/traefik/docker-compose.letsencrypt.dns.yml.j2
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ services:
traefik:
deploy:
labels:
- traefik.http.routers.wwwsecure-catchall.tls.certresolver=myresolver
- traefik.http.routers.www-catchall.tls.certresolver=myresolver
- traefik.http.routers.api.tls.certresolver=myresolver
- traefik.http.middlewares.ops_whitelist_ips.ipallowlist.sourcerange=${TRAEFIK_IPWHITELIST_SOURCERANGE}
# What follows is a tested workaround to ensure letsencrypt certificates for products' domains are generated
Expand Down
39 changes: 24 additions & 15 deletions services/traefik/docker-compose.yml.j2
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,15 @@ services:
command:
- "--api=true"
- "--api.dashboard=true"
- "--accesslog=true"
- "--accesslog.format=json"
- "--accesslog.fields.defaultmode=keep"
- "--accesslog.fields.names.ClientUsername=keep"
- "--accesslog.fields.headers.defaultmode=keep"
- "--accesslog.fields.headers.names.User-Agent=keep"
- "--accesslog.fields.headers.names.Authorization=drop"
- "--accesslog.fields.headers.names.Content-Type=keep"
- "--log.level=${OPS_TRAEFIK_LOGLEVEL}"
- "--accesslog=false"
- "--metrics.prometheus=true"
- "--metrics.prometheus.addEntryPointsLabels=true"
- "--metrics.prometheus.addServicesLabels=true"
Expand All @@ -18,9 +25,9 @@ services:
- "--entryPoints.http.transport.respondingTimeouts.idleTimeout=21600s" #6h, for https://github.com/traefik/traefik/issues/10805
- "--entryPoints.http.transport.respondingTimeouts.writeTimeout=21600s" #6h, for https://github.com/traefik/traefik/issues/10805
- "--entryPoints.http.transport.respondingTimeouts.readTimeout=21600s" #6h, for https://github.com/traefik/traefik/issues/10805
- --entrypoints.http.http.redirections.entrypoint.to=https
- --entrypoints.http.http.redirections.entrypoint.scheme=https
- --entrypoints.http.http.redirections.entrypoint.permanent=true
- "--entrypoints.http.http.redirections.entrypoint.to=https"
- "--entrypoints.http.http.redirections.entrypoint.scheme=https"
- "--entrypoints.http.http.redirections.entrypoint.permanent=true"
- '--entryPoints.postgres.address=:5432'
- '--entryPoints.postgres2.address=:5433'
- "--entryPoints.https.address=:443"
Expand Down Expand Up @@ -90,16 +97,12 @@ services:
# via https://community.traefik.io/t/v2-2-8-global-redirect-www-to-non-www-with-http-to-https/7428
# see also: https://community.traefik.io/t/get-a-valid-ssl-certificate-for-www-domains-via-traefik-and-lets-encrypt/2023
# Global redirection: https (www.) to https
- traefik.http.routers.wwwsecure-catchall.rule=HostRegexp(`(?P<host>(www\.).+)`)
- traefik.http.routers.wwwsecure-catchall.entrypoints=https
- traefik.http.routers.wwwsecure-catchall.tls=true
- traefik.http.routers.wwwsecure-catchall.middlewares=wwwtohttps
# middleware: http(s)://(www.) to https://
- traefik.http.middlewares.wwwtohttps.redirectregex.regex=^https?://(?:www\.)?(.+)
- traefik.http.middlewares.wwwtohttps.redirectregex.replacement=https://$${1}
- traefik.http.middlewares.wwwtohttps.redirectregex.permanent=true
# Explicit www domain certificate
- traefik.http.routers.wwwsecure-catchall.tls.domains[0].main=www.${MACHINE_FQDN}
- traefik.http.routers.www-catchall.rule=Host(`www.osparc.local`)
- traefik.http.routers.www-catchall.priority=100000
- traefik.http.routers.www-catchall.entrypoints=https,http
- traefik.http.routers.www-catchall.tls=true
- traefik.http.routers.www-catchall.middlewares=strip-www
###########################
# basic authentication
# Note: all dollar signs in the hash need to be doubled for escaping.
Expand Down Expand Up @@ -137,6 +140,12 @@ services:
- traefik.http.middlewares.authenticated_platform_user.forwardauth.address=http://${WEBSERVER_HOST}:${WEBSERVER_PORT}/v0/auth:check
- traefik.http.middlewares.authenticated_platform_user.forwardauth.trustForwardHeader=true
- traefik.http.middlewares.authenticated_platform_user.forwardauth.authResponseHeaders=Set-Cookie,osparc-sc2
#
# middleware: http(s)://(www.) to https://
- traefik.http.middlewares.strip-www.redirectregex.regex=^(https?)://www\.(.+)
- traefik.http.middlewares.strip-www.redirectregex.replacement=$${1}://$${2}
- traefik.http.middlewares.strip-www.redirectregex.permanent=true
networks:
public: null
monitored: null
Expand All @@ -145,7 +154,7 @@ services:
deploy:
placement:
constraints:
- node.labels.ops==true
- node.labels.traefik==true
labels:
- traefik.enable=true
- traefik.docker.network=${PUBLIC_NETWORK}
Expand Down

0 comments on commit 2f0279c

Please sign in to comment.