wip: 完成 client api 分析

This commit is contained in:
loveuer
2024-12-19 15:03:36 +08:00
commit 64cdd0cb0e
76 changed files with 5146 additions and 0 deletions

70
internal/api/api.go Normal file
View File

@ -0,0 +1,70 @@
package api
import (
"context"
"fmt"
"time"
"esway/internal/handler"
"esway/internal/middleware/auth"
"esway/internal/middleware/logger"
"esway/internal/middleware/oplog"
"esway/internal/middleware/privilege"
"esway/internal/model"
"esway/internal/opt"
"github.com/loveuer/nf"
"github.com/loveuer/nf/nft/resp"
)
func initApp(ctx context.Context) *nf.App {
engine := nf.New(nf.Config{DisableLogger: true, DisableBanner: true, DisableMessagePrint: true})
engine.Use(logger.New())
// todo: add project prefix, if you need
// for example: app := engine.Group("/api/{project}")
app := engine.Group("/api")
app.Get("/available", func() nf.HandlerFunc {
return func(c *nf.Ctx) error {
now := time.Now()
return resp.Resp200(c, nf.Map{"ok": opt.OK, "start": opt.Start, "now": now, "duration": fmt.Sprint(now.Sub(opt.Start))})
}
}())
{
api := app.Group("/user")
api.Post("/auth/login", oplog.NewOpLog(ctx), handler.AuthLogin)
api.Get("/auth/login", auth.NewAuth(), handler.AuthVerify)
api.Post("/auth/logout", auth.NewAuth(), oplog.NewOpLog(ctx), handler.AuthLogout)
api.Post("/update", auth.NewAuth(), handler.UserUpdate)
mng := api.Group("/manage")
mng.Use(auth.NewAuth(), privilege.Verify(
privilege.RelationAnd,
model.PrivilegeUserManage,
))
mng.Get("/user/list", handler.ManageUserList)
mng.Post("/user/create", oplog.NewOpLog(ctx), handler.ManageUserCreate)
mng.Post("/user/update", oplog.NewOpLog(ctx), handler.ManageUserUpdate)
mng.Post("/user/delete", oplog.NewOpLog(ctx), handler.ManageUserDelete)
}
{
api := app.Group("/log")
api.Use(auth.NewAuth(), privilege.Verify(privilege.RelationAnd, model.PrivilegeOpLog))
api.Get("/category/list", handler.LogCategories())
api.Get("/content/list", handler.LogList)
}
{
// todo: 替换 xxx
// todo: 这里写你的模块和接口
api := app.Group("/xxx")
api.Use(auth.NewAuth())
_ = api // todo: 添加自己的接口后删除该行
}
return engine
}

45
internal/api/start.go Normal file
View File

@ -0,0 +1,45 @@
package api
import (
"context"
"fmt"
"net"
"esway/internal/opt"
"esway/internal/tool"
"github.com/loveuer/nf/nft/log"
)
func Start(ctx context.Context) error {
app := initApp(ctx)
ready := make(chan bool)
ln, err := net.Listen("tcp", opt.Cfg.Listen.Dashboard)
if err != nil {
return fmt.Errorf("api.MustStart: net listen tcp address=%v err=%v", opt.Cfg.Listen.Dashboard, err)
}
go func() {
ready <- true
fmt.Printf("esway: dashboard listen at %s\n", opt.Cfg.Listen.Dashboard)
if err = app.RunListener(ln); err != nil {
log.Panic("api.MustStart: app run err=%v", err)
}
}()
<-ready
go func() {
ready <- true
<-ctx.Done()
if err = app.Shutdown(tool.Timeout(2)); err != nil {
log.Error("api.MustStart: app shutdown err=%v", err)
}
}()
<-ready
return nil
}