Przeglądaj źródła

#1032: legacy code can have duplicated IDs for same repository

Unknwon 10 lat temu
rodzic
commit
6b70a0c0d9
1 zmienionych plików z 4 dodań i 1 usunięć
  1. 4 1
      models/migrations/migrations.go

+ 4 - 1
models/migrations/migrations.go

@@ -341,12 +341,15 @@ func teamToTeamRepo(x *xorm.Engine) error {
 		orgID := com.StrTo(team["org_id"]).MustInt64()
 		teamID := com.StrTo(team["id"]).MustInt64()
 
+		// #1032: legacy code can have duplicated IDs for same repository.
+		mark := make(map[int64]bool)
 		for _, idStr := range strings.Split(string(team["repo_ids"]), "|") {
 			repoID := com.StrTo(strings.TrimPrefix(idStr, "$")).MustInt64()
-			if repoID == 0 {
+			if repoID == 0 || mark[repoID] {
 				continue
 			}
 
+			mark[repoID] = true
 			teamRepos = append(teamRepos, &TeamRepo{
 				OrgID:  orgID,
 				TeamID: teamID,