summaryrefslogtreecommitdiffstats
path: root/modules/context/package.go
diff options
context:
space:
mode:
authorKN4CK3R <admin@oldschoolhack.me>2022-05-19 17:56:45 +0200
committerGitHub <noreply@github.com>2022-05-19 17:56:45 +0200
commitce52514762b914a5467a48c89fe67535ecc1a801 (patch)
treecdf886e567c943839cdf19a80c71d6371644fa7a /modules/context/package.go
parent3e5ea9a9788b4c908a85b7ccc532e559ab8610a0 (diff)
downloadgitea-ce52514762b914a5467a48c89fe67535ecc1a801.tar.gz
gitea-ce52514762b914a5467a48c89fe67535ecc1a801.zip
Fix org package owner permissions (#19742)
Old code did not respect owner visibility and the organization access calculation was wrong if the user was not a member.
Diffstat (limited to 'modules/context/package.go')
-rw-r--r--modules/context/package.go34
1 files changed, 21 insertions, 13 deletions
diff --git a/modules/context/package.go b/modules/context/package.go
index cb352fb18a..4c52907dc5 100644
--- a/modules/context/package.go
+++ b/modules/context/package.go
@@ -12,6 +12,7 @@ import (
packages_model "code.gitea.io/gitea/models/packages"
"code.gitea.io/gitea/models/perm"
user_model "code.gitea.io/gitea/models/user"
+ "code.gitea.io/gitea/modules/structs"
)
// Package contains owner, access mode and optional the package descriptor
@@ -50,22 +51,29 @@ func packageAssignment(ctx *Context, errCb func(int, string, interface{})) {
Owner: ctx.ContextUser,
}
- if ctx.Doer != nil && ctx.Doer.ID == ctx.ContextUser.ID {
- ctx.Package.AccessMode = perm.AccessModeOwner
+ if ctx.Package.Owner.IsOrganization() {
+ // 1. Get user max authorize level for the org (may be none, if user is not member of the org)
+ if ctx.Doer != nil {
+ var err error
+ ctx.Package.AccessMode, err = organization.OrgFromUser(ctx.Package.Owner).GetOrgUserMaxAuthorizeLevel(ctx.Doer.ID)
+ if err != nil {
+ errCb(http.StatusInternalServerError, "GetOrgUserMaxAuthorizeLevel", err)
+ return
+ }
+ }
+ // 2. If authorize level is none, check if org is visible to user
+ if ctx.Package.AccessMode == perm.AccessModeNone && organization.HasOrgOrUserVisible(ctx, ctx.Package.Owner, ctx.Doer) {
+ ctx.Package.AccessMode = perm.AccessModeRead
+ }
} else {
- if ctx.Package.Owner.IsOrganization() {
- if organization.HasOrgOrUserVisible(ctx, ctx.Package.Owner, ctx.Doer) {
+ if ctx.Doer != nil && !ctx.Doer.IsGhost() {
+ // 1. Check if user is package owner
+ if ctx.Doer.ID == ctx.Package.Owner.ID {
+ ctx.Package.AccessMode = perm.AccessModeOwner
+ } else if ctx.Package.Owner.Visibility == structs.VisibleTypePublic || ctx.Package.Owner.Visibility == structs.VisibleTypeLimited { // 2. Check if package owner is public or limited
ctx.Package.AccessMode = perm.AccessModeRead
- if ctx.Doer != nil {
- var err error
- ctx.Package.AccessMode, err = organization.OrgFromUser(ctx.Package.Owner).GetOrgUserMaxAuthorizeLevel(ctx.Doer.ID)
- if err != nil {
- errCb(http.StatusInternalServerError, "GetOrgUserMaxAuthorizeLevel", err)
- return
- }
- }
}
- } else {
+ } else if ctx.Package.Owner.Visibility == structs.VisibleTypePublic { // 3. Check if package owner is public
ctx.Package.AccessMode = perm.AccessModeRead
}
}