|
|
|
package table
|
|
|
|
|
|
|
|
import (
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
FriendModelTableName = ""
|
|
|
|
ConversationModelTableName = ""
|
|
|
|
)
|
|
|
|
|
|
|
|
type FriendModel struct {
|
|
|
|
OwnerUserID string `gorm:"column:owner_user_id;primary_key;size:64"`
|
|
|
|
FriendUserID string `gorm:"column:friend_user_id;primary_key;size:64"`
|
|
|
|
Remark string `gorm:"column:remark;size:255"`
|
|
|
|
CreateTime time.Time `gorm:"column:create_time"`
|
|
|
|
AddSource int32 `gorm:"column:add_source"`
|
|
|
|
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
|
|
|
Ex string `gorm:"column:ex;size:1024"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ConversationModel struct {
|
|
|
|
OwnerUserID string `gorm:"column:owner_user_id;primary_key;type:char(128)" json:"OwnerUserID"`
|
|
|
|
ConversationID string `gorm:"column:conversation_id;primary_key;type:char(128)" json:"conversationID"`
|
|
|
|
ConversationType int32 `gorm:"column:conversation_type" json:"conversationType"`
|
|
|
|
UserID string `gorm:"column:user_id;type:char(64)" json:"userID"`
|
|
|
|
GroupID string `gorm:"column:group_id;type:char(128)" json:"groupID"`
|
|
|
|
RecvMsgOpt int32 `gorm:"column:recv_msg_opt" json:"recvMsgOpt"`
|
|
|
|
UnreadCount int32 `gorm:"column:unread_count" json:"unreadCount"`
|
|
|
|
DraftTextTime int64 `gorm:"column:draft_text_time" json:"draftTextTime"`
|
|
|
|
IsPinned bool `gorm:"column:is_pinned" json:"isPinned"`
|
|
|
|
IsPrivateChat bool `gorm:"column:is_private_chat" json:"isPrivateChat"`
|
|
|
|
BurnDuration int32 `gorm:"column:burn_duration;default:30" json:"burnDuration"`
|
|
|
|
GroupAtType int32 `gorm:"column:group_at_type" json:"groupAtType"`
|
|
|
|
IsNotInGroup bool `gorm:"column:is_not_in_group" json:"isNotInGroup"`
|
|
|
|
UpdateUnreadCountTime int64 `gorm:"column:update_unread_count_time" json:"updateUnreadCountTime"`
|
|
|
|
AttachedInfo string `gorm:"column:attached_info;type:varchar(1024)" json:"attachedInfo"`
|
|
|
|
Ex string `gorm:"column:ex;type:varchar(1024)" json:"ex"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type GroupModel struct {
|
|
|
|
GroupID string `gorm:"column:group_id;primary_key;size:64" json:"groupID" binding:"required"`
|
|
|
|
GroupName string `gorm:"column:name;size:255" json:"groupName"`
|
|
|
|
Notification string `gorm:"column:notification;size:255" json:"notification"`
|
|
|
|
Introduction string `gorm:"column:introduction;size:255" json:"introduction"`
|
|
|
|
FaceURL string `gorm:"column:face_url;size:255" json:"faceURL"`
|
|
|
|
CreateTime time.Time `gorm:"column:create_time;index:create_time"`
|
|
|
|
Ex string `gorm:"column:ex" json:"ex;size:1024" json:"ex"`
|
|
|
|
Status int32 `gorm:"column:status"`
|
|
|
|
CreatorUserID string `gorm:"column:creator_user_id;size:64"`
|
|
|
|
GroupType int32 `gorm:"column:group_type"`
|
|
|
|
NeedVerification int32 `gorm:"column:need_verification"`
|
|
|
|
LookMemberInfo int32 `gorm:"column:look_member_info" json:"lookMemberInfo"`
|
|
|
|
ApplyMemberFriend int32 `gorm:"column:apply_member_friend" json:"applyMemberFriend"`
|
|
|
|
NotificationUpdateTime time.Time `gorm:"column:notification_update_time"`
|
|
|
|
NotificationUserID string `gorm:"column:notification_user_id;size:64"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *GroupModel) EqID(i interface{}) bool {
|
|
|
|
switch v := i.(type) {
|
|
|
|
case GroupModel:
|
|
|
|
return f.GroupID == v.GroupID
|
|
|
|
case *GroupModel:
|
|
|
|
return f.GroupID == v.GroupID
|
|
|
|
default:
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func DuplicateRemoval[T any](arr []T, fn func(t T) string) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func aaa() {
|
|
|
|
DuplicateRemoval([]GroupModel{}, func(t GroupModel) string {
|
|
|
|
return t.GroupID
|
|
|
|
})
|
|
|
|
|
|
|
|
DuplicateRemoval([]*GroupModel{}, func(t *GroupModel) string {
|
|
|
|
return t.GroupID
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
type FriendRequestModel struct {
|
|
|
|
FromUserID string `gorm:"column:from_user_id;primary_key;size:64"`
|
|
|
|
ToUserID string `gorm:"column:to_user_id;primary_key;size:64"`
|
|
|
|
HandleResult int32 `gorm:"column:handle_result"`
|
|
|
|
ReqMsg string `gorm:"column:req_msg;size:255"`
|
|
|
|
CreateTime time.Time `gorm:"column:create_time"`
|
|
|
|
HandlerUserID string `gorm:"column:handler_user_id;size:64"`
|
|
|
|
HandleMsg string `gorm:"column:handle_msg;size:255"`
|
|
|
|
HandleTime time.Time `gorm:"column:handle_time"`
|
|
|
|
Ex string `gorm:"column:ex;size:1024"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type GroupMemberModel struct {
|
|
|
|
GroupID string `gorm:"column:group_id;primary_key;size:64"`
|
|
|
|
UserID string `gorm:"column:user_id;primary_key;size:64"`
|
|
|
|
Nickname string `gorm:"column:nickname;size:255"`
|
|
|
|
FaceURL string `gorm:"column:user_group_face_url;size:255"`
|
|
|
|
RoleLevel int32 `gorm:"column:role_level"`
|
|
|
|
JoinTime time.Time `gorm:"column:join_time"`
|
|
|
|
JoinSource int32 `gorm:"column:join_source"`
|
|
|
|
InviterUserID string `gorm:"column:inviter_user_id;size:64"`
|
|
|
|
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
|
|
|
MuteEndTime time.Time `gorm:"column:mute_end_time"`
|
|
|
|
Ex string `gorm:"column:ex;size:1024"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type GroupRequestModel struct {
|
|
|
|
UserID string `gorm:"column:user_id;primary_key;size:64"`
|
|
|
|
GroupID string `gorm:"column:group_id;primary_key;size:64"`
|
|
|
|
HandleResult int32 `gorm:"column:handle_result"`
|
|
|
|
ReqMsg string `gorm:"column:req_msg;size:1024"`
|
|
|
|
HandledMsg string `gorm:"column:handle_msg;size:1024"`
|
|
|
|
ReqTime time.Time `gorm:"column:req_time"`
|
|
|
|
HandleUserID string `gorm:"column:handle_user_id;size:64"`
|
|
|
|
HandledTime time.Time `gorm:"column:handle_time"`
|
|
|
|
JoinSource int32 `gorm:"column:join_source"`
|
|
|
|
InviterUserID string `gorm:"column:inviter_user_id;size:64"`
|
|
|
|
Ex string `gorm:"column:ex;size:1024"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type UserModel struct {
|
|
|
|
UserID string `gorm:"column:user_id;primary_key;size:64"`
|
|
|
|
Nickname string `gorm:"column:name;size:255"`
|
|
|
|
FaceURL string `gorm:"column:face_url;size:255"`
|
|
|
|
Gender int32 `gorm:"column:gender"`
|
|
|
|
PhoneNumber string `gorm:"column:phone_number;size:32"`
|
|
|
|
Birth time.Time `gorm:"column:birth"`
|
|
|
|
Email string `gorm:"column:email;size:64"`
|
|
|
|
Ex string `gorm:"column:ex;size:1024"`
|
|
|
|
CreateTime time.Time `gorm:"column:create_time;index:create_time"`
|
|
|
|
AppMangerLevel int32 `gorm:"column:app_manger_level"`
|
|
|
|
GlobalRecvMsgOpt int32 `gorm:"column:global_recv_msg_opt"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type BlackModel struct {
|
|
|
|
OwnerUserID string `gorm:"column:owner_user_id;primary_key;size:64"`
|
|
|
|
BlockUserID string `gorm:"column:block_user_id;primary_key;size:64"`
|
|
|
|
CreateTime time.Time `gorm:"column:create_time"`
|
|
|
|
AddSource int32 `gorm:"column:add_source"`
|
|
|
|
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
|
|
|
Ex string `gorm:"column:ex;size:1024"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type ChatLogModel struct {
|
|
|
|
ServerMsgID string `gorm:"column:server_msg_id;primary_key;type:char(64)" json:"serverMsgID"`
|
|
|
|
ClientMsgID string `gorm:"column:client_msg_id;type:char(64)" json:"clientMsgID"`
|
|
|
|
SendID string `gorm:"column:send_id;type:char(64);index:send_id,priority:2" json:"sendID"`
|
|
|
|
RecvID string `gorm:"column:recv_id;type:char(64);index:recv_id,priority:2" json:"recvID"`
|
|
|
|
SenderPlatformID int32 `gorm:"column:sender_platform_id" json:"senderPlatformID"`
|
|
|
|
SenderNickname string `gorm:"column:sender_nick_name;type:varchar(255)" json:"senderNickname"`
|
|
|
|
SenderFaceURL string `gorm:"column:sender_face_url;type:varchar(255);" json:"senderFaceURL"`
|
|
|
|
SessionType int32 `gorm:"column:session_type;index:session_type,priority:2;index:session_type_alone" json:"sessionType"`
|
|
|
|
MsgFrom int32 `gorm:"column:msg_from" json:"msgFrom"`
|
|
|
|
ContentType int32 `gorm:"column:content_type;index:content_type,priority:2;index:content_type_alone" json:"contentType"`
|
|
|
|
Content string `gorm:"column:content;type:varchar(3000)" json:"content"`
|
|
|
|
Status int32 `gorm:"column:status" json:"status"`
|
|
|
|
SendTime time.Time `gorm:"column:send_time;index:sendTime;index:content_type,priority:1;index:session_type,priority:1;index:recv_id,priority:1;index:send_id,priority:1" json:"sendTime"`
|
|
|
|
CreateTime time.Time `gorm:"column:create_time" json:"createTime"`
|
|
|
|
Ex string `gorm:"column:ex;type:varchar(1024)" json:"ex"`
|
|
|
|
DB *gorm.DB
|
|
|
|
}
|