summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2019-10-24 10:52:17 +0800
committerGitHub <noreply@github.com>2019-10-24 10:52:17 +0800
commitbd7709a60200a760d872f8210dae9b527fc99d8f (patch)
tree241a710cf45f6530dcff1aa8cf1de56a571c6a2a
parentab791fe7bbcf7b57e1ba0e577172b6d6252847a7 (diff)
downloadgitea-bd7709a60200a760d872f8210dae9b527fc99d8f.tar.gz
gitea-bd7709a60200a760d872f8210dae9b527fc99d8f.zip
Hide some user information via API if user have no enough permission (#8655)
* Hide some user information via API if user have no enough permission * fix test
-rw-r--r--integrations/api_team_user_test.go1
-rw-r--r--routers/api/v1/convert/convert.go8
2 files changed, 4 insertions, 5 deletions
diff --git a/integrations/api_team_user_test.go b/integrations/api_team_user_test.go
index 70d52c1360..4df4dac016 100644
--- a/integrations/api_team_user_test.go
+++ b/integrations/api_team_user_test.go
@@ -29,7 +29,6 @@ func TestAPITeamUser(t *testing.T) {
var user2 *api.User
DecodeJSON(t, resp, &user2)
user2.Created = user2.Created.In(time.Local)
- user2.LastLogin = user2.LastLogin.In(time.Local)
user := models.AssertExistsAndLoadBean(t, &models.User{Name: "user2"}).(*models.User)
assert.Equal(t, convert.ToUser(user, true, false), user2)
diff --git a/routers/api/v1/convert/convert.go b/routers/api/v1/convert/convert.go
index 0262051390..07456f8dd6 100644
--- a/routers/api/v1/convert/convert.go
+++ b/routers/api/v1/convert/convert.go
@@ -237,12 +237,9 @@ func ToTeam(team *models.Team) *api.Team {
// ToUser convert models.User to api.User
func ToUser(user *models.User, signed, authed bool) *api.User {
result := &api.User{
- ID: user.ID,
UserName: user.Name,
AvatarURL: user.AvatarLink(),
FullName: markup.Sanitize(user.FullName),
- IsAdmin: user.IsAdmin,
- LastLogin: user.LastLoginUnix.AsTime(),
Created: user.CreatedUnix.AsTime(),
}
// hide primary email if API caller isn't user itself or an admin
@@ -250,8 +247,11 @@ func ToUser(user *models.User, signed, authed bool) *api.User {
result.Email = ""
} else if user.KeepEmailPrivate && !authed {
result.Email = user.GetEmail()
- } else {
+ } else { // only user himself and admin could visit these information
+ result.ID = user.ID
result.Email = user.Email
+ result.IsAdmin = user.IsAdmin
+ result.LastLogin = user.LastLoginUnix.AsTime()
}
return result
}