mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 21:22:16 +08:00 
			
		
		
		
	Merge branch 'openimsdk:main' into main
This commit is contained in:
		
						commit
						c025c725f1
					
				
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -12,7 +12,7 @@ require ( | |||||||
| 	github.com/gorilla/websocket v1.5.1 | 	github.com/gorilla/websocket v1.5.1 | ||||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||||
| 	github.com/mitchellh/mapstructure v1.5.0 | 	github.com/mitchellh/mapstructure v1.5.0 | ||||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.48 | 	github.com/openimsdk/protocol v0.0.72-alpha.53 | ||||||
| 	github.com/openimsdk/tools v0.0.50-alpha.16 | 	github.com/openimsdk/tools v0.0.50-alpha.16 | ||||||
| 	github.com/pkg/errors v0.9.1 // indirect | 	github.com/pkg/errors v0.9.1 // indirect | ||||||
| 	github.com/prometheus/client_golang v1.18.0 | 	github.com/prometheus/client_golang v1.18.0 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -319,8 +319,8 @@ github.com/onsi/gomega v1.25.0 h1:Vw7br2PCDYijJHSfBOWhov+8cAnUf8MfMaIOV323l6Y= | |||||||
| github.com/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | github.com/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | ||||||
| github.com/openimsdk/gomake v0.0.14-alpha.5 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | github.com/openimsdk/gomake v0.0.14-alpha.5 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | ||||||
| github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||||
| github.com/openimsdk/protocol v0.0.72-alpha.48 h1:DVeT8Kej6OjB9bsxQ0q6FU160anwfPuVmAL/1J6VzqM= | github.com/openimsdk/protocol v0.0.72-alpha.53 h1:DMzvDd418GaJJLT2Iw+AX+oNc41DROWErXDkZxB+MMM= | ||||||
| github.com/openimsdk/protocol v0.0.72-alpha.48/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | github.com/openimsdk/protocol v0.0.72-alpha.53/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.16 h1:bC1AQvJMuOHtZm8LZRvN8L5mH1Ws2VYdL+TLTs1iGSc= | github.com/openimsdk/tools v0.0.50-alpha.16 h1:bC1AQvJMuOHtZm8LZRvN8L5mH1Ws2VYdL+TLTs1iGSc= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.16/go.mod h1:h1cYmfyaVtgFbKmb1Cfsl8XwUOMTt8ubVUQrdGtsUh4= | github.com/openimsdk/tools v0.0.50-alpha.16/go.mod h1:h1cYmfyaVtgFbKmb1Cfsl8XwUOMTt8ubVUQrdGtsUh4= | ||||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||||
|  | |||||||
| @ -198,13 +198,6 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | |||||||
| 		objectGroup.POST("/initiate_form_data", t.InitiateFormData) | 		objectGroup.POST("/initiate_form_data", t.InitiateFormData) | ||||||
| 		objectGroup.POST("/complete_form_data", t.CompleteFormData) | 		objectGroup.POST("/complete_form_data", t.CompleteFormData) | ||||||
| 		objectGroup.GET("/*name", t.ObjectRedirect) | 		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 | 	// Message | ||||||
| 	msgGroup := r.Group("/msg") | 	msgGroup := r.Group("/msg") | ||||||
| @ -297,6 +290,4 @@ func GinParseToken(authRPC *rpcclient.Auth) gin.HandlerFunc { | |||||||
| var Whitelist = []string{ | var Whitelist = []string{ | ||||||
| 	"/auth/get_admin_token", | 	"/auth/get_admin_token", | ||||||
| 	"/auth/parse_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) { | func (o *ThirdApi) GetPrometheus(c *gin.Context) { | ||||||
| 	c.Redirect(http.StatusFound, o.GrafanaUrl) | 	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 { | 	switch ws.msgGatewayConfig.Share.MultiLogin.Policy { | ||||||
| 	case constant.DefalutNotKick: | 	case constant.DefalutNotKick: | ||||||
| 	case constant.WebAndOther: |  | ||||||
| 		if constant.PlatformIDToClass(newClient.PlatformID) == constant.WebPlatformStr { |  | ||||||
| 			return |  | ||||||
| 		} |  | ||||||
| 		fallthrough |  | ||||||
| 	case constant.PCAndOther: | 	case constant.PCAndOther: | ||||||
| 		if constant.PlatformIDToClass(newClient.PlatformID) == constant.TerminalPC { | 		if constant.PlatformIDToClass(newClient.PlatformID) == constant.TerminalPC { | ||||||
| 			return | 			return | ||||||
| @ -356,7 +351,7 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | |||||||
| 			log.ZWarn(newClient.ctx, "InvalidateToken err", err, "userID", newClient.UserID, | 			log.ZWarn(newClient.ctx, "InvalidateToken err", err, "userID", newClient.UserID, | ||||||
| 				"platformID", newClient.PlatformID) | 				"platformID", newClient.PlatformID) | ||||||
| 		} | 		} | ||||||
| 	case constant.PcMobileAndWeb: | 	case constant.AllLoginButSameClassKick: | ||||||
| 		clients, ok := ws.clients.GetAll(newClient.UserID) | 		clients, ok := ws.clients.GetAll(newClient.UserID) | ||||||
| 		if !ok { | 		if !ok { | ||||||
| 			return | 			return | ||||||
| @ -370,21 +365,6 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		kickTokenFunc(kickClients) | 		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 { | 	if req.UserID != opUserID { | ||||||
| 		req.UserID = mcontext.GetOpUserID(ctx) |  | ||||||
| 		adminIDs, err := g.db.GetGroupRoleLevelMemberIDs(ctx, req.GroupID, constant.GroupAdmin) | 		adminIDs, err := g.db.GetGroupRoleLevelMemberIDs(ctx, req.GroupID, constant.GroupAdmin) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return nil, err | 			return nil, err | ||||||
| @ -1820,10 +1819,11 @@ func (g *groupServer) GetSpecifiedUserGroupRequestInfo(ctx context.Context, req | |||||||
| 		adminIDs = append(adminIDs, owners[0].UserID) | 		adminIDs = append(adminIDs, owners[0].UserID) | ||||||
| 		adminIDs = append(adminIDs, g.config.Share.IMAdminUserID...) | 		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") | 			return nil, errs.ErrNoPermission.WrapMsg("opUser no permission") | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	requests, err := g.db.FindGroupRequests(ctx, req.GroupID, []string{req.UserID}) | 	requests, err := g.db.FindGroupRequests(ctx, req.GroupID, []string{req.UserID}) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		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 |  | ||||||
| } |  | ||||||
| @ -44,7 +44,6 @@ type thirdServer struct { | |||||||
| 	defaultExpire time.Duration | 	defaultExpire time.Duration | ||||||
| 	config        *Config | 	config        *Config | ||||||
| 	minio         *minio.Minio | 	minio         *minio.Minio | ||||||
| 	applicationDatabase controller.ApplicationDatabase |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type Config struct { | type Config struct { | ||||||
| @ -75,10 +74,6 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	applicationMgo, err := mgo.NewApplicationMgo(mgocli.GetDB()) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return err |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	// Select the oss method according to the profile policy | 	// Select the oss method according to the profile policy | ||||||
| 	enable := config.RpcConfig.Object.Enable | 	enable := config.RpcConfig.Object.Enable | ||||||
| @ -110,7 +105,6 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 		defaultExpire: time.Hour * 24 * 7, | 		defaultExpire: time.Hour * 24 * 7, | ||||||
| 		config:        config, | 		config:        config, | ||||||
| 		minio:         minioCli, | 		minio:         minioCli, | ||||||
| 		applicationDatabase: controller.NewApplicationDatabase(applicationMgo, redis.NewApplicationRedisCache(applicationMgo, rdb)), |  | ||||||
| 	}) | 	}) | ||||||
| 	return nil | 	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]) | 				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: | 	case constant.PCAndOther: | ||||||
| 		if unkickTerminal == "" { |  | ||||||
| 		unkickTerminal = constant.TerminalPC | 		unkickTerminal = constant.TerminalPC | ||||||
| 		} |  | ||||||
| 		if constant.PlatformIDToClass(platformID) != unkickTerminal { | 		if constant.PlatformIDToClass(platformID) != unkickTerminal { | ||||||
| 			for plt, ts := range loginTokenMap { | 			for plt, ts := range loginTokenMap { | ||||||
| 				if constant.PlatformIDToClass(plt) != unkickTerminal { | 				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 ( | 		var ( | ||||||
| 			reserved = make(map[string]bool) | 			reserved = make(map[string]struct{}) | ||||||
| 		) | 		) | ||||||
| 
 | 
 | ||||||
| 		for plt, ts := range loginTokenMap { | 		for plt, ts := range loginTokenMap { | ||||||
| 			if constant.PlatformIDToClass(plt) == constant.PlatformIDToClass(platformID) { | 			if constant.PlatformIDToClass(plt) == constant.PlatformIDToClass(platformID) { | ||||||
| 				kickToken = append(kickToken, ts...) | 				kickToken = append(kickToken, ts...) | ||||||
| 			} else { | 			} else { | ||||||
| 				if !reserved[constant.PlatformIDToClass(plt)] { | 				if _, ok := reserved[constant.PlatformIDToClass(plt)]; !ok { | ||||||
| 					reserved[constant.PlatformIDToClass(plt)] = true | 					reserved[constant.PlatformIDToClass(plt)] = struct{}{} | ||||||
| 					kickToken = append(kickToken, ts[:len(ts)-1]...) | 					kickToken = append(kickToken, ts[:len(ts)-1]...) | ||||||
| 					continue | 					continue | ||||||
| 				} else { | 				} 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: | 	default: | ||||||
| 		return nil, nil, errs.New("unknown multiLogin policy").Wrap() | 		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