Files
open-im-server/internal/rpc/msg/as_read.go
T

133 lines
4.8 KiB
Go
Raw Normal View History

2023-06-02 16:38:15 +08:00
package msg
import (
"context"
2023-06-12 20:04:14 +08:00
"errors"
2023-06-02 16:38:15 +08:00
2023-06-05 14:31:02 +08:00
"github.com/OpenIMSDK/Open-IM-Server/pkg/common/constant"
2023-06-12 20:04:14 +08:00
"github.com/OpenIMSDK/Open-IM-Server/pkg/common/log"
2023-06-06 16:57:48 +08:00
"github.com/OpenIMSDK/Open-IM-Server/pkg/errs"
2023-06-02 16:38:15 +08:00
"github.com/OpenIMSDK/Open-IM-Server/pkg/proto/msg"
2023-06-05 18:01:59 +08:00
"github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws"
2023-06-12 20:04:14 +08:00
"github.com/go-redis/redis/v8"
2023-06-02 16:38:15 +08:00
)
2023-06-06 18:46:06 +08:00
func (m *msgServer) GetConversationsHasReadAndMaxSeq(ctx context.Context, req *msg.GetConversationsHasReadAndMaxSeqReq) (*msg.GetConversationsHasReadAndMaxSeqResp, error) {
conversationIDs, err := m.ConversationLocalCache.GetConversationIDs(ctx, req.UserID)
if err != nil {
return nil, err
}
hasReadSeqs, err := m.MsgDatabase.GetHasReadSeqs(ctx, req.UserID, conversationIDs)
if err != nil {
return nil, err
}
maxSeqs, err := m.MsgDatabase.GetMaxSeqs(ctx, conversationIDs)
if err != nil {
return nil, err
}
resp := &msg.GetConversationsHasReadAndMaxSeqResp{Seqs: make(map[string]*msg.Seqs)}
for conversarionID, maxSeq := range maxSeqs {
resp.Seqs[conversarionID] = &msg.Seqs{
HasReadSeq: hasReadSeqs[conversarionID],
MaxSeq: maxSeq,
}
}
return resp, nil
}
2023-06-14 16:30:56 +08:00
func (m *msgServer) SetConversationHasReadSeq(ctx context.Context, req *msg.SetConversationHasReadSeqReq) (resp *msg.SetConversationHasReadSeqResp, err error) {
2023-06-14 12:20:47 +08:00
maxSeq, err := m.MsgDatabase.GetMaxSeq(ctx, req.ConversationID)
if err != nil {
return
}
if req.HasReadSeq > maxSeq {
return nil, errs.ErrArgs.Wrap("hasReadSeq must not be bigger than maxSeq")
}
if err := m.MsgDatabase.SetHasReadSeq(ctx, req.UserID, req.ConversationID, req.HasReadSeq); err != nil {
return nil, err
}
if err = m.sendMarkAsReadNotification(ctx, req.ConversationID, constant.SingleChatType, req.UserID, req.UserID, nil, req.HasReadSeq); err != nil {
return
}
2023-06-14 14:28:01 +08:00
return &msg.SetConversationHasReadSeqResp{}, nil
2023-06-14 12:20:47 +08:00
}
2023-06-02 16:38:15 +08:00
func (m *msgServer) MarkMsgsAsRead(ctx context.Context, req *msg.MarkMsgsAsReadReq) (resp *msg.MarkMsgsAsReadResp, err error) {
2023-06-06 16:57:48 +08:00
if len(req.Seqs) < 1 {
return nil, errs.ErrArgs.Wrap("seqs must not be empty")
}
2023-06-07 17:39:41 +08:00
maxSeq, err := m.MsgDatabase.GetMaxSeq(ctx, req.ConversationID)
if err != nil {
return
}
hasReadSeq := req.Seqs[len(req.Seqs)-1]
if hasReadSeq > maxSeq {
return nil, errs.ErrArgs.Wrap("hasReadSeq must not be bigger than maxSeq")
}
2023-06-06 16:57:48 +08:00
conversations, err := m.Conversation.GetConversationsByConversationID(ctx, []string{req.ConversationID})
2023-06-05 14:31:02 +08:00
if err != nil {
return
}
2023-06-14 12:20:47 +08:00
if err = m.MsgDatabase.MarkSingleChatMsgsAsRead(ctx, req.UserID, req.ConversationID, req.Seqs); err != nil {
2023-06-05 14:31:02 +08:00
return
}
2023-06-13 11:05:02 +08:00
currentHasReadSeq, err := m.MsgDatabase.GetHasReadSeq(ctx, req.UserID, req.ConversationID)
if err != nil && errors.Unwrap(err) != redis.Nil {
2023-06-06 16:57:48 +08:00
return
}
2023-06-13 11:05:02 +08:00
if hasReadSeq > currentHasReadSeq {
err = m.MsgDatabase.SetHasReadSeq(ctx, req.UserID, req.ConversationID, hasReadSeq)
if err != nil {
return
}
}
2023-06-06 18:46:06 +08:00
if err = m.sendMarkAsReadNotification(ctx, req.ConversationID, conversations[0].ConversationType, req.UserID, m.conversationAndGetRecvID(conversations[0], req.UserID), req.Seqs, hasReadSeq); err != nil {
2023-06-05 14:31:02 +08:00
return
}
return &msg.MarkMsgsAsReadResp{}, nil
}
2023-06-12 18:52:35 +08:00
func (m *msgServer) MarkConversationAsRead(ctx context.Context, req *msg.MarkConversationAsReadReq) (resp *msg.MarkConversationAsReadResp, err error) {
2023-06-14 12:20:47 +08:00
conversations, err := m.Conversation.GetConversationsByConversationID(ctx, []string{req.ConversationID})
if err != nil {
return
}
2023-06-12 18:52:35 +08:00
hasReadSeq, err := m.MsgDatabase.GetHasReadSeq(ctx, req.UserID, req.ConversationID)
2023-06-14 18:17:32 +08:00
if err != nil && errs.Unwrap(err) != redis.Nil {
2023-06-12 18:52:35 +08:00
return
}
2023-06-12 20:04:14 +08:00
log.ZDebug(ctx, "MarkConversationAsRead", "hasReadSeq", hasReadSeq, "req.HasReadSeq", req.HasReadSeq)
2023-06-12 18:52:35 +08:00
var seqs []int64
for i := hasReadSeq + 1; i <= req.HasReadSeq; i++ {
seqs = append(seqs, i)
}
2023-06-14 12:20:47 +08:00
if len(seqs) > 0 {
log.ZDebug(ctx, "MarkConversationAsRead", "seqs", seqs, "conversationID", req.ConversationID)
if err = m.MsgDatabase.MarkSingleChatMsgsAsRead(ctx, req.UserID, req.ConversationID, seqs); err != nil {
return
}
2023-06-12 18:52:35 +08:00
}
if req.HasReadSeq > hasReadSeq {
err = m.MsgDatabase.SetHasReadSeq(ctx, req.UserID, req.ConversationID, req.HasReadSeq)
if err != nil {
return
}
hasReadSeq = req.HasReadSeq
}
if err = m.sendMarkAsReadNotification(ctx, req.ConversationID, conversations[0].ConversationType, req.UserID, m.conversationAndGetRecvID(conversations[0], req.UserID), seqs, hasReadSeq); err != nil {
return
}
return &msg.MarkConversationAsReadResp{}, nil
}
2023-06-06 18:46:06 +08:00
func (m *msgServer) sendMarkAsReadNotification(ctx context.Context, conversationID string, sesstionType int32, sendID, recvID string, seqs []int64, hasReadSeq int64) error {
2023-06-05 18:01:59 +08:00
tips := &sdkws.MarkAsReadTips{
MarkAsReadUserID: sendID,
ConversationID: conversationID,
Seqs: seqs,
2023-06-06 18:46:06 +08:00
HasReadSeq: hasReadSeq,
2023-06-05 18:01:59 +08:00
}
2023-06-06 16:57:48 +08:00
m.notificationSender.NotificationWithSesstionType(ctx, sendID, recvID, constant.HasReadReceipt, sesstionType, tips)
2023-06-05 14:31:02 +08:00
return nil
2023-06-02 16:38:15 +08:00
}