|
|
@ -67,9 +67,8 @@ func HasAccess(u *User, repo *Repository, testMode AccessMode) (bool, error) { |
|
|
|
return hasAccess(x, u, repo, testMode) |
|
|
|
return hasAccess(x, u, repo, testMode) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// GetAccessibleRepositories finds all repositories where a user has access to,
|
|
|
|
// GetRepositoryAccesses finds all repositories with their access mode where a user has access but does not own.
|
|
|
|
// besides he/she owns.
|
|
|
|
func (u *User) GetRepositoryAccesses() (map[*Repository]AccessMode, error) { |
|
|
|
func (u *User) GetAccessibleRepositories() (map[*Repository]AccessMode, error) { |
|
|
|
|
|
|
|
accesses := make([]*Access, 0, 10) |
|
|
|
accesses := make([]*Access, 0, 10) |
|
|
|
if err := x.Find(&accesses, &Access{UserID: u.Id}); err != nil { |
|
|
|
if err := x.Find(&accesses, &Access{UserID: u.Id}); err != nil { |
|
|
|
return nil, err |
|
|
|
return nil, err |
|
|
@ -80,7 +79,7 @@ func (u *User) GetAccessibleRepositories() (map[*Repository]AccessMode, error) { |
|
|
|
repo, err := GetRepositoryByID(access.RepoID) |
|
|
|
repo, err := GetRepositoryByID(access.RepoID) |
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
if IsErrRepoNotExist(err) { |
|
|
|
if IsErrRepoNotExist(err) { |
|
|
|
log.Error(4, "%v", err) |
|
|
|
log.Error(4, "GetRepositoryByID: %v", err) |
|
|
|
continue |
|
|
|
continue |
|
|
|
} |
|
|
|
} |
|
|
|
return nil, err |
|
|
|
return nil, err |
|
|
@ -92,11 +91,24 @@ func (u *User) GetAccessibleRepositories() (map[*Repository]AccessMode, error) { |
|
|
|
} |
|
|
|
} |
|
|
|
repos[repo] = access.Mode |
|
|
|
repos[repo] = access.Mode |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// FIXME: should we generate an ordered list here? Random looks weird.
|
|
|
|
|
|
|
|
return repos, nil |
|
|
|
return repos, nil |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// GetAccessibleRepositories finds all repositories where a user has access but does not own.
|
|
|
|
|
|
|
|
func (u *User) GetAccessibleRepositories() ([]*Repository, error) { |
|
|
|
|
|
|
|
accesses := make([]*Access, 0, 10) |
|
|
|
|
|
|
|
if err := x.Find(&accesses, &Access{UserID: u.Id}); err != nil { |
|
|
|
|
|
|
|
return nil, err |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
repoIDs := make([]int64, 0, len(accesses)) |
|
|
|
|
|
|
|
for _, access := range accesses { |
|
|
|
|
|
|
|
repoIDs = append(repoIDs, access.RepoID) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
repos := make([]*Repository, 0, len(repoIDs)) |
|
|
|
|
|
|
|
return repos, x.Where("owner_id != ?", u.Id).In("id", repoIDs).Desc("updated").Find(&repos) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func maxAccessMode(modes ...AccessMode) AccessMode { |
|
|
|
func maxAccessMode(modes ...AccessMode) AccessMode { |
|
|
|
max := ACCESS_MODE_NONE |
|
|
|
max := ACCESS_MODE_NONE |
|
|
|
for _, mode := range modes { |
|
|
|
for _, mode := range modes { |
|
|
|