gitea源码

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright 2022 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package context
  4. import (
  5. "fmt"
  6. "net/http"
  7. "strings"
  8. user_model "code.gitea.io/gitea/models/user"
  9. )
  10. // UserAssignmentWeb returns a middleware to handle context-user assignment for web routes
  11. func UserAssignmentWeb() func(ctx *Context) {
  12. return func(ctx *Context) {
  13. errorFn := func(status int, obj any) {
  14. err, ok := obj.(error)
  15. if !ok {
  16. err = fmt.Errorf("%s", obj)
  17. }
  18. if status == http.StatusNotFound {
  19. ctx.NotFound(err)
  20. } else {
  21. ctx.ServerError("UserAssignmentWeb", err)
  22. }
  23. }
  24. ctx.ContextUser = userAssignment(ctx.Base, ctx.Doer, errorFn)
  25. ctx.Data["ContextUser"] = ctx.ContextUser
  26. }
  27. }
  28. // UserIDAssignmentAPI returns a middleware to handle context-user assignment for api routes
  29. func UserIDAssignmentAPI() func(ctx *APIContext) {
  30. return func(ctx *APIContext) {
  31. userID := ctx.PathParamInt64("user-id")
  32. if ctx.IsSigned && ctx.Doer.ID == userID {
  33. ctx.ContextUser = ctx.Doer
  34. } else {
  35. var err error
  36. ctx.ContextUser, err = user_model.GetUserByID(ctx, userID)
  37. if err != nil {
  38. if user_model.IsErrUserNotExist(err) {
  39. ctx.APIError(http.StatusNotFound, err)
  40. } else {
  41. ctx.APIErrorInternal(err)
  42. }
  43. }
  44. }
  45. }
  46. }
  47. // UserAssignmentAPI returns a middleware to handle context-user assignment for api routes
  48. func UserAssignmentAPI() func(ctx *APIContext) {
  49. return func(ctx *APIContext) {
  50. ctx.ContextUser = userAssignment(ctx.Base, ctx.Doer, ctx.APIError)
  51. }
  52. }
  53. func userAssignment(ctx *Base, doer *user_model.User, errCb func(int, any)) (contextUser *user_model.User) {
  54. username := ctx.PathParam("username")
  55. if doer != nil && strings.EqualFold(doer.LowerName, username) {
  56. contextUser = doer
  57. } else {
  58. var err error
  59. contextUser, err = user_model.GetUserByName(ctx, username)
  60. if err != nil {
  61. if user_model.IsErrUserNotExist(err) {
  62. if redirectUserID, err := user_model.LookupUserRedirect(ctx, username); err == nil {
  63. RedirectToUser(ctx, username, redirectUserID)
  64. } else if user_model.IsErrUserRedirectNotExist(err) {
  65. errCb(http.StatusNotFound, err)
  66. } else {
  67. errCb(http.StatusInternalServerError, fmt.Errorf("LookupUserRedirect: %w", err))
  68. }
  69. } else {
  70. errCb(http.StatusInternalServerError, fmt.Errorf("GetUserByName: %w", err))
  71. }
  72. }
  73. }
  74. return contextUser
  75. }