diff options
author | Unknown <joe2010xtmf@163.com> | 2014-07-04 22:43:39 -0400 |
---|---|---|
committer | Unknown <joe2010xtmf@163.com> | 2014-07-04 22:43:39 -0400 |
commit | fd5412ec47018a72c1f05aca487e10ea0a665e45 (patch) | |
tree | 3c36958f40764b3bcaa4247f7a578640e7c40751 | |
parent | baa255e8991edaa69c29794553dcb37ecbc6b78d (diff) | |
download | gitea-fd5412ec47018a72c1f05aca487e10ea0a665e45.tar.gz gitea-fd5412ec47018a72c1f05aca487e10ea0a665e45.zip |
Work on #274
-rw-r--r-- | models/org.go | 6 | ||||
-rw-r--r-- | models/repo.go | 51 |
2 files changed, 22 insertions, 35 deletions
diff --git a/models/org.go b/models/org.go index 2625ed428d..2efef534b4 100644 --- a/models/org.go +++ b/models/org.go @@ -6,6 +6,7 @@ package models import ( "errors" + "os" "strings" "github.com/gogits/gogs/modules/base" @@ -97,6 +98,11 @@ func CreateOrganization(org, owner *User) (*User, error) { return nil, err } + if err = os.MkdirAll(UserPath(org.Name), os.ModePerm); err != nil { + sess.Rollback() + return nil, err + } + // Create default owner team. t := &Team{ OrgId: org.Id, diff --git a/models/repo.go b/models/repo.go index f2df050577..54177bb6fb 100644 --- a/models/repo.go +++ b/models/repo.go @@ -626,46 +626,25 @@ func TransferOwnership(u *User, newOwner string, repo *Repository) (err error) { return err } - // Update accesses. - /*accesses := make([]Access, 0, 10) - if err = x.Find(&accesses, &Access{RepoName: u.LowerName + "/" + repo.LowerName}); err != nil { - return err - }*/ - sess := x.NewSession() defer sess.Close() if err = sess.Begin(); err != nil { return err } - access := &Access{ - RepoName: newUser.LowerName + "/" + repo.LowerName, - } - - sess.Where("repo_name = ?", u.LowerName+"/"+repo.LowerName) - _, err = sess.And("user_name = ?", u.LowerName).Update(&Access{UserName: newUser.LowerName}) - if err != nil { + if _, err = sess.Where("repo_name = ?", u.LowerName+"/"+repo.LowerName). + And("user_name = ?", u.LowerName).Update(&Access{UserName: newUser.LowerName}); err != nil { sess.Rollback() return err } - _, err = sess.Where("repo_name = ?", u.LowerName+"/"+repo.LowerName).Update(access) - if err != nil { + if _, err = sess.Where("repo_name = ?", u.LowerName+"/"+repo.LowerName).Update(&Access{ + RepoName: newUser.LowerName + "/" + repo.LowerName, + }); err != nil { sess.Rollback() return err } - /* - for i := range accesses { - accesses[i].RepoName = newUser.LowerName + "/" + repo.LowerName - if accesses[i].UserName == u.LowerName { - accesses[i].UserName = newUser.LowerName - } - if err = UpdateAccessWithSession(sess, &accesses[i]); err != nil { - return err - } - }*/ - // Update repository. repo.OwnerId = newUser.Id if _, err := sess.Id(repo.Id).Update(repo); err != nil { @@ -686,26 +665,28 @@ func TransferOwnership(u *User, newOwner string, repo *Repository) (err error) { return err } + // Change repository directory name. + if err = os.Rename(RepoPath(u.Name, repo.Name), RepoPath(newUser.Name, repo.Name)); err != nil { + sess.Rollback() + return err + } + + if err = sess.Commit(); err != nil { + return err + } + // Add watch of new owner to repository. if !IsWatching(newUser.Id, repo.Id) { if err = WatchRepo(newUser.Id, repo.Id, true); err != nil { - sess.Rollback() return err } } if err = TransferRepoAction(u, newUser, repo); err != nil { - sess.Rollback() return err } - // Change repository directory name. - if err = os.Rename(RepoPath(u.Name, repo.Name), RepoPath(newUser.Name, repo.Name)); err != nil { - sess.Rollback() - return err - } - - return sess.Commit() + return nil } // ChangeRepositoryName changes all corresponding setting from old repository name to new one. |