|
|
|
package friend
|
|
|
|
|
|
|
|
import (
|
|
|
|
"Open_IM/internal/push/content_struct"
|
|
|
|
"Open_IM/internal/push/logic"
|
|
|
|
"Open_IM/pkg/common/constant"
|
|
|
|
"Open_IM/pkg/common/db/mysql_model/im_mysql_model"
|
|
|
|
"Open_IM/pkg/common/log"
|
|
|
|
"Open_IM/pkg/common/token_verify"
|
|
|
|
pbChat "Open_IM/pkg/proto/chat"
|
|
|
|
pbFriend "Open_IM/pkg/proto/friend"
|
|
|
|
"Open_IM/pkg/utils"
|
|
|
|
"context"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (s *friendServer) AddFriendResponse(ctx context.Context, req *pbFriend.AddFriendResponseReq) (*pbFriend.CommonResp, error) {
|
|
|
|
log.Info(req.Token, req.OperationID, "rpc add friend response is server,args=%s", req.String())
|
|
|
|
//Parse token, to find current user information
|
|
|
|
claims, err := token_verify.ParseToken(req.Token)
|
|
|
|
if err != nil {
|
|
|
|
log.Error(req.Token, req.OperationID, "err=%s,parse token failed", err.Error())
|
|
|
|
return &pbFriend.CommonResp{ErrorCode: constant.ErrParseToken.ErrCode, ErrorMsg: constant.ErrParseToken.ErrMsg}, nil
|
|
|
|
}
|
|
|
|
//Check there application before agreeing or refuse to a friend's application
|
|
|
|
if _, err = im_mysql_model.FindFriendApplyFromFriendReqByUid(req.Uid, claims.UID); err != nil {
|
|
|
|
log.Error(req.Token, req.OperationID, "No such application record")
|
|
|
|
return &pbFriend.CommonResp{ErrorCode: constant.ErrAgreeToAddFriend.ErrCode, ErrorMsg: constant.ErrAgreeToAddFriend.ErrMsg}, nil
|
|
|
|
}
|
|
|
|
//Change friend request status flag
|
|
|
|
err = im_mysql_model.UpdateFriendRelationshipToFriendReq(req.Uid, claims.UID, req.Flag)
|
|
|
|
if err != nil {
|
|
|
|
log.Error(req.Token, req.OperationID, "err=%s,update friend request table failed", err.Error())
|
|
|
|
return &pbFriend.CommonResp{ErrorCode: constant.ErrMysql.ErrCode, ErrorMsg: constant.ErrAgreeToAddFriend.ErrMsg}, nil
|
|
|
|
}
|
|
|
|
log.Info(req.Token, req.OperationID, "rpc add friend response success return,userid=%s,flag=%d", req.Uid, req.Flag)
|
|
|
|
//Change the status of the friend request form
|
|
|
|
if req.Flag == constant.FriendFlag {
|
|
|
|
//Establish friendship after find friend relationship not exists
|
|
|
|
_, err := im_mysql_model.FindFriendRelationshipFromFriend(claims.UID, req.Uid)
|
|
|
|
//fixme If there is an error, it means that there is no friend record or database err, if no friend record should be inserted,Continue down execution
|
|
|
|
if err != nil {
|
|
|
|
log.Error("", req.OperationID, err.Error())
|
|
|
|
}
|
|
|
|
//Establish two single friendship
|
|
|
|
err = im_mysql_model.InsertToFriend(claims.UID, req.Uid, req.Flag)
|
|
|
|
if err != nil {
|
|
|
|
log.Error(req.Token, req.OperationID, "err=%s,create friendship failed", err.Error())
|
|
|
|
}
|
|
|
|
err = im_mysql_model.InsertToFriend(req.Uid, claims.UID, req.Flag)
|
|
|
|
if err != nil {
|
|
|
|
log.Error(req.Token, req.OperationID, "err=%s,create friendship failed", err.Error())
|
|
|
|
}
|
|
|
|
//Push message when establish friends successfully
|
|
|
|
//senderInfo, errSend := im_mysql_model.FindUserByUID(claims.UID)
|
|
|
|
//if errSend == nil {
|
|
|
|
// logic.SendMsgByWS(&pbChat.WSToMsgSvrChatMsg{
|
|
|
|
// SendID: claims.UID,
|
|
|
|
// RecvID: req.Uid,
|
|
|
|
// Content: content_struct.NewContentStructString(1, "", senderInfo.Name+" agreed to add you as a friend."),
|
|
|
|
// SendTime: utils.GetCurrentTimestampBySecond(),
|
|
|
|
// MsgFrom: constant.UserMsgType, //Notification message identification
|
|
|
|
// ContentType: constant.AcceptFriendApplicationTip, //Add friend flag
|
|
|
|
// SessionType: constant.SingleChatType,
|
|
|
|
// OperationID: req.OperationID,
|
|
|
|
// })
|
|
|
|
//}
|
|
|
|
}
|
|
|
|
if req.Flag == constant.RefuseFriendFlag {
|
|
|
|
senderInfo, errSend := im_mysql_model.FindUserByUID(claims.UID)
|
|
|
|
if errSend == nil {
|
|
|
|
logic.SendMsgByWS(&pbChat.WSToMsgSvrChatMsg{
|
|
|
|
SendID: claims.UID,
|
|
|
|
RecvID: req.Uid,
|
|
|
|
Content: content_struct.NewContentStructString(0, "", senderInfo.Name+" refuse to add you as a friend."),
|
|
|
|
SendTime: utils.GetCurrentTimestampBySecond(),
|
|
|
|
MsgFrom: constant.UserMsgType, //Notification message identification
|
|
|
|
ContentType: constant.RefuseFriendApplicationTip, //Add friend flag
|
|
|
|
SessionType: constant.SingleChatType,
|
|
|
|
OperationID: req.OperationID,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return &pbFriend.CommonResp{}, nil
|
|
|
|
}
|