mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 21:28:11 +09:00 
			
		
		
		
	Restrict permission check on repositories and fix some problems (#5314)
* fix units permission problems * fix some bugs and merge LoadUnits to repoAssignment * refactor permission struct and add some copyright heads * remove unused codes * fix routes units check * improve permission check * add unit tests for permission * fix typo * fix tests * fix some routes * fix api permission check * improve permission check * fix some permission check * fix tests * fix tests * improve some permission check * fix some permission check * refactor AccessLevel * fix bug * fix tests * fix tests * fix tests * fix AccessLevel * rename CanAccess * fix tests * fix comment * fix bug * add missing unit for test repos * fix bug * rename some functions * fix routes check
This commit is contained in:
		| @@ -497,12 +497,12 @@ func authenticate(ctx *context.Context, repository *models.Repository, authoriza | ||||
| 		accessMode = models.AccessModeWrite | ||||
| 	} | ||||
|  | ||||
| 	if !repository.IsPrivate && !requireWrite { | ||||
| 		return true | ||||
| 	perm, err := models.GetUserRepoPermission(repository, ctx.User) | ||||
| 	if err != nil { | ||||
| 		return false | ||||
| 	} | ||||
| 	if ctx.IsSigned { | ||||
| 		accessCheck, _ := models.HasAccess(ctx.User.ID, repository, accessMode) | ||||
| 		return accessCheck | ||||
| 		return perm.CanAccess(accessMode, models.UnitTypeCode) | ||||
| 	} | ||||
|  | ||||
| 	user, repo, opStr, err := parseToken(authorization) | ||||
| @@ -511,8 +511,11 @@ func authenticate(ctx *context.Context, repository *models.Repository, authoriza | ||||
| 	} | ||||
| 	ctx.User = user | ||||
| 	if opStr == "basic" { | ||||
| 		accessCheck, _ := models.HasAccess(ctx.User.ID, repository, accessMode) | ||||
| 		return accessCheck | ||||
| 		perm, err = models.GetUserRepoPermission(repository, ctx.User) | ||||
| 		if err != nil { | ||||
| 			return false | ||||
| 		} | ||||
| 		return perm.CanAccess(accessMode, models.UnitTypeCode) | ||||
| 	} | ||||
| 	if repository.ID == repo.ID { | ||||
| 		if requireWrite && opStr != "upload" { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user