Skip to content

Commit a98bf03

Browse files
6543lunny
andauthored
Convert User expose ID each time (#12855) (#12883)
* Convert User expose ID each time (#12855) * git blame tells me a lot of gitea things happen here around 2018, add header * move user code int its own file * expose user id * adopt things from APIFormat * fix test * CI.restart() * No Refactor * CI.restart() Co-authored-by: Lunny Xiao <[email protected]>
1 parent 65aef7b commit a98bf03

File tree

3 files changed

+15
-4
lines changed

3 files changed

+15
-4
lines changed

integrations/api_pull_review_test.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ func TestAPIPullReview(t *testing.T) {
4343
assert.EqualValues(t, 10, reviews[5].ID)
4444
assert.EqualValues(t, "REQUEST_CHANGES", reviews[5].State)
4545
assert.EqualValues(t, 1, reviews[5].CodeCommentsCount)
46-
assert.EqualValues(t, 0, reviews[5].Reviewer.ID) // ghost user
46+
assert.EqualValues(t, -1, reviews[5].Reviewer.ID) // ghost user
4747
assert.EqualValues(t, false, reviews[5].Stale)
4848
assert.EqualValues(t, true, reviews[5].Official)
4949

integrations/api_user_search_test.go

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,9 +5,12 @@
55
package integrations
66

77
import (
8+
"fmt"
89
"net/http"
910
"testing"
1011

12+
"code.gitea.io/gitea/models"
13+
"code.gitea.io/gitea/modules/setting"
1114
api "code.gitea.io/gitea/modules/structs"
1215

1316
"github.com/stretchr/testify/assert"
@@ -45,8 +48,14 @@ func TestAPIUserSearchNotLoggedIn(t *testing.T) {
4548
var results SearchResults
4649
DecodeJSON(t, resp, &results)
4750
assert.NotEmpty(t, results.Data)
51+
var modelUser *models.User
4852
for _, user := range results.Data {
4953
assert.Contains(t, user.UserName, query)
50-
assert.Empty(t, user.Email)
54+
modelUser = models.AssertExistsAndLoadBean(t, &models.User{ID: user.ID}).(*models.User)
55+
if modelUser.KeepEmailPrivate {
56+
assert.EqualValues(t, fmt.Sprintf("%s@%s", modelUser.LowerName, setting.Service.NoReplyAddress), user.Email)
57+
} else {
58+
assert.EqualValues(t, modelUser.Email, user.Email)
59+
}
5160
}
5261
}

modules/convert/convert.go

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
// Copyright 2015 The Gogs Authors. All rights reserved.
2+
// Copyright 2018 The Gitea Authors. All rights reserved.
23
// Use of this source code is governed by a MIT-style
34
// license that can be found in the LICENSE file.
45

@@ -335,9 +336,11 @@ func ToTeam(team *models.Team) *api.Team {
335336
// signed shall only be set if requester is logged in. authed shall only be set if user is site admin or user himself
336337
func ToUser(user *models.User, signed, authed bool) *api.User {
337338
result := &api.User{
339+
ID: user.ID,
338340
UserName: user.Name,
339-
AvatarURL: user.AvatarLink(),
340341
FullName: markup.Sanitize(user.FullName),
342+
Email: user.GetEmail(),
343+
AvatarURL: user.AvatarLink(),
341344
Created: user.CreatedUnix.AsTime(),
342345
}
343346
// hide primary email if API caller is anonymous or user keep email private
@@ -346,7 +349,6 @@ func ToUser(user *models.User, signed, authed bool) *api.User {
346349
}
347350
// only site admin will get these information and possibly user himself
348351
if authed {
349-
result.ID = user.ID
350352
result.IsAdmin = user.IsAdmin
351353
result.LastLogin = user.LastLoginUnix.AsTime()
352354
result.Language = user.Language

0 commit comments

Comments
 (0)