mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Decouple the different contexts from each other (#24786)
Replace #16455 Close #21803 Mixing different Gitea contexts together causes some problems: 1. Unable to respond proper content when error occurs, eg: Web should respond HTML while API should respond JSON 2. Unclear dependency, eg: it's unclear when Context is used in APIContext, which fields should be initialized, which methods are necessary. To make things clear, this PR introduces a Base context, it only provides basic Req/Resp/Data features. This PR mainly moves code. There are still many legacy problems and TODOs in code, leave unrelated changes to future PRs.
This commit is contained in:
		| @@ -149,7 +149,7 @@ func repoAssignment() func(ctx *context.APIContext) { | ||||
| 			if err != nil { | ||||
| 				if user_model.IsErrUserNotExist(err) { | ||||
| 					if redirectUserID, err := user_model.LookupUserRedirect(userName); err == nil { | ||||
| 						context.RedirectToUser(ctx.Context, userName, redirectUserID) | ||||
| 						context.RedirectToUser(ctx.Base, userName, redirectUserID) | ||||
| 					} else if user_model.IsErrUserRedirectNotExist(err) { | ||||
| 						ctx.NotFound("GetUserByName", err) | ||||
| 					} else { | ||||
| @@ -170,7 +170,7 @@ func repoAssignment() func(ctx *context.APIContext) { | ||||
| 			if repo_model.IsErrRepoNotExist(err) { | ||||
| 				redirectRepoID, err := repo_model.LookupRedirect(owner.ID, repoName) | ||||
| 				if err == nil { | ||||
| 					context.RedirectToRepo(ctx.Context, redirectRepoID) | ||||
| 					context.RedirectToRepo(ctx.Base, redirectRepoID) | ||||
| 				} else if repo_model.IsErrRedirectNotExist(err) { | ||||
| 					ctx.NotFound() | ||||
| 				} else { | ||||
| @@ -274,7 +274,7 @@ func reqToken(requiredScope auth_model.AccessTokenScope) func(ctx *context.APICo | ||||
| 			ctx.Error(http.StatusForbidden, "reqToken", "token does not have required scope: "+requiredScope) | ||||
| 			return | ||||
| 		} | ||||
| 		if ctx.Context.IsBasicAuth { | ||||
| 		if ctx.IsBasicAuth { | ||||
| 			ctx.CheckForOTP() | ||||
| 			return | ||||
| 		} | ||||
| @@ -295,7 +295,7 @@ func reqExploreSignIn() func(ctx *context.APIContext) { | ||||
|  | ||||
| func reqBasicAuth() func(ctx *context.APIContext) { | ||||
| 	return func(ctx *context.APIContext) { | ||||
| 		if !ctx.Context.IsBasicAuth { | ||||
| 		if !ctx.IsBasicAuth { | ||||
| 			ctx.Error(http.StatusUnauthorized, "reqBasicAuth", "auth required") | ||||
| 			return | ||||
| 		} | ||||
| @@ -375,7 +375,7 @@ func reqAnyRepoReader() func(ctx *context.APIContext) { | ||||
| // reqOrgOwnership user should be an organization owner, or a site admin | ||||
| func reqOrgOwnership() func(ctx *context.APIContext) { | ||||
| 	return func(ctx *context.APIContext) { | ||||
| 		if ctx.Context.IsUserSiteAdmin() { | ||||
| 		if ctx.IsUserSiteAdmin() { | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| @@ -407,7 +407,7 @@ func reqOrgOwnership() func(ctx *context.APIContext) { | ||||
| // reqTeamMembership user should be an team member, or a site admin | ||||
| func reqTeamMembership() func(ctx *context.APIContext) { | ||||
| 	return func(ctx *context.APIContext) { | ||||
| 		if ctx.Context.IsUserSiteAdmin() { | ||||
| 		if ctx.IsUserSiteAdmin() { | ||||
| 			return | ||||
| 		} | ||||
| 		if ctx.Org.Team == nil { | ||||
| @@ -444,7 +444,7 @@ func reqTeamMembership() func(ctx *context.APIContext) { | ||||
| // reqOrgMembership user should be an organization member, or a site admin | ||||
| func reqOrgMembership() func(ctx *context.APIContext) { | ||||
| 	return func(ctx *context.APIContext) { | ||||
| 		if ctx.Context.IsUserSiteAdmin() { | ||||
| 		if ctx.IsUserSiteAdmin() { | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| @@ -512,7 +512,7 @@ func orgAssignment(args ...bool) func(ctx *context.APIContext) { | ||||
| 				if organization.IsErrOrgNotExist(err) { | ||||
| 					redirectUserID, err := user_model.LookupUserRedirect(ctx.Params(":org")) | ||||
| 					if err == nil { | ||||
| 						context.RedirectToUser(ctx.Context, ctx.Params(":org"), redirectUserID) | ||||
| 						context.RedirectToUser(ctx.Base, ctx.Params(":org"), redirectUserID) | ||||
| 					} else if user_model.IsErrUserRedirectNotExist(err) { | ||||
| 						ctx.NotFound("GetOrgByName", err) | ||||
| 					} else { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user