mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	Merge remote-tracking branch 'origin/main' into stream_msg
# Conflicts: # go.mod # go.sum
This commit is contained in:
		
						commit
						a499339c99
					
				| @ -198,13 +198,6 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | ||||
| 		objectGroup.POST("/initiate_form_data", t.InitiateFormData) | ||||
| 		objectGroup.POST("/complete_form_data", t.CompleteFormData) | ||||
| 		objectGroup.GET("/*name", t.ObjectRedirect) | ||||
| 
 | ||||
| 		applicationGroup := r.Group("application") | ||||
| 		applicationGroup.POST("/add_version", t.AddApplicationVersion) | ||||
| 		applicationGroup.POST("/update_version", t.UpdateApplicationVersion) | ||||
| 		applicationGroup.POST("/delete_version", t.DeleteApplicationVersion) | ||||
| 		applicationGroup.POST("/latest_version", t.LatestApplicationVersion) | ||||
| 		applicationGroup.POST("/page_versions", t.PageApplicationVersion) | ||||
| 	} | ||||
| 	// Message | ||||
| 	msgGroup := r.Group("/msg") | ||||
| @ -299,6 +292,4 @@ func GinParseToken(authRPC *rpcclient.Auth) gin.HandlerFunc { | ||||
| var Whitelist = []string{ | ||||
| 	"/auth/get_admin_token", | ||||
| 	"/auth/parse_token", | ||||
| 	"/application/latest_version", | ||||
| 	"/application/page_versions", | ||||
| } | ||||
|  | ||||
| @ -170,23 +170,3 @@ func (o *ThirdApi) SearchLogs(c *gin.Context) { | ||||
| func (o *ThirdApi) GetPrometheus(c *gin.Context) { | ||||
| 	c.Redirect(http.StatusFound, o.GrafanaUrl) | ||||
| } | ||||
| 
 | ||||
| func (o *ThirdApi) LatestApplicationVersion(c *gin.Context) { | ||||
| 	a2r.Call(third.ThirdClient.LatestApplicationVersion, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *ThirdApi) AddApplicationVersion(c *gin.Context) { | ||||
| 	a2r.Call(third.ThirdClient.AddApplicationVersion, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *ThirdApi) UpdateApplicationVersion(c *gin.Context) { | ||||
| 	a2r.Call(third.ThirdClient.UpdateApplicationVersion, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *ThirdApi) DeleteApplicationVersion(c *gin.Context) { | ||||
| 	a2r.Call(third.ThirdClient.DeleteApplicationVersion, o.Client, c) | ||||
| } | ||||
| 
 | ||||
| func (o *ThirdApi) PageApplicationVersion(c *gin.Context) { | ||||
| 	a2r.Call(third.ThirdClient.PageApplicationVersion, o.Client, c) | ||||
| } | ||||
|  | ||||
| @ -327,11 +327,6 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | ||||
| 
 | ||||
| 	switch ws.msgGatewayConfig.Share.MultiLogin.Policy { | ||||
| 	case constant.DefalutNotKick: | ||||
| 	case constant.WebAndOther: | ||||
| 		if constant.PlatformIDToClass(newClient.PlatformID) == constant.WebPlatformStr { | ||||
| 			return | ||||
| 		} | ||||
| 		fallthrough | ||||
| 	case constant.PCAndOther: | ||||
| 		if constant.PlatformIDToClass(newClient.PlatformID) == constant.TerminalPC { | ||||
| 			return | ||||
| @ -356,7 +351,7 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | ||||
| 			log.ZWarn(newClient.ctx, "InvalidateToken err", err, "userID", newClient.UserID, | ||||
| 				"platformID", newClient.PlatformID) | ||||
| 		} | ||||
| 	case constant.PcMobileAndWeb: | ||||
| 	case constant.AllLoginButSameClassKick: | ||||
| 		clients, ok := ws.clients.GetAll(newClient.UserID) | ||||
| 		if !ok { | ||||
| 			return | ||||
| @ -370,21 +365,6 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | ||||
| 			} | ||||
| 		} | ||||
| 		kickTokenFunc(kickClients) | ||||
| 
 | ||||
| 	case constant.SingleTerminalLogin: | ||||
| 		clients, ok := ws.clients.GetAll(newClient.UserID) | ||||
| 		if !ok { | ||||
| 			return | ||||
| 		} | ||||
| 		var ( | ||||
| 			kickClients []*Client | ||||
| 		) | ||||
| 		for _, client := range clients { | ||||
| 			kickClients = append(kickClients, client) | ||||
| 		} | ||||
| 		kickTokenFunc(kickClients) | ||||
| 	case constant.Customize: | ||||
| 		// todo | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -1811,7 +1811,6 @@ func (g *groupServer) GetSpecifiedUserGroupRequestInfo(ctx context.Context, req | ||||
| 	} | ||||
| 
 | ||||
| 	if req.UserID != opUserID { | ||||
| 		req.UserID = mcontext.GetOpUserID(ctx) | ||||
| 		adminIDs, err := g.db.GetGroupRoleLevelMemberIDs(ctx, req.GroupID, constant.GroupAdmin) | ||||
| 		if err != nil { | ||||
| 			return nil, err | ||||
| @ -1820,10 +1819,11 @@ func (g *groupServer) GetSpecifiedUserGroupRequestInfo(ctx context.Context, req | ||||
| 		adminIDs = append(adminIDs, owners[0].UserID) | ||||
| 		adminIDs = append(adminIDs, g.config.Share.IMAdminUserID...) | ||||
| 
 | ||||
| 		if !datautil.Contain(req.UserID, adminIDs...) { | ||||
| 		if !datautil.Contain(opUserID, adminIDs...) { | ||||
| 			return nil, errs.ErrNoPermission.WrapMsg("opUser no permission") | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	requests, err := g.db.FindGroupRequests(ctx, req.GroupID, []string{req.UserID}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -1,136 +0,0 @@ | ||||
| package third | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/authverify" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||
| 	"github.com/openimsdk/protocol/third" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/redis/go-redis/v9" | ||||
| 	"go.mongodb.org/mongo-driver/bson/primitive" | ||||
| 	"go.mongodb.org/mongo-driver/mongo" | ||||
| 	"time" | ||||
| ) | ||||
| 
 | ||||
| func IsNotFound(err error) bool { | ||||
| 	switch errs.Unwrap(err) { | ||||
| 	case redis.Nil, mongo.ErrNoDocuments: | ||||
| 		return true | ||||
| 	default: | ||||
| 		return false | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) db2pbApplication(val *model.Application) *third.ApplicationVersion { | ||||
| 	return &third.ApplicationVersion{ | ||||
| 		Id:         val.ID.Hex(), | ||||
| 		Platform:   val.Platform, | ||||
| 		Version:    val.Version, | ||||
| 		Url:        val.Url, | ||||
| 		Text:       val.Text, | ||||
| 		Force:      val.Force, | ||||
| 		Latest:     val.Latest, | ||||
| 		Hot:        val.Hot, | ||||
| 		CreateTime: val.CreateTime.UnixMilli(), | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) getLatestApplicationVersion(ctx context.Context, platform string, hot bool) (*third.ApplicationVersion, error) { | ||||
| 	res, err := t.applicationDatabase.LatestVersion(ctx, platform, hot) | ||||
| 	if err == nil { | ||||
| 		return t.db2pbApplication(res), nil | ||||
| 	} else if IsNotFound(err) { | ||||
| 		return nil, nil | ||||
| 	} else { | ||||
| 		return nil, err | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) LatestApplicationVersion(ctx context.Context, req *third.LatestApplicationVersionReq) (*third.LatestApplicationVersionResp, error) { | ||||
| 	var ( | ||||
| 		resp third.LatestApplicationVersionResp | ||||
| 		err  error | ||||
| 	) | ||||
| 	resp.Version, err = t.getLatestApplicationVersion(ctx, req.Platform, false) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	resp.Hot, err = t.getLatestApplicationVersion(ctx, req.Platform, true) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &resp, nil | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) AddApplicationVersion(ctx context.Context, req *third.AddApplicationVersionReq) (*third.AddApplicationVersionResp, error) { | ||||
| 	if err := authverify.CheckAdmin(ctx, t.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	val := &model.Application{ | ||||
| 		ID:         primitive.NewObjectID(), | ||||
| 		Platform:   req.Platform, | ||||
| 		Version:    req.Version, | ||||
| 		Url:        req.Url, | ||||
| 		Text:       req.Text, | ||||
| 		Force:      req.Force, | ||||
| 		Latest:     req.Latest, | ||||
| 		Hot:        req.Hot, | ||||
| 		CreateTime: time.Now(), | ||||
| 	} | ||||
| 	if err := t.applicationDatabase.AddVersion(ctx, val); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &third.AddApplicationVersionResp{}, nil | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) UpdateApplicationVersion(ctx context.Context, req *third.UpdateApplicationVersionReq) (*third.UpdateApplicationVersionResp, error) { | ||||
| 	if err := authverify.CheckAdmin(ctx, t.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	oid, err := primitive.ObjectIDFromHex(req.Id) | ||||
| 	if err != nil { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("invalid id " + err.Error()) | ||||
| 	} | ||||
| 	update := make(map[string]any) | ||||
| 	putUpdate(update, "platform", req.Platform) | ||||
| 	putUpdate(update, "version", req.Version) | ||||
| 	putUpdate(update, "url", req.Url) | ||||
| 	putUpdate(update, "text", req.Text) | ||||
| 	putUpdate(update, "force", req.Force) | ||||
| 	putUpdate(update, "latest", req.Latest) | ||||
| 	putUpdate(update, "hot", req.Hot) | ||||
| 	if err := t.applicationDatabase.UpdateVersion(ctx, oid, update); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &third.UpdateApplicationVersionResp{}, nil | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) DeleteApplicationVersion(ctx context.Context, req *third.DeleteApplicationVersionReq) (*third.DeleteApplicationVersionResp, error) { | ||||
| 	if err := authverify.CheckAdmin(ctx, t.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	ids := make([]primitive.ObjectID, 0, len(req.Id)) | ||||
| 	for _, id := range req.Id { | ||||
| 		oid, err := primitive.ObjectIDFromHex(id) | ||||
| 		if err != nil { | ||||
| 			return nil, errs.ErrArgs.WrapMsg("invalid id " + err.Error()) | ||||
| 		} | ||||
| 		ids = append(ids, oid) | ||||
| 	} | ||||
| 	if err := t.applicationDatabase.DeleteVersion(ctx, ids); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &third.DeleteApplicationVersionResp{}, nil | ||||
| } | ||||
| 
 | ||||
| func (t *thirdServer) PageApplicationVersion(ctx context.Context, req *third.PageApplicationVersionReq) (*third.PageApplicationVersionResp, error) { | ||||
| 	total, res, err := t.applicationDatabase.PageVersion(ctx, req.Platform, req.Pagination) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &third.PageApplicationVersionResp{ | ||||
| 		Total:    total, | ||||
| 		Versions: datautil.Slice(res, t.db2pbApplication), | ||||
| 	}, nil | ||||
| } | ||||
| @ -38,13 +38,12 @@ import ( | ||||
| ) | ||||
| 
 | ||||
| type thirdServer struct { | ||||
| 	thirdDatabase       controller.ThirdDatabase | ||||
| 	s3dataBase          controller.S3Database | ||||
| 	userRpcClient       rpcclient.UserRpcClient | ||||
| 	defaultExpire       time.Duration | ||||
| 	config              *Config | ||||
| 	minio               *minio.Minio | ||||
| 	applicationDatabase controller.ApplicationDatabase | ||||
| 	thirdDatabase controller.ThirdDatabase | ||||
| 	s3dataBase    controller.S3Database | ||||
| 	userRpcClient rpcclient.UserRpcClient | ||||
| 	defaultExpire time.Duration | ||||
| 	config        *Config | ||||
| 	minio         *minio.Minio | ||||
| } | ||||
| 
 | ||||
| type Config struct { | ||||
| @ -75,10 +74,6 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	applicationMgo, err := mgo.NewApplicationMgo(mgocli.GetDB()) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	// Select the oss method according to the profile policy | ||||
| 	enable := config.RpcConfig.Object.Enable | ||||
| @ -104,13 +99,12 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 	} | ||||
| 	localcache.InitLocalCache(&config.LocalCacheConfig) | ||||
| 	third.RegisterThirdServer(server, &thirdServer{ | ||||
| 		thirdDatabase:       controller.NewThirdDatabase(redis.NewThirdCache(rdb), logdb), | ||||
| 		userRpcClient:       rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID), | ||||
| 		s3dataBase:          controller.NewS3Database(rdb, o, s3db), | ||||
| 		defaultExpire:       time.Hour * 24 * 7, | ||||
| 		config:              config, | ||||
| 		minio:               minioCli, | ||||
| 		applicationDatabase: controller.NewApplicationDatabase(applicationMgo, redis.NewApplicationRedisCache(applicationMgo, rdb)), | ||||
| 		thirdDatabase: controller.NewThirdDatabase(redis.NewThirdCache(rdb), logdb), | ||||
| 		userRpcClient: rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID), | ||||
| 		s3dataBase:    controller.NewS3Database(rdb, o, s3db), | ||||
| 		defaultExpire: time.Hour * 24 * 7, | ||||
| 		config:        config, | ||||
| 		minio:         minioCli, | ||||
| 	}) | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
							
								
								
									
										11
									
								
								pkg/common/storage/cache/application.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								pkg/common/storage/cache/application.go
									
									
									
									
										vendored
									
									
								
							| @ -1,11 +0,0 @@ | ||||
| package cache | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||
| ) | ||||
| 
 | ||||
| type ApplicationCache interface { | ||||
| 	LatestVersion(ctx context.Context, platform string, hot bool) (*model.Application, error) | ||||
| 	DeleteCache(ctx context.Context, platforms []string) error | ||||
| } | ||||
							
								
								
									
										15
									
								
								pkg/common/storage/cache/cachekey/application.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								pkg/common/storage/cache/cachekey/application.go
									
									
									
									
										vendored
									
									
								
							| @ -1,15 +0,0 @@ | ||||
| package cachekey | ||||
| 
 | ||||
| const ( | ||||
| 	ApplicationLatestVersion = "APPLICATION_LATEST_VERSION:" | ||||
| ) | ||||
| 
 | ||||
| func GetApplicationLatestVersionKey(platform string, hot bool) string { | ||||
| 	var hotStr string | ||||
| 	if hot { | ||||
| 		hotStr = "1:" | ||||
| 	} else { | ||||
| 		hotStr = "0:" | ||||
| 	} | ||||
| 	return ApplicationLatestVersion + hotStr + platform | ||||
| } | ||||
							
								
								
									
										44
									
								
								pkg/common/storage/cache/redis/application.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										44
									
								
								pkg/common/storage/cache/redis/application.go
									
									
									
									
										vendored
									
									
								
							| @ -1,44 +0,0 @@ | ||||
| package redis | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/dtm-labs/rockscache" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/cachekey" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||
| 	"github.com/redis/go-redis/v9" | ||||
| 	"time" | ||||
| ) | ||||
| 
 | ||||
| func NewApplicationRedisCache(db database.Application, rdb redis.UniversalClient) *ApplicationRedisCache { | ||||
| 	return &ApplicationRedisCache{ | ||||
| 		db:         db, | ||||
| 		rcClient:   rockscache.NewClient(rdb, *GetRocksCacheOptions()), | ||||
| 		deleter:    NewBatchDeleterRedis(rdb, GetRocksCacheOptions(), nil), | ||||
| 		expireTime: time.Hour * 24 * 7, | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| type ApplicationRedisCache struct { | ||||
| 	db         database.Application | ||||
| 	rcClient   *rockscache.Client | ||||
| 	deleter    *BatchDeleterRedis | ||||
| 	expireTime time.Duration | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationRedisCache) LatestVersion(ctx context.Context, platform string, hot bool) (*model.Application, error) { | ||||
| 	return getCache(ctx, a.rcClient, cachekey.GetApplicationLatestVersionKey(platform, hot), a.expireTime, func(ctx context.Context) (*model.Application, error) { | ||||
| 		return a.db.LatestVersion(ctx, platform, hot) | ||||
| 	}) | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationRedisCache) DeleteCache(ctx context.Context, platforms []string) error { | ||||
| 	if len(platforms) == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	keys := make([]string, 0, len(platforms)*2) | ||||
| 	for _, platform := range platforms { | ||||
| 		keys = append(keys, cachekey.GetApplicationLatestVersionKey(platform, true), cachekey.GetApplicationLatestVersionKey(platform, false)) | ||||
| 	} | ||||
| 	return a.deleter.ExecDelWithKeys(ctx, keys) | ||||
| } | ||||
| @ -1,69 +0,0 @@ | ||||
| package controller | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||
| 	"github.com/openimsdk/tools/db/pagination" | ||||
| 	"go.mongodb.org/mongo-driver/bson/primitive" | ||||
| ) | ||||
| 
 | ||||
| type ApplicationDatabase interface { | ||||
| 	LatestVersion(ctx context.Context, platform string, hot bool) (*model.Application, error) | ||||
| 	AddVersion(ctx context.Context, val *model.Application) error | ||||
| 	UpdateVersion(ctx context.Context, id primitive.ObjectID, update map[string]any) error | ||||
| 	DeleteVersion(ctx context.Context, id []primitive.ObjectID) error | ||||
| 	PageVersion(ctx context.Context, platforms []string, page pagination.Pagination) (int64, []*model.Application, error) | ||||
| } | ||||
| 
 | ||||
| func NewApplicationDatabase(db database.Application, cache cache.ApplicationCache) ApplicationDatabase { | ||||
| 	return &applicationDatabase{db: db, cache: cache} | ||||
| } | ||||
| 
 | ||||
| type applicationDatabase struct { | ||||
| 	db    database.Application | ||||
| 	cache cache.ApplicationCache | ||||
| } | ||||
| 
 | ||||
| func (a *applicationDatabase) LatestVersion(ctx context.Context, platform string, hot bool) (*model.Application, error) { | ||||
| 	return a.cache.LatestVersion(ctx, platform, hot) | ||||
| } | ||||
| 
 | ||||
| func (a *applicationDatabase) AddVersion(ctx context.Context, val *model.Application) error { | ||||
| 	if err := a.db.AddVersion(ctx, val); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return a.cache.DeleteCache(ctx, []string{val.Platform}) | ||||
| } | ||||
| 
 | ||||
| func (a *applicationDatabase) UpdateVersion(ctx context.Context, id primitive.ObjectID, update map[string]any) error { | ||||
| 	platforms, err := a.db.FindPlatform(ctx, []primitive.ObjectID{id}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := a.db.UpdateVersion(ctx, id, update); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if p, ok := update["platform"]; ok { | ||||
| 		if val, ok := p.(string); ok { | ||||
| 			platforms = append(platforms, val) | ||||
| 		} | ||||
| 	} | ||||
| 	return a.cache.DeleteCache(ctx, platforms) | ||||
| } | ||||
| 
 | ||||
| func (a *applicationDatabase) DeleteVersion(ctx context.Context, id []primitive.ObjectID) error { | ||||
| 	platforms, err := a.db.FindPlatform(ctx, id) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := a.db.DeleteVersion(ctx, id); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	return a.cache.DeleteCache(ctx, platforms) | ||||
| } | ||||
| 
 | ||||
| func (a *applicationDatabase) PageVersion(ctx context.Context, platforms []string, page pagination.Pagination) (int64, []*model.Application, error) { | ||||
| 	return a.db.PageVersion(ctx, platforms, page) | ||||
| } | ||||
| @ -172,17 +172,8 @@ func (a *authDatabase) checkToken(ctx context.Context, tokens map[int]map[string | ||||
| 				kickToken = append(kickToken, ts[len(ts)-1]) | ||||
| 			} | ||||
| 		} | ||||
| 	case constant.SingleTerminalLogin: | ||||
| 		for _, ts := range loginTokenMap { | ||||
| 			kickToken = append(kickToken, ts...) | ||||
| 		} | ||||
| 	case constant.WebAndOther: | ||||
| 		unkickTerminal = constant.WebPlatformStr | ||||
| 		fallthrough | ||||
| 	case constant.PCAndOther: | ||||
| 		if unkickTerminal == "" { | ||||
| 			unkickTerminal = constant.TerminalPC | ||||
| 		} | ||||
| 		unkickTerminal = constant.TerminalPC | ||||
| 		if constant.PlatformIDToClass(platformID) != unkickTerminal { | ||||
| 			for plt, ts := range loginTokenMap { | ||||
| 				if constant.PlatformIDToClass(plt) != unkickTerminal { | ||||
| @ -214,17 +205,17 @@ func (a *authDatabase) checkToken(ctx context.Context, tokens map[int]map[string | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	case constant.PcMobileAndWeb: | ||||
| 	case constant.AllLoginButSameClassKick: | ||||
| 		var ( | ||||
| 			reserved = make(map[string]bool) | ||||
| 			reserved = make(map[string]struct{}) | ||||
| 		) | ||||
| 
 | ||||
| 		for plt, ts := range loginTokenMap { | ||||
| 			if constant.PlatformIDToClass(plt) == constant.PlatformIDToClass(platformID) { | ||||
| 				kickToken = append(kickToken, ts...) | ||||
| 			} else { | ||||
| 				if !reserved[constant.PlatformIDToClass(plt)] { | ||||
| 					reserved[constant.PlatformIDToClass(plt)] = true | ||||
| 				if _, ok := reserved[constant.PlatformIDToClass(plt)]; !ok { | ||||
| 					reserved[constant.PlatformIDToClass(plt)] = struct{}{} | ||||
| 					kickToken = append(kickToken, ts[:len(ts)-1]...) | ||||
| 					continue | ||||
| 				} else { | ||||
| @ -232,22 +223,6 @@ func (a *authDatabase) checkToken(ctx context.Context, tokens map[int]map[string | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 	case constant.Customize: | ||||
| 		if a.multiLogin.CustomizeLoginNum[platformID] <= 0 { | ||||
| 			return nil, nil, errs.New("Do not allow login on this end").Wrap() | ||||
| 		} | ||||
| 		for plt, ts := range loginTokenMap { | ||||
| 			l := len(ts) | ||||
| 			if platformID == plt { | ||||
| 				l++ | ||||
| 			} | ||||
| 			// a.multiLogin.CustomizeLoginNum[platformID] must > 0 | ||||
| 			limit := min(a.multiLogin.CustomizeLoginNum[plt], a.multiLogin.MaxNumOneEnd) | ||||
| 			if l > limit { | ||||
| 				kickToken = append(kickToken, ts[:l-limit]...) | ||||
| 			} | ||||
| 		} | ||||
| 	default: | ||||
| 		return nil, nil, errs.New("unknown multiLogin policy").Wrap() | ||||
| 	} | ||||
|  | ||||
| @ -1,17 +0,0 @@ | ||||
| package database | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||
| 	"github.com/openimsdk/tools/db/pagination" | ||||
| 	"go.mongodb.org/mongo-driver/bson/primitive" | ||||
| ) | ||||
| 
 | ||||
| type Application interface { | ||||
| 	LatestVersion(ctx context.Context, platform string, hot bool) (*model.Application, error) | ||||
| 	AddVersion(ctx context.Context, val *model.Application) error | ||||
| 	UpdateVersion(ctx context.Context, id primitive.ObjectID, update map[string]any) error | ||||
| 	DeleteVersion(ctx context.Context, id []primitive.ObjectID) error | ||||
| 	PageVersion(ctx context.Context, platforms []string, page pagination.Pagination) (int64, []*model.Application, error) | ||||
| 	FindPlatform(ctx context.Context, id []primitive.ObjectID) ([]string, error) | ||||
| } | ||||
| @ -1,83 +0,0 @@ | ||||
| package mgo | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model" | ||||
| 	"github.com/openimsdk/tools/db/mongoutil" | ||||
| 	"github.com/openimsdk/tools/db/pagination" | ||||
| 	"go.mongodb.org/mongo-driver/bson" | ||||
| 	"go.mongodb.org/mongo-driver/bson/primitive" | ||||
| 	"go.mongodb.org/mongo-driver/mongo" | ||||
| 	"go.mongodb.org/mongo-driver/mongo/options" | ||||
| ) | ||||
| 
 | ||||
| func NewApplicationMgo(db *mongo.Database) (*ApplicationMgo, error) { | ||||
| 	coll := db.Collection("application") | ||||
| 	_, err := coll.Indexes().CreateMany(context.Background(), []mongo.IndexModel{ | ||||
| 		{ | ||||
| 			Keys: bson.D{ | ||||
| 				{Key: "platform", Value: 1}, | ||||
| 				{Key: "version", Value: 1}, | ||||
| 				{Key: "hot", Value: 1}, | ||||
| 			}, | ||||
| 			Options: options.Index().SetUnique(true), | ||||
| 		}, | ||||
| 		{ | ||||
| 			Keys: bson.D{ | ||||
| 				{Key: "latest", Value: -1}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &ApplicationMgo{coll: coll}, nil | ||||
| } | ||||
| 
 | ||||
| type ApplicationMgo struct { | ||||
| 	coll *mongo.Collection | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) sort() any { | ||||
| 	return bson.D{{"latest", -1}, {"_id", -1}} | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) LatestVersion(ctx context.Context, platform string, hot bool) (*model.Application, error) { | ||||
| 	return mongoutil.FindOne[*model.Application](ctx, a.coll, bson.M{"platform": platform, "hot": hot}, options.FindOne().SetSort(a.sort())) | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) AddVersion(ctx context.Context, val *model.Application) error { | ||||
| 	if val.ID.IsZero() { | ||||
| 		val.ID = primitive.NewObjectID() | ||||
| 	} | ||||
| 	return mongoutil.InsertMany(ctx, a.coll, []*model.Application{val}) | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) UpdateVersion(ctx context.Context, id primitive.ObjectID, update map[string]any) error { | ||||
| 	if len(update) == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return mongoutil.UpdateOne(ctx, a.coll, bson.M{"_id": id}, bson.M{"$set": update}, true) | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) DeleteVersion(ctx context.Context, id []primitive.ObjectID) error { | ||||
| 	if len(id) == 0 { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return mongoutil.DeleteMany(ctx, a.coll, bson.M{"_id": bson.M{"$in": id}}) | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) PageVersion(ctx context.Context, platforms []string, page pagination.Pagination) (int64, []*model.Application, error) { | ||||
| 	filter := bson.M{} | ||||
| 	if len(platforms) > 0 { | ||||
| 		filter["platform"] = bson.M{"$in": platforms} | ||||
| 	} | ||||
| 	return mongoutil.FindPage[*model.Application](ctx, a.coll, filter, page, options.Find().SetSort(a.sort())) | ||||
| } | ||||
| 
 | ||||
| func (a *ApplicationMgo) FindPlatform(ctx context.Context, id []primitive.ObjectID) ([]string, error) { | ||||
| 	if len(id) == 0 { | ||||
| 		return nil, nil | ||||
| 	} | ||||
| 	return mongoutil.Find[string](ctx, a.coll, bson.M{"_id": bson.M{"$in": id}}, options.Find().SetProjection(bson.M{"_id": 0, "platform": 1})) | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user