mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-30 07:44:19 +08:00 
			
		
		
		
	* fix: GetUserReqApplicationList error when there is a disbanded group chat
* fix: error when querying some information about disbanded group
* fix: GetUserReqApplicationList dismissed group error
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* merge
* cicd: robot automated Change
* sdkws.MsgData
* user
* interface{} -> any
* user
* third
* group
* group
* group
* group
* group
* group
* conversation
* standalone mysql db model
* tx
* s3
* group
* mongo
* group
* group
* group
* group
* group
* group
* refactor: add openim mysql to mongo refactor
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* refactor: add openim mysql to mongo refactor
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* remove mysql
* remove mysql
* friend
* friend
* friend
* friend
* friend
* friend
* group
* convert
* index
* index
* all
* all
* mysql2mongo
* data conversion
* up35
* up35
* feat: add format set
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* fix: fix scripts
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* merge main
* merge main
* Update init-config.sh
* fix: user args check
---------
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
Co-authored-by: withchao <withchao@users.noreply.github.com>
Co-authored-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
Co-authored-by: Xinwei Xiong <3293172751@qq.com>
		
	
			
		
			
				
	
	
		
			67 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright © 2023 OpenIM. All rights reserved.
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package relation
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	GroupModelTableName = "groups"
 | |
| )
 | |
| 
 | |
| 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;autoCreateTime"`
 | |
| 	Ex                     string    `gorm:"column:ex"                                           json:"ex;size:1024"`
 | |
| 	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 (GroupModel) TableName() string {
 | |
| 	return GroupModelTableName
 | |
| }
 | |
| 
 | |
| type GroupModelInterface interface {
 | |
| 	NewTx(tx any) GroupModelInterface
 | |
| 	Create(ctx context.Context, groups []*GroupModel) (err error)
 | |
| 	UpdateMap(ctx context.Context, groupID string, args map[string]interface{}) (err error)
 | |
| 	UpdateStatus(ctx context.Context, groupID string, status int32) (err error)
 | |
| 	Find(ctx context.Context, groupIDs []string) (groups []*GroupModel, err error)
 | |
| 	FindNotDismissedGroup(ctx context.Context, groupIDs []string) (groups []*GroupModel, err error)
 | |
| 	Take(ctx context.Context, groupID string) (group *GroupModel, err error)
 | |
| 	Search(
 | |
| 		ctx context.Context,
 | |
| 		keyword string,
 | |
| 		pageNumber, showNumber int32,
 | |
| 	) (total uint32, groups []*GroupModel, err error)
 | |
| 	GetGroupIDsByGroupType(ctx context.Context, groupType int) (groupIDs []string, err error)
 | |
| 	// 获取群总数
 | |
| 	CountTotal(ctx context.Context, before *time.Time) (count int64, err error)
 | |
| 	// 获取范围内群增量
 | |
| 	CountRangeEverydayTotal(ctx context.Context, start time.Time, end time.Time) (map[string]int64, error)
 | |
| }
 |