mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 04:32:10 +08:00 
			
		
		
		
	feat: add nickname for adminUser
This commit is contained in:
		
							parent
							
								
									6912ad6f33
								
							
						
					
					
						commit
						a726cc73fd
					
				| @ -1,6 +1,8 @@ | ||||
| secret: openIM123 | ||||
| 
 | ||||
| imAdminUserID: [imAdmin] | ||||
| imAdminUser: | ||||
|   imAdmin: superAdmin  # The userID and nickname of the admin. Format: userID:nickname | ||||
| #  imAdmin2: superAdmin2  # You can add more admin users by following the format above. | ||||
| 
 | ||||
| # 1: For Android, iOS, Windows, Mac, and web platforms, only one instance can be online at a time | ||||
| multiLogin: | ||||
|  | ||||
| @ -29,6 +29,7 @@ import ( | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/mw" | ||||
| 	"github.com/openimsdk/tools/mw/api" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	clientv3 "go.etcd.io/etcd/client/v3" | ||||
| ) | ||||
| 
 | ||||
| @ -98,7 +99,7 @@ func newGinRouter(ctx context.Context, client discovery.SvcDiscoveryRegistry, cf | ||||
| 		r.Use(gzip.Gzip(gzip.BestSpeed)) | ||||
| 	} | ||||
| 	r.Use(api.GinLogger(), prommetricsGin(), gin.RecoveryWithWriter(gin.DefaultErrorWriter, mw.GinPanicErr), mw.CorsHandler(), | ||||
| 		mw.GinParseOperationID(), GinParseToken(rpcli.NewAuthClient(authConn)), setGinIsAdmin(cfg.Share.IMAdminUserID)) | ||||
| 		mw.GinParseOperationID(), GinParseToken(rpcli.NewAuthClient(authConn)), setGinIsAdmin(datautil.Keys(cfg.Share.IMAdminUser))) | ||||
| 
 | ||||
