summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2021-12-30 13:03:40 +0800
committerGitHub <noreply@github.com>2021-12-30 13:03:40 +0800
commit626b10794fbc8b834883d96640767fa09b0a499d (patch)
tree3671902605ae1669f64a5480e4f663a2f1aa336f
parente0b41f8c374181be7387a1399813e849ec4590b9 (diff)
downloadgitea-626b10794fbc8b834883d96640767fa09b0a499d.tar.gz
gitea-626b10794fbc8b834883d96640767fa09b0a499d.zip
Fix performance regression when user has many organization (#18125)
-rw-r--r--models/repo.go30
1 files changed, 18 insertions, 12 deletions
diff --git a/models/repo.go b/models/repo.go
index 897ceeede9..1fc8bd207b 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -294,13 +294,27 @@ func CanUserForkRepo(user *user_model.User, repo *repo_model.Repository) (bool,
return false, nil
}
+// FindUserOrgForks returns the forked repositories for one user from a repository
+func FindUserOrgForks(repoID, userID int64) ([]*repo_model.Repository, error) {
+ var cond builder.Cond = builder.And(
+ builder.Eq{"fork_id": repoID},
+ builder.In("owner_id",
+ builder.Select("org_id").
+ From("org_user").
+ Where(builder.Eq{"uid": userID}),
+ ),
+ )
+
+ var repos []*repo_model.Repository
+ return repos, db.GetEngine(db.DefaultContext).Table("repository").Where(cond).Find(&repos)
+}
+
// GetForksByUserAndOrgs return forked repos of the user and owned orgs
func GetForksByUserAndOrgs(user *user_model.User, repo *repo_model.Repository) ([]*repo_model.Repository, error) {
var repoList []*repo_model.Repository
if user == nil {
return repoList, nil
}
- var forkedRepo *repo_model.Repository
forkedRepo, err := repo_model.GetUserFork(repo.ID, user.ID)
if err != nil {
return repoList, err
@@ -308,19 +322,11 @@ func GetForksByUserAndOrgs(user *user_model.User, repo *repo_model.Repository) (
if forkedRepo != nil {
repoList = append(repoList, forkedRepo)
}
- canCreateRepos, err := GetOrgsCanCreateRepoByUserID(user.ID)
+ orgForks, err := FindUserOrgForks(repo.ID, user.ID)
if err != nil {
- return repoList, err
- }
- for _, org := range canCreateRepos {
- forkedRepo, err := repo_model.GetUserFork(repo.ID, org.ID)
- if err != nil {
- return repoList, err
- }
- if forkedRepo != nil {
- repoList = append(repoList, forkedRepo)
- }
+ return nil, err
}
+ repoList = append(repoList, orgForks...)
return repoList, nil
}