summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
author6543 <6543@obermui.de>2019-12-29 15:24:50 +0100
committerLauris BH <lauris@nix.lv>2019-12-29 16:24:50 +0200
commitd59536c222857713d95846d77903282afe608f23 (patch)
treef75b7f5df55bb18a9b7d3f88f8effedd3b893e18
parentae9d342f5413031ed01eb74e7c7640ffa2cff13e (diff)
downloadgitea-d59536c222857713d95846d77903282afe608f23.tar.gz
gitea-d59536c222857713d95846d77903282afe608f23.zip
[BugFix] use default avatar for ghost user (fix 500 error) (#9536)
* remove since it is there for 3years * fix 500 error for ghost avatar * dont insert "-1" in any case to issue.poster_id * fix lint * Test: ghost avatar link * fix test * Revert "remove since it is there for 3years" This reverts commit fd9ad05159c84ba804b126d2a959963d82578b22. * Revert "dont insert "-1" in any case to issue.poster_id" This reverts commit 05469ab6d815a6cc6478a256018b9ed1a12749e0. Co-authored-by: zeripath <art27@cantab.net>
-rw-r--r--integrations/links_test.go1
-rw-r--r--routers/user/avatar.go20
2 files changed, 14 insertions, 7 deletions
diff --git a/integrations/links_test.go b/integrations/links_test.go
index 329e54528a..e69d9306ed 100644
--- a/integrations/links_test.go
+++ b/integrations/links_test.go
@@ -51,6 +51,7 @@ func TestRedirectsNoLogin(t *testing.T) {
"/user2/repo1/src/master": "/user2/repo1/src/branch/master",
"/user2/repo1/src/master/file.txt": "/user2/repo1/src/branch/master/file.txt",
"/user2/repo1/src/master/directory/file.txt": "/user2/repo1/src/branch/master/directory/file.txt",
+ "/user/avatar/Ghost/-1": "/img/avatar_default.png",
}
for link, redirectLink := range redirects {
req := NewRequest(t, "GET", link)
diff --git a/routers/user/avatar.go b/routers/user/avatar.go
index 20597c72ff..045206c50a 100644
--- a/routers/user/avatar.go
+++ b/routers/user/avatar.go
@@ -6,6 +6,7 @@ package user
import (
"strconv"
+ "strings"
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
@@ -23,14 +24,19 @@ func Avatar(ctx *context.Context) {
log.Debug("Asked avatar for user %v and size %v", userName, size)
- user, err := models.GetUserByName(userName)
- if err != nil {
- if models.IsErrUserNotExist(err) {
- ctx.ServerError("Requested avatar for invalid user", err)
- } else {
- ctx.ServerError("Retrieving user by name", err)
+ var user *models.User
+ if strings.ToLower(userName) != "ghost" {
+ user, err = models.GetUserByName(userName)
+ if err != nil {
+ if models.IsErrUserNotExist(err) {
+ ctx.ServerError("Requested avatar for invalid user", err)
+ } else {
+ ctx.ServerError("Retrieving user by name", err)
+ }
+ return
}
- return
+ } else {
+ user = models.NewGhostUser()
}
ctx.Redirect(user.RealSizedAvatarLink(size))