mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 16:00:24 +08:00 
			
		
		
		
	实现基本的图表管理
This commit is contained in:
		
							
								
								
									
										143
									
								
								internal/db/models/metric_chart_dao.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										143
									
								
								internal/db/models/metric_chart_dao.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,143 @@
 | 
			
		||||
package models
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"github.com/TeaOSLab/EdgeAPI/internal/errors"
 | 
			
		||||
	_ "github.com/go-sql-driver/mysql"
 | 
			
		||||
	"github.com/iwind/TeaGo/Tea"
 | 
			
		||||
	"github.com/iwind/TeaGo/dbs"
 | 
			
		||||
	"github.com/iwind/TeaGo/maps"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	MetricChartStateEnabled  = 1 // 已启用
 | 
			
		||||
	MetricChartStateDisabled = 0 // 已禁用
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type MetricChartDAO dbs.DAO
 | 
			
		||||
 | 
			
		||||
func NewMetricChartDAO() *MetricChartDAO {
 | 
			
		||||
	return dbs.NewDAO(&MetricChartDAO{
 | 
			
		||||
		DAOObject: dbs.DAOObject{
 | 
			
		||||
			DB:     Tea.Env,
 | 
			
		||||
			Table:  "edgeMetricCharts",
 | 
			
		||||
			Model:  new(MetricChart),
 | 
			
		||||
			PkName: "id",
 | 
			
		||||
		},
 | 
			
		||||
	}).(*MetricChartDAO)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var SharedMetricChartDAO *MetricChartDAO
 | 
			
		||||
 | 
			
		||||
func init() {
 | 
			
		||||
	dbs.OnReady(func() {
 | 
			
		||||
		SharedMetricChartDAO = NewMetricChartDAO()
 | 
			
		||||
	})
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// EnableMetricChart 启用条目
 | 
			
		||||
func (this *MetricChartDAO) EnableMetricChart(tx *dbs.Tx, chartId int64) error {
 | 
			
		||||
	_, err := this.Query(tx).
 | 
			
		||||
		Pk(chartId).
 | 
			
		||||
		Set("state", MetricChartStateEnabled).
 | 
			
		||||
		Update()
 | 
			
		||||
	return err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// DisableMetricChart 禁用条目
 | 
			
		||||
func (this *MetricChartDAO) DisableMetricChart(tx *dbs.Tx, chartId int64) error {
 | 
			
		||||
	_, err := this.Query(tx).
 | 
			
		||||
		Pk(chartId).
 | 
			
		||||
		Set("state", MetricChartStateDisabled).
 | 
			
		||||
		Update()
 | 
			
		||||
	return err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// FindEnabledMetricChart 查找启用中的条目
 | 
			
		||||
func (this *MetricChartDAO) FindEnabledMetricChart(tx *dbs.Tx, chartId int64) (*MetricChart, error) {
 | 
			
		||||
	result, err := this.Query(tx).
 | 
			
		||||
		Pk(chartId).
 | 
			
		||||
		Attr("state", MetricChartStateEnabled).
 | 
			
		||||
		Find()
 | 
			
		||||
	if result == nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return result.(*MetricChart), err
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// FindMetricChartName 根据主键查找名称
 | 
			
		||||
func (this *MetricChartDAO) FindMetricChartName(tx *dbs.Tx, chartId int64) (string, error) {
 | 
			
		||||
	return this.Query(tx).
 | 
			
		||||
		Pk(chartId).
 | 
			
		||||
		Result("name").
 | 
			
		||||
		FindStringCol("")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// CreateChart 创建图表
 | 
			
		||||
func (this *MetricChartDAO) CreateChart(tx *dbs.Tx, itemId int64, name string, chartType string, widthDiv int32, maxItems int32, params maps.Map) (int64, error) {
 | 
			
		||||
	op := NewMetricChartOperator()
 | 
			
		||||
	op.ItemId = itemId
 | 
			
		||||
	op.Name = name
 | 
			
		||||
	op.Type = chartType
 | 
			
		||||
	op.WidthDiv = widthDiv
 | 
			
		||||
	op.MaxItems = maxItems
 | 
			
		||||
 | 
			
		||||
	if params == nil {
 | 
			
		||||
		params = maps.Map{}
 | 
			
		||||
	}
 | 
			
		||||
	paramsJSON, err := json.Marshal(params)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return 0, err
 | 
			
		||||
	}
 | 
			
		||||
	op.Params = paramsJSON
 | 
			
		||||
	op.IsOn = true
 | 
			
		||||
	op.State = MetricChartStateEnabled
 | 
			
		||||
	return this.SaveInt64(tx, op)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// UpdateChart 修改图表
 | 
			
		||||
func (this *MetricChartDAO) UpdateChart(tx *dbs.Tx, chartId int64, name string, chartType string, widthDiv int32, maxItems int32, params maps.Map, isOn bool) error {
 | 
			
		||||
	if chartId <= 0 {
 | 
			
		||||
		return errors.New("invalid chartId")
 | 
			
		||||
	}
 | 
			
		||||
	op := NewMetricChartOperator()
 | 
			
		||||
	op.Id = chartId
 | 
			
		||||
	op.Name = name
 | 
			
		||||
	op.Type = chartType
 | 
			
		||||
	op.WidthDiv = widthDiv
 | 
			
		||||
	op.MaxItems = maxItems
 | 
			
		||||
 | 
			
		||||
	if params == nil {
 | 
			
		||||
		params = maps.Map{}
 | 
			
		||||
	}
 | 
			
		||||
	paramsJSON, err := json.Marshal(params)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	op.Params = paramsJSON
 | 
			
		||||
 | 
			
		||||
	op.IsOn = isOn
 | 
			
		||||
 | 
			
		||||
	return this.Save(tx, op)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// CountEnabledCharts 计算图表数量
 | 
			
		||||
func (this *MetricChartDAO) CountEnabledCharts(tx *dbs.Tx, itemId int64) (int64, error) {
 | 
			
		||||
	return this.Query(tx).
 | 
			
		||||
		Attr("itemId", itemId).
 | 
			
		||||
		State(MetricChartStateEnabled).
 | 
			
		||||
		Count()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// ListEnabledCharts 列出单页图表
 | 
			
		||||
func (this *MetricChartDAO) ListEnabledCharts(tx *dbs.Tx, itemId int64, offset int64, size int64) (result []*MetricChart, err error) {
 | 
			
		||||
	_, err = this.Query(tx).
 | 
			
		||||
		Attr("itemId", itemId).
 | 
			
		||||
		State(MetricChartStateEnabled).
 | 
			
		||||
		Offset(offset).
 | 
			
		||||
		Limit(size).
 | 
			
		||||
		DescPk().
 | 
			
		||||
		Slice(&result).
 | 
			
		||||
		FindAll()
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										6
									
								
								internal/db/models/metric_chart_dao_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								internal/db/models/metric_chart_dao_test.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,6 @@
 | 
			
		||||
package models
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	_ "github.com/go-sql-driver/mysql"
 | 
			
		||||
	_ "github.com/iwind/TeaGo/bootstrap"
 | 
			
		||||
)
 | 
			
		||||
							
								
								
									
										32
									
								
								internal/db/models/metric_chart_model.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								internal/db/models/metric_chart_model.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,32 @@
 | 
			
		||||
package models
 | 
			
		||||
 | 
			
		||||
// MetricChart 指标图表
 | 
			
		||||
type MetricChart struct {
 | 
			
		||||
	Id       uint32 `field:"id"`       // ID
 | 
			
		||||
	ItemId   uint32 `field:"itemId"`   // 指标ID
 | 
			
		||||
	Name     string `field:"name"`     // 名称
 | 
			
		||||
	Type     string `field:"type"`     // 图形类型
 | 
			
		||||
	WidthDiv int32  `field:"widthDiv"` // 宽度划分
 | 
			
		||||
	Params   string `field:"params"`   // 图形参数
 | 
			
		||||
	Order    uint32 `field:"order"`    // 排序
 | 
			
		||||
	IsOn     uint8  `field:"isOn"`     // 是否启用
 | 
			
		||||
	State    uint8  `field:"state"`    // 状态
 | 
			
		||||
	MaxItems uint32 `field:"maxItems"` // 最多条目
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type MetricChartOperator struct {
 | 
			
		||||
	Id       interface{} // ID
 | 
			
		||||
	ItemId   interface{} // 指标ID
 | 
			
		||||
	Name     interface{} // 名称
 | 
			
		||||
	Type     interface{} // 图形类型
 | 
			
		||||
	WidthDiv interface{} // 宽度划分
 | 
			
		||||
	Params   interface{} // 图形参数
 | 
			
		||||
	Order    interface{} // 排序
 | 
			
		||||
	IsOn     interface{} // 是否启用
 | 
			
		||||
	State    interface{} // 状态
 | 
			
		||||
	MaxItems interface{} // 最多条目
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func NewMetricChartOperator() *MetricChartOperator {
 | 
			
		||||
	return &MetricChartOperator{}
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										1
									
								
								internal/db/models/metric_chart_model_ext.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								internal/db/models/metric_chart_model_ext.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
package models
 | 
			
		||||
@@ -458,6 +458,11 @@ func (this *APINode) registerServices(server *grpc.Server) {
 | 
			
		||||
		pb.RegisterMetricStatServiceServer(server, instance)
 | 
			
		||||
		this.rest(instance)
 | 
			
		||||
	}
 | 
			
		||||
	{
 | 
			
		||||
		instance := this.serviceInstance(&services.MetricChartService{}).(*services.MetricChartService)
 | 
			
		||||
		pb.RegisterMetricChartServiceServer(server, instance)
 | 
			
		||||
		this.rest(instance)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// TODO check service names
 | 
			
		||||
	for serviceName := range server.GetServiceInfo() {
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										147
									
								
								internal/rpc/services/service_metric_chart.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										147
									
								
								internal/rpc/services/service_metric_chart.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,147 @@
 | 
			
		||||
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
 | 
			
		||||
 | 
			
		||||
package services
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"encoding/json"
 | 
			
		||||
	"github.com/TeaOSLab/EdgeAPI/internal/db/models"
 | 
			
		||||
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
			
		||||
	"github.com/iwind/TeaGo/maps"
 | 
			
		||||
	"github.com/iwind/TeaGo/types"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// MetricChartService 指标图表相关服务
 | 
			
		||||
type MetricChartService struct {
 | 
			
		||||
	BaseService
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// CreateMetricChart 创建图表
 | 
			
		||||
func (this *MetricChartService) CreateMetricChart(ctx context.Context, req *pb.CreateMetricChartRequest) (*pb.CreateMetricChartResponse, error) {
 | 
			
		||||
	_, err := this.ValidateAdmin(ctx, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var tx = this.NullTx()
 | 
			
		||||
	var params = maps.Map{}
 | 
			
		||||
	if len(req.ParamsJSON) > 0 {
 | 
			
		||||
		err = json.Unmarshal(req.ParamsJSON, ¶ms)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return nil, err
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	chartId, err := models.SharedMetricChartDAO.CreateChart(tx, req.MetricItemId, req.Name, req.Type, req.WidthDiv, req.MaxItems, params)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return &pb.CreateMetricChartResponse{MetricChartId: chartId}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// UpdateMetricChart 修改图表
 | 
			
		||||
func (this *MetricChartService) UpdateMetricChart(ctx context.Context, req *pb.UpdateMetricChartRequest) (*pb.RPCSuccess, error) {
 | 
			
		||||
	_, err := this.ValidateAdmin(ctx, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var tx = this.NullTx()
 | 
			
		||||
	var params = maps.Map{}
 | 
			
		||||
	if len(req.ParamsJSON) > 0 {
 | 
			
		||||
		err = json.Unmarshal(req.ParamsJSON, ¶ms)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return nil, err
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	err = models.SharedMetricChartDAO.UpdateChart(tx, req.MetricChartId, req.Name, req.Type, req.WidthDiv, req.MaxItems, params, req.IsOn)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return this.Success()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// FindEnabledMetricChart 查找单个图表
 | 
			
		||||
func (this *MetricChartService) FindEnabledMetricChart(ctx context.Context, req *pb.FindEnabledMetricChartRequest) (*pb.FindEnabledMetricChartResponse, error) {
 | 
			
		||||
	_, err := this.ValidateAdmin(ctx, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var tx = this.NullTx()
 | 
			
		||||
	chart, err := models.SharedMetricChartDAO.FindEnabledMetricChart(tx, req.MetricChartId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if chart == nil {
 | 
			
		||||
		return &pb.FindEnabledMetricChartResponse{MetricChart: nil}, nil
 | 
			
		||||
	}
 | 
			
		||||
	return &pb.FindEnabledMetricChartResponse{
 | 
			
		||||
		MetricChart: &pb.MetricChart{
 | 
			
		||||
			Id:         int64(chart.Id),
 | 
			
		||||
			Name:       chart.Name,
 | 
			
		||||
			Type:       chart.Type,
 | 
			
		||||
			WidthDiv:   types.Int32(chart.WidthDiv),
 | 
			
		||||
			MaxItems:   types.Int32(chart.MaxItems),
 | 
			
		||||
			ParamsJSON: []byte(chart.Params),
 | 
			
		||||
			IsOn:       chart.IsOn == 1,
 | 
			
		||||
			MetricItem: &pb.MetricItem{Id: int64(chart.ItemId)},
 | 
			
		||||
		},
 | 
			
		||||
	}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// CountEnabledMetricCharts 计算图表数量
 | 
			
		||||
func (this *MetricChartService) CountEnabledMetricCharts(ctx context.Context, req *pb.CountEnabledMetricChartsRequest) (*pb.RPCCountResponse, error) {
 | 
			
		||||
	_, err := this.ValidateAdmin(ctx, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var tx = this.NullTx()
 | 
			
		||||
	count, err := models.SharedMetricChartDAO.CountEnabledCharts(tx, req.MetricItemId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return this.SuccessCount(count)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// ListEnabledMetricCharts 列出单页图表
 | 
			
		||||
func (this *MetricChartService) ListEnabledMetricCharts(ctx context.Context, req *pb.ListEnabledMetricChartsRequest) (*pb.ListEnabledMetricChartsResponse, error) {
 | 
			
		||||
	_, err := this.ValidateAdmin(ctx, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var tx = this.NullTx()
 | 
			
		||||
	charts, err := models.SharedMetricChartDAO.ListEnabledCharts(tx, req.MetricItemId, req.Offset, req.Size)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	var pbCharts []*pb.MetricChart
 | 
			
		||||
	for _, chart := range charts {
 | 
			
		||||
		pbCharts = append(pbCharts, &pb.MetricChart{
 | 
			
		||||
			Id:         int64(chart.Id),
 | 
			
		||||
			Name:       chart.Name,
 | 
			
		||||
			Type:       chart.Type,
 | 
			
		||||
			WidthDiv:   types.Int32(chart.WidthDiv),
 | 
			
		||||
			MaxItems:   types.Int32(chart.MaxItems),
 | 
			
		||||
			ParamsJSON: []byte(chart.Params),
 | 
			
		||||
			IsOn:       chart.IsOn == 1,
 | 
			
		||||
		})
 | 
			
		||||
	}
 | 
			
		||||
	return &pb.ListEnabledMetricChartsResponse{MetricCharts: pbCharts}, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// DeleteMetricChart 删除图表
 | 
			
		||||
func (this *MetricChartService) DeleteMetricChart(ctx context.Context, req *pb.DeleteMetricChartRequest) (*pb.RPCSuccess, error) {
 | 
			
		||||
	_, err := this.ValidateAdmin(ctx, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var tx = this.NullTx()
 | 
			
		||||
	err = models.SharedMetricChartDAO.DisableMetricChart(tx, req.MetricChartId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return this.Success()
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user