gitea: Multi-domain support, ROOT_URL problem, use relative URLs in templates instead of absolute URLs
At the moment, Gitea users must set ROOT_URL correctly in app.ini, otherwise many URLs on the web UI will be wrong, which makes the web UI doesn’t work properly (CSRF tokens and cookies can not work across domains)
The ROOT_URL must be set to the full URL which the users visit, with correct scheme(eg: https://the-gitea-domain/) and correct sub path if it is used (eg: https://the-gitea-domain/my-gitea-path/).
New code should always use relative URLs for Web UI.
Many maintainers have answered the issues about incorrect ROOT_URL again and again.
Using HTMLURL(and other absolute URLs) in templates is the root case that Gitea can only serve web under ROOT_URL.
That’s why we have to force users to set ROOT_URL correctly.
If all URLs in template can be refactored to use Relative URL correctly, then we do not need to force users set ROOT_URL correctly again and again.
The ROOT_URL is still needed because for example, some webhooks need the absolute URL for external systems, and Gitea should show absolute URL on the UI for clone link, etc.
Related:
- https://github.com/go-gitea/gitea/issues/14254
- https://github.com/go-gitea/gitea/issues/17912
- https://github.com/go-gitea/gitea/issues/17843
- https://github.com/go-gitea/gitea/issues/19340
- https://github.com/go-gitea/gitea/issues/19963
- https://github.com/go-gitea/gitea/issues/6397 (5 up-votes!)
- https://github.com/go-gitea/gitea/issues/8697 (19 up-votes!)
- https://github.com/go-gitea/gitea/issues/20091
- https://github.com/go-gitea/gitea/issues/20450
Some more related:
- #20436 , after installation, Gitea may redirect user to an incorrect location.
- #20089 , it may resolve the incorrect redirection problem during installation.
The PR to detect the problem:
About this issue
- Original URL
- State: closed
- Created 2 years ago
- Reactions: 29
- Comments: 20 (11 by maintainers)
Links to this issue
Commits related to this issue
- Use link in UI which returned a relative url but not html_url which contains an absolute url (#21986) partially fix #19345 This PR add some `Link` methods for different objects. The `Link` method... — committed to go-gitea/gitea by lunny a year ago
- Improve AppUrl/ROOT_URL checking (#22836) After some PRs: * #21986 * #22795 * #22808 * #22831 * #22839 Users won't be affected by the ROOT_URL problem in most cases. Close #19345 This PR ... — committed to go-gitea/gitea by wxiaoguang a year ago
Most problems in this issue have been addressed by #21986, so I think it’s good to:
Now the “Multidomain support” is about 50%-70%.
+1, relative URLs may even enable use cases like running on multiple domains. Thought IIRC, ROOT_URL still needs to stay in the config because sometimes absolute URLs need to be built, like for PR link when pushing via SSH. But it’s good nonetheless to remove dependencies on ROOT_URL where possible.
Thank you very much, i found the PR after posting the comment.
$CustomPath/public/css/header.css:$CustomPath/templates/custom/header.tmpl:Hacky but it works 😁
edited by wxiaoguang: ⚠️ please see the WARNING in other comments, do not do so ⚠️
So I think we need an
ALLOWED_ROOT_URLS, which could have a glob matching. When a request to a disallowed root url, Gitea should return 404 or redirect to 404.I found it’s difficult to get the right root url in the backend because maybe there are some reverse proxies. So it’s only done by frontend.
But
ROOT_URLcannot be removed because some places need that. i.e. When sending an email, the link needs an absolute url. We can reuseROOT_URLas the default value of that.First time I have tried gitea and find it surprising that there is no mention of this at all on the docs. The docs give an impression that the user can set the environment, but this is incorrect. I’ll give a subset of examples, there are several more:
Documentation: Install with docker
To bind the integrated OpenSSH daemon and the webserver on a different port, adjust the port section. It’s common to just change the host port and **keep the ports within the container like they are**.Gitea explicitly overrides a lot of headers and links. The advice to differentiate the environment e.g. inside and outside a container, only makes sense if the application offers the configuration feature. E.g. docker mapping to port 3000, instead of 80 or 443, will make you really wonder what the source of the fault is then links dont work. At least by mimic’ing the env on standard ports, some subset will resolve properly.
Documentation: Managing deployments with environemt variables
In addition to the environment variables above, **any settings in app.ini can be set or overridden with an environment variable** of the form: GITEA__SECTION_NAME__KEY_NAME.This is pure misinformation as the application never properly supported configuration in this manner. The docs seems to be describing a roadmap of how it should end up to be, rather than the factual.
Documentation: Recommended server configuration
NOTE: Many of the following directories can be configured using [Environment Variables](https://docs.gitea.io/en-us/environment-variables/) as well! Of note, configuring GITEA_WORK_DIR will tell Gitea where to base its working directory, as well as ease installation.and
Documentation: reverse proxies
No, the application will override the proxy headers e.g. all of the repository links. This will break your env if you rely on the proxy with redirects URI also.
If you follow the docs you will end up with a broken system going in a loop until you find the source of the problem. Would it be possible to mention that this doesnt work on the docs? 😃
⚠️ WARNING about ignoring the “inconsistent domain” message
To be clear : if you see the error message but you ignore it, you will run into problem.
Please DO NOT do so before Gitea has a clear solution, unless that you are very very sure about what you are doing and you can resolve all your users’ problems. That’s why I didn’t make an option or provide any detail steps for hiding it.
I will hide some unrelated comments and edit to put some warnings in some comments, because if many users ignore the warning, there will be a lot of duplicate issues here reporting that “something doesn’t work” (it happened before).
For example, user who log in
https://git/can not do preview if the ROOT_URL ishttps://git.domain/. They can not do inline PR comment either, there could be more similar problems. You can only ignore the error message if you are sure your users won’t use these affected features on different domains.If you are sure you can ignore the warning, there is a bypass method to hide the warning, see the FAQ in #18971 .
edited: ⚠️ please see the WARNING in other comments, do not do so ⚠️
We need a new global variable
ROOT_URL_PATH, it could be/or sub path like/gitea. For repository, we could have a newHTMLURLPath