mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 21:22:16 +08:00 
			
		
		
		
	feat: SendBusinessNotification supported configuration parameters (#3048)
* pb * fix: Modifying other fields while setting IsPrivateChat does not take effect * fix: quote message error revoke * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * upgrading pkg tools * fix * fix * optimize log output * feat: support GetLastMessage * feat: support GetLastMessage * feat: s3 switch * feat: s3 switch * fix: GetUsersOnline * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters
This commit is contained in:
		
							parent
							
								
									5312089069
								
							
						
					
					
						commit
						592084a891
					
				| @ -251,13 +251,32 @@ func (m *MessageApi) SendBusinessNotification(c *gin.Context) { | ||||
| 		Key              string `json:"key"` | ||||
| 		Data             string `json:"data"` | ||||
| 		SendUserID       string `json:"sendUserID" binding:"required"` | ||||
| 		RecvUserID string `json:"recvUserID" binding:"required"` | ||||
| 		RecvUserID       string `json:"recvUserID"` | ||||
| 		RecvGroupID      string `json:"recvGroupID"` | ||||
| 		SendMsg          bool   `json:"sendMsg"` | ||||
| 		ReliabilityLevel *int   `json:"reliabilityLevel"` | ||||
| 	}{} | ||||
| 	if err := c.BindJSON(&req); err != nil { | ||||
| 		apiresp.GinError(c, errs.ErrArgs.WithDetail(err.Error()).Wrap()) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	if req.RecvUserID == "" && req.RecvGroupID == "" { | ||||
| 		apiresp.GinError(c, errs.ErrArgs.WrapMsg("recvUserID and recvGroupID cannot be empty at the same time")) | ||||
| 		return | ||||
| 	} | ||||
| 	if req.RecvUserID != "" && req.RecvGroupID != "" { | ||||
| 		apiresp.GinError(c, errs.ErrArgs.WrapMsg("recvUserID and recvGroupID cannot be set at the same time")) | ||||
| 		return | ||||
| 	} | ||||
| 	var sessionType int32 | ||||
| 	if req.RecvUserID != "" { | ||||
| 		sessionType = constant.SingleChatType | ||||
| 	} else { | ||||
| 		sessionType = constant.ReadGroupChatType | ||||
| 	} | ||||
| 	if req.ReliabilityLevel == nil { | ||||
| 		req.ReliabilityLevel = datautil.ToPtr(1) | ||||
| 	} | ||||
| 	if !authverify.IsAppManagerUid(c, m.imAdminUserID) { | ||||
| 		apiresp.GinError(c, errs.ErrNoPermission.WrapMsg("only app manager can send message")) | ||||
| 		return | ||||
| @ -266,6 +285,7 @@ func (m *MessageApi) SendBusinessNotification(c *gin.Context) { | ||||
| 		MsgData: &sdkws.MsgData{ | ||||
| 			SendID:  req.SendUserID, | ||||
| 			RecvID:  req.RecvUserID, | ||||
| 			GroupID: req.RecvGroupID, | ||||
| 			Content: []byte(jsonutil.StructToJsonString(&sdkws.NotificationElem{ | ||||
| 				Detail: jsonutil.StructToJsonString(&struct { | ||||
| 					Key  string `json:"key"` | ||||
| @ -274,12 +294,12 @@ func (m *MessageApi) SendBusinessNotification(c *gin.Context) { | ||||
| 			})), | ||||
| 			MsgFrom:     constant.SysMsgType, | ||||
| 			ContentType: constant.BusinessNotification, | ||||
| 			SessionType: constant.SingleChatType, | ||||
| 			SessionType: sessionType, | ||||
| 			CreateTime:  timeutil.GetCurrentTimestampByMill(), | ||||
| 			ClientMsgID: idutil.GetMsgIDByMD5(mcontext.GetOpUserID(c)), | ||||
| 			Options: config.GetOptionsByNotification(config.NotificationConfig{ | ||||
| 				IsSendMsg:        false, | ||||
| 				ReliabilityLevel: 1, | ||||
| 				IsSendMsg:        req.SendMsg, | ||||
| 				ReliabilityLevel: *req.ReliabilityLevel, | ||||
| 				UnreadCount:      false, | ||||
| 			}), | ||||
| 		}, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user