| 	u := NewUserApi(user.NewUserClient(userConn), client, cfg.Discovery.RpcService) | ||||
| 	{ | ||||
| @ -232,7 +233,7 @@ func newGinRouter(ctx context.Context, client discovery.SvcDiscoveryRegistry, cf | ||||
| 		objectGroup.GET("/*name", t.ObjectRedirect) | ||||
| 	} | ||||
| 	// Message | ||||
| 	m := NewMessageApi(msg.NewMsgClient(msgConn), rpcli.NewUserClient(userConn), cfg.Share.IMAdminUserID) | ||||
| 	m := NewMessageApi(msg.NewMsgClient(msgConn), rpcli.NewUserClient(userConn), datautil.Keys(cfg.Share.IMAdminUser)) | ||||
| 	{ | ||||
| 		msgGroup := r.Group("/msg") | ||||
| 		msgGroup.POST("/newest_seq", m.GetSeq) | ||||
| @ -309,7 +310,7 @@ func newGinRouter(ctx context.Context, client discovery.SvcDiscoveryRegistry, cf | ||||
| 	if cfg.Discovery.Enable == config.ETCD { | ||||
| 		etcdClient = client.(*etcd.SvcDiscoveryRegistryImpl).GetClient() | ||||
| 	} | ||||
| 	cm := NewConfigManager(cfg.Share.IMAdminUserID, &cfg.AllConfig, etcdClient, string(cfg.ConfigPath)) | ||||
| 	cm := NewConfigManager(datautil.Keys(cfg.Share.IMAdminUser), &cfg.AllConfig, etcdClient, string(cfg.ConfigPath)) | ||||
| 	{ | ||||
| 		configGroup := r.Group("/config", cm.CheckAdmin) | ||||
| 		configGroup.POST("/get_config_list", cm.GetConfigList) | ||||
|  | ||||
| @ -130,7 +130,7 @@ func NewWsServer(msgGatewayConfig *Config, opts ...Option) *WsServer { | ||||
| 	for _, o := range opts { | ||||
| 		o(&config) | ||||
| 	} | ||||
| 	//userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||
| 	//userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUser) | ||||
| 
 | ||||
| 	v := validator.New() | ||||
| 	return &WsServer{ | ||||
|  | ||||
| @ -317,8 +317,8 @@ func (c *ConsumerHandler) groupMessagesHandler(ctx context.Context, groupID stri | ||||
| 					return err | ||||
| 				} | ||||
| 				log.ZDebug(ctx, "GroupDismissedNotificationInfo****", "groupID", groupID, "num", len(*pushToUserIDs), "list", pushToUserIDs) | ||||
| 				if len(c.config.Share.IMAdminUserID) > 0 { | ||||
| 					ctx = mcontext.WithOpUserIDContext(ctx, c.config.Share.IMAdminUserID[0]) | ||||
| 				if len(c.config.Share.IMAdminUser) > 0 { | ||||
| 					ctx = mcontext.WithOpUserIDContext(ctx, datautil.Keys(c.config.Share.IMAdminUser)[0]) | ||||
| 				} | ||||
| 				defer func(groupID string) { | ||||
| 					if err := c.groupClient.DismissGroup(ctx, groupID, true); err != nil { | ||||
|  | ||||
| @ -49,6 +49,7 @@ type authServer struct { | ||||
| 	RegisterCenter discovery.Conn | ||||
| 	config         *Config | ||||
| 	userClient     *rpcli.UserClient | ||||
| 	adminUserIDs   []string | ||||
| } | ||||
| 
 | ||||
| type Config struct { | ||||
| @ -90,10 +91,11 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 			config.Share.Secret, | ||||
| 			config.RpcConfig.TokenPolicy.Expire, | ||||
| 			config.Share.MultiLogin, | ||||
| 			config.Share.IMAdminUserID, | ||||
| 			datautil.Keys(config.Share.IMAdminUser), | ||||
| 		), | ||||
| 		config:     config, | ||||
| 		userClient: rpcli.NewUserClient(userConn), | ||||
| 		config:       config, | ||||
| 		userClient:   rpcli.NewUserClient(userConn), | ||||
| 		adminUserIDs: datautil.Keys(config.Share.IMAdminUser), | ||||
| 	}) | ||||
| 	return nil | ||||
| } | ||||
| @ -104,8 +106,8 @@ func (s *authServer) GetAdminToken(ctx context.Context, req *pbauth.GetAdminToke | ||||
| 		return nil, errs.ErrNoPermission.WrapMsg("secret invalid") | ||||
| 	} | ||||
| 
 | ||||
| 	if !datautil.Contain(req.UserID, s.config.Share.IMAdminUserID...) { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("userID is error.", "userID", req.UserID, "adminUserID", s.config.Share.IMAdminUserID) | ||||
| 	if !datautil.Contain(req.UserID, s.adminUserIDs...) { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("userID is error.", "userID", req.UserID, "adminUserID", s.adminUserIDs) | ||||
| 
 | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
| @ -63,6 +63,7 @@ type groupServer struct { | ||||
| 	userClient         *rpcli.UserClient | ||||
| 	msgClient          *rpcli.MsgClient | ||||
| 	conversationClient *rpcli.ConversationClient | ||||
| 	adminUserIDs       []string | ||||
| } | ||||
| 
 | ||||
| type Config struct { | ||||
| @ -116,6 +117,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 		userClient:         rpcli.NewUserClient(userConn), | ||||
| 		msgClient:          rpcli.NewMsgClient(msgConn), | ||||
| 		conversationClient: rpcli.NewConversationClient(conversationConn), | ||||
| 		adminUserIDs:       datautil.Keys(config.Share.IMAdminUser), | ||||
| 	} | ||||
| 	gs.db = controller.NewGroupDatabase(rdb, &config.LocalCacheConfig, groupDB, groupMemberDB, groupRequestDB, mgocli.GetTx(), grouphash.NewGroupHashFromGroupServer(&gs)) | ||||
| 	gs.notification = NewNotificationSender(gs.db, config, gs.userClient, gs.msgClient, gs.conversationClient) | ||||
| @ -1901,7 +1903,7 @@ func (g *groupServer) GetSpecifiedUserGroupRequestInfo(ctx context.Context, req | ||||
| 		} | ||||
| 
 | ||||
| 		adminIDs = append(adminIDs, owners[0].UserID) | ||||
| 		adminIDs = append(adminIDs, g.config.Share.IMAdminUserID...) | ||||
| 		adminIDs = append(adminIDs, g.adminUserIDs...) | ||||
| 
 | ||||
| 		if !datautil.Contain(opUserID, adminIDs...) { | ||||
| 			return nil, errs.ErrNoPermission.WrapMsg("opUser no permission") | ||||
|  | ||||
| @ -109,8 +109,8 @@ func (m *msgServer) RevokeMsg(ctx context.Context, req *msg.RevokeMsgReq) (*msg. | ||||
| 	revokerUserID := mcontext.GetOpUserID(ctx) | ||||
| 	var flag bool | ||||
| 
 | ||||
| 	if len(m.config.Share.IMAdminUserID) > 0 { | ||||
| 		flag = datautil.Contain(revokerUserID, m.config.Share.IMAdminUserID...) | ||||
| 	if len(m.config.Share.IMAdminUser) > 0 { | ||||
| 		flag = datautil.Contain(revokerUserID, m.adminUserIDs...) | ||||
| 	} | ||||
| 	tips := sdkws.RevokeMsgTips{ | ||||
| 		RevokerUserID:  revokerUserID, | ||||
|  | ||||
| @ -22,6 +22,7 @@ import ( | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/dbbuild" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/mqbuild" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 
 | ||||
| 	"google.golang.org/grpc" | ||||
| 
 | ||||
| @ -71,6 +72,8 @@ type msgServer struct { | ||||
| 	config                 *Config                          // Global configuration settings. | ||||
| 	webhookClient          *webhook.Client | ||||
| 	conversationClient     *rpcli.ConversationClient | ||||
| 
 | ||||
| 	adminUserIDs []string | ||||
| } | ||||
| 
 | ||||
| func (m *msgServer) addInterceptorHandler(interceptorFunc ...MessageInterceptorFunc) { | ||||
| @ -145,6 +148,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 		config:                 config, | ||||
| 		webhookClient:          webhook.NewWebhookClient(config.WebhooksConfig.URL), | ||||
| 		conversationClient:     conversationClient, | ||||
| 		adminUserIDs:           datautil.Keys(config.Share.IMAdminUser), | ||||
| 	} | ||||
| 
 | ||||
| 	s.notificationSender = notification.NewNotificationSender(&config.NotificationConfig, notification.WithLocalSendMsg(s.SendMsg)) | ||||
|  | ||||
| @ -54,7 +54,7 @@ type MessageRevoked struct { | ||||
| func (m *msgServer) messageVerification(ctx context.Context, data *msg.SendMsgReq) error { | ||||
| 	switch data.MsgData.SessionType { | ||||
| 	case constant.SingleChatType: | ||||
| 		if datautil.Contain(data.MsgData.SendID, m.config.Share.IMAdminUserID...) { | ||||
| 		if datautil.Contain(data.MsgData.SendID, m.adminUserIDs...) { | ||||
| 			return nil | ||||
| 		} | ||||
| 		if data.MsgData.ContentType <= constant.NotificationEnd && | ||||
| @ -102,7 +102,7 @@ func (m *msgServer) messageVerification(ctx context.Context, data *msg.SendMsgRe | ||||
| 			return nil | ||||
| 		} | ||||
| 
 | ||||
| 		if datautil.Contain(data.MsgData.SendID, m.config.Share.IMAdminUserID...) { | ||||
| 		if datautil.Contain(data.MsgData.SendID, m.adminUserIDs...) { | ||||
| 			return nil | ||||
| 		} | ||||
| 		if data.MsgData.ContentType <= constant.NotificationEnd && | ||||
|  | ||||
| @ -65,6 +65,8 @@ type userServer struct { | ||||
| 	groupClient              *rpcli.GroupClient | ||||
| 	relationClient           *rpcli.RelationClient | ||||
| 	clientConfig             controller.ClientConfigDatabase | ||||
| 
 | ||||
| 	adminUserIDs []string | ||||
| } | ||||
| 
 | ||||
| type Config struct { | ||||
| @ -92,8 +94,8 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 
 | ||||
| 	users := make([]*tablerelation.User, 0) | ||||
| 
 | ||||
| 	for _, v := range config.Share.IMAdminUserID { | ||||
| 		users = append(users, &tablerelation.User{UserID: v, Nickname: v, AppMangerLevel: constant.AppAdmin}) | ||||
| 	for uid, name := range config.Share.IMAdminUser { | ||||
| 		users = append(users, &tablerelation.User{UserID: uid, Nickname: name, AppMangerLevel: constant.AppAdmin}) | ||||
| 	} | ||||
| 	userDB, err := mgo.NewUserMongo(mgocli.GetDB()) | ||||
| 	if err != nil { | ||||
| @ -130,6 +132,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 		clientConfig:             controller.NewClientConfigDatabase(clientConfigDB, redis.NewClientConfigCache(rdb, clientConfigDB), mgocli.GetTx()), | ||||
| 		groupClient:              rpcli.NewGroupClient(groupConn), | ||||
| 		relationClient:           rpcli.NewRelationClient(friendConn), | ||||
| 		adminUserIDs:             datautil.Keys(config.Share.IMAdminUser), | ||||
| 	} | ||||
| 	pbuser.RegisterUserServer(server, u) | ||||
| 	return u.db.InitOnce(context.Background(), users) | ||||
| @ -648,7 +651,7 @@ func (s *userServer) userModelToResp(users []*tablerelation.User, pagination pag | ||||
| 	accounts := make([]*pbuser.NotificationAccountInfo, 0) | ||||
| 	var total int64 | ||||
| 	for _, v := range users { | ||||
| 		if v.AppMangerLevel >= constant.AppNotificationAdmin && !datautil.Contain(v.UserID, s.config.Share.IMAdminUserID...) { | ||||
| 		if v.AppMangerLevel >= constant.AppNotificationAdmin && !datautil.Contain(v.UserID, s.adminUserIDs...) { | ||||
| 			if appManagerLevel != nil { | ||||
| 				if v.AppMangerLevel != *appManagerLevel { | ||||
| 					continue | ||||
|  | ||||
| @ -10,6 +10,7 @@ import ( | ||||
| 	"github.com/openimsdk/protocol/third" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 	"github.com/openimsdk/tools/discovery/etcd" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| @ -32,7 +33,7 @@ func Start(ctx context.Context, conf *Config, client discovery.SvcDiscoveryRegis | ||||
| 		<-ctx.Done() | ||||
| 		return nil | ||||
| 	} | ||||
| 	ctx = mcontext.SetOpUserID(ctx, conf.Share.IMAdminUserID[0]) | ||||
| 	ctx = mcontext.SetOpUserID(ctx, datautil.Keys(conf.Share.IMAdminUser)[0]) | ||||
| 
 | ||||
| 	msgConn, err := client.GetConn(ctx, conf.Discovery.RpcService.Msg) | ||||
| 	if err != nil { | ||||
|  | ||||
| @ -356,10 +356,10 @@ type AfterConfig struct { | ||||
| } | ||||
| 
 | ||||
| type Share struct { | ||||
| 	Secret         string         `yaml:"secret"` | ||||
| 	IMAdminUserID  []string       `yaml:"imAdminUserID"` | ||||
| 	MultiLogin     MultiLogin     `yaml:"multiLogin"` | ||||
| 	RPCMaxBodySize MaxRequestBody `yaml:"rpcMaxBodySize"` | ||||
| 	Secret         string            `yaml:"secret"` | ||||
| 	IMAdminUser    map[string]string `yaml:"imAdminUserID"` | ||||
| 	MultiLogin     MultiLogin        `yaml:"multiLogin"` | ||||
| 	RPCMaxBodySize MaxRequestBody    `yaml:"rpcMaxBodySize"` | ||||
| } | ||||
| 
 | ||||
| type MaxRequestBody struct { | ||||
|  | ||||
| @ -69,8 +69,8 @@ func Start[T any](ctx context.Context, disc *conf.Discovery, prometheusConfig *c | ||||
| 		grpcsrv.GrpcServerRequestValidate(), | ||||
| 		grpcsrv.GrpcServerPanicCapture(), | ||||
| 	) | ||||
| 	if shareConfig != nil && len(shareConfig.IMAdminUserID) > 0 { | ||||
| 		options = append(options, grpcServerIMAdminUserID(shareConfig.IMAdminUserID)) | ||||
| 	if shareConfig != nil && len(shareConfig.IMAdminUser) > 0 { | ||||
| 		options = append(options, grpcServerIMAdminUserID(datautil.Keys(shareConfig.IMAdminUser))) | ||||
| 	} | ||||
| 	var clientOptions []grpc.DialOption | ||||
| 	if maxRequestBody != nil { | ||||
|  | ||||
| @ -97,16 +97,34 @@ func (u *userDatabase) InitOnce(ctx context.Context, users []*model.User) error | ||||
| 	} | ||||
| 
 | ||||
| 	// Determine which users are missing from the database. | ||||
| 	missingUsers := datautil.SliceAnySub(users, existingUsers, func(e *model.User) string { | ||||
| 	var ( | ||||
| 		missing, update []*model.User | ||||
| 	) | ||||
| 	existMap := datautil.SliceToMap(existingUsers, func(e *model.User) string { | ||||
| 		return e.UserID | ||||
| 	}) | ||||
| 	orgMap := datautil.SliceToMap(users, func(e *model.User) string { return e.UserID }) | ||||
| 	for k, u1 := range orgMap { | ||||
| 		if u2, ok := existMap[k]; !ok { | ||||
| 			missing = append(missing, u1) | ||||
| 		} else if u1.Nickname != u2.Nickname { | ||||
| 			update = append(update, u1) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Create records for missing users. | ||||
| 	if len(missingUsers) > 0 { | ||||
| 		if err := u.userDB.Create(ctx, missingUsers); err != nil { | ||||
| 	if len(missing) > 0 { | ||||
| 		if err := u.userDB.Create(ctx, missing); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	if len(update) > 0 { | ||||
| 		for i := range update { | ||||
| 			if err := u.userDB.UpdateByMap(ctx, update[i].UserID, map[string]any{"nickname": update[i].Nickname}); err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| @ -23,6 +23,7 @@ import ( | ||||
| 	pbuser "github.com/openimsdk/protocol/user" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/system/program" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| ) | ||||
| 
 | ||||
| // 1. Create 100K New Users | ||||
| @ -446,7 +447,7 @@ func main() { | ||||
| 			Share: *share, | ||||
| 			Api:   *apiConfig, | ||||
| 		}, | ||||
| 		AdminUserID: share.IMAdminUserID[0], | ||||
| 		AdminUserID: datautil.Keys(share.IMAdminUser)[0], | ||||
| 		Ctx:         ctx, | ||||
| 		Cancel:      cancel, | ||||
| 		HttpClient: &http.Client{ | ||||
|  | ||||
| @ -24,6 +24,7 @@ import ( | ||||
| 	pbuser "github.com/openimsdk/protocol/user" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/system/program" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| ) | ||||
| 
 | ||||
| /* | ||||
| @ -319,7 +320,7 @@ func main() { | ||||
| 			Share: *share, | ||||
| 			Api:   *apiConfig, | ||||
| 		}, | ||||
| 		AdminUserID: share.IMAdminUserID[0], | ||||
| 		AdminUserID: datautil.Keys(share.IMAdminUser)[0], | ||||
| 		Ctx:         ctx, | ||||
| 		Cancel:      cancel, | ||||
| 		HttpClient: &http.Client{ | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user