Files
EdgeAPI/internal/rpc/services/service_authority_node.go

246 lines
6.7 KiB
Go
Raw Normal View History

2021-04-13 21:23:26 +08:00
package services
import (
"context"
2022-06-06 19:39:08 +08:00
"encoding/json"
2021-04-13 21:23:26 +08:00
"github.com/TeaOSLab/EdgeAPI/internal/db/models/authority"
"github.com/TeaOSLab/EdgeAPI/internal/errors"
rpcutils "github.com/TeaOSLab/EdgeAPI/internal/rpc/utils"
2022-06-06 19:39:08 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
2021-04-13 21:23:26 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"google.golang.org/grpc/metadata"
2022-06-06 19:39:08 +08:00
"time"
2021-04-13 21:23:26 +08:00
)
type AuthorityNodeService struct {
BaseService
}
// CreateAuthorityNode 创建认证节点
func (this *AuthorityNodeService) CreateAuthorityNode(ctx context.Context, req *pb.CreateAuthorityNodeRequest) (*pb.CreateAuthorityNodeResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
nodeId, err := authority.SharedAuthorityNodeDAO.CreateAuthorityNode(tx, req.Name, req.Description, req.IsOn)
if err != nil {
return nil, err
}
2021-11-24 12:00:38 +08:00
return &pb.CreateAuthorityNodeResponse{AuthorityNodeId: nodeId}, nil
2021-04-13 21:23:26 +08:00
}
// UpdateAuthorityNode 修改认证节点
func (this *AuthorityNodeService) UpdateAuthorityNode(ctx context.Context, req *pb.UpdateAuthorityNodeRequest) (*pb.RPCSuccess, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
2021-11-24 12:00:38 +08:00
err = authority.SharedAuthorityNodeDAO.UpdateAuthorityNode(tx, req.AuthorityNodeId, req.Name, req.Description, req.IsOn)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
return this.Success()
}
// DeleteAuthorityNode 删除认证节点
func (this *AuthorityNodeService) DeleteAuthorityNode(ctx context.Context, req *pb.DeleteAuthorityNodeRequest) (*pb.RPCSuccess, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
2021-11-24 12:00:38 +08:00
err = authority.SharedAuthorityNodeDAO.DisableAuthorityNode(tx, req.AuthorityNodeId)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
return this.Success()
}
// FindAllEnabledAuthorityNodes 列出所有可用认证节点
func (this *AuthorityNodeService) FindAllEnabledAuthorityNodes(ctx context.Context, req *pb.FindAllEnabledAuthorityNodesRequest) (*pb.FindAllEnabledAuthorityNodesResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
nodes, err := authority.SharedAuthorityNodeDAO.FindAllEnabledAuthorityNodes(tx)
if err != nil {
return nil, err
}
result := []*pb.AuthorityNode{}
for _, node := range nodes {
result = append(result, &pb.AuthorityNode{
Id: int64(node.Id),
2022-03-22 21:45:07 +08:00
IsOn: node.IsOn,
2021-04-13 21:23:26 +08:00
UniqueId: node.UniqueId,
Secret: node.Secret,
Name: node.Name,
Description: node.Description,
})
}
2021-11-24 12:00:38 +08:00
return &pb.FindAllEnabledAuthorityNodesResponse{AuthorityNodes: result}, nil
2021-04-13 21:23:26 +08:00
}
// CountAllEnabledAuthorityNodes 计算认证节点数量
func (this *AuthorityNodeService) CountAllEnabledAuthorityNodes(ctx context.Context, req *pb.CountAllEnabledAuthorityNodesRequest) (*pb.RPCCountResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
count, err := authority.SharedAuthorityNodeDAO.CountAllEnabledAuthorityNodes(tx)
if err != nil {
return nil, err
}
return this.SuccessCount(count)
}
// ListEnabledAuthorityNodes 列出单页的认证节点
func (this *AuthorityNodeService) ListEnabledAuthorityNodes(ctx context.Context, req *pb.ListEnabledAuthorityNodesRequest) (*pb.ListEnabledAuthorityNodesResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
nodes, err := authority.SharedAuthorityNodeDAO.ListEnabledAuthorityNodes(tx, req.Offset, req.Size)
if err != nil {
return nil, err
}
result := []*pb.AuthorityNode{}
for _, node := range nodes {
result = append(result, &pb.AuthorityNode{
Id: int64(node.Id),
2022-03-22 21:45:07 +08:00
IsOn: node.IsOn,
2021-04-13 21:23:26 +08:00
UniqueId: node.UniqueId,
Secret: node.Secret,
Name: node.Name,
Description: node.Description,
2022-03-22 19:30:30 +08:00
StatusJSON: node.Status,
2021-04-13 21:23:26 +08:00
})
}
2021-11-24 12:00:38 +08:00
return &pb.ListEnabledAuthorityNodesResponse{AuthorityNodes: result}, nil
2021-04-13 21:23:26 +08:00
}
// FindEnabledAuthorityNode 根据ID查找节点
func (this *AuthorityNodeService) FindEnabledAuthorityNode(ctx context.Context, req *pb.FindEnabledAuthorityNodeRequest) (*pb.FindEnabledAuthorityNodeResponse, error) {
2021-07-11 18:05:57 +08:00
_, err := this.ValidateAdmin(ctx, 0)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
2021-11-24 12:00:38 +08:00
node, err := authority.SharedAuthorityNodeDAO.FindEnabledAuthorityNode(tx, req.AuthorityNodeId)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
if node == nil {
2021-11-24 12:00:38 +08:00
return &pb.FindEnabledAuthorityNodeResponse{AuthorityNode: nil}, nil
2021-04-13 21:23:26 +08:00
}
result := &pb.AuthorityNode{
Id: int64(node.Id),
2022-03-22 21:45:07 +08:00
IsOn: node.IsOn,
2021-04-13 21:23:26 +08:00
UniqueId: node.UniqueId,
Secret: node.Secret,
Name: node.Name,
Description: node.Description,
}
2021-11-24 12:00:38 +08:00
return &pb.FindEnabledAuthorityNodeResponse{AuthorityNode: result}, nil
2021-04-13 21:23:26 +08:00
}
// FindCurrentAuthorityNode 获取当前认证节点的版本
func (this *AuthorityNodeService) FindCurrentAuthorityNode(ctx context.Context, req *pb.FindCurrentAuthorityNodeRequest) (*pb.FindCurrentAuthorityNodeResponse, error) {
2021-07-22 18:42:57 +08:00
_, err := this.ValidateAuthorityNode(ctx)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
md, ok := metadata.FromIncomingContext(ctx)
if !ok {
return nil, errors.New("context: need 'nodeId'")
}
nodeIds := md.Get("nodeid")
if len(nodeIds) == 0 {
return nil, errors.New("invalid 'nodeId'")
}
nodeId := nodeIds[0]
node, err := authority.SharedAuthorityNodeDAO.FindEnabledAuthorityNodeWithUniqueId(tx, nodeId)
if err != nil {
return nil, err
}
if node == nil {
2021-11-24 12:00:38 +08:00
return &pb.FindCurrentAuthorityNodeResponse{AuthorityNode: nil}, nil
2021-04-13 21:23:26 +08:00
}
result := &pb.AuthorityNode{
Id: int64(node.Id),
2022-03-22 21:45:07 +08:00
IsOn: node.IsOn,
2021-04-13 21:23:26 +08:00
UniqueId: node.UniqueId,
Secret: node.Secret,
Name: node.Name,
Description: node.Description,
}
2021-11-24 12:00:38 +08:00
return &pb.FindCurrentAuthorityNodeResponse{AuthorityNode: result}, nil
2021-04-13 21:23:26 +08:00
}
// UpdateAuthorityNodeStatus 更新节点状态
func (this *AuthorityNodeService) UpdateAuthorityNodeStatus(ctx context.Context, req *pb.UpdateAuthorityNodeStatusRequest) (*pb.RPCSuccess, error) {
// 校验节点
_, nodeId, err := this.ValidateNodeId(ctx, rpcutils.UserTypeAuthority)
if err != nil {
return nil, err
}
2021-11-24 12:00:38 +08:00
if req.AuthorityNodeId > 0 {
nodeId = req.AuthorityNodeId
2021-04-13 21:23:26 +08:00
}
if nodeId <= 0 {
return nil, errors.New("'nodeId' should be greater than 0")
}
2022-06-06 19:39:08 +08:00
var tx = this.NullTx()
// 修改时间戳
var nodeStatus = &nodeconfigs.NodeStatus{}
err = json.Unmarshal(req.StatusJSON, nodeStatus)
if err != nil {
return nil, errors.New("decode node status json failed: " + err.Error())
}
nodeStatus.UpdatedAt = time.Now().Unix()
2021-04-13 21:23:26 +08:00
2022-06-06 19:39:08 +08:00
// 保存
err = authority.SharedAuthorityNodeDAO.UpdateNodeStatus(tx, nodeId, nodeStatus)
2021-04-13 21:23:26 +08:00
if err != nil {
return nil, err
}
return this.Success()
}