mirror of
https://gitee.com/XM-GO/PandaX.git
synced 2026-04-23 02:48:34 +08:00
75 lines
2.2 KiB
Go
75 lines
2.2 KiB
Go
// ==========================================================================
|
||
// 生成日期:2023-03-29 20:01:11 +0800 CST
|
||
// 生成路径: apps/visual/services/rulechain.go
|
||
// 生成人:panda
|
||
// ==========================================================================
|
||
|
||
package services
|
||
|
||
import (
|
||
"github.com/PandaXGO/PandaKit/biz"
|
||
"pandax/apps/rule/entity"
|
||
"pandax/pkg/global"
|
||
"pandax/pkg/tool"
|
||
)
|
||
|
||
type (
|
||
RuleChainMsgLogModel interface {
|
||
Insert(data entity.RuleChainMsgLog) *entity.RuleChainMsgLog
|
||
FindListPage(page, pageSize int, data entity.RuleChainMsgLog) (*[]entity.RuleChainMsgLog, int64)
|
||
Delete(data entity.RuleChainMsgLog)
|
||
}
|
||
|
||
ruleChainLogModelImpl struct {
|
||
table string
|
||
}
|
||
)
|
||
|
||
var RuleChainMsgLogModelDao RuleChainMsgLogModel = &ruleChainLogModelImpl{
|
||
table: `rule_chain_msg_log`,
|
||
}
|
||
|
||
func (m *ruleChainLogModelImpl) Insert(data entity.RuleChainMsgLog) *entity.RuleChainMsgLog {
|
||
err := global.Db.Table(m.table).Create(&data).Error
|
||
biz.ErrIsNil(err, "添加规则链失败")
|
||
return &data
|
||
}
|
||
|
||
func (m *ruleChainLogModelImpl) FindListPage(page, pageSize int, data entity.RuleChainMsgLog) (*[]entity.RuleChainMsgLog, int64) {
|
||
list := make([]entity.RuleChainMsgLog, 0)
|
||
var total int64 = 0
|
||
offset := pageSize * (page - 1)
|
||
db := global.Db.Table(m.table)
|
||
// 此处填写 where参数判断
|
||
if data.DeviceName != "" {
|
||
db = db.Where("device_name = ?", data.DeviceName)
|
||
}
|
||
if data.MessageId != "" {
|
||
db = db.Where("message_id = ?", data.MessageId)
|
||
}
|
||
if data.MsgType != "" {
|
||
db = db.Where("msg_type = ?", data.MsgType)
|
||
}
|
||
// 组织数据访问权限
|
||
tool.OrgAuthSet(db, data.RoleId, data.Owner)
|
||
err := db.Count(&total).Error
|
||
err = db.Order("create_at").Limit(pageSize).Offset(offset).Find(&list).Error
|
||
biz.ErrIsNil(err, "查询规则链分页列表失败")
|
||
return &list, total
|
||
}
|
||
|
||
func (m *ruleChainLogModelImpl) Delete(data entity.RuleChainMsgLog) {
|
||
db := global.Db.Table(m.table)
|
||
// 此处填写 where参数判断
|
||
if data.DeviceName != "" {
|
||
db = db.Where("device_name = ?", data.DeviceName)
|
||
}
|
||
if data.MessageId != "" {
|
||
db = db.Where("message_id = ?", data.MessageId)
|
||
}
|
||
if data.MsgType != "" {
|
||
db = db.Where("msg_type = ?", data.MsgType)
|
||
}
|
||
biz.ErrIsNil(db.Delete(&entity.RuleChainMsgLog{}).Error, "删除规则链失败")
|
||
}
|