summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorUnknwon <joe2010xtmf@163.com>2014-08-16 16:58:32 +0800
committerUnknwon <joe2010xtmf@163.com>2014-08-16 16:58:32 +0800
commita60edbe88c62f6f5b8c1d74fdd295a2492ef30e9 (patch)
treebef3adb8e81e5ceebf4f25fbfb609fccd086b029
parentbba707de36d9bfbdb3001e3e89fac0c072aa14e9 (diff)
downloadgitea-a60edbe88c62f6f5b8c1d74fdd295a2492ef30e9.tar.gz
gitea-a60edbe88c62f6f5b8c1d74fdd295a2492ef30e9.zip
Add/remove member need add/remove access to repositories as well
-rw-r--r--models/org.go118
-rw-r--r--models/repo.go2
-rw-r--r--routers/org/teams.go4
3 files changed, 113 insertions, 11 deletions
diff --git a/models/org.go b/models/org.go
index b810422280..cd4163bab3 100644
--- a/models/org.go
+++ b/models/org.go
@@ -7,8 +7,11 @@ package models
import (
"errors"
"os"
+ "path"
"strings"
+ "github.com/Unknwon/com"
+
"github.com/gogits/gogs/modules/base"
)
@@ -342,10 +345,11 @@ type Team struct {
Name string
Description string
Authorize AuthorizeType
- RepoIds string `xorm:"TEXT"`
- NumMembers int
+ RepoIds string `xorm:"TEXT"`
+ Repos []*Repository `xorm:"-"`
+ Members []*User `xorm:"-"`
NumRepos int
- Members []*User `xorm:"-"`
+ NumMembers int
}
// IsTeamMember returns true if given user is a member of team.
@@ -353,12 +357,40 @@ func (t *Team) IsMember(uid int64) bool {
return IsTeamMember(t.OrgId, t.Id, uid)
}
-// GetMembers returns all members in given team of organization.
+// GetRepositories returns all repositories in team of organization.
+func (t *Team) GetRepositories() error {
+ idStrs := strings.Split(t.RepoIds, "|")
+ t.Repos = make([]*Repository, 0, len(idStrs))
+ for _, str := range idStrs {
+ id := com.StrTo(str).MustInt64()
+ if id == 0 {
+ continue
+ }
+ repo, err := GetRepositoryById(id)
+ if err != nil {
+ return err
+ }
+ t.Repos = append(t.Repos, repo)
+ }
+ return nil
+}
+
+// GetMembers returns all members in team of organization.
func (t *Team) GetMembers() (err error) {
t.Members, err = GetTeamMembers(t.OrgId, t.Id)
return err
}
+// AddMember adds new member to team of organization.
+func (t *Team) AddMember(uid int64) error {
+ return AddTeamMember(t.OrgId, t.Id, uid)
+}
+
+// RemoveMember removes member from team of organization.
+func (t *Team) RemoveMember(uid int64) error {
+ return RemoveTeamMember(t.OrgId, t.Id, uid)
+}
+
// NewTeam creates a record of new team.
// It's caller's responsibility to assign organization ID.
func NewTeam(t *Team) error {
@@ -483,13 +515,29 @@ func AddTeamMember(orgId, teamId, uid int64) error {
return nil
}
- // We can use raw SQL here but we also want to vertify there is a such team.
+ // Get team and its repositories.
t, err := GetTeamById(teamId)
if err != nil {
return err
}
t.NumMembers++
+ if err = t.GetRepositories(); err != nil {
+ return err
+ }
+
+ // Get organization.
+ org, err := GetUserById(orgId)
+ if err != nil {
+ return err
+ }
+
+ // Get user.
+ u, err := GetUserById(uid)
+ if err != nil {
+ return err
+ }
+
sess := x.NewSession()
defer sess.Close()
if err = sess.Begin(); err != nil {
@@ -502,6 +550,15 @@ func AddTeamMember(orgId, teamId, uid int64) error {
TeamId: teamId,
}
+ mode := READABLE
+ if t.Authorize > ORG_READABLE {
+ mode = WRITABLE
+ }
+ access := &Access{
+ UserName: u.LowerName,
+ Mode: mode,
+ }
+
if _, err = sess.Insert(tu); err != nil {
sess.Rollback()
return err
@@ -510,15 +567,47 @@ func AddTeamMember(orgId, teamId, uid int64) error {
return err
}
+ // Give access to team repositories.
+ for _, repo := range t.Repos {
+ access.RepoName = path.Join(org.LowerName, repo.LowerName)
+ if _, err = sess.Insert(access); err != nil {
+ sess.Rollback()
+ return err
+ }
+ }
+
return sess.Commit()
}
-// RemoveMember removes member from given team of given organization.
-func RemoveMember(orgId, teamId, uid int64) error {
+// RemoveTeamMember removes member from given team of given organization.
+func RemoveTeamMember(orgId, teamId, uid int64) error {
if !IsTeamMember(orgId, teamId, uid) {
return nil
}
+ // Get team and its repositories.
+ t, err := GetTeamById(teamId)
+ if err != nil {
+ return err
+ }
+ t.NumMembers--
+
+ if err = t.GetRepositories(); err != nil {
+ return err
+ }
+
+ // Get organization.
+ org, err := GetUserById(orgId)
+ if err != nil {
+ return err
+ }
+
+ // Get user.
+ u, err := GetUserById(uid)
+ if err != nil {
+ return err
+ }
+
sess := x.NewSession()
defer sess.Close()
if err := sess.Begin(); err != nil {
@@ -531,13 +620,26 @@ func RemoveMember(orgId, teamId, uid int64) error {
TeamId: teamId,
}
+ access := &Access{
+ UserName: u.LowerName,
+ }
+
if _, err := sess.Delete(tu); err != nil {
sess.Rollback()
return err
- } else if _, err = sess.Exec("UPDATE `team` SET num_members = num_members - 1 WHERE id = ?", teamId); err != nil {
+ } else if _, err = sess.Id(t.Id).AllCols().Update(t); err != nil {
sess.Rollback()
return err
}
+ // Delete access to team repositories.
+ for _, repo := range t.Repos {
+ access.RepoName = path.Join(org.LowerName, repo.LowerName)
+ if _, err = sess.Delete(access); err != nil {
+ sess.Rollback()
+ return err
+ }
+ }
+
return sess.Commit()
}
diff --git a/models/repo.go b/models/repo.go
index bec3cb212f..218887cca2 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -502,7 +502,7 @@ func CreateRepository(u *User, name, desc, lang, license string, private, mirror
}
access := &Access{
UserName: u.LowerName,
- RepoName: strings.ToLower(path.Join(u.Name, repo.Name)),
+ RepoName: path.Join(u.LowerName, repo.LowerName),
Mode: mode,
}
// Give access to all members in owner team.
diff --git a/routers/org/teams.go b/routers/org/teams.go
index bc12a97160..d082576cc8 100644
--- a/routers/org/teams.go
+++ b/routers/org/teams.go
@@ -41,9 +41,9 @@ func TeamsAction(ctx *middleware.Context) {
var err error
switch ctx.Params(":action") {
case "join":
- err = models.AddTeamMember(ctx.Org.Organization.Id, ctx.Org.Team.Id, ctx.User.Id)
+ err = ctx.Org.Team.AddMember(ctx.User.Id)
case "leave":
- err = models.RemoveMember(ctx.Org.Organization.Id, ctx.Org.Team.Id, ctx.User.Id)
+ err = ctx.Org.Team.RemoveMember(ctx.User.Id)
}
if err != nil {