添加运行模式配置,优化调试和生产环境的日志输出
This commit is contained in:
11
pkg/env/env.go
vendored
11
pkg/env/env.go
vendored
@@ -13,6 +13,7 @@ import (
|
|||||||
|
|
||||||
var (
|
var (
|
||||||
AppName = "platform"
|
AppName = "platform"
|
||||||
|
RunMode = "debug" // debug, production
|
||||||
)
|
)
|
||||||
|
|
||||||
func loadApp() {
|
func loadApp() {
|
||||||
@@ -20,6 +21,16 @@ func loadApp() {
|
|||||||
if _AppName != "" {
|
if _AppName != "" {
|
||||||
AppName = _AppName
|
AppName = _AppName
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_RunMode := os.Getenv("RUN_MODE")
|
||||||
|
switch _RunMode {
|
||||||
|
case "debug", "production":
|
||||||
|
RunMode = _RunMode
|
||||||
|
case "":
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
panic("环境变量 RUN_MODE 的值只能是 debug 或 production")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// endregion
|
// endregion
|
||||||
|
|||||||
@@ -1,19 +1,24 @@
|
|||||||
package logs
|
package logs
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/lmittmann/tint"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"os"
|
"os"
|
||||||
"platform/pkg/env"
|
"platform/pkg/env"
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/lmittmann/tint"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func Init() {
|
func Init() {
|
||||||
slog.SetDefault(slog.New(
|
|
||||||
tint.NewHandler(os.Stdout, &tint.Options{
|
var writer = os.Stdout
|
||||||
|
var timeFormat = "2006-01-02 15:04:05"
|
||||||
|
|
||||||
|
var handler slog.Handler
|
||||||
|
switch env.RunMode {
|
||||||
|
case "debug":
|
||||||
|
handler = tint.NewHandler(writer, &tint.Options{
|
||||||
|
AddSource: true,
|
||||||
Level: env.LogLevel,
|
Level: env.LogLevel,
|
||||||
TimeFormat: time.Kitchen,
|
TimeFormat: timeFormat,
|
||||||
ReplaceAttr: func(_ []string, attr slog.Attr) slog.Attr {
|
ReplaceAttr: func(_ []string, attr slog.Attr) slog.Attr {
|
||||||
err, ok := attr.Value.Any().(error)
|
err, ok := attr.Value.Any().(error)
|
||||||
if ok {
|
if ok {
|
||||||
@@ -21,6 +26,19 @@ func Init() {
|
|||||||
}
|
}
|
||||||
return attr
|
return attr
|
||||||
},
|
},
|
||||||
}),
|
})
|
||||||
))
|
case "production":
|
||||||
|
handler = slog.NewJSONHandler(writer, &slog.HandlerOptions{
|
||||||
|
AddSource: false,
|
||||||
|
Level: env.LogLevel,
|
||||||
|
ReplaceAttr: func(_ []string, a slog.Attr) slog.Attr {
|
||||||
|
if a.Key == "time" {
|
||||||
|
return slog.String("time", a.Value.Time().Format(timeFormat))
|
||||||
|
}
|
||||||
|
return a
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
slog.SetDefault(slog.New(handler))
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -66,6 +66,11 @@ func Protect(c *fiber.Ctx, types []services.PayloadType, permissions []string) (
|
|||||||
return nil, fiber.NewError(fiber.StatusForbidden, "没有权限")
|
return nil, fiber.NewError(fiber.StatusForbidden, "没有权限")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 保存到上下文
|
||||||
|
c.Locals("auth", auth)
|
||||||
|
c.Locals("authid", auth.Payload.Id)
|
||||||
|
c.Locals("authtype", auth.Payload.Type.Name())
|
||||||
|
|
||||||
return auth, nil
|
return auth, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -237,6 +237,20 @@ const (
|
|||||||
PayloadClientConfidential
|
PayloadClientConfidential
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func (t PayloadType) Name() string {
|
||||||
|
switch t {
|
||||||
|
case PayloadUser:
|
||||||
|
return "user"
|
||||||
|
case PayloadAdmin:
|
||||||
|
return "admn"
|
||||||
|
case PayloadClientPublic:
|
||||||
|
return "cpub"
|
||||||
|
case PayloadClientConfidential:
|
||||||
|
return "ccnf"
|
||||||
|
}
|
||||||
|
return "unknown"
|
||||||
|
}
|
||||||
|
|
||||||
type Agent struct {
|
type Agent struct {
|
||||||
Id int32 `json:"id,omitempty"`
|
Id int32 `json:"id,omitempty"`
|
||||||
Addr string `json:"addr,omitempty"`
|
Addr string `json:"addr,omitempty"`
|
||||||
|
|||||||
@@ -51,15 +51,17 @@ func (s *Server) Run() error {
|
|||||||
ErrorHandler: ErrorHandler,
|
ErrorHandler: ErrorHandler,
|
||||||
})
|
})
|
||||||
|
|
||||||
s.fiber.Use(logger.New(logger.Config{
|
|
||||||
DisableColors: false,
|
|
||||||
}))
|
|
||||||
s.fiber.Use(requestid.New(requestid.Config{
|
s.fiber.Use(requestid.New(requestid.Config{
|
||||||
Generator: func() string {
|
Generator: func() string {
|
||||||
binary, _ := uuid.New().MarshalBinary()
|
binary, _ := uuid.New().MarshalBinary()
|
||||||
return base62.EncodeToString(binary)
|
return base62.EncodeToString(binary)
|
||||||
},
|
},
|
||||||
}))
|
}))
|
||||||
|
s.fiber.Use(logger.New(logger.Config{
|
||||||
|
Format: "🚀 ${time} | ${locals:authtype} ${locals:authid} | ${method} ${path} | ${status} | ${latency} | ${error}\n",
|
||||||
|
TimeFormat: "2006-01-02 15:04:05",
|
||||||
|
TimeZone: "Asia/Shanghai",
|
||||||
|
}))
|
||||||
|
|
||||||
ApplyRouters(s.fiber)
|
ApplyRouters(s.fiber)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user