mirror of
https://codeberg.org/forgejo/forgejo
synced 2024-12-12 22:41:59 +01:00
9836b7db7b
Backport #23823 by @wxiaoguang Thanks to @trwnh Close #23802 The ActivityPub id is an HTTPS URI that should remain constant, even if the user changes their name. Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
82 lines
2.3 KiB
Go
82 lines
2.3 KiB
Go
// Copyright 2022 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package context
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
|
|
user_model "code.gitea.io/gitea/models/user"
|
|
"code.gitea.io/gitea/modules/context"
|
|
)
|
|
|
|
// UserAssignmentWeb returns a middleware to handle context-user assignment for web routes
|
|
func UserAssignmentWeb() func(ctx *context.Context) {
|
|
return func(ctx *context.Context) {
|
|
userAssignment(ctx, func(status int, title string, obj interface{}) {
|
|
err, ok := obj.(error)
|
|
if !ok {
|
|
err = fmt.Errorf("%s", obj)
|
|
}
|
|
if status == http.StatusNotFound {
|
|
ctx.NotFound(title, err)
|
|
} else {
|
|
ctx.ServerError(title, err)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// UserIDAssignmentAPI returns a middleware to handle context-user assignment for api routes
|
|
func UserIDAssignmentAPI() func(ctx *context.APIContext) {
|
|
return func(ctx *context.APIContext) {
|
|
userID := ctx.ParamsInt64(":user-id")
|
|
|
|
if ctx.IsSigned && ctx.Doer.ID == userID {
|
|
ctx.ContextUser = ctx.Doer
|
|
} else {
|
|
var err error
|
|
ctx.ContextUser, err = user_model.GetUserByID(ctx, userID)
|
|
if err != nil {
|
|
if user_model.IsErrUserNotExist(err) {
|
|
ctx.Error(http.StatusNotFound, "GetUserByID", err)
|
|
} else {
|
|
ctx.Error(http.StatusInternalServerError, "GetUserByID", err)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// UserAssignmentAPI returns a middleware to handle context-user assignment for api routes
|
|
func UserAssignmentAPI() func(ctx *context.APIContext) {
|
|
return func(ctx *context.APIContext) {
|
|
userAssignment(ctx.Context, ctx.Error)
|
|
}
|
|
}
|
|
|
|
func userAssignment(ctx *context.Context, errCb func(int, string, interface{})) {
|
|
username := ctx.Params(":username")
|
|
|
|
if ctx.IsSigned && ctx.Doer.LowerName == strings.ToLower(username) {
|
|
ctx.ContextUser = ctx.Doer
|
|
} else {
|
|
var err error
|
|
ctx.ContextUser, err = user_model.GetUserByName(ctx, username)
|
|
if err != nil {
|
|
if user_model.IsErrUserNotExist(err) {
|
|
if redirectUserID, err := user_model.LookupUserRedirect(username); err == nil {
|
|
context.RedirectToUser(ctx, username, redirectUserID)
|
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
|
errCb(http.StatusNotFound, "GetUserByName", err)
|
|
} else {
|
|
errCb(http.StatusInternalServerError, "LookupUserRedirect", err)
|
|
}
|
|
} else {
|
|
errCb(http.StatusInternalServerError, "GetUserByName", err)
|
|
}
|
|
}
|
|
}
|
|
}
|