You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
476 lines
13 KiB
476 lines
13 KiB
package convert
|
|
|
|
import (
|
|
"OpenIM/internal/common/check"
|
|
"OpenIM/pkg/common/db/table/relation"
|
|
discoveryRegistry "OpenIM/pkg/discoveryregistry"
|
|
sdk "OpenIM/pkg/proto/sdkws"
|
|
utils2 "OpenIM/pkg/utils"
|
|
"context"
|
|
utils "github.com/OpenIMSDK/open_utils"
|
|
"time"
|
|
)
|
|
|
|
type DBFriend struct {
|
|
*relation.FriendModel
|
|
userCheck *check.UserCheck
|
|
}
|
|
|
|
func NewDBFriend(friend *relation.FriendModel, zk discoveryRegistry.SvcDiscoveryRegistry) *DBFriend {
|
|
return &DBFriend{FriendModel: friend, userCheck: check.NewUserCheck(zk)}
|
|
}
|
|
|
|
type PBFriend struct {
|
|
*sdk.FriendInfo
|
|
}
|
|
|
|
func NewPBFriend(friendInfo *sdk.FriendInfo) *PBFriend {
|
|
return &PBFriend{FriendInfo: friendInfo}
|
|
}
|
|
|
|
func (*PBFriend) PB2DB(friends []*sdk.FriendInfo) (DBFriends []*relation.FriendModel, err error) {
|
|
for _, v := range friends {
|
|
u, err := NewPBFriend(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBFriends = append(DBFriends, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
func (db *DBFriend) DB2PB(ctx context.Context, friends []*relation.FriendModel) (PBFriends []*sdk.FriendInfo, err error) {
|
|
userIDs := utils2.Slice(friends, func(e *relation.FriendModel) string { return e.FriendUserID })
|
|
users, err := db.userCheck.GetUsersInfoMap(ctx, userIDs, true)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
for _, v := range friends {
|
|
pbfriend := &sdk.FriendInfo{FriendUser: &sdk.UserInfo{}}
|
|
utils.CopyStructFields(pbfriend, users[v.OwnerUserID])
|
|
utils.CopyStructFields(pbfriend.FriendUser, users[v.FriendUserID])
|
|
pbfriend.CreateTime = v.CreateTime.Unix()
|
|
pbfriend.FriendUser.CreateTime = v.CreateTime.Unix()
|
|
}
|
|
return
|
|
}
|
|
|
|
func (db *DBFriend) Convert(ctx context.Context) (*sdk.FriendInfo, error) {
|
|
pbfriend := &sdk.FriendInfo{FriendUser: &sdk.UserInfo{}}
|
|
utils.CopyStructFields(pbfriend, db)
|
|
user, err := db.userCheck.GetUserInfo(ctx, db.FriendUserID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
utils.CopyStructFields(pbfriend.FriendUser, user)
|
|
pbfriend.CreateTime = db.CreateTime.Unix()
|
|
|
|
pbfriend.FriendUser.CreateTime = db.CreateTime.Unix()
|
|
return pbfriend, nil
|
|
}
|
|
|
|
func (pb *PBFriend) Convert() (*relation.FriendModel, error) {
|
|
dbFriend := &relation.FriendModel{}
|
|
utils.CopyStructFields(dbFriend, pb)
|
|
dbFriend.FriendUserID = pb.FriendUser.UserID
|
|
dbFriend.CreateTime = utils.UnixSecondToTime(pb.CreateTime)
|
|
return dbFriend, nil
|
|
}
|
|
|
|
type DBFriendRequest struct {
|
|
*relation.FriendRequestModel
|
|
userCheck *check.UserCheck
|
|
}
|
|
|
|
func NewDBFriendRequest(friendRequest *relation.FriendRequestModel, zk discoveryRegistry.SvcDiscoveryRegistry) *DBFriendRequest {
|
|
return &DBFriendRequest{FriendRequestModel: friendRequest, userCheck: check.NewUserCheck(zk)}
|
|
}
|
|
|
|
type PBFriendRequest struct {
|
|
*sdk.FriendRequest
|
|
}
|
|
|
|
func NewPBFriendRequest(friendRequest *sdk.FriendRequest) *PBFriendRequest {
|
|
return &PBFriendRequest{FriendRequest: friendRequest}
|
|
}
|
|
|
|
func (*PBFriendRequest) PB2DB(friendRequests []*sdk.FriendRequest) (DBFriendRequests []*relation.FriendRequestModel, err error) {
|
|
for _, v := range friendRequests {
|
|
u, err := NewPBFriendRequest(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBFriendRequests = append(DBFriendRequests, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
func (db *DBFriendRequest) DB2PB(ctx context.Context, friendRequests []*relation.FriendRequestModel) (PBFriendRequests []*sdk.FriendRequest, err error) {
|
|
userIDs := make([]string, 0)
|
|
if len(friendRequests) > 0 {
|
|
userIDs = append(userIDs, friendRequests[0].FromUserID)
|
|
}
|
|
users, err := db.userCheck.GetUsersInfoMap(ctx, userIDs, true)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
for _, v := range friendRequests {
|
|
pbFriendRequest := &sdk.FriendRequest{}
|
|
pbFriendRequest.FromNickname = users[v.FromUserID].Nickname
|
|
pbFriendRequest.FromFaceURL = users[v.FromUserID].FaceURL
|
|
pbFriendRequest.FromGender = users[v.FromUserID].Gender
|
|
pbFriendRequest.ToNickname = users[v.ToUserID].Nickname
|
|
pbFriendRequest.ToFaceURL = users[v.ToUserID].FaceURL
|
|
pbFriendRequest.ToGender = users[v.ToUserID].Gender
|
|
pbFriendRequest.CreateTime = db.CreateTime.Unix()
|
|
pbFriendRequest.HandleTime = db.HandleTime.Unix()
|
|
PBFriendRequests = append(PBFriendRequests, pbFriendRequest)
|
|
}
|
|
return
|
|
}
|
|
|
|
func (pb *PBFriendRequest) Convert() (*relation.FriendRequestModel, error) {
|
|
dbFriendRequest := &relation.FriendRequestModel{}
|
|
utils.CopyStructFields(dbFriendRequest, pb)
|
|
dbFriendRequest.CreateTime = utils.UnixSecondToTime(int64(pb.CreateTime))
|
|
dbFriendRequest.HandleTime = utils.UnixSecondToTime(int64(pb.HandleTime))
|
|
return dbFriendRequest, nil
|
|
}
|
|
func (db *DBFriendRequest) Convert(ctx context.Context) (*sdk.FriendRequest, error) {
|
|
pbFriendRequest := &sdk.FriendRequest{}
|
|
utils.CopyStructFields(pbFriendRequest, db)
|
|
user, err := db.userCheck.GetUserInfo(ctx, db.FromUserID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
pbFriendRequest.FromNickname = user.Nickname
|
|
pbFriendRequest.FromFaceURL = user.FaceURL
|
|
pbFriendRequest.FromGender = user.Gender
|
|
user, err = db.userCheck.GetUserInfo(ctx, db.ToUserID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
pbFriendRequest.ToNickname = user.Nickname
|
|
pbFriendRequest.ToFaceURL = user.FaceURL
|
|
pbFriendRequest.ToGender = user.Gender
|
|
pbFriendRequest.CreateTime = db.CreateTime.Unix()
|
|
pbFriendRequest.HandleTime = db.HandleTime.Unix()
|
|
return pbFriendRequest, nil
|
|
}
|
|
|
|
type DBBlack struct {
|
|
*relation.BlackModel
|
|
userCheck *check.UserCheck
|
|
}
|
|
|
|
func (*PBBlack) PB2DB(blacks []*sdk.BlackInfo) (DBBlacks []*relation.BlackModel, err error) {
|
|
for _, v := range blacks {
|
|
u, err := NewPBBlack(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBBlacks = append(DBBlacks, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
func (db *DBBlack) DB2PB(ctx context.Context, blacks []*relation.BlackModel) (PBBlacks []*sdk.BlackInfo, err error) {
|
|
userIDs := make([]string, 0)
|
|
for _, v := range blacks {
|
|
userIDs = append(userIDs, v.BlockUserID)
|
|
}
|
|
if len(blacks) > 0 {
|
|
userIDs = append(userIDs, blacks[0].OwnerUserID)
|
|
}
|
|
|
|
users, err := db.userCheck.GetUsersInfoMap(ctx, userIDs, true)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
for _, v := range blacks {
|
|
pbBlack := &sdk.BlackInfo{}
|
|
utils.CopyStructFields(pbBlack, users[v.OwnerUserID])
|
|
utils.CopyStructFields(pbBlack.BlackUserInfo, users[v.BlockUserID])
|
|
PBBlacks = append(PBBlacks, pbBlack)
|
|
}
|
|
return
|
|
}
|
|
|
|
func NewDBBlack(black *relation.BlackModel, zk discoveryRegistry.SvcDiscoveryRegistry) *DBBlack {
|
|
return &DBBlack{BlackModel: black, userCheck: check.NewUserCheck(zk)}
|
|
}
|
|
|
|
type PBBlack struct {
|
|
*sdk.BlackInfo
|
|
}
|
|
|
|
func NewPBBlack(blackInfo *sdk.BlackInfo) *PBBlack {
|
|
return &PBBlack{BlackInfo: blackInfo}
|
|
}
|
|
|
|
func (pb *PBBlack) Convert() (*relation.BlackModel, error) {
|
|
dbBlack := &relation.BlackModel{}
|
|
dbBlack.BlockUserID = pb.BlackUserInfo.UserID
|
|
dbBlack.CreateTime = utils.UnixSecondToTime(pb.CreateTime)
|
|
return dbBlack, nil
|
|
}
|
|
func (db *DBBlack) Convert(ctx context.Context) (*sdk.BlackInfo, error) {
|
|
pbBlack := &sdk.BlackInfo{}
|
|
utils.CopyStructFields(pbBlack, db)
|
|
pbBlack.CreateTime = db.CreateTime.Unix()
|
|
user, err := db.userCheck.GetUserInfo(ctx, db.BlockUserID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
utils.CopyStructFields(pbBlack.BlackUserInfo, user)
|
|
return pbBlack, nil
|
|
}
|
|
|
|
type DBGroup struct {
|
|
*relation.GroupModel
|
|
zk discoveryRegistry.SvcDiscoveryRegistry
|
|
groupCheck *check.GroupChecker
|
|
}
|
|
|
|
func (*PBGroup) PB2DB(groups []*sdk.GroupInfo) (DBGroups []*relation.GroupModel, err error) {
|
|
for _, v := range groups {
|
|
u, err := NewPBGroup(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBGroups = append(DBGroups, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
//func (db *DBGroup) DB2PB(ctx context.Context, zk discoveryRegistry.SvcDiscoveryRegistry, groups []*relation.GroupModel) (PBGroups []*sdk.GroupInfo, err error) {
|
|
// for _, v := range groups {
|
|
// u, err := NewDBGroup(v, zk).Convert(ctx)
|
|
// if err != nil {
|
|
// return nil, err
|
|
// }
|
|
// PBGroups = append(PBGroups, u)
|
|
// }
|
|
// return
|
|
//}
|
|
|
|
func NewDBGroup(groupModel *relation.GroupModel, zk discoveryRegistry.SvcDiscoveryRegistry) *DBGroup {
|
|
return &DBGroup{GroupModel: groupModel, groupCheck: check.NewGroupChecker(zk)}
|
|
}
|
|
|
|
type PBGroup struct {
|
|
*sdk.GroupInfo
|
|
}
|
|
|
|
func NewPBGroup(groupInfo *sdk.GroupInfo) *PBGroup {
|
|
return &PBGroup{GroupInfo: groupInfo}
|
|
}
|
|
|
|
func (pb *PBGroup) Convert() (*relation.GroupModel, error) {
|
|
dst := &relation.GroupModel{}
|
|
err := utils.CopyStructFields(dst, pb)
|
|
return dst, err
|
|
}
|
|
func (db *DBGroup) Convert(ctx context.Context) (*sdk.GroupInfo, error) {
|
|
dst := &sdk.GroupInfo{}
|
|
utils.CopyStructFields(dst, db)
|
|
user, err := db.groupCheck.GetOwnerInfo(ctx, db.GroupID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
dst.OwnerUserID = user.UserID
|
|
|
|
g, err := db.groupCheck.GetGroupInfo(ctx, db.GroupID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
dst.MemberCount = g.MemberCount
|
|
dst.CreateTime = db.CreateTime.Unix()
|
|
dst.NotificationUpdateTime = db.NotificationUpdateTime.Unix()
|
|
if db.NotificationUpdateTime.Unix() < 0 {
|
|
dst.NotificationUpdateTime = 0
|
|
}
|
|
return dst, nil
|
|
}
|
|
|
|
type DBGroupMember struct {
|
|
*relation.GroupMemberModel
|
|
userCheck *check.UserCheck
|
|
}
|
|
|
|
func (*PBGroupMember) PB2DB(groupMembers []*sdk.GroupMemberFullInfo) (DBGroupMembers []*relation.GroupMemberModel, err error) {
|
|
for _, v := range groupMembers {
|
|
u, err := NewPBGroupMember(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBGroupMembers = append(DBGroupMembers, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
//func (*DBGroupMember) DB2PB(ctx context.Context, groupMembers []*relation.GroupMemberModel) (PBGroupMembers []*sdk.GroupMemberFullInfo, err error) {
|
|
// for _, v := range groupMembers {
|
|
// u, err := NewDBGroupMember(v).Convert(ctx)
|
|
// if err != nil {
|
|
// return nil, err
|
|
// }
|
|
// PBGroupMembers = append(PBGroupMembers, u)
|
|
// }
|
|
// return
|
|
//}
|
|
|
|
func NewDBGroupMember(groupMember *relation.GroupMemberModel) *DBGroupMember {
|
|
return &DBGroupMember{GroupMemberModel: groupMember}
|
|
}
|
|
|
|
type PBGroupMember struct {
|
|
*sdk.GroupMemberFullInfo
|
|
}
|
|
|
|
func NewPBGroupMember(groupMemberFullInfo *sdk.GroupMemberFullInfo) *PBGroupMember {
|
|
return &PBGroupMember{GroupMemberFullInfo: groupMemberFullInfo}
|
|
}
|
|
|
|
func (pb *PBGroupMember) Convert() (*relation.GroupMemberModel, error) {
|
|
dst := &relation.GroupMemberModel{}
|
|
utils.CopyStructFields(dst, pb)
|
|
dst.JoinTime = utils.UnixSecondToTime(int64(pb.JoinTime))
|
|
dst.MuteEndTime = utils.UnixSecondToTime(int64(pb.MuteEndTime))
|
|
return dst, nil
|
|
}
|
|
func (db *DBGroupMember) Convert(ctx context.Context) (*sdk.GroupMemberFullInfo, error) {
|
|
dst := &sdk.GroupMemberFullInfo{}
|
|
utils.CopyStructFields(dst, db)
|
|
|
|
user, err := db.userCheck.GetUserInfo(ctx, db.UserID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
dst.AppMangerLevel = user.AppMangerLevel
|
|
|
|
dst.JoinTime = db.JoinTime.Unix()
|
|
if db.JoinTime.Unix() < 0 {
|
|
dst.JoinTime = 0
|
|
}
|
|
dst.MuteEndTime = db.MuteEndTime.Unix()
|
|
if dst.MuteEndTime < time.Now().Unix() {
|
|
dst.MuteEndTime = 0
|
|
}
|
|
return dst, nil
|
|
}
|
|
|
|
type DBGroupRequest struct {
|
|
*relation.GroupRequestModel
|
|
}
|
|
|
|
func (*PBGroupRequest) PB2DB(groupRequests []*sdk.GroupRequest) (DBGroupRequests []*relation.GroupRequestModel, err error) {
|
|
for _, v := range groupRequests {
|
|
u, err := NewPBGroupRequest(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBGroupRequests = append(DBGroupRequests, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
//func (*DBGroupRequest) DB2PB(groupRequests []*relation.GroupRequestModel) (PBGroupRequests []*sdk.GroupRequest, err error) {
|
|
// for _, v := range groupRequests {
|
|
// u, err := NewDBGroupRequest(v).Convert()
|
|
// if err != nil {
|
|
// return nil, err
|
|
// }
|
|
// PBGroupRequests = append(PBGroupRequests, u)
|
|
// }
|
|
// return
|
|
//}
|
|
|
|
func NewDBGroupRequest(groupRequest *relation.GroupRequestModel) *DBGroupRequest {
|
|
return &DBGroupRequest{GroupRequestModel: groupRequest}
|
|
}
|
|
|
|
type PBGroupRequest struct {
|
|
*sdk.GroupRequest
|
|
}
|
|
|
|
func NewPBGroupRequest(groupRequest *sdk.GroupRequest) *PBGroupRequest {
|
|
return &PBGroupRequest{GroupRequest: groupRequest}
|
|
}
|
|
|
|
func (pb *PBGroupRequest) Convert() (*relation.GroupRequestModel, error) {
|
|
dst := &relation.GroupRequestModel{}
|
|
utils.CopyStructFields(dst, pb)
|
|
dst.ReqTime = utils.UnixSecondToTime(int64(pb.ReqTime))
|
|
dst.HandledTime = utils.UnixSecondToTime(int64(pb.HandleTime))
|
|
return dst, nil
|
|
}
|
|
func (db *DBGroupRequest) Convert() (*sdk.GroupRequest, error) {
|
|
dst := &sdk.GroupRequest{}
|
|
utils.CopyStructFields(dst, db)
|
|
dst.ReqTime = db.ReqTime.Unix()
|
|
dst.HandleTime = db.HandledTime.Unix()
|
|
return dst, nil
|
|
}
|
|
|
|
type DBUser struct {
|
|
*relation.UserModel
|
|
}
|
|
|
|
func NewDBUser(user *relation.UserModel) *DBUser {
|
|
return &DBUser{UserModel: user}
|
|
}
|
|
|
|
type PBUser struct {
|
|
*sdk.UserInfo
|
|
}
|
|
|
|
func NewPBUser(userInfo *sdk.UserInfo) *PBUser {
|
|
return &PBUser{UserInfo: userInfo}
|
|
}
|
|
|
|
func (*PBUser) PB2DB(users []*sdk.UserInfo) (DBUsers []*relation.UserModel, err error) {
|
|
for _, v := range users {
|
|
u, err := NewPBUser(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
DBUsers = append(DBUsers, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
func (*DBUser) DB2PB(users []*relation.UserModel) (PBUsers []*sdk.UserInfo, err error) {
|
|
for _, v := range users {
|
|
u, err := NewDBUser(v).Convert()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
PBUsers = append(PBUsers, u)
|
|
}
|
|
return
|
|
}
|
|
|
|
func (pb *PBUser) Convert() (*relation.UserModel, error) {
|
|
dst := &relation.UserModel{}
|
|
utils.CopyStructFields(dst, pb)
|
|
dst.Birth = utils.UnixSecondToTime(pb.Birthday)
|
|
dst.CreateTime = utils.UnixSecondToTime(pb.CreateTime)
|
|
return dst, nil
|
|
}
|
|
|
|
func (db *DBUser) Convert() (*sdk.UserInfo, error) {
|
|
dst := &sdk.UserInfo{}
|
|
utils.CopyStructFields(dst, db)
|
|
dst.CreateTime = db.CreateTime.Unix()
|
|
dst.Birthday = db.Birth.Unix()
|
|
return dst, nil
|
|
}
|
|
|
|
func (db *DBUser) ConvertPublic() (*sdk.PublicUserInfo, error) {
|
|
dst := &sdk.PublicUserInfo{}
|
|
utils.CopyStructFields(dst, db)
|
|
return dst, nil
|
|
}
|