Files
Atay-Makhzan/modules/context/org.go
T

266 lines
6.8 KiB
Go
Raw Normal View History

2014-08-14 14:12:21 +08:00
// Copyright 2014 The Gogs Authors. All rights reserved.
2020-01-24 19:00:29 +00:00
// Copyright 2020 The Gitea Authors.
// SPDX-License-Identifier: MIT
2014-08-14 14:12:21 +08:00
2016-03-11 11:56:52 -05:00
package context
2014-08-14 14:12:21 +08:00
import (
2016-01-31 13:28:42 +00:00
"strings"
"code.gitea.io/gitea/models/organization"
2021-11-28 19:58:28 +08:00
"code.gitea.io/gitea/models/perm"
2023-01-20 19:42:33 +08:00
"code.gitea.io/gitea/models/unit"
user_model "code.gitea.io/gitea/models/user"
"code.gitea.io/gitea/modules/setting"
"code.gitea.io/gitea/modules/structs"
2014-08-14 14:12:21 +08:00
)
2016-11-25 14:51:01 +08:00
// Organization contains organization context
2016-03-13 17:37:44 -04:00
type Organization struct {
IsOwner bool
IsMember bool
IsTeamMember bool // Is member of team.
IsTeamAdmin bool // In owner team or team that has admin permission level.
Organization *organization.Organization
OrgLink string
CanCreateOrgRepo bool
PublicMemberOnly bool // Only display public members
2016-03-13 17:37:44 -04:00
Team *organization.Team
Teams []*organization.Team
2016-03-13 17:37:44 -04:00
}
2023-01-20 19:42:33 +08:00
func (org *Organization) CanWriteUnit(ctx *Context, unitType unit.Type) bool {
return org.Organization.UnitPermission(ctx, ctx.Doer, unitType) >= perm.AccessModeWrite
2023-01-20 19:42:33 +08:00
}
func (org *Organization) CanReadUnit(ctx *Context, unitType unit.Type) bool {
return org.Organization.UnitPermission(ctx, ctx.Doer, unitType) >= perm.AccessModeRead
}
2023-01-20 19:42:33 +08:00
func GetOrganizationByParams(ctx *Context) {
orgName := ctx.Params(":org")
var err error
2023-01-20 19:42:33 +08:00
ctx.Org.Organization, err = organization.GetOrgByName(ctx, orgName)
if err != nil {
if organization.IsErrOrgNotExist(err) {
redirectUserID, err := user_model.LookupUserRedirect(ctx, orgName)
if err == nil {
RedirectToUser(ctx.Base, orgName, redirectUserID)
} else if user_model.IsErrUserRedirectNotExist(err) {
ctx.NotFound("GetUserByName", err)
} else {
ctx.ServerError("LookupUserRedirect", err)
}
} else {
ctx.ServerError("GetUserByName", err)
}
return
}
2023-01-20 19:42:33 +08:00
}
2016-11-25 14:51:01 +08:00
// HandleOrgAssignment handles organization assignment
func HandleOrgAssignment(ctx *Context, args ...bool) {
var (
2016-01-31 13:28:42 +00:00
requireMember bool
requireOwner bool
requireTeamMember bool
requireTeamAdmin bool
)
if len(args) >= 1 {
requireMember = args[0]
}
if len(args) >= 2 {
requireOwner = args[1]
}
if len(args) >= 3 {
2016-01-31 13:28:42 +00:00
requireTeamMember = args[2]
}
if len(args) >= 4 {
requireTeamAdmin = args[3]
}
2014-08-14 14:12:21 +08:00
var err error
if ctx.ContextUser == nil {
// if Organization is not defined, get it from params
if ctx.Org.Organization == nil {
GetOrganizationByParams(ctx)
if ctx.Written() {
return
}
2014-08-14 14:12:21 +08:00
}
} else if ctx.ContextUser.IsOrganization() {
if ctx.Org == nil {
ctx.Org = &Organization{}
}
ctx.Org.Organization = (*organization.Organization)(ctx.ContextUser)
} else {
// ContextUser is an individual User
return
}
org := ctx.Org.Organization
// Handle Visibility
if org.Visibility != structs.VisibleTypePublic && !ctx.IsSigned {
// We must be signed in to see limited or private organizations
ctx.NotFound("OrgAssignment", err)
return
}
if org.Visibility == structs.VisibleTypePrivate {
requireMember = true
} else if ctx.IsSigned && ctx.Doer.IsRestricted {
requireMember = true
}
ctx.ContextUser = org.AsUser()
ctx.Data["Org"] = org
2014-08-14 14:12:21 +08:00
// Admin has super access.
2022-03-22 08:03:22 +01:00
if ctx.IsSigned && ctx.Doer.IsAdmin {
ctx.Org.IsOwner = true
ctx.Org.IsMember = true
2016-01-31 13:28:42 +00:00
ctx.Org.IsTeamMember = true
ctx.Org.IsTeamAdmin = true
ctx.Org.CanCreateOrgRepo = true
} else if ctx.IsSigned {
2022-03-22 08:03:22 +01:00
ctx.Org.IsOwner, err = org.IsOwnedBy(ctx.Doer.ID)
if err != nil {
2018-01-10 22:34:17 +01:00
ctx.ServerError("IsOwnedBy", err)
return
}
if ctx.Org.IsOwner {
ctx.Org.IsMember = true
2016-01-31 13:28:42 +00:00
ctx.Org.IsTeamMember = true
ctx.Org.IsTeamAdmin = true
ctx.Org.CanCreateOrgRepo = true
} else {
2022-03-22 08:03:22 +01:00
ctx.Org.IsMember, err = org.IsOrgMember(ctx.Doer.ID)
if err != nil {
2018-01-10 22:34:17 +01:00
ctx.ServerError("IsOrgMember", err)
return
2014-08-14 14:12:21 +08:00
}
2022-03-22 08:03:22 +01:00
ctx.Org.CanCreateOrgRepo, err = org.CanCreateOrgRepo(ctx.Doer.ID)
if err != nil {
ctx.ServerError("CanCreateOrgRepo", err)
return
}
2014-08-14 14:12:21 +08:00
}
} else {
// Fake data.
ctx.Data["SignedUser"] = &user_model.User{}
}
if (requireMember && !ctx.Org.IsMember) ||
(requireOwner && !ctx.Org.IsOwner) {
2018-01-10 22:34:17 +01:00
ctx.NotFound("OrgAssignment", err)
return
}
ctx.Data["IsOrganizationOwner"] = ctx.Org.IsOwner
ctx.Data["IsOrganizationMember"] = ctx.Org.IsMember
ctx.Data["IsPackageEnabled"] = setting.Packages.Enabled
2022-10-11 02:12:03 +03:00
ctx.Data["IsRepoIndexerEnabled"] = setting.Indexer.RepoIndexerEnabled
ctx.Data["IsPublicMember"] = func(uid int64) bool {
is, _ := organization.IsPublicMembership(ctx.Org.Organization.ID, uid)
return is
}
ctx.Data["CanCreateOrgRepo"] = ctx.Org.CanCreateOrgRepo
ctx.Org.OrgLink = org.AsUser().OrganisationLink()
ctx.Data["OrgLink"] = ctx.Org.OrgLink
// Member
ctx.Org.PublicMemberOnly = ctx.Doer == nil || !ctx.Org.IsMember && !ctx.Doer.IsAdmin
opts := &organization.FindOrgMembersOpts{
OrgID: org.ID,
PublicOnly: ctx.Org.PublicMemberOnly,
}
ctx.Data["NumMembers"], err = organization.CountOrgMembers(opts)
if err != nil {
ctx.ServerError("CountOrgMembers", err)
return
}
// Team.
2016-01-31 13:28:42 +00:00
if ctx.Org.IsMember {
shouldSeeAllTeams := false
if ctx.Org.IsOwner {
shouldSeeAllTeams = true
} else {
2022-03-22 08:03:22 +01:00
teams, err := org.GetUserTeams(ctx.Doer.ID)
if err != nil {
ctx.ServerError("GetUserTeams", err)
return
}
for _, team := range teams {
if team.IncludesAllRepositories && team.AccessMode >= perm.AccessModeAdmin {
shouldSeeAllTeams = true
break
}
}
}
if shouldSeeAllTeams {
ctx.Org.Teams, err = org.LoadTeams()
if err != nil {
2021-08-12 14:43:08 +02:00
ctx.ServerError("LoadTeams", err)
return
}
} else {
2022-03-22 08:03:22 +01:00
ctx.Org.Teams, err = org.GetUserTeams(ctx.Doer.ID)
if err != nil {
2018-01-10 22:34:17 +01:00
ctx.ServerError("GetUserTeams", err)
return
}
2016-01-31 13:28:42 +00:00
}
ctx.Data["NumTeams"] = len(ctx.Org.Teams)
2016-01-31 13:28:42 +00:00
}
teamName := ctx.Params(":team")
if len(teamName) > 0 {
2016-01-31 13:28:42 +00:00
teamExists := false
for _, team := range ctx.Org.Teams {
2016-02-04 13:03:34 -05:00
if team.LowerName == strings.ToLower(teamName) {
2016-01-31 13:28:42 +00:00
teamExists = true
ctx.Org.Team = team
ctx.Org.IsTeamMember = true
ctx.Data["Team"] = ctx.Org.Team
break
}
2016-01-31 13:28:42 +00:00
}
if !teamExists {
2018-01-10 22:34:17 +01:00
ctx.NotFound("OrgAssignment", err)
2016-01-31 13:28:42 +00:00
return
}
ctx.Data["IsTeamMember"] = ctx.Org.IsTeamMember
if requireTeamMember && !ctx.Org.IsTeamMember {
2018-01-10 22:34:17 +01:00
ctx.NotFound("OrgAssignment", err)
return
}
2016-01-31 13:28:42 +00:00
ctx.Org.IsTeamAdmin = ctx.Org.Team.IsOwnerTeam() || ctx.Org.Team.AccessMode >= perm.AccessModeAdmin
ctx.Data["IsTeamAdmin"] = ctx.Org.IsTeamAdmin
if requireTeamAdmin && !ctx.Org.IsTeamAdmin {
2018-01-10 22:34:17 +01:00
ctx.NotFound("OrgAssignment", err)
2016-01-31 13:28:42 +00:00
return
}
}
ctx.Data["ContextUser"] = ctx.ContextUser
ctx.Data["CanReadProjects"] = ctx.Org.CanReadUnit(ctx, unit.TypeProjects)
ctx.Data["CanReadPackages"] = ctx.Org.CanReadUnit(ctx, unit.TypePackages)
ctx.Data["CanReadCode"] = ctx.Org.CanReadUnit(ctx, unit.TypeCode)
}
// OrgAssignment returns a middleware to handle organization assignment
2021-01-26 23:36:53 +08:00
func OrgAssignment(args ...bool) func(ctx *Context) {
return func(ctx *Context) {
HandleOrgAssignment(ctx, args...)
2014-08-14 14:12:21 +08:00
}
}