diff options
author | a1012112796 <1012112796@qq.com> | 2020-11-29 20:50:58 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-29 14:50:58 +0200 |
commit | 25421f08c0448d8695ea7546038db18579a82541 (patch) | |
tree | 719b13a9f6295ba4c5e3bb87cd4aae6d3339a4a3 /models | |
parent | bdb491e76441a323ecd02c4650e2d2bf6a15d495 (diff) | |
download | gitea-25421f08c0448d8695ea7546038db18579a82541.tar.gz gitea-25421f08c0448d8695ea7546038db18579a82541.zip |
ui: show 'owner' tag for real owner (#13689) (#13743)
* ui: show 'owner' tag for real owner
Signed-off-by: a1012112796 <1012112796@qq.com>
* Update custom/conf/app.example.ini
* simplify logic
fix logic
fix a small bug about original author
* remove system manager tag
Co-authored-by: techknowlogick <techknowlogick@gitea.io>
Co-authored-by: Lauris BH <lauris@nix.lv>
Diffstat (limited to 'models')
-rw-r--r-- | models/repo_permission.go | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/models/repo_permission.go b/models/repo_permission.go index 7768bb6257..138613b2e9 100644 --- a/models/repo_permission.go +++ b/models/repo_permission.go @@ -271,6 +271,27 @@ func getUserRepoPermission(e Engine, repo *Repository, user *User) (perm Permiss return } +// IsUserRealRepoAdmin check if this user is real repo admin +func IsUserRealRepoAdmin(repo *Repository, user *User) (bool, error) { + if repo.OwnerID == user.ID { + return true, nil + } + + sess := x.NewSession() + defer sess.Close() + + if err := repo.getOwner(sess); err != nil { + return false, err + } + + accessMode, err := accessLevel(sess, user, repo) + if err != nil { + return false, err + } + + return accessMode >= AccessModeAdmin, nil +} + // IsUserRepoAdmin return true if user has admin right of a repo func IsUserRepoAdmin(repo *Repository, user *User) (bool, error) { return isUserRepoAdmin(x, repo, user) |