2025-03-18 17:57:07 +08:00
|
|
|
package web
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"errors"
|
2025-04-19 14:59:19 +08:00
|
|
|
"log/slog"
|
2025-05-24 12:37:16 +08:00
|
|
|
"platform/web/auth"
|
|
|
|
|
"platform/web/core"
|
2025-04-19 14:59:19 +08:00
|
|
|
"reflect"
|
2025-03-18 17:57:07 +08:00
|
|
|
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func ErrorHandler(c *fiber.Ctx, err error) error {
|
2025-04-19 14:59:19 +08:00
|
|
|
|
2025-05-09 11:10:17 +08:00
|
|
|
var code = fiber.StatusInternalServerError
|
|
|
|
|
var message = "服务器异常"
|
2025-04-19 14:59:19 +08:00
|
|
|
|
|
|
|
|
var fiberErr *fiber.Error
|
2025-11-17 18:38:10 +08:00
|
|
|
var authErr auth.AuthErr
|
2025-05-24 12:37:16 +08:00
|
|
|
var bizErr *core.BizErr
|
2025-08-15 18:11:35 +08:00
|
|
|
var servErr *core.ServErr
|
2025-05-09 11:10:17 +08:00
|
|
|
|
|
|
|
|
switch {
|
|
|
|
|
|
|
|
|
|
// fiber 错误
|
|
|
|
|
case errors.As(err, &fiberErr):
|
2025-04-19 14:59:19 +08:00
|
|
|
code = fiberErr.Code
|
|
|
|
|
message = fiberErr.Message
|
2025-05-09 11:10:17 +08:00
|
|
|
|
2025-05-24 12:37:16 +08:00
|
|
|
// 认证授权错误
|
|
|
|
|
case errors.As(err, &authErr):
|
|
|
|
|
switch {
|
2025-11-17 18:38:10 +08:00
|
|
|
case errors.Is(err, auth.ErrAuthenticateUnauthorize):
|
2025-05-24 12:37:16 +08:00
|
|
|
code = fiber.StatusUnauthorized
|
2025-11-17 18:38:10 +08:00
|
|
|
case errors.Is(err, auth.ErrAuthenticateForbidden):
|
2025-05-24 12:37:16 +08:00
|
|
|
code = fiber.StatusForbidden
|
|
|
|
|
default:
|
|
|
|
|
code = fiber.StatusBadRequest
|
|
|
|
|
}
|
|
|
|
|
message = err.Error()
|
|
|
|
|
|
2025-08-15 18:11:35 +08:00
|
|
|
// 已处理的业务错误
|
2025-05-24 12:37:16 +08:00
|
|
|
case errors.As(err, &bizErr):
|
|
|
|
|
code = fiber.StatusBadRequest
|
|
|
|
|
message = err.Error()
|
2025-08-15 18:11:35 +08:00
|
|
|
|
|
|
|
|
case errors.As(err, &servErr):
|
|
|
|
|
code = fiber.StatusInternalServerError
|
|
|
|
|
message = err.Error()
|
2025-05-09 11:10:17 +08:00
|
|
|
|
|
|
|
|
// 所有未手动声明的错误类型
|
|
|
|
|
default:
|
2025-06-17 10:53:05 +08:00
|
|
|
slog.Warn("未处理的异常", slog.String("type", reflect.TypeOf(err).Name()), slog.String("error", err.Error()))
|
2025-03-18 17:57:07 +08:00
|
|
|
}
|
2025-04-19 14:59:19 +08:00
|
|
|
|
2025-03-18 17:57:07 +08:00
|
|
|
c.Set(fiber.HeaderContentType, fiber.MIMETextPlainCharsetUTF8)
|
|
|
|
|
return c.Status(code).SendString(message)
|
|
|
|
|
}
|