mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	Replace #25892 Close #21942 Close #25464 Major changes: 1. Serve "robots.txt" and ".well-known/security.txt" in the "public" custom path * All files in "public/.well-known" can be served, just like "public/assets" 3. Add a test for ".well-known/security.txt" 4. Simplify the "FileHandlerFunc" logic, now the paths are consistent so the code can be simpler 5. Add CORS header for ".well-known" endpoints 6. Add logs to tell users they should move some of their legacy custom public files ``` 2023/07/19 13:00:37 cmd/web.go:178:serveInstalled() [E] Found legacy public asset "img" in CustomPath. Please move it to /work/gitea/custom/public/assets/img 2023/07/19 13:00:37 cmd/web.go:182:serveInstalled() [E] Found legacy public asset "robots.txt" in CustomPath. Please move it to /work/gitea/custom/public/robots.txt ``` This PR is not breaking. --------- Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Giteabot <teabot@gitea.io>
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2020 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package install
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"html"
 | |
| 	"net/http"
 | |
| 
 | |
| 	"code.gitea.io/gitea/modules/public"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	"code.gitea.io/gitea/modules/web"
 | |
| 	"code.gitea.io/gitea/routers/common"
 | |
| 	"code.gitea.io/gitea/routers/web/healthcheck"
 | |
| 	"code.gitea.io/gitea/services/forms"
 | |
| )
 | |
| 
 | |
| // Routes registers the installation routes
 | |
| func Routes() *web.Route {
 | |
| 	base := web.NewRoute()
 | |
| 	base.Use(common.ProtocolMiddlewares()...)
 | |
| 	base.Methods("GET, HEAD", "/assets/*", public.FileHandlerFunc())
 | |
| 
 | |
| 	r := web.NewRoute()
 | |
| 	r.Use(common.Sessioner(), Contexter())
 | |
| 	r.Get("/", Install) // it must be on the root, because the "install.js" use the window.location to replace the "localhost" AppURL
 | |
| 	r.Post("/", web.Bind(forms.InstallForm{}), SubmitInstall)
 | |
| 	r.Get("/post-install", InstallDone)
 | |
| 	r.Get("/api/healthz", healthcheck.Check)
 | |
| 	r.NotFound(installNotFound)
 | |
| 
 | |
| 	base.Mount("", r)
 | |
| 	return base
 | |
| }
 | |
| 
 | |
| func installNotFound(w http.ResponseWriter, req *http.Request) {
 | |
| 	w.Header().Add("Content-Type", "text/html; charset=utf-8")
 | |
| 	w.Header().Add("Refresh", fmt.Sprintf("1; url=%s", setting.AppSubURL+"/"))
 | |
| 	// do not use 30x status, because the "post-install" page needs to use 404/200 to detect if Gitea has been installed.
 | |
| 	// the fetch API could follow 30x requests to the page with 200 status.
 | |
| 	w.WriteHeader(http.StatusNotFound)
 | |
| 	_, _ = fmt.Fprintf(w, `Not Found. <a href="%s">Go to default page</a>.`, html.EscapeString(setting.AppSubURL+"/"))
 | |
| }
 |