Files
EdgeAPI/internal/rpc/services/service_message.go

193 lines
4.8 KiB
Go
Raw Normal View History

2020-10-20 20:18:06 +08:00
package services
import (
"context"
"github.com/TeaOSLab/EdgeAPI/internal/db/models"
2021-08-08 10:29:48 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
2020-10-20 20:18:06 +08:00
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
)
2021-08-08 10:29:48 +08:00
// MessageService 消息相关服务
2020-10-20 20:18:06 +08:00
type MessageService struct {
2020-11-24 15:02:44 +08:00
BaseService
2020-10-20 20:18:06 +08:00
}
2021-08-08 10:29:48 +08:00
// CountUnreadMessages 计算未读消息数
2020-11-12 14:41:28 +08:00
func (this *MessageService) CountUnreadMessages(ctx context.Context, req *pb.CountUnreadMessagesRequest) (*pb.RPCCountResponse, error) {
2020-10-20 20:18:06 +08:00
// 校验请求
2020-12-18 21:18:53 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
count, err := models.SharedMessageDAO.CountUnreadMessages(tx, adminId, userId)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
2020-11-24 17:36:47 +08:00
return this.SuccessCount(count)
2020-10-20 20:18:06 +08:00
}
2021-08-08 10:29:48 +08:00
// ListUnreadMessages 列出单页未读消息
2020-10-20 20:18:06 +08:00
func (this *MessageService) ListUnreadMessages(ctx context.Context, req *pb.ListUnreadMessagesRequest) (*pb.ListUnreadMessagesResponse, error) {
// 校验请求
2020-12-18 21:18:53 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
messages, err := models.SharedMessageDAO.ListUnreadMessages(tx, adminId, userId, req.Offset, req.Size)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
result := []*pb.Message{}
for _, message := range messages {
var pbCluster *pb.NodeCluster = nil
var pbNode *pb.Node = nil
if message.ClusterId > 0 {
2021-08-08 10:29:48 +08:00
switch message.Role {
case nodeconfigs.NodeRoleNode:
cluster, err := models.SharedNodeClusterDAO.FindEnabledNodeCluster(tx, int64(message.ClusterId))
if err != nil {
return nil, err
}
if cluster != nil {
pbCluster = &pb.NodeCluster{
Id: int64(cluster.Id),
Name: cluster.Name,
}
}
case nodeconfigs.NodeRoleDNS:
2021-08-08 15:47:48 +08:00
cluster, err := models.SharedNSClusterDAO.FindEnabledNSCluster(tx, int64(message.ClusterId))
2021-08-08 10:29:48 +08:00
if err != nil {
return nil, err
}
if cluster != nil {
pbCluster = &pb.NodeCluster{
Id: int64(cluster.Id),
Name: cluster.Name,
}
2020-10-20 20:18:06 +08:00
}
}
}
if message.NodeId > 0 {
2021-08-08 10:29:48 +08:00
switch message.Role {
case nodeconfigs.NodeRoleNode:
node, err := models.SharedNodeDAO.FindEnabledNode(tx, int64(message.NodeId))
if err != nil {
return nil, err
}
if node != nil {
pbNode = &pb.Node{
Id: int64(node.Id),
Name: node.Name,
}
}
case nodeconfigs.NodeRoleDNS:
2021-08-08 15:47:48 +08:00
node, err := models.SharedNSNodeDAO.FindEnabledNSNode(tx, int64(message.NodeId))
2021-08-08 10:29:48 +08:00
if err != nil {
return nil, err
}
if node != nil {
pbNode = &pb.Node{
Id: int64(node.Id),
Name: node.Name,
}
2020-10-20 20:18:06 +08:00
}
}
}
result = append(result, &pb.Message{
2020-12-17 17:36:20 +08:00
Id: int64(message.Id),
2021-08-08 10:29:48 +08:00
Role: message.Role,
2020-12-17 17:36:20 +08:00
Type: message.Type,
Body: message.Body,
Level: message.Level,
ParamsJSON: []byte(message.Params),
IsRead: message.IsRead == 1,
CreatedAt: int64(message.CreatedAt),
NodeCluster: pbCluster,
Node: pbNode,
2020-10-20 20:18:06 +08:00
})
}
return &pb.ListUnreadMessagesResponse{Messages: result}, nil
}
2021-08-08 10:29:48 +08:00
// UpdateMessageRead 设置消息已读状态
func (this *MessageService) UpdateMessageRead(ctx context.Context, req *pb.UpdateMessageReadRequest) (*pb.RPCSuccess, error) {
2020-10-20 20:18:06 +08:00
// 校验请求
2020-12-18 21:18:53 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
2020-12-15 11:52:57 +08:00
// 校验权限
exists, err := models.SharedMessageDAO.CheckMessageUser(tx, req.MessageId, adminId, userId)
2020-12-15 11:52:57 +08:00
if err != nil {
return nil, err
}
if !exists {
return nil, this.PermissionError()
}
err = models.SharedMessageDAO.UpdateMessageRead(tx, req.MessageId, req.IsRead)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
2020-11-24 15:02:44 +08:00
return this.Success()
2020-10-20 20:18:06 +08:00
}
2021-08-08 10:29:48 +08:00
// UpdateMessagesRead 设置一组消息已读状态
func (this *MessageService) UpdateMessagesRead(ctx context.Context, req *pb.UpdateMessagesReadRequest) (*pb.RPCSuccess, error) {
2020-10-20 20:18:06 +08:00
// 校验请求
2020-12-18 21:18:53 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
2020-12-15 11:52:57 +08:00
// 校验权限
for _, messageId := range req.MessageIds {
exists, err := models.SharedMessageDAO.CheckMessageUser(tx, messageId, adminId, userId)
2020-12-15 11:52:57 +08:00
if err != nil {
return nil, err
}
if !exists {
return nil, this.PermissionError()
}
err = models.SharedMessageDAO.UpdateMessageRead(tx, messageId, req.IsRead)
2020-12-15 11:52:57 +08:00
if err != nil {
return nil, err
}
2020-10-20 20:18:06 +08:00
}
2020-11-24 15:02:44 +08:00
return this.Success()
2020-10-20 20:18:06 +08:00
}
2021-08-08 10:29:48 +08:00
// UpdateAllMessagesRead 设置所有消息为已读
func (this *MessageService) UpdateAllMessagesRead(ctx context.Context, req *pb.UpdateAllMessagesReadRequest) (*pb.RPCSuccess, error) {
2020-10-20 20:18:06 +08:00
// 校验请求
2020-12-15 11:52:57 +08:00
// 校验请求
2020-12-18 21:18:53 +08:00
adminId, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
tx := this.NullTx()
err = models.SharedMessageDAO.UpdateAllMessagesRead(tx, adminId, userId)
2020-10-20 20:18:06 +08:00
if err != nil {
return nil, err
}
2020-11-24 15:02:44 +08:00
return this.Success()
2020-10-20 20:18:06 +08:00
}