mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	Add a config option to block "expensive" pages for anonymous users (#34024)
Fix #33966 ``` ;; User must sign in to view anything. ;; It could be set to "expensive" to block anonymous users accessing some pages which consume a lot of resources, ;; for example: block anonymous AI crawlers from accessing repo code pages. ;; The "expensive" mode is experimental and subject to change. ;REQUIRE_SIGNIN_VIEW = false ```
This commit is contained in:
		| @@ -43,7 +43,8 @@ var Service = struct { | ||||
| 	ShowRegistrationButton                  bool | ||||
| 	EnablePasswordSignInForm                bool | ||||
| 	ShowMilestonesDashboardPage             bool | ||||
| 	RequireSignInView                       bool | ||||
| 	RequireSignInViewStrict                 bool | ||||
| 	BlockAnonymousAccessExpensive           bool | ||||
| 	EnableNotifyMail                        bool | ||||
| 	EnableBasicAuth                         bool | ||||
| 	EnablePasskeyAuth                       bool | ||||
| @@ -159,7 +160,18 @@ func loadServiceFrom(rootCfg ConfigProvider) { | ||||
| 	Service.EmailDomainBlockList = CompileEmailGlobList(sec, "EMAIL_DOMAIN_BLOCKLIST") | ||||
| 	Service.ShowRegistrationButton = sec.Key("SHOW_REGISTRATION_BUTTON").MustBool(!(Service.DisableRegistration || Service.AllowOnlyExternalRegistration)) | ||||
| 	Service.ShowMilestonesDashboardPage = sec.Key("SHOW_MILESTONES_DASHBOARD_PAGE").MustBool(true) | ||||
| 	Service.RequireSignInView = sec.Key("REQUIRE_SIGNIN_VIEW").MustBool() | ||||
|  | ||||
| 	// boolean values are considered as "strict" | ||||
| 	var err error | ||||
| 	Service.RequireSignInViewStrict, err = sec.Key("REQUIRE_SIGNIN_VIEW").Bool() | ||||
| 	if s := sec.Key("REQUIRE_SIGNIN_VIEW").String(); err != nil && s != "" { | ||||
| 		// non-boolean value only supports "expensive" at the moment | ||||
| 		Service.BlockAnonymousAccessExpensive = s == "expensive" | ||||
| 		if !Service.BlockAnonymousAccessExpensive { | ||||
| 			log.Fatal("Invalid config option: REQUIRE_SIGNIN_VIEW = %s", s) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	Service.EnableBasicAuth = sec.Key("ENABLE_BASIC_AUTHENTICATION").MustBool(true) | ||||
| 	Service.EnablePasswordSignInForm = sec.Key("ENABLE_PASSWORD_SIGNIN_FORM").MustBool(true) | ||||
| 	Service.EnablePasskeyAuth = sec.Key("ENABLE_PASSKEY_AUTHENTICATION").MustBool(true) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user