mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 03:57:13 +08:00 
			
		
		
		
	Move FCGI req.URL.Path fix-up to the FCGI listener (#15292)
Simplify the web.go FCGI path by moving the req.URL.Path fix-up to listener Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de>
This commit is contained in:
		| @ -9,9 +9,11 @@ import ( | |||||||
| 	"net" | 	"net" | ||||||
| 	"net/http" | 	"net/http" | ||||||
| 	"net/http/fcgi" | 	"net/http/fcgi" | ||||||
|  | 	"strings" | ||||||
|  |  | ||||||
| 	"code.gitea.io/gitea/modules/graceful" | 	"code.gitea.io/gitea/modules/graceful" | ||||||
| 	"code.gitea.io/gitea/modules/log" | 	"code.gitea.io/gitea/modules/log" | ||||||
|  | 	"code.gitea.io/gitea/modules/setting" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func runHTTP(network, listenAddr, name string, m http.Handler) error { | func runHTTP(network, listenAddr, name string, m http.Handler) error { | ||||||
| @ -48,7 +50,12 @@ func runFCGI(network, listenAddr, name string, m http.Handler) error { | |||||||
| 	fcgiServer := graceful.NewServer(network, listenAddr, name) | 	fcgiServer := graceful.NewServer(network, listenAddr, name) | ||||||
|  |  | ||||||
| 	err := fcgiServer.ListenAndServe(func(listener net.Listener) error { | 	err := fcgiServer.ListenAndServe(func(listener net.Listener) error { | ||||||
| 		return fcgi.Serve(listener, m) | 		return fcgi.Serve(listener, http.HandlerFunc(func(resp http.ResponseWriter, req *http.Request) { | ||||||
|  | 			if setting.AppSubURL != "" { | ||||||
|  | 				req.URL.Path = strings.TrimPrefix(req.URL.Path, setting.AppSubURL) | ||||||
|  | 			} | ||||||
|  | 			m.ServeHTTP(resp, req) | ||||||
|  | 		})) | ||||||
| 	}) | 	}) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		log.Fatal("Failed to start FCGI main server: %v", err) | 		log.Fatal("Failed to start FCGI main server: %v", err) | ||||||
|  | |||||||
| @ -168,15 +168,6 @@ func WebRoutes() *web.Route { | |||||||
| 		r.Use(h) | 		r.Use(h) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if (setting.Protocol == setting.FCGI || setting.Protocol == setting.FCGIUnix) && setting.AppSubURL != "" { |  | ||||||
| 		r.Use(func(next http.Handler) http.Handler { |  | ||||||
| 			return http.HandlerFunc(func(resp http.ResponseWriter, req *http.Request) { |  | ||||||
| 				req.URL.Path = strings.TrimPrefix(req.URL.Path, setting.AppSubURL) |  | ||||||
| 				next.ServeHTTP(resp, req) |  | ||||||
| 			}) |  | ||||||
| 		}) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	mailer.InitMailRender(templates.Mailer()) | 	mailer.InitMailRender(templates.Mailer()) | ||||||
|  |  | ||||||
| 	if setting.Service.EnableCaptcha { | 	if setting.Service.EnableCaptcha { | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 zeripath
					zeripath