mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	Replace #27894 Backport #30592 Co-authored-by: delvh <dev.lh@web.de> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		
							
								
								
									
										10
									
								
								assets/go-licenses.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										10
									
								
								assets/go-licenses.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								go.mod
									
									
									
									
									
								
							| @@ -15,7 +15,6 @@ require ( | ||||
| 	gitea.com/lunny/levelqueue v0.4.2-0.20230414023320-3c0159fe0fe4 | ||||
| 	github.com/42wim/sshsig v0.0.0-20211121163825-841cf5bbc121 | ||||
| 	github.com/Azure/go-ntlmssp v0.0.0-20221128193559-754e69321358 | ||||
| 	github.com/NYTimes/gziphandler v1.1.1 | ||||
| 	github.com/PuerkitoBio/goquery v1.8.1 | ||||
| 	github.com/alecthomas/chroma/v2 v2.13.0 | ||||
| 	github.com/blakesmith/ar v0.0.0-20190502131153-809d4375e1fb | ||||
|   | ||||
							
								
								
									
										2
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.sum
									
									
									
									
									
								
							| @@ -99,8 +99,6 @@ github.com/Masterminds/sprig/v3 v3.2.3/go.mod h1:rXcFaZ2zZbLRJv/xSysmlgIM1u11eBa | ||||
| github.com/Microsoft/go-winio v0.5.2/go.mod h1:WpS1mjBmmwHBEWmogvA2mj8546UReBk4v8QkMxJ6pZY= | ||||
| github.com/Microsoft/go-winio v0.6.1 h1:9/kr64B9VUZrLm5YYwbGtUJnMgqWVOdUAXu6Migciow= | ||||
| github.com/Microsoft/go-winio v0.6.1/go.mod h1:LRdKpFKfdobln8UmuiYcKPot9D2v6svN5+sAH+4kjUM= | ||||
| github.com/NYTimes/gziphandler v1.1.1 h1:ZUDjpQae29j0ryrS0u/B8HZfJBtBQHjqw2rQ2cqUQ3I= | ||||
| github.com/NYTimes/gziphandler v1.1.1/go.mod h1:n/CVRwUEOgIxrgPvAQhUUr9oeUtvrhMomdKFjzJNB0c= | ||||
| github.com/ProtonMail/go-crypto v1.0.0 h1:LRuvITjQWX+WIfr930YHG2HNfjR1uOfyf5vE0kC2U78= | ||||
| github.com/ProtonMail/go-crypto v1.0.0/go.mod h1:EjAoLdwvbIOoOQr3ihjnSoLZRtE8azugULFRteWMNc0= | ||||
| github.com/PuerkitoBio/goquery v1.8.1 h1:uQxhNlArOIdbrH1tr0UXwdVFgDcZDrZVdcpygAcwmWM= | ||||
|   | ||||
| @@ -128,6 +128,16 @@ func hasResponseBeenWritten(argsIn []reflect.Value) bool { | ||||
| 	return false | ||||
| } | ||||
|  | ||||
| func wrapHandlerProvider[T http.Handler](hp func(next http.Handler) T, funcInfo *routing.FuncInfo) func(next http.Handler) http.Handler { | ||||
| 	return func(next http.Handler) http.Handler { | ||||
| 		h := hp(next) // this handle could be dynamically generated, so we can't use it for debug info | ||||
| 		return http.HandlerFunc(func(resp http.ResponseWriter, req *http.Request) { | ||||
| 			routing.UpdateFuncInfo(req.Context(), funcInfo) | ||||
| 			h.ServeHTTP(resp, req) | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // toHandlerProvider converts a handler to a handler provider | ||||
| // A handler provider is a function that takes a "next" http.Handler, it can be used as a middleware | ||||
| func toHandlerProvider(handler any) func(next http.Handler) http.Handler { | ||||
| @@ -138,13 +148,9 @@ func toHandlerProvider(handler any) func(next http.Handler) http.Handler { | ||||
| 	} | ||||
|  | ||||
| 	if hp, ok := handler.(func(next http.Handler) http.Handler); ok { | ||||
| 		return func(next http.Handler) http.Handler { | ||||
| 			h := hp(next) // this handle could be dynamically generated, so we can't use it for debug info | ||||
| 			return http.HandlerFunc(func(resp http.ResponseWriter, req *http.Request) { | ||||
| 				routing.UpdateFuncInfo(req.Context(), funcInfo) | ||||
| 				h.ServeHTTP(resp, req) | ||||
| 			}) | ||||
| 		} | ||||
| 		return wrapHandlerProvider(hp, funcInfo) | ||||
| 	} else if hp, ok := handler.(func(http.Handler) http.HandlerFunc); ok { | ||||
| 		return wrapHandlerProvider(hp, funcInfo) | ||||
| 	} | ||||
|  | ||||
| 	provider := func(next http.Handler) http.Handler { | ||||
|   | ||||
| @@ -48,9 +48,9 @@ import ( | ||||
| 	_ "code.gitea.io/gitea/modules/session" // to registers all internal adapters | ||||
|  | ||||
| 	"gitea.com/go-chi/captcha" | ||||
| 	"github.com/NYTimes/gziphandler" | ||||
| 	chi_middleware "github.com/go-chi/chi/v5/middleware" | ||||
| 	"github.com/go-chi/cors" | ||||
| 	"github.com/klauspost/compress/gzhttp" | ||||
| 	"github.com/prometheus/client_golang/prometheus" | ||||
| ) | ||||
|  | ||||
| @@ -244,11 +244,13 @@ func Routes() *web.Route { | ||||
| 	var mid []any | ||||
|  | ||||
| 	if setting.EnableGzip { | ||||
| 		h, err := gziphandler.GzipHandlerWithOpts(gziphandler.MinSize(GzipMinSize)) | ||||
| 		// random jitter is recommended by: https://pkg.go.dev/github.com/klauspost/compress/gzhttp#readme-breach-mitigation | ||||
| 		// compression level 6 is the gzip default and a good general tradeoff between speed, CPU usage, and compression | ||||
| 		wrapper, err := gzhttp.NewWrapper(gzhttp.RandomJitter(32, 0, false), gzhttp.MinSize(GzipMinSize), gzhttp.CompressionLevel(6)) | ||||
| 		if err != nil { | ||||
| 			log.Fatal("GzipHandlerWithOpts failed: %v", err) | ||||
| 			log.Fatal("gzhttp.NewWrapper failed: %v", err) | ||||
| 		} | ||||
| 		mid = append(mid, h) | ||||
| 		mid = append(mid, wrapper) | ||||
| 	} | ||||
|  | ||||
| 	if setting.Service.EnableCaptcha { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user