Skip to content

Commit 773addf

Browse files
inxoniclafriks
authored andcommitted
Backported #5383 on v1.6: API: '/orgs/:org/repos': return private repos with read access (#5310) (#3829) (#5393)
Signed-off-by: Daniel Balko <[email protected]>
1 parent 0da8bc9 commit 773addf

File tree

2 files changed

+46
-19
lines changed

2 files changed

+46
-19
lines changed

integrations/api_repo_test.go

+37-12
Original file line numberDiff line numberDiff line change
@@ -212,21 +212,46 @@ func TestAPIViewRepo(t *testing.T) {
212212
func TestAPIOrgRepos(t *testing.T) {
213213
prepareTestEnv(t)
214214
user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
215+
user2 := models.AssertExistsAndLoadBean(t, &models.User{ID: 1}).(*models.User)
216+
user3 := models.AssertExistsAndLoadBean(t, &models.User{ID: 5}).(*models.User)
215217
// User3 is an Org. Check their repos.
216218
sourceOrg := models.AssertExistsAndLoadBean(t, &models.User{ID: 3}).(*models.User)
217-
// Login as User2.
218-
session := loginUser(t, user.Name)
219-
token := getTokenForLoggedInUser(t, session)
220-
req := NewRequestf(t, "GET", "/api/v1/orgs/%s/repos?token="+token, sourceOrg.Name)
221-
resp := session.MakeRequest(t, req, http.StatusOK)
222219

223-
var apiRepos []*api.Repository
224-
DecodeJSON(t, resp, &apiRepos)
225-
expectedLen := models.GetCount(t, models.Repository{OwnerID: sourceOrg.ID},
226-
models.Cond("is_private = ?", false))
227-
assert.Len(t, apiRepos, expectedLen)
228-
for _, repo := range apiRepos {
229-
assert.False(t, repo.Private)
220+
expectedResults := map[*models.User]struct {
221+
count int
222+
includesPrivate bool
223+
}{
224+
nil: {count: 1},
225+
user: {count: 2, includesPrivate: true},
226+
user2: {count: 3, includesPrivate: true},
227+
user3: {count: 1},
228+
}
229+
230+
for userToLogin, expected := range expectedResults {
231+
var session *TestSession
232+
var testName string
233+
var token string
234+
if userToLogin != nil && userToLogin.ID > 0 {
235+
testName = fmt.Sprintf("LoggedUser%d", userToLogin.ID)
236+
session = loginUser(t, userToLogin.Name)
237+
token = getTokenForLoggedInUser(t, session)
238+
} else {
239+
testName = "AnonymousUser"
240+
session = emptyTestSession(t)
241+
}
242+
t.Run(testName, func(t *testing.T) {
243+
req := NewRequestf(t, "GET", "/api/v1/orgs/%s/repos?token="+token, sourceOrg.Name)
244+
resp := session.MakeRequest(t, req, http.StatusOK)
245+
246+
var apiRepos []*api.Repository
247+
DecodeJSON(t, resp, &apiRepos)
248+
assert.Len(t, apiRepos, expected.count)
249+
for _, repo := range apiRepos {
250+
if !expected.includesPrivate {
251+
assert.False(t, repo.Private)
252+
}
253+
}
254+
})
230255
}
231256
}
232257

routers/api/v1/user/repo.go

+9-7
Original file line numberDiff line numberDiff line change
@@ -11,14 +11,13 @@ import (
1111
)
1212

1313
// listUserRepos - List the repositories owned by the given user.
14-
func listUserRepos(ctx *context.APIContext, u *models.User) {
15-
showPrivateRepos := ctx.IsSigned && (ctx.User.ID == u.ID || ctx.User.IsAdmin)
16-
repos, err := models.GetUserRepositories(u.ID, showPrivateRepos, 1, u.NumRepos, "")
14+
func listUserRepos(ctx *context.APIContext, u *models.User, private bool) {
15+
repos, err := models.GetUserRepositories(u.ID, private, 1, u.NumRepos, "")
1716
if err != nil {
1817
ctx.Error(500, "GetUserRepositories", err)
1918
return
2019
}
21-
apiRepos := make([]*api.Repository, len(repos))
20+
apiRepos := make([]*api.Repository, 0, len(repos))
2221
var ctxUserID int64
2322
if ctx.User != nil {
2423
ctxUserID = ctx.User.ID
@@ -29,7 +28,9 @@ func listUserRepos(ctx *context.APIContext, u *models.User) {
2928
ctx.Error(500, "AccessLevel", err)
3029
return
3130
}
32-
apiRepos[i] = repos[i].APIFormat(access)
31+
if ctx.IsSigned && ctx.User.IsAdmin || access >= models.AccessModeRead {
32+
apiRepos = append(apiRepos, repos[i].APIFormat(access))
33+
}
3334
}
3435
ctx.JSON(200, &apiRepos)
3536
}
@@ -54,7 +55,8 @@ func ListUserRepos(ctx *context.APIContext) {
5455
if ctx.Written() {
5556
return
5657
}
57-
listUserRepos(ctx, user)
58+
private := ctx.IsSigned && (ctx.User.ID == user.ID || ctx.User.IsAdmin)
59+
listUserRepos(ctx, user, private)
5860
}
5961

6062
// ListMyRepos - list the repositories you own or have access to.
@@ -106,5 +108,5 @@ func ListOrgRepos(ctx *context.APIContext) {
106108
// responses:
107109
// "200":
108110
// "$ref": "#/responses/RepositoryList"
109-
listUserRepos(ctx, ctx.Org.Organization)
111+
listUserRepos(ctx, ctx.Org.Organization, ctx.IsSigned)
110112
}

0 commit comments

Comments
 (0)