Files
PandaX/apps/device/services/product.go

161 lines
4.8 KiB
Go

package services
import (
"github.com/PandaXGO/PandaKit/biz"
"pandax/apps/device/entity"
"pandax/pkg/cache"
"pandax/pkg/global"
)
type (
ProductModel interface {
Insert(data entity.Product) *entity.Product
FindOne(id string) *entity.ProductRes
FindListPage(page, pageSize int, data entity.Product) (*[]entity.ProductRes, int64)
FindList(data entity.Product) *[]entity.ProductRes
Update(data entity.Product) *entity.Product
Delete(ids []string)
FindProductCount() entity.DeviceCount
}
productModelImpl struct {
table string
}
)
var ProductModelDao ProductModel = &productModelImpl{
table: `products`,
}
func (m *productModelImpl) Insert(data entity.Product) *entity.Product {
tx := global.Db.Begin()
// 添加产品及规则链到redis中
err := tx.Table(m.table).Create(&data).Error
biz.ErrIsNil(err, "添加产品失败")
// 创建taos数据库超级表
err = createDeviceStable(data.Id)
if err != nil {
tx.Rollback()
biz.ErrIsNil(err, "添加设备失败,超级表创建失败")
}
tx.Commit()
return &data
}
func (m *productModelImpl) FindOne(id string) *entity.ProductRes {
resData := new(entity.ProductRes)
db := global.Db.Table(m.table).Where("id = ?", id)
err := db.Preload("ProductCategory").First(resData).Error
biz.ErrIsNil(err, "查询产品失败")
return resData
}
func (m *productModelImpl) FindListPage(page, pageSize int, data entity.Product) (*[]entity.ProductRes, int64) {
list := make([]entity.ProductRes, 0)
var total int64 = 0
offset := pageSize * (page - 1)
db := global.Db.Table(m.table)
// 此处填写 where参数判断
if data.Status != "" {
db = db.Where("status = ?", data.Status)
}
if data.DeviceType != "" {
db = db.Where("device_type = ?", data.DeviceType)
}
if data.ProductCategoryId != "" {
db = db.Where("product_category_id = ?", data.ProductCategoryId)
}
if data.ProtocolName != "" {
db = db.Where("protocol_name like ?", "%"+data.ProtocolName+"%")
}
if data.Name != "" {
db = db.Where("name like ?", "%"+data.Name+"%")
}
if data.RuleChainId != "" {
db = db.Where("rule_chain_id = ?", data.RuleChainId)
}
err := db.Count(&total).Error
err = db.Order("create_time").Preload("ProductCategory").Limit(pageSize).Offset(offset).Find(&list).Error
biz.ErrIsNil(err, "查询产品分页列表失败")
return &list, total
}
func (m *productModelImpl) FindList(data entity.Product) *[]entity.ProductRes {
list := make([]entity.ProductRes, 0)
db := global.Db.Table(m.table)
// 此处填写 where参数判断
if data.Status != "" {
db = db.Where("status = ?", data.Status)
}
if data.DeviceType != "" {
db = db.Where("device_type = ?", data.DeviceType)
}
if data.ProductCategoryId != "" {
db = db.Where("product_category_id = ?", data.ProductCategoryId)
}
if data.ProtocolName != "" {
db = db.Where("protocol_name like ?", "%"+data.ProtocolName+"%")
}
if data.Name != "" {
db = db.Where("name like ?", "%"+data.Name+"%")
}
if data.RuleChainId != "" {
db = db.Where("rule_chain_id = ?", data.RuleChainId)
}
biz.ErrIsNil(db.Order("create_time").Preload("ProductCategory").Find(&list).Error, "查询产品列表失败")
return &list
}
func (m *productModelImpl) Update(data entity.Product) *entity.Product {
// go的一些默认值 int 0 bool false 保存失败需要先转成map
err := global.Db.Table(m.table).Where("id = ?", data.Id).Updates(data).Error
biz.ErrIsNil(err, "修改产品失败")
return &data
}
func (m *productModelImpl) Delete(ids []string) {
biz.ErrIsNil(global.Db.Table(m.table).Delete(&entity.Product{}, "id in (?)", ids).Error, "删除产品失败")
for _, id := range ids {
// 删除超级表
err := deleteDeviceStable(id)
global.Log.Error("时序数据库超级表删除失败", err)
// 删除所有缓存
cache.DelProductRule(id)
}
}
func createDeviceStable(productId string) error {
err := global.TdDb.CreateStable(productId + "_" + entity.ATTRIBUTES_TSL)
if err != nil {
return err
}
err = global.TdDb.CreateStable(productId + "_" + entity.TELEMETRY_TSL)
if err != nil {
return err
}
return nil
}
func deleteDeviceStable(productId string) error {
err := global.TdDb.DropStable(productId + "_" + entity.ATTRIBUTES_TSL)
if err != nil {
return err
}
err = global.TdDb.DropStable(productId + "_" + entity.TELEMETRY_TSL)
if err != nil {
return err
}
return nil
}
// 获取产品数量统计
func (m *productModelImpl) FindProductCount() (count entity.DeviceCount) {
sql := `SELECT COUNT(*) AS total, (SELECT COUNT(*) FROM products WHERE DATE(create_time) = CURDATE()) AS today FROM products`
if global.Conf.Server.DbType == "postgresql" {
sql = `SELECT COUNT(*) AS total, (SELECT COUNT(*) FROM products WHERE DATE(create_time) = current_date) AS today FROM products`
}
err := global.Db.Raw(sql).Scan(&count).Error
biz.ErrIsNil(err, "获取产品统计总数失败")
return
}