mirror of
https://github.com/go-gitea/gitea.git
synced 2025-12-15 21:45:35 +08:00
Check user visibility when redirecting to a renamed user (#36148)
Fix #34169
This commit is contained in:
parent
29057ea55f
commit
1f5237e0d7
@ -152,7 +152,7 @@ func repoAssignment() func(ctx *context.APIContext) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
if user_model.IsErrUserNotExist(err) {
|
if user_model.IsErrUserNotExist(err) {
|
||||||
if redirectUserID, err := user_model.LookupUserRedirect(ctx, userName); err == nil {
|
if redirectUserID, err := user_model.LookupUserRedirect(ctx, userName); err == nil {
|
||||||
context.RedirectToUser(ctx.Base, userName, redirectUserID)
|
context.RedirectToUser(ctx.Base, ctx.Doer, userName, redirectUserID)
|
||||||
} else if user_model.IsErrUserRedirectNotExist(err) {
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
||||||
ctx.APIErrorNotFound("GetUserByName", err)
|
ctx.APIErrorNotFound("GetUserByName", err)
|
||||||
} else {
|
} else {
|
||||||
@ -612,7 +612,7 @@ func orgAssignment(args ...bool) func(ctx *context.APIContext) {
|
|||||||
if organization.IsErrOrgNotExist(err) {
|
if organization.IsErrOrgNotExist(err) {
|
||||||
redirectUserID, err := user_model.LookupUserRedirect(ctx, ctx.PathParam("org"))
|
redirectUserID, err := user_model.LookupUserRedirect(ctx, ctx.PathParam("org"))
|
||||||
if err == nil {
|
if err == nil {
|
||||||
context.RedirectToUser(ctx.Base, ctx.PathParam("org"), redirectUserID)
|
context.RedirectToUser(ctx.Base, ctx.Doer, ctx.PathParam("org"), redirectUserID)
|
||||||
} else if user_model.IsErrUserRedirectNotExist(err) {
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
||||||
ctx.APIErrorNotFound("GetOrgByName", err)
|
ctx.APIErrorNotFound("GetOrgByName", err)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@ -16,7 +16,7 @@ func GetUserByPathParam(ctx *context.APIContext, name string) *user_model.User {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
if user_model.IsErrUserNotExist(err) {
|
if user_model.IsErrUserNotExist(err) {
|
||||||
if redirectUserID, err2 := user_model.LookupUserRedirect(ctx, username); err2 == nil {
|
if redirectUserID, err2 := user_model.LookupUserRedirect(ctx, username); err2 == nil {
|
||||||
context.RedirectToUser(ctx.Base, username, redirectUserID)
|
context.RedirectToUser(ctx.Base, ctx.Doer, username, redirectUserID)
|
||||||
} else {
|
} else {
|
||||||
ctx.APIErrorNotFound("GetUserByName", err)
|
ctx.APIErrorNotFound("GetUserByName", err)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -20,15 +20,27 @@ import (
|
|||||||
"code.gitea.io/gitea/modules/httplib"
|
"code.gitea.io/gitea/modules/httplib"
|
||||||
"code.gitea.io/gitea/modules/log"
|
"code.gitea.io/gitea/modules/log"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"code.gitea.io/gitea/modules/structs"
|
||||||
"code.gitea.io/gitea/modules/templates"
|
"code.gitea.io/gitea/modules/templates"
|
||||||
"code.gitea.io/gitea/modules/web/middleware"
|
"code.gitea.io/gitea/modules/web/middleware"
|
||||||
)
|
)
|
||||||
|
|
||||||
// RedirectToUser redirect to a differently-named user
|
// RedirectToUser redirect to a differently-named user
|
||||||
func RedirectToUser(ctx *Base, userName string, redirectUserID int64) {
|
func RedirectToUser(ctx *Base, doer *user_model.User, userName string, redirectUserID int64) {
|
||||||
user, err := user_model.GetUserByID(ctx, redirectUserID)
|
user, err := user_model.GetUserByID(ctx, redirectUserID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.HTTPError(http.StatusInternalServerError, "unable to get user")
|
if user_model.IsErrUserNotExist(err) {
|
||||||
|
ctx.HTTPError(http.StatusNotFound, "user does not exist")
|
||||||
|
} else {
|
||||||
|
ctx.HTTPError(http.StatusInternalServerError, "unable to get user")
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle Visibility
|
||||||
|
if user.Visibility != structs.VisibleTypePublic && doer == nil {
|
||||||
|
// We must be signed in to see limited or private organizations
|
||||||
|
ctx.HTTPError(http.StatusNotFound, "user does not exist")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -49,7 +49,7 @@ func GetOrganizationByParams(ctx *Context) {
|
|||||||
if organization.IsErrOrgNotExist(err) {
|
if organization.IsErrOrgNotExist(err) {
|
||||||
redirectUserID, err := user_model.LookupUserRedirect(ctx, orgName)
|
redirectUserID, err := user_model.LookupUserRedirect(ctx, orgName)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
RedirectToUser(ctx.Base, orgName, redirectUserID)
|
RedirectToUser(ctx.Base, ctx.Doer, orgName, redirectUserID)
|
||||||
} else if user_model.IsErrUserRedirectNotExist(err) {
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
||||||
ctx.NotFound(err)
|
ctx.NotFound(err)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@ -443,7 +443,7 @@ func RepoAssignment(ctx *Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if redirectUserID, err := user_model.LookupUserRedirect(ctx, userName); err == nil {
|
if redirectUserID, err := user_model.LookupUserRedirect(ctx, userName); err == nil {
|
||||||
RedirectToUser(ctx.Base, userName, redirectUserID)
|
RedirectToUser(ctx.Base, ctx.Doer, userName, redirectUserID)
|
||||||
} else if user_model.IsErrUserRedirectNotExist(err) {
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
||||||
ctx.NotFound(nil)
|
ctx.NotFound(nil)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@ -69,7 +69,7 @@ func userAssignment(ctx *Base, doer *user_model.User, errCb func(int, any)) (con
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
if user_model.IsErrUserNotExist(err) {
|
if user_model.IsErrUserNotExist(err) {
|
||||||
if redirectUserID, err := user_model.LookupUserRedirect(ctx, username); err == nil {
|
if redirectUserID, err := user_model.LookupUserRedirect(ctx, username); err == nil {
|
||||||
RedirectToUser(ctx, username, redirectUserID)
|
RedirectToUser(ctx, doer, username, redirectUserID)
|
||||||
} else if user_model.IsErrUserRedirectNotExist(err) {
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
||||||
errCb(http.StatusNotFound, err)
|
errCb(http.StatusNotFound, err)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@ -45,6 +45,78 @@ func TestRenameUsername(t *testing.T) {
|
|||||||
unittest.AssertNotExistsBean(t, &user_model.User{Name: "user2"})
|
unittest.AssertNotExistsBean(t, &user_model.User{Name: "user2"})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestViewLimitedAndPrivateUserAndRename(t *testing.T) {
|
||||||
|
defer tests.PrepareTestEnv(t)()
|
||||||
|
|
||||||
|
// user 22 is a limited visibility org
|
||||||
|
org22 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 22})
|
||||||
|
req := NewRequest(t, "GET", "/"+org22.Name)
|
||||||
|
MakeRequest(t, req, http.StatusNotFound)
|
||||||
|
|
||||||
|
session := loginUser(t, "user1")
|
||||||
|
oldName := org22.Name
|
||||||
|
newName := "org22_renamed"
|
||||||
|
req = NewRequestWithValues(t, "POST", "/org/"+oldName+"/settings/rename", map[string]string{
|
||||||
|
"_csrf": GetUserCSRFToken(t, session),
|
||||||
|
"org_name": oldName,
|
||||||
|
"new_org_name": newName,
|
||||||
|
})
|
||||||
|
session.MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
|
unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: newName})
|
||||||
|
unittest.AssertNotExistsBean(t, &user_model.User{Name: oldName})
|
||||||
|
|
||||||
|
req = NewRequest(t, "GET", "/"+oldName)
|
||||||
|
MakeRequest(t, req, http.StatusNotFound) // anonymous user cannot visit limited visibility org via old name
|
||||||
|
req = NewRequest(t, "GET", "/"+oldName)
|
||||||
|
session.MakeRequest(t, req, http.StatusTemporaryRedirect) // login user can visit limited visibility org via old name
|
||||||
|
|
||||||
|
// org 23 is a private visibility org
|
||||||
|
org23 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 23})
|
||||||
|
req = NewRequest(t, "GET", "/"+org23.Name)
|
||||||
|
MakeRequest(t, req, http.StatusNotFound)
|
||||||
|
|
||||||
|
oldName = org23.Name
|
||||||
|
newName = "org23_renamed"
|
||||||
|
req = NewRequestWithValues(t, "POST", "/org/"+oldName+"/settings/rename", map[string]string{
|
||||||
|
"_csrf": GetUserCSRFToken(t, session),
|
||||||
|
"org_name": oldName,
|
||||||
|
"new_org_name": newName,
|
||||||
|
})
|
||||||
|
session.MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
|
unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: newName})
|
||||||
|
unittest.AssertNotExistsBean(t, &user_model.User{Name: oldName})
|
||||||
|
|
||||||
|
req = NewRequest(t, "GET", "/"+oldName)
|
||||||
|
MakeRequest(t, req, http.StatusNotFound) // anonymous user cannot visit limited visibility org via old name
|
||||||
|
req = NewRequest(t, "GET", "/"+oldName)
|
||||||
|
session.MakeRequest(t, req, http.StatusTemporaryRedirect) // login user can visit limited visibility org via old name
|
||||||
|
|
||||||
|
// user 31 is a private visibility user
|
||||||
|
user31 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 31})
|
||||||
|
req = NewRequest(t, "GET", "/"+user31.Name)
|
||||||
|
MakeRequest(t, req, http.StatusNotFound)
|
||||||
|
|
||||||
|
oldName = user31.Name
|
||||||
|
newName = "user31_renamed"
|
||||||
|
session2 := loginUser(t, oldName)
|
||||||
|
req = NewRequestWithValues(t, "POST", "/user/settings", map[string]string{
|
||||||
|
"_csrf": GetUserCSRFToken(t, session2),
|
||||||
|
"name": newName,
|
||||||
|
"visibility": "2", // private
|
||||||
|
})
|
||||||
|
session2.MakeRequest(t, req, http.StatusSeeOther)
|
||||||
|
|
||||||
|
unittest.AssertExistsAndLoadBean(t, &user_model.User{Name: newName})
|
||||||
|
unittest.AssertNotExistsBean(t, &user_model.User{Name: oldName})
|
||||||
|
|
||||||
|
req = NewRequest(t, "GET", "/"+oldName)
|
||||||
|
MakeRequest(t, req, http.StatusNotFound) // anonymous user cannot visit private visibility user via old name
|
||||||
|
req = NewRequest(t, "GET", "/"+oldName)
|
||||||
|
session.MakeRequest(t, req, http.StatusTemporaryRedirect) // login user2 can visit private visibility user via old name
|
||||||
|
}
|
||||||
|
|
||||||
func TestRenameInvalidUsername(t *testing.T) {
|
func TestRenameInvalidUsername(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
defer tests.PrepareTestEnv(t)()
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user