From d8a1cd5be839cd9e270aa6d50bc620bc7b6a3782 Mon Sep 17 00:00:00 2001 From: Ivan Koldakov Date: Fri, 21 Jun 2024 20:18:55 +0700 Subject: [PATCH] Extract schemes --- futuramaapi/middlewares/secure.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/futuramaapi/middlewares/secure.py b/futuramaapi/middlewares/secure.py index 1d2eaca..e0f7b20 100644 --- a/futuramaapi/middlewares/secure.py +++ b/futuramaapi/middlewares/secure.py @@ -1,4 +1,5 @@ import logging +from typing import ClassVar from starlette import status from starlette.datastructures import URL @@ -15,6 +16,10 @@ class HTTPSRedirectMiddleware(BaseHTTPMiddleware): https_port: int = 443 http_port: int = 80 + insecure_to_secure: ClassVar[dict[str, str]] = { + "http": "https", + "ws": "wss", + } def is_secure(self, headers: dict): try: @@ -39,7 +44,7 @@ def is_secure(self, headers: dict): def _fix_url(self, scope: Scope, /): url = URL(scope=scope) - redirect_scheme = {"http": "https", "ws": "wss"}[url.scheme] + redirect_scheme = self.insecure_to_secure[url.scheme] netloc = url.hostname if url.port in (self.http_port, self.https_port) else url.netloc return url.replace(scheme=redirect_scheme, netloc=netloc)