mirror of
https://github.com/memohai/Memoh.git
synced 2026-04-25 07:00:48 +09:00
d12092870f
- Update LLMClient test to match NewLLMClient signature by passing nil logger - Add nil check for logger in NewLLMClient to prevent panic, defaulting to slog.Default()
107 lines
2.7 KiB
Go
107 lines
2.7 KiB
Go
package server
|
|
|
|
import (
|
|
"log/slog"
|
|
"strings"
|
|
|
|
"github.com/labstack/echo/v4"
|
|
"github.com/labstack/echo/v4/middleware"
|
|
|
|
"github.com/memohai/memoh/internal/auth"
|
|
"github.com/memohai/memoh/internal/handlers"
|
|
)
|
|
|
|
type Server struct {
|
|
echo *echo.Echo
|
|
addr string
|
|
logger *slog.Logger
|
|
}
|
|
|
|
func NewServer(log *slog.Logger, addr string, jwtSecret string, pingHandler *handlers.PingHandler, authHandler *handlers.AuthHandler, memoryHandler *handlers.MemoryHandler, embeddingsHandler *handlers.EmbeddingsHandler, chatHandler *handlers.ChatHandler, swaggerHandler *handlers.SwaggerHandler, providersHandler *handlers.ProvidersHandler, modelsHandler *handlers.ModelsHandler, settingsHandler *handlers.SettingsHandler, historyHandler *handlers.HistoryHandler, scheduleHandler *handlers.ScheduleHandler, subagentHandler *handlers.SubagentHandler, containerdHandler *handlers.ContainerdHandler, channelHandler *handlers.ChannelHandler) *Server {
|
|
if addr == "" {
|
|
addr = ":8080"
|
|
}
|
|
|
|
e := echo.New()
|
|
e.HideBanner = true
|
|
e.Use(middleware.Recover())
|
|
e.Use(middleware.RequestLoggerWithConfig(middleware.RequestLoggerConfig{
|
|
LogStatus: true,
|
|
LogURI: true,
|
|
LogMethod: true,
|
|
LogValuesFunc: func(c echo.Context, v middleware.RequestLoggerValues) error {
|
|
log.Info("request",
|
|
slog.String("method", v.Method),
|
|
slog.String("uri", v.URI),
|
|
slog.Int("status", v.Status),
|
|
slog.Duration("latency", v.Latency),
|
|
slog.String("remote_ip", c.RealIP()),
|
|
)
|
|
return nil
|
|
},
|
|
}))
|
|
e.Use(auth.JWTMiddleware(jwtSecret, func(c echo.Context) bool {
|
|
path := c.Request().URL.Path
|
|
if path == "/ping" || path == "/api/swagger.json" || path == "/auth/login" {
|
|
return true
|
|
}
|
|
if strings.HasPrefix(path, "/api/docs") {
|
|
return true
|
|
}
|
|
return false
|
|
}))
|
|
|
|
if pingHandler != nil {
|
|
pingHandler.Register(e)
|
|
}
|
|
if authHandler != nil {
|
|
authHandler.Register(e)
|
|
}
|
|
if memoryHandler != nil {
|
|
memoryHandler.Register(e)
|
|
}
|
|
if embeddingsHandler != nil {
|
|
embeddingsHandler.Register(e)
|
|
}
|
|
if chatHandler != nil {
|
|
chatHandler.Register(e)
|
|
}
|
|
if swaggerHandler != nil {
|
|
swaggerHandler.Register(e)
|
|
}
|
|
if settingsHandler != nil {
|
|
settingsHandler.Register(e)
|
|
}
|
|
if historyHandler != nil {
|
|
historyHandler.Register(e)
|
|
}
|
|
if scheduleHandler != nil {
|
|
scheduleHandler.Register(e)
|
|
}
|
|
if subagentHandler != nil {
|
|
subagentHandler.Register(e)
|
|
}
|
|
if providersHandler != nil {
|
|
providersHandler.Register(e)
|
|
}
|
|
if modelsHandler != nil {
|
|
modelsHandler.Register(e)
|
|
}
|
|
if containerdHandler != nil {
|
|
containerdHandler.Register(e)
|
|
}
|
|
if channelHandler != nil {
|
|
channelHandler.Register(e)
|
|
}
|
|
|
|
return &Server{
|
|
echo: e,
|
|
addr: addr,
|
|
logger: log.With(slog.String("component", "server")),
|
|
}
|
|
}
|
|
|
|
func (s *Server) Start() error {
|
|
return s.echo.Start(s.addr)
|
|
}
|