mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-03 23:20:26 +08:00
370 lines
11 KiB
Go
370 lines
11 KiB
Go
package services
|
|
|
|
import (
|
|
"context"
|
|
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
|
|
"github.com/TeaOSLab/EdgeAPI/internal/utils"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
"github.com/iwind/TeaGo/types"
|
|
)
|
|
|
|
type NodeIPAddressService struct {
|
|
BaseService
|
|
}
|
|
|
|
// CreateNodeIPAddress 创建IP地址
|
|
func (this *NodeIPAddressService) CreateNodeIPAddress(ctx context.Context, req *pb.CreateNodeIPAddressRequest) (*pb.CreateNodeIPAddressResponse, error) {
|
|
// 校验请求
|
|
adminId, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
addressId, err := models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, req.Role, req.Name, req.Ip, req.CanAccess, req.IsUp, 0, req.NodeClusterIds)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &pb.CreateNodeIPAddressResponse{NodeIPAddressId: addressId}, nil
|
|
}
|
|
|
|
// CreateNodeIPAddresses 批量创建IP地址
|
|
func (this *NodeIPAddressService) CreateNodeIPAddresses(ctx context.Context, req *pb.CreateNodeIPAddressesRequest) (*pb.CreateNodeIPAddressesResponse, error) {
|
|
// 校验请求
|
|
adminId, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
// 创建分组
|
|
groupId, err := models.SharedNodeIPAddressGroupDAO.CreateGroup(tx, req.GroupValue, req.GroupValue)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var result = []int64{}
|
|
for _, ip := range req.IpList {
|
|
addressId, err := models.SharedNodeIPAddressDAO.CreateAddress(tx, adminId, req.NodeId, req.Role, req.Name, ip, req.CanAccess, req.IsUp, groupId, req.NodeClusterIds)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
result = append(result, addressId)
|
|
}
|
|
|
|
return &pb.CreateNodeIPAddressesResponse{NodeIPAddressIds: result}, nil
|
|
}
|
|
|
|
// UpdateNodeIPAddress 修改IP地址
|
|
func (this *NodeIPAddressService) UpdateNodeIPAddress(ctx context.Context, req *pb.UpdateNodeIPAddressRequest) (*pb.RPCSuccess, error) {
|
|
// 校验请求
|
|
adminId, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
err = models.SharedNodeIPAddressDAO.UpdateAddress(tx, adminId, req.NodeIPAddressId, req.Name, req.Ip, req.CanAccess, req.IsOn, req.IsUp, req.ClusterIds)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return this.Success()
|
|
}
|
|
|
|
// UpdateNodeIPAddressNodeId 修改IP地址所属节点
|
|
func (this *NodeIPAddressService) UpdateNodeIPAddressNodeId(ctx context.Context, req *pb.UpdateNodeIPAddressNodeIdRequest) (*pb.RPCSuccess, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
err = models.SharedNodeIPAddressDAO.UpdateAddressNodeId(tx, req.NodeIPAddressId, req.NodeId)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return this.Success()
|
|
}
|
|
|
|
// DisableNodeIPAddress 禁用单个IP地址
|
|
func (this *NodeIPAddressService) DisableNodeIPAddress(ctx context.Context, req *pb.DisableNodeIPAddressRequest) (*pb.DisableNodeIPAddressResponse, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
err = models.SharedNodeIPAddressDAO.DisableAddress(tx, req.NodeIPAddressId)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &pb.DisableNodeIPAddressResponse{}, nil
|
|
}
|
|
|
|
// DisableAllNodeIPAddressesWithNodeId 禁用某个节点的IP地址
|
|
func (this *NodeIPAddressService) DisableAllNodeIPAddressesWithNodeId(ctx context.Context, req *pb.DisableAllNodeIPAddressesWithNodeIdRequest) (*pb.DisableAllNodeIPAddressesWithNodeIdResponse, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
err = models.SharedNodeIPAddressDAO.DisableAllAddressesWithNodeId(tx, req.NodeId, req.Role)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &pb.DisableAllNodeIPAddressesWithNodeIdResponse{}, nil
|
|
}
|
|
|
|
// FindEnabledNodeIPAddress 查找单个IP地址
|
|
func (this *NodeIPAddressService) FindEnabledNodeIPAddress(ctx context.Context, req *pb.FindEnabledNodeIPAddressRequest) (*pb.FindEnabledNodeIPAddressResponse, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
address, err := models.SharedNodeIPAddressDAO.FindEnabledAddress(tx, req.NodeIPAddressId)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if address == nil {
|
|
return &pb.FindEnabledNodeIPAddressResponse{
|
|
NodeIPAddress: nil,
|
|
}, nil
|
|
}
|
|
|
|
// CDN集群
|
|
var pbNodeClusters = []*pb.NodeCluster{}
|
|
if len(address.ClusterIds) > 0 {
|
|
if address.Role == nodeconfigs.NodeRoleNode { // 边缘节点
|
|
var clusterIds = address.DecodeClusterIds()
|
|
for _, clusterId := range clusterIds {
|
|
cluster, err := models.SharedNodeClusterDAO.FindClusterBasicInfo(tx, clusterId, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if cluster != nil {
|
|
pbNodeClusters = append(pbNodeClusters, &pb.NodeCluster{
|
|
Id: int64(cluster.Id),
|
|
Name: cluster.Name,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return &pb.FindEnabledNodeIPAddressResponse{NodeIPAddress: &pb.NodeIPAddress{
|
|
Id: int64(address.Id),
|
|
NodeId: int64(address.NodeId),
|
|
Role: address.Role,
|
|
Name: address.Name,
|
|
Ip: address.Ip,
|
|
Description: address.Description,
|
|
State: int64(address.State),
|
|
Order: int64(address.Order),
|
|
CanAccess: address.CanAccess,
|
|
IsOn: address.IsOn,
|
|
IsUp: address.IsUp,
|
|
IsHealthy: address.IsHealthy,
|
|
BackupIP: address.DecodeBackupIP(),
|
|
NodeClusters: pbNodeClusters,
|
|
}}, nil
|
|
}
|
|
|
|
// FindAllEnabledNodeIPAddressesWithNodeId 查找节点的所有地址
|
|
func (this *NodeIPAddressService) FindAllEnabledNodeIPAddressesWithNodeId(ctx context.Context, req *pb.FindAllEnabledNodeIPAddressesWithNodeIdRequest) (*pb.FindAllEnabledNodeIPAddressesWithNodeIdResponse, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
|
|
addresses, err := models.SharedNodeIPAddressDAO.FindAllEnabledAddressesWithNode(tx, req.NodeId, req.Role)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var result = []*pb.NodeIPAddress{}
|
|
var cacheMap = utils.NewCacheMap()
|
|
for _, address := range addresses {
|
|
// 集群
|
|
var pbNodeClusters = []*pb.NodeCluster{}
|
|
var clusterIds = address.DecodeClusterIds()
|
|
if len(clusterIds) > 0 {
|
|
if address.Role == nodeconfigs.NodeRoleNode { // 边缘节点
|
|
for _, clusterId := range clusterIds {
|
|
nodeCluster, err := models.SharedNodeClusterDAO.FindClusterBasicInfo(tx, clusterId, cacheMap)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if nodeCluster != nil {
|
|
pbNodeClusters = append(pbNodeClusters, &pb.NodeCluster{
|
|
Id: int64(nodeCluster.Id),
|
|
Name: nodeCluster.Name,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
result = append(result, &pb.NodeIPAddress{
|
|
Id: int64(address.Id),
|
|
NodeId: int64(address.NodeId),
|
|
Role: address.Role,
|
|
Name: address.Name,
|
|
Ip: address.Ip,
|
|
Description: address.Description,
|
|
State: int64(address.State),
|
|
Order: int64(address.Order),
|
|
CanAccess: address.CanAccess,
|
|
IsOn: address.IsOn,
|
|
IsUp: address.IsUp,
|
|
IsHealthy: address.IsHealthy,
|
|
BackupIP: address.DecodeBackupIP(),
|
|
NodeClusters: pbNodeClusters,
|
|
})
|
|
}
|
|
|
|
return &pb.FindAllEnabledNodeIPAddressesWithNodeIdResponse{NodeIPAddresses: result}, nil
|
|
}
|
|
|
|
// CountAllEnabledNodeIPAddresses 计算IP地址数量
|
|
func (this *NodeIPAddressService) CountAllEnabledNodeIPAddresses(ctx context.Context, req *pb.CountAllEnabledNodeIPAddressesRequest) (*pb.RPCCountResponse, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
count, err := models.SharedNodeIPAddressDAO.CountAllEnabledIPAddresses(tx, req.Role, req.NodeClusterId, types.Int8(req.UpState), req.Keyword)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return this.SuccessCount(count)
|
|
}
|
|
|
|
// ListEnabledNodeIPAddresses 列出单页IP地址
|
|
func (this *NodeIPAddressService) ListEnabledNodeIPAddresses(ctx context.Context, req *pb.ListEnabledNodeIPAddressesRequest) (*pb.ListEnabledNodeIPAddressesResponse, error) {
|
|
// 校验请求
|
|
_, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
addresses, err := models.SharedNodeIPAddressDAO.ListEnabledIPAddresses(tx, req.Role, req.NodeClusterId, types.Int8(req.UpState), req.Keyword, req.Offset, req.Size)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var pbAddrs = []*pb.NodeIPAddress{}
|
|
for _, addr := range addresses {
|
|
var clusterIds = addr.DecodeClusterIds()
|
|
var pbNodeClusters = []*pb.NodeCluster{}
|
|
if len(clusterIds) > 0 {
|
|
if addr.Role == nodeconfigs.NodeRoleNode { // 边缘节点
|
|
for _, clusterId := range clusterIds {
|
|
cluster, err := models.SharedNodeClusterDAO.FindClusterBasicInfo(tx, clusterId, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if cluster != nil {
|
|
pbNodeClusters = append(pbNodeClusters, &pb.NodeCluster{
|
|
Id: int64(cluster.Id),
|
|
Name: cluster.Name,
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
pbAddrs = append(pbAddrs, &pb.NodeIPAddress{
|
|
Id: int64(addr.Id),
|
|
NodeId: int64(addr.NodeId),
|
|
Role: addr.Role,
|
|
Name: addr.Name,
|
|
Ip: addr.Ip,
|
|
Description: addr.Description,
|
|
CanAccess: addr.CanAccess,
|
|
IsOn: addr.IsOn,
|
|
IsUp: addr.IsUp,
|
|
IsHealthy: addr.IsHealthy,
|
|
BackupIP: addr.DecodeBackupIP(),
|
|
NodeClusters: pbNodeClusters,
|
|
})
|
|
}
|
|
return &pb.ListEnabledNodeIPAddressesResponse{NodeIPAddresses: pbAddrs}, nil
|
|
}
|
|
|
|
// UpdateNodeIPAddressIsUp 设置上下线状态
|
|
func (this *NodeIPAddressService) UpdateNodeIPAddressIsUp(ctx context.Context, req *pb.UpdateNodeIPAddressIsUpRequest) (*pb.RPCSuccess, error) {
|
|
// 校验请求
|
|
adminId, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
err = models.SharedNodeIPAddressDAO.UpdateAddressIsUp(tx, req.NodeIPAddressId, req.IsUp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// 增加日志
|
|
if req.IsUp {
|
|
err = models.SharedNodeIPAddressLogDAO.CreateLog(tx, adminId, req.NodeIPAddressId, "手动上线")
|
|
} else {
|
|
err = models.SharedNodeIPAddressLogDAO.CreateLog(tx, adminId, req.NodeIPAddressId, "手动下线")
|
|
}
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return this.Success()
|
|
}
|
|
|
|
// RestoreNodeIPAddressBackupIP 还原备用IP状态
|
|
func (this *NodeIPAddressService) RestoreNodeIPAddressBackupIP(ctx context.Context, req *pb.RestoreNodeIPAddressBackupIPRequest) (*pb.RPCSuccess, error) {
|
|
// 校验请求
|
|
adminId, err := this.ValidateAdmin(ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var tx = this.NullTx()
|
|
err = models.SharedNodeIPAddressDAO.UpdateAddressBackupIP(tx, req.NodeIPAddressId, 0, "")
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// 增加日志
|
|
err = models.SharedNodeIPAddressLogDAO.CreateLog(tx, adminId, req.NodeIPAddressId, "恢复IP状态")
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return this.Success()
|
|
}
|