mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 21:28:11 +09:00 
			
		
		
		
	Support public code/issue access for private repositories (#33127)
Close #8649, close #639 (will add "anonymous access" in following PRs)
This commit is contained in:
		| @@ -9,24 +9,13 @@ import ( | ||||
| 	auth_model "code.gitea.io/gitea/models/auth" | ||||
| 	repo_model "code.gitea.io/gitea/models/repo" | ||||
| 	"code.gitea.io/gitea/models/unit" | ||||
| 	"code.gitea.io/gitea/modules/log" | ||||
| ) | ||||
|  | ||||
| // RequireRepoAdmin returns a middleware for requiring repository admin permission | ||||
| func RequireRepoAdmin() func(ctx *Context) { | ||||
| 	return func(ctx *Context) { | ||||
| 		if !ctx.IsSigned || !ctx.Repo.IsAdmin() { | ||||
| 			ctx.NotFound(ctx.Req.URL.RequestURI(), nil) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // RequireRepoWriter returns a middleware for requiring repository write to the specify unitType | ||||
| func RequireRepoWriter(unitType unit.Type) func(ctx *Context) { | ||||
| 	return func(ctx *Context) { | ||||
| 		if !ctx.Repo.CanWrite(unitType) { | ||||
| 			ctx.NotFound(ctx.Req.URL.RequestURI(), nil) | ||||
| 			ctx.NotFound("RequireRepoAdmin denies the request", nil) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| @@ -42,75 +31,30 @@ func CanEnableEditor() func(ctx *Context) { | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // RequireRepoWriterOr returns a middleware for requiring repository write to one of the unit permission | ||||
| func RequireRepoWriterOr(unitTypes ...unit.Type) func(ctx *Context) { | ||||
| // RequireUnitWriter returns a middleware for requiring repository write to one of the unit permission | ||||
| func RequireUnitWriter(unitTypes ...unit.Type) func(ctx *Context) { | ||||
| 	return func(ctx *Context) { | ||||
| 		for _, unitType := range unitTypes { | ||||
| 			if ctx.Repo.CanWrite(unitType) { | ||||
| 				return | ||||
| 			} | ||||
| 		} | ||||
| 		ctx.NotFound(ctx.Req.URL.RequestURI(), nil) | ||||
| 		ctx.NotFound("RequireUnitWriter denies the request", nil) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // RequireRepoReader returns a middleware for requiring repository read to the specify unitType | ||||
| func RequireRepoReader(unitType unit.Type) func(ctx *Context) { | ||||
| 	return func(ctx *Context) { | ||||
| 		if !ctx.Repo.CanRead(unitType) { | ||||
| 			if unitType == unit.TypeCode && canWriteAsMaintainer(ctx) { | ||||
| 				return | ||||
| 			} | ||||
| 			if log.IsTrace() { | ||||
| 				if ctx.IsSigned { | ||||
| 					log.Trace("Permission Denied: User %-v cannot read %-v in Repo %-v\n"+ | ||||
| 						"User in Repo has Permissions: %-+v", | ||||
| 						ctx.Doer, | ||||
| 						unitType, | ||||
| 						ctx.Repo.Repository, | ||||
| 						ctx.Repo.Permission) | ||||
| 				} else { | ||||
| 					log.Trace("Permission Denied: Anonymous user cannot read %-v in Repo %-v\n"+ | ||||
| 						"Anonymous user in Repo has Permissions: %-+v", | ||||
| 						unitType, | ||||
| 						ctx.Repo.Repository, | ||||
| 						ctx.Repo.Permission) | ||||
| 				} | ||||
| 			} | ||||
| 			ctx.NotFound(ctx.Req.URL.RequestURI(), nil) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // RequireRepoReaderOr returns a middleware for requiring repository write to one of the unit permission | ||||
| func RequireRepoReaderOr(unitTypes ...unit.Type) func(ctx *Context) { | ||||
| // RequireUnitReader returns a middleware for requiring repository write to one of the unit permission | ||||
| func RequireUnitReader(unitTypes ...unit.Type) func(ctx *Context) { | ||||
| 	return func(ctx *Context) { | ||||
| 		for _, unitType := range unitTypes { | ||||
| 			if ctx.Repo.CanRead(unitType) { | ||||
| 				return | ||||
| 			} | ||||
| 		} | ||||
| 		if log.IsTrace() { | ||||
| 			var format string | ||||
| 			var args []any | ||||
| 			if ctx.IsSigned { | ||||
| 				format = "Permission Denied: User %-v cannot read [" | ||||
| 				args = append(args, ctx.Doer) | ||||
| 			} else { | ||||
| 				format = "Permission Denied: Anonymous user cannot read [" | ||||
| 			if unitType == unit.TypeCode && canWriteAsMaintainer(ctx) { | ||||
| 				return | ||||
| 			} | ||||
| 			for _, unit := range unitTypes { | ||||
| 				format += "%-v, " | ||||
| 				args = append(args, unit) | ||||
| 			} | ||||
|  | ||||
| 			format = format[:len(format)-2] + "] in Repo %-v\n" + | ||||
| 				"User in Repo has Permissions: %-+v" | ||||
| 			args = append(args, ctx.Repo.Repository, ctx.Repo.Permission) | ||||
| 			log.Trace(format, args...) | ||||
| 		} | ||||
| 		ctx.NotFound(ctx.Req.URL.RequestURI(), nil) | ||||
| 		ctx.NotFound("RequireUnitReader denies the request", nil) | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user