2022-03-26 10:04:22 +01:00
|
|
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
2022-11-27 19:20:29 +01:00
|
|
|
// SPDX-License-Identifier: MIT
|
2022-03-26 10:04:22 +01:00
|
|
|
|
|
|
|
package context
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
user_model "code.gitea.io/gitea/models/user"
|
|
|
|
)
|
|
|
|
|
|
|
|
// UserAssignmentWeb returns a middleware to handle context-user assignment for web routes
|
2024-02-27 08:12:22 +01:00
|
|
|
func UserAssignmentWeb() func(ctx *Context) {
|
|
|
|
return func(ctx *Context) {
|
2023-07-04 20:36:08 +02:00
|
|
|
errorFn := func(status int, title string, obj any) {
|
2022-03-26 10:04:22 +01:00
|
|
|
err, ok := obj.(error)
|
|
|
|
if !ok {
|
|
|
|
err = fmt.Errorf("%s", obj)
|
|
|
|
}
|
|
|
|
if status == http.StatusNotFound {
|
|
|
|
ctx.NotFound(title, err)
|
|
|
|
} else {
|
|
|
|
ctx.ServerError(title, err)
|
|
|
|
}
|
2023-05-21 03:50:53 +02:00
|
|
|
}
|
|
|
|
ctx.ContextUser = userAssignment(ctx.Base, ctx.Doer, errorFn)
|
2023-09-06 08:38:14 +02:00
|
|
|
ctx.Data["ContextUser"] = ctx.ContextUser
|
2022-03-26 10:04:22 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-04 04:08:23 +02:00
|
|
|
// UserIDAssignmentAPI returns a middleware to handle context-user assignment for api routes
|
2024-02-27 08:12:22 +01:00
|
|
|
func UserIDAssignmentAPI() func(ctx *APIContext) {
|
|
|
|
return func(ctx *APIContext) {
|
2024-12-24 14:47:45 +01:00
|
|
|
userID := ctx.PathParamInt64("user-id")
|
2023-04-04 04:08:23 +02:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-26 10:04:22 +01:00
|
|
|
// UserAssignmentAPI returns a middleware to handle context-user assignment for api routes
|
2024-02-27 08:12:22 +01:00
|
|
|
func UserAssignmentAPI() func(ctx *APIContext) {
|
|
|
|
return func(ctx *APIContext) {
|
2023-05-21 03:50:53 +02:00
|
|
|
ctx.ContextUser = userAssignment(ctx.Base, ctx.Doer, ctx.Error)
|
2022-03-26 10:04:22 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-27 08:12:22 +01:00
|
|
|
func userAssignment(ctx *Base, doer *user_model.User, errCb func(int, string, any)) (contextUser *user_model.User) {
|
2024-12-24 14:47:45 +01:00
|
|
|
username := ctx.PathParam("username")
|
2022-03-26 10:04:22 +01:00
|
|
|
|
2023-05-21 03:50:53 +02:00
|
|
|
if doer != nil && doer.LowerName == strings.ToLower(username) {
|
|
|
|
contextUser = doer
|
2022-03-26 10:04:22 +01:00
|
|
|
} else {
|
|
|
|
var err error
|
2023-05-21 03:50:53 +02:00
|
|
|
contextUser, err = user_model.GetUserByName(ctx, username)
|
2022-03-26 10:04:22 +01:00
|
|
|
if err != nil {
|
|
|
|
if user_model.IsErrUserNotExist(err) {
|
2023-09-25 15:17:37 +02:00
|
|
|
if redirectUserID, err := user_model.LookupUserRedirect(ctx, username); err == nil {
|
2024-02-27 08:12:22 +01:00
|
|
|
RedirectToUser(ctx, username, redirectUserID)
|
2022-03-26 10:04:22 +01:00
|
|
|
} else if user_model.IsErrUserRedirectNotExist(err) {
|
|
|
|
errCb(http.StatusNotFound, "GetUserByName", err)
|
|
|
|
} else {
|
|
|
|
errCb(http.StatusInternalServerError, "LookupUserRedirect", err)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
errCb(http.StatusInternalServerError, "GetUserByName", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-05-21 03:50:53 +02:00
|
|
|
return contextUser
|
2022-03-26 10:04:22 +01:00
|
|
|
}
|