Merge branch 'errcode' of github.com:OpenIMSDK/Open-IM-Server into errcode

This commit is contained in:
wangchuxiao 2023-05-26 20:55:01 +08:00
commit be79131498
2 changed files with 59 additions and 49 deletions

View File

@ -18,15 +18,9 @@ import (
func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg.RevokeMsgResp, error) { func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg.RevokeMsgResp, error) {
defer log.ZInfo(ctx, "RevokeMsg return line") defer log.ZInfo(ctx, "RevokeMsg return line")
//if req.UserID == "" { if req.UserID == "" {
// return nil, errs.ErrArgs.Wrap("user_id is empty") return nil, errs.ErrArgs.Wrap("user_id is empty")
//} }
//if req.RecvID == "" && req.GroupID == "" {
// return nil, errs.ErrArgs.Wrap("recv_id and group_id are empty")
//}
//if req.RecvID != "" && req.GroupID != "" {
// return nil, errs.ErrArgs.Wrap("recv_id and group_id cannot exist at the same time")
//}
if req.ConversationID == "" { if req.ConversationID == "" {
return nil, errs.ErrArgs.Wrap("conversation_id is empty") return nil, errs.ErrArgs.Wrap("conversation_id is empty")
} }
@ -47,33 +41,39 @@ func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg.
if len(msgs) == 0 { if len(msgs) == 0 {
return nil, errs.ErrRecordNotFound.Wrap("msg not found") return nil, errs.ErrRecordNotFound.Wrap("msg not found")
} }
if msgs[0].SendID == "" || msgs[0].RecvID == "" {
return nil, errs.ErrRecordNotFound.Wrap("sendID or recvID is empty")
}
// todo: 判断是否已经撤回
data, _ := json.Marshal(msgs[0]) data, _ := json.Marshal(msgs[0])
log.ZInfo(ctx, "GetMsgBySeqs", "conversationID", req.ConversationID, "seq", req.Seq, "msg", string(data)) log.ZInfo(ctx, "GetMsgBySeqs", "conversationID", req.ConversationID, "seq", req.Seq, "msg", string(data))
//sendID := msgs[0] if !tokenverify.IsAppManagerUid(ctx) {
//if !tokenverify.IsAppManagerUid(ctx) { switch msgs[0].SessionType {
// if req.GroupID == "" { case constant.SingleChatType:
// if req.UserID != sendID { if err := tokenverify.CheckAccessV3(ctx, msgs[0].SendID); err != nil {
// return nil, errs.ErrNoPermission.Wrap("no permission") return nil, err
// } }
// } else { case constant.SuperGroupChatType:
// members, err := m.Group.GetGroupMemberInfoMap(ctx, req.GroupID, utils.Distinct([]string{req.UserID, sendID}), true) members, err := m.Group.GetGroupMemberInfoMap(ctx, msgs[0].RecvID, utils.Distinct([]string{req.UserID, msgs[0].SendID}), true)
// if err != nil { if err != nil {
// return nil, err return nil, err
// } }
// if req.UserID != sendID { if req.UserID != msgs[0].SendID {
// roleLevel := members[req.UserID].RoleLevel roleLevel := members[req.UserID].RoleLevel
// switch members[req.UserID].RoleLevel { switch members[req.UserID].RoleLevel {
// case constant.GroupOwner: case constant.GroupOwner:
// case constant.GroupAdmin: case constant.GroupAdmin:
// if roleLevel != constant.GroupOrdinaryUsers { if roleLevel != constant.GroupOrdinaryUsers {
// return nil, errs.ErrNoPermission.Wrap("no permission") return nil, errs.ErrNoPermission.Wrap("no permission")
// } }
// default: default:
// return nil, errs.ErrNoPermission.Wrap("no permission") return nil, errs.ErrNoPermission.Wrap("no permission")
// } }
// } }
// } default:
//} return nil, errs.ErrInternalServer.Wrap("msg sessionType not supported")
}
}
err = m.MsgDatabase.RevokeMsg(ctx, req.ConversationID, req.Seq, &unRelationTb.RevokeModel{ err = m.MsgDatabase.RevokeMsg(ctx, req.ConversationID, req.Seq, &unRelationTb.RevokeModel{
UserID: req.UserID, UserID: req.UserID,
Nickname: user.Nickname, Nickname: user.Nickname,
@ -110,7 +110,7 @@ func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg.
CreateTime: utils.GetCurrentTimestampByMill(), CreateTime: utils.GetCurrentTimestampByMill(),
ClientMsgID: utils.GetMsgID(req.UserID), ClientMsgID: utils.GetMsgID(req.UserID),
Options: config.GetOptionsByNotification(config.NotificationConf{ Options: config.GetOptionsByNotification(config.NotificationConf{
IsSendMsg: true, IsSendMsg: false,
ReliabilityLevel: 2, ReliabilityLevel: 2,
}), }),
OfflinePushInfo: nil, OfflinePushInfo: nil,

View File

@ -5,7 +5,10 @@ import (
"github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws"
) )
func MsgPb2DB(msg *sdkws.MsgData) unrelation.MsgDataModel { func MsgPb2DB(msg *sdkws.MsgData) *unrelation.MsgDataModel {
if msg == nil {
return nil
}
var msgDataModel unrelation.MsgDataModel var msgDataModel unrelation.MsgDataModel
msgDataModel.SendID = msg.SendID msgDataModel.SendID = msg.SendID
msgDataModel.RecvID = msg.RecvID msgDataModel.RecvID = msg.RecvID
@ -24,6 +27,7 @@ func MsgPb2DB(msg *sdkws.MsgData) unrelation.MsgDataModel {
msgDataModel.CreateTime = msg.CreateTime msgDataModel.CreateTime = msg.CreateTime
msgDataModel.Status = msg.Status msgDataModel.Status = msg.Status
msgDataModel.Options = msg.Options msgDataModel.Options = msg.Options
if msg.OfflinePushInfo != nil {
msgDataModel.OfflinePush = &unrelation.OfflinePushModel{ msgDataModel.OfflinePush = &unrelation.OfflinePushModel{
Title: msg.OfflinePushInfo.Title, Title: msg.OfflinePushInfo.Title,
Desc: msg.OfflinePushInfo.Desc, Desc: msg.OfflinePushInfo.Desc,
@ -31,14 +35,18 @@ func MsgPb2DB(msg *sdkws.MsgData) unrelation.MsgDataModel {
IOSPushSound: msg.OfflinePushInfo.IOSPushSound, IOSPushSound: msg.OfflinePushInfo.IOSPushSound,
IOSBadgeCount: msg.OfflinePushInfo.IOSBadgeCount, IOSBadgeCount: msg.OfflinePushInfo.IOSBadgeCount,
} }
}
msgDataModel.AtUserIDList = msg.AtUserIDList msgDataModel.AtUserIDList = msg.AtUserIDList
msgDataModel.AttachedInfo = msg.AttachedInfo msgDataModel.AttachedInfo = msg.AttachedInfo
msgDataModel.Ex = msg.Ex msgDataModel.Ex = msg.Ex
return msgDataModel return &msgDataModel
} }
func MsgDB2Pb(msgModel *unrelation.MsgDataModel) *sdkws.MsgData { func MsgDB2Pb(msgModel *unrelation.MsgDataModel) *sdkws.MsgData {
if msgModel == nil {
return nil
}
var msg sdkws.MsgData var msg sdkws.MsgData
msg.SendID = msgModel.SendID msg.SendID = msgModel.SendID
msg.RecvID = msgModel.RecvID msg.RecvID = msgModel.RecvID
@ -57,6 +65,7 @@ func MsgDB2Pb(msgModel *unrelation.MsgDataModel) *sdkws.MsgData {
msg.CreateTime = msgModel.CreateTime msg.CreateTime = msgModel.CreateTime
msg.Status = msgModel.Status msg.Status = msgModel.Status
msg.Options = msgModel.Options msg.Options = msgModel.Options
if msgModel.OfflinePush != nil {
msg.OfflinePushInfo = &sdkws.OfflinePushInfo{ msg.OfflinePushInfo = &sdkws.OfflinePushInfo{
Title: msgModel.OfflinePush.Title, Title: msgModel.OfflinePush.Title,
Desc: msgModel.OfflinePush.Desc, Desc: msgModel.OfflinePush.Desc,
@ -64,6 +73,7 @@ func MsgDB2Pb(msgModel *unrelation.MsgDataModel) *sdkws.MsgData {
IOSPushSound: msgModel.OfflinePush.IOSPushSound, IOSPushSound: msgModel.OfflinePush.IOSPushSound,
IOSBadgeCount: msgModel.OfflinePush.IOSBadgeCount, IOSBadgeCount: msgModel.OfflinePush.IOSBadgeCount,
} }
}
msg.AtUserIDList = msgModel.AtUserIDList msg.AtUserIDList = msgModel.AtUserIDList
msg.AttachedInfo = msgModel.AttachedInfo msg.AttachedInfo = msgModel.AttachedInfo
msg.Ex = msgModel.Ex msg.Ex = msgModel.Ex