mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 05:02:11 +08:00 
			
		
		
		
	feat: set configs
This commit is contained in:
		
							parent
							
								
									887e0b7314
								
							
						
					
					
						commit
						eb49616d7a
					
				| @ -15,6 +15,7 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/apiresp" | 	"github.com/openimsdk/tools/apiresp" | ||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| 	"github.com/openimsdk/tools/log" | 	"github.com/openimsdk/tools/log" | ||||||
|  | 	"github.com/openimsdk/tools/utils/datautil" | ||||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||||
| 	clientv3 "go.etcd.io/etcd/client/v3" | 	clientv3 "go.etcd.io/etcd/client/v3" | ||||||
| ) | ) | ||||||
| @ -144,6 +145,110 @@ func (cm *ConfigManager) SetConfig(c *gin.Context) { | |||||||
| 	apiresp.GinSuccess(c, nil) | 	apiresp.GinSuccess(c, nil) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (cm *ConfigManager) SetConfigs(c *gin.Context) { | ||||||
|  | 	if cm.config.Discovery.Enable != config.ETCD { | ||||||
|  | 		apiresp.GinError(c, errs.New("only etcd support set config").Wrap()) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 	var req apistruct.SetConfigsReq | ||||||
|  | 	if err := c.BindJSON(&req); err != nil { | ||||||
|  | 		apiresp.GinError(c, errs.ErrArgs.WithDetail(err.Error()).Wrap()) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 	var ( | ||||||
|  | 		err error | ||||||
|  | 		ops []*clientv3.Op | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	for _, cf := range req.Configs { | ||||||
|  | 		var op *clientv3.Op | ||||||
|  | 		switch cf.ConfigName { | ||||||
|  | 		case cm.config.Discovery.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Discovery](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Kafka.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Kafka](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.LocalCache.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.LocalCache](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Log.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Log](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Minio.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Minio](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Mongo.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Mongo](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Notification.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Notification](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.API.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.API](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.CronTask.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.CronTask](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.MsgGateway.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.MsgGateway](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.MsgTransfer.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.MsgTransfer](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Push.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Push](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Auth.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Auth](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Conversation.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Conversation](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Friend.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Friend](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Group.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Group](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Msg.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Msg](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Third.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Third](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.User.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.User](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Redis.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Redis](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Share.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Share](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		case cm.config.Webhooks.GetConfigFileName(): | ||||||
|  | 			op, err = compareAndOp[config.Webhooks](c, cm.config.Name2Config(cf.ConfigName), &cf, cm) | ||||||
|  | 		default: | ||||||
|  | 			apiresp.GinError(c, errs.ErrArgs.Wrap()) | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 		if err != nil { | ||||||
|  | 			apiresp.GinError(c, errs.ErrArgs.WithDetail(err.Error()).Wrap()) | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 		if op != nil { | ||||||
|  | 			ops = append(ops, op) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if len(ops) > 0 { | ||||||
|  | 		tx := cm.client.Txn(c) | ||||||
|  | 		if _, err = tx.Then(datautil.Batch(func(op *clientv3.Op) clientv3.Op { return *op }, ops)...).Commit(); err != nil { | ||||||
|  | 			apiresp.GinError(c, errs.WrapMsg(err, "save to etcd failed")) | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	apiresp.GinSuccess(c, nil) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func compareAndOp[T any](c *gin.Context, old any, req *apistruct.SetConfigReq, cm *ConfigManager) (*clientv3.Op, error) { | ||||||
|  | 	conf := new(T) | ||||||
|  | 	err := json.Unmarshal([]byte(req.Data), &conf) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, errs.ErrArgs.WithDetail(err.Error()).Wrap() | ||||||
|  | 	} | ||||||
|  | 	eq := reflect.DeepEqual(old, conf) | ||||||
|  | 	if eq { | ||||||
|  | 		return nil, nil | ||||||
|  | 	} | ||||||
|  | 	data, err := json.Marshal(conf) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, errs.ErrArgs.WithDetail(err.Error()).Wrap() | ||||||
|  | 	} | ||||||
|  | 	op := clientv3.OpPut(etcd.BuildKey(req.ConfigName), string(data)) | ||||||
|  | 	return &op, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func compareAndSave[T any](c *gin.Context, old any, req *apistruct.SetConfigReq, cm *ConfigManager) error { | func compareAndSave[T any](c *gin.Context, old any, req *apistruct.SetConfigReq, cm *ConfigManager) error { | ||||||
| 	conf := new(T) | 	conf := new(T) | ||||||
| 	err := json.Unmarshal([]byte(req.Data), &conf) | 	err := json.Unmarshal([]byte(req.Data), &conf) | ||||||
|  | |||||||
| @ -307,6 +307,7 @@ func newGinRouter(ctx context.Context, client discovery.Conn, cfg *Config) (*gin | |||||||
| 		configGroup.POST("/get_config_list", cm.GetConfigList) | 		configGroup.POST("/get_config_list", cm.GetConfigList) | ||||||
| 		configGroup.POST("/get_config", cm.GetConfig) | 		configGroup.POST("/get_config", cm.GetConfig) | ||||||
| 		configGroup.POST("/set_config", cm.SetConfig) | 		configGroup.POST("/set_config", cm.SetConfig) | ||||||
|  | 		configGroup.POST("/set_configs", cm.SetConfigs) | ||||||
| 		configGroup.POST("/reset_config", cm.ResetConfig) | 		configGroup.POST("/reset_config", cm.ResetConfig) | ||||||
| 		configGroup.POST("/set_enable_config_manager", cm.SetEnableConfigManager) | 		configGroup.POST("/set_enable_config_manager", cm.SetEnableConfigManager) | ||||||
| 		configGroup.POST("/get_enable_config_manager", cm.GetEnableConfigManager) | 		configGroup.POST("/get_enable_config_manager", cm.GetEnableConfigManager) | ||||||
|  | |||||||
| @ -15,6 +15,10 @@ type SetConfigReq struct { | |||||||
| 	Data       string `json:"data"` | 	Data       string `json:"data"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | type SetConfigsReq struct { | ||||||
|  | 	Configs []SetConfigReq `json:"configs"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
| type SetEnableConfigManagerReq struct { | type SetEnableConfigManagerReq struct { | ||||||
| 	Enable bool `json:"enable"` | 	Enable bool `json:"enable"` | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user