I'm new to Traefik and I've set up an API serivice in docker behind traefik. Traefik is configured to use Let's Encrypt resolver to automatically deal with the SSL stuff for the hostname of this service so all the clients are talking with this API endpoint in https url e.g. https://xxx and the API service itself (a uvicorn server) is running in non-ssl mode. Everything works fine in normal case.
However, in certain cases, the API endpoint will send out some redirect responses. Those redirect response is targeting to http://xxx which is a different hostname because the API endpoint itself is running in non-ssl mode I guess. The client receiving such a redirect response will not carry the Authorization Header by default because the hostname has changed (from https to http).
I'm wondering what's the conventional practice to make the redirect response sent from service behind traefik to be starting with https. Thank you!
The specific API service I'm using is FastAPI. I noticed that I've never configured the hostname anywhere so I guess the redirect response is just tweaking the path. This let me recall that when traefik router is talking with the services, Traefik will terminate the SSL connections as said in the documentation. Probably the request from router to my service is tweaked to be http://xxx from the original https one sent by the client to traefik i.e. https://xxx. And thus the redirect response is on top of http://xxx. Is my understanding correct here?
As for fastapi's configuration on this, the only thing I found is set a root_path but no settings for root_url. I'm still confirming on that side but I feel it's likely to be not doable. Is there any other way out?
I had the same issue with FastAPI. The redirects happen if the URL on the path does / doesn’t include a slash (although this behaviour should have been fixed in a recent FastAPI release).
The way I fixed it was to add a trailing slash to the end of the route the in the FastAPI router followed by a “?” to indicate it’s optional so that the path is correctly matched and a redirect won’t happen e.g. https://base-path/home/?
Thanks for your response. Unfortunately I have long been noticed this workaround however it has two critical disadvantages:
It does not solve the problem of some other redirect response thrown by us on purpose
Even though the above can be solved with some more efforts, this "/?" route path is no longer supported since April.20 version of fastapi and starlette.
So unfortunately this can't be a long-term, and complete workaround.