feat(tags): add endpoint to query all node tags
This commit is contained in:
parent
42df466104
commit
1f824fd5a9
@ -168,6 +168,9 @@ type (
|
|||||||
ResetSortRequest {
|
ResetSortRequest {
|
||||||
Sort []SortItem `json:"sort"`
|
Sort []SortItem `json:"sort"`
|
||||||
}
|
}
|
||||||
|
QueryNodeTagResponse {
|
||||||
|
Tags []string `json:"tags"`
|
||||||
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
@server (
|
@server (
|
||||||
@ -231,5 +234,9 @@ service ppanel {
|
|||||||
@doc "Reset node sort"
|
@doc "Reset node sort"
|
||||||
@handler ResetSortWithNode
|
@handler ResetSortWithNode
|
||||||
post /node/sort (ResetSortRequest)
|
post /node/sort (ResetSortRequest)
|
||||||
|
|
||||||
|
@doc "Query all node tags"
|
||||||
|
@handler QueryNodeTag
|
||||||
|
get /node/tags returns (QueryNodeTagResponse)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
18
internal/handler/admin/server/queryNodeTagHandler.go
Normal file
18
internal/handler/admin/server/queryNodeTagHandler.go
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package server
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
"github.com/perfect-panel/server/internal/logic/admin/server"
|
||||||
|
"github.com/perfect-panel/server/internal/svc"
|
||||||
|
"github.com/perfect-panel/server/pkg/result"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Query all node tags
|
||||||
|
func QueryNodeTagHandler(svcCtx *svc.ServiceContext) func(c *gin.Context) {
|
||||||
|
return func(c *gin.Context) {
|
||||||
|
|
||||||
|
l := server.NewQueryNodeTagLogic(c.Request.Context(), svcCtx)
|
||||||
|
resp, err := l.QueryNodeTag()
|
||||||
|
result.HttpResult(c, resp, err)
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -323,6 +323,9 @@ func RegisterHandlers(router *gin.Engine, serverCtx *svc.ServiceContext) {
|
|||||||
// Toggle Node Status
|
// Toggle Node Status
|
||||||
adminServerGroupRouter.POST("/node/status/toggle", adminServer.ToggleNodeStatusHandler(serverCtx))
|
adminServerGroupRouter.POST("/node/status/toggle", adminServer.ToggleNodeStatusHandler(serverCtx))
|
||||||
|
|
||||||
|
// Query all node tags
|
||||||
|
adminServerGroupRouter.GET("/node/tags", adminServer.QueryNodeTagHandler(serverCtx))
|
||||||
|
|
||||||
// Update Node
|
// Update Node
|
||||||
adminServerGroupRouter.POST("/node/update", adminServer.UpdateNodeHandler(serverCtx))
|
adminServerGroupRouter.POST("/node/update", adminServer.UpdateNodeHandler(serverCtx))
|
||||||
|
|
||||||
|
|||||||
46
internal/logic/admin/server/queryNodeTagLogic.go
Normal file
46
internal/logic/admin/server/queryNodeTagLogic.go
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
package server
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/perfect-panel/server/internal/model/node"
|
||||||
|
"github.com/perfect-panel/server/internal/svc"
|
||||||
|
"github.com/perfect-panel/server/internal/types"
|
||||||
|
"github.com/perfect-panel/server/pkg/logger"
|
||||||
|
"github.com/perfect-panel/server/pkg/tool"
|
||||||
|
"github.com/perfect-panel/server/pkg/xerr"
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
)
|
||||||
|
|
||||||
|
type QueryNodeTagLogic struct {
|
||||||
|
logger.Logger
|
||||||
|
ctx context.Context
|
||||||
|
svcCtx *svc.ServiceContext
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewQueryNodeTagLogic Query all node tags
|
||||||
|
func NewQueryNodeTagLogic(ctx context.Context, svcCtx *svc.ServiceContext) *QueryNodeTagLogic {
|
||||||
|
return &QueryNodeTagLogic{
|
||||||
|
Logger: logger.WithContext(ctx),
|
||||||
|
ctx: ctx,
|
||||||
|
svcCtx: svcCtx,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l *QueryNodeTagLogic) QueryNodeTag() (resp *types.QueryNodeTagResponse, err error) {
|
||||||
|
|
||||||
|
var nodes []*node.Node
|
||||||
|
if err = l.svcCtx.DB.WithContext(l.ctx).Model(&node.Node{}).Find(&nodes).Error; err != nil {
|
||||||
|
l.Errorw("[QueryNodeTag] Query Database Error: ", logger.Field("error", err.Error()))
|
||||||
|
return nil, errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), "[QueryNodeTag] Query Database Error")
|
||||||
|
}
|
||||||
|
var tags []string
|
||||||
|
for _, item := range nodes {
|
||||||
|
tags = append(tags, strings.Split(item.Tags, ",")...)
|
||||||
|
}
|
||||||
|
|
||||||
|
return &types.QueryNodeTagResponse{
|
||||||
|
Tags: tool.RemoveDuplicateElements(tags...),
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
@ -1477,6 +1477,10 @@ type QueryDocumentListResponse struct {
|
|||||||
List []Document `json:"list"`
|
List []Document `json:"list"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type QueryNodeTagResponse struct {
|
||||||
|
Tags []string `json:"tags"`
|
||||||
|
}
|
||||||
|
|
||||||
type QueryOrderDetailRequest struct {
|
type QueryOrderDetailRequest struct {
|
||||||
OrderNo string `form:"order_no" validate:"required"`
|
OrderNo string `form:"order_no" validate:"required"`
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user