Files
EdgeAPI/internal/db/models/message_receiver_dao.go

201 lines
4.9 KiB
Go
Raw Normal View History

2021-04-12 19:19:15 +08:00
package models
import (
"encoding/json"
_ "github.com/go-sql-driver/mysql"
"github.com/iwind/TeaGo/Tea"
"github.com/iwind/TeaGo/dbs"
"github.com/iwind/TeaGo/maps"
)
const (
MessageReceiverStateEnabled = 1 // 已启用
MessageReceiverStateDisabled = 0 // 已禁用
)
type MessageReceiverDAO dbs.DAO
func NewMessageReceiverDAO() *MessageReceiverDAO {
return dbs.NewDAO(&MessageReceiverDAO{
DAOObject: dbs.DAOObject{
DB: Tea.Env,
Table: "edgeMessageReceivers",
Model: new(MessageReceiver),
PkName: "id",
},
}).(*MessageReceiverDAO)
}
var SharedMessageReceiverDAO *MessageReceiverDAO
func init() {
dbs.OnReady(func() {
SharedMessageReceiverDAO = NewMessageReceiverDAO()
})
}
// EnableMessageReceiver 启用条目
func (this *MessageReceiverDAO) EnableMessageReceiver(tx *dbs.Tx, id int64) error {
_, err := this.Query(tx).
Pk(id).
Set("state", MessageReceiverStateEnabled).
Update()
return err
}
// DisableMessageReceiver 禁用条目
func (this *MessageReceiverDAO) DisableMessageReceiver(tx *dbs.Tx, id int64) error {
_, err := this.Query(tx).
Pk(id).
Set("state", MessageReceiverStateDisabled).
Update()
return err
}
// FindEnabledMessageReceiver 查找启用中的条目
func (this *MessageReceiverDAO) FindEnabledMessageReceiver(tx *dbs.Tx, id int64) (*MessageReceiver, error) {
result, err := this.Query(tx).
Pk(id).
Attr("state", MessageReceiverStateEnabled).
Find()
if result == nil {
return nil, err
}
return result.(*MessageReceiver), err
}
// DisableReceivers 禁用一组接收人
func (this *MessageReceiverDAO) DisableReceivers(tx *dbs.Tx, clusterId int64, nodeId int64, serverId int64) error {
return this.Query(tx).
Attr("clusterId", clusterId).
Attr("nodeId", nodeId).
Attr("serverId", serverId).
Set("state", MessageReceiverStateDisabled).
UpdateQuickly()
}
// CreateReceiver 创建接收人
func (this *MessageReceiverDAO) CreateReceiver(tx *dbs.Tx, role string, clusterId int64, nodeId int64, serverId int64, messageType MessageType, params maps.Map, recipientId int64, recipientGroupId int64) (int64, error) {
var op = NewMessageReceiverOperator()
op.Role = role
op.ClusterId = clusterId
op.NodeId = nodeId
op.ServerId = serverId
2021-04-12 19:19:15 +08:00
op.Type = messageType
if params == nil {
params = maps.Map{}
}
paramsJSON, err := json.Marshal(params)
if err != nil {
return 0, err
}
op.Params = paramsJSON
op.RecipientId = recipientId
op.RecipientGroupId = recipientGroupId
op.State = MessageReceiverStateEnabled
return this.SaveInt64(tx, op)
}
// CountAllEnabledReceivers 计算接收人数量
func (this *MessageReceiverDAO) CountAllEnabledReceivers(tx *dbs.Tx, role string, clusterId int64, nodeId int64, serverId int64, messageType string) (int64, error) {
query := this.Query(tx)
if len(messageType) > 0 {
query.Attr("type", []string{"*", messageType}) // *表示所有的
2021-07-18 15:52:34 +08:00
}
return query.
Attr("role", role).
Attr("clusterId", clusterId).
Attr("nodeId", nodeId).
Attr("serverId", serverId).
State(MessageReceiverStateEnabled).
Count()
}
2021-07-18 15:52:34 +08:00
// FindEnabledBestFitReceivers 查询最适合的接收人
func (this *MessageReceiverDAO) FindEnabledBestFitReceivers(tx *dbs.Tx, role string, clusterId int64, nodeId int64, serverId int64, messageType string) (result []*MessageReceiver, err error) {
// serverId优先
query := this.Query(tx)
if len(messageType) > 0 {
query.Attr("type", []string{"*", messageType}) // *表示所有的
}
if len(role) > 0 {
query.Attr("role", role)
}
if serverId > 0 {
query.Attr("serverId", serverId)
} else if nodeId > 0 {
query.Attr("nodeId", nodeId)
} else if clusterId > 0 {
query.Attr("clusterId", clusterId)
}
_, err = query.
State(MessageReceiverStateEnabled).
AscPk().
Slice(&result).
FindAll()
if err != nil || len(result) > 0 {
return
}
// nodeId优先
if serverId > 0 && nodeId > 0 {
query = this.Query(tx)
if len(messageType) > 0 {
query.Attr("type", []string{"*", messageType}) // *表示所有的
}
if len(role) > 0 {
query.Attr("role", role)
}
query.Attr("nodeId", nodeId)
2021-07-18 15:52:34 +08:00
_, err = query.
State(MessageReceiverStateEnabled).
AscPk().
Slice(&result).
FindAll()
if err != nil || len(result) > 0 {
return
2021-07-18 15:52:34 +08:00
}
}
2021-07-18 15:52:34 +08:00
// clusterId优先
if (serverId > 0 || nodeId > 0) && clusterId > 0 {
query = this.Query(tx)
if len(messageType) > 0 {
query.Attr("type", []string{"*", messageType}) // *表示所有的
}
if len(role) > 0 {
query.Attr("role", role)
}
query.Attr("clusterId", clusterId)
_, err = query.
State(MessageReceiverStateEnabled).
AscPk().
Slice(&result).
FindAll()
if err != nil || len(result) > 0 {
return
2021-07-18 15:52:34 +08:00
}
}
// 去掉集群ID
query = this.Query(tx)
2021-05-04 21:02:31 +08:00
if len(messageType) > 0 {
query.Attr("type", []string{"*", messageType}) // *表示所有的
}
if len(role) > 0 {
query.Attr("role", role)
}
_, err = query.
2021-05-04 21:02:31 +08:00
State(MessageReceiverStateEnabled).
AscPk().
Slice(&result).
FindAll()
if err != nil || len(result) > 0 {
return
}
return
2021-05-04 21:02:31 +08:00
}