mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 05:02:11 +08:00 
			
		
		
		
	fix: solve webhook incorrect attentionID references.
This commit is contained in:
		
							parent
							
								
									75367545ea
								
							
						
					
					
						commit
						59400021ea
					
				| @ -16,7 +16,7 @@ afterUpdateUserInfoEx: | |||||||
| afterSendSingleMsg: | afterSendSingleMsg: | ||||||
|   enable: false |   enable: false | ||||||
|   timeout: 5 |   timeout: 5 | ||||||
|   # Only the recvID specified in attentionIds will send the callback |   # Only the recvIDs specified in attentionIds will send the callback | ||||||
|   # if not set, all user messages will be callback |   # if not set, all user messages will be callback | ||||||
|   attentionIds: [] |   attentionIds: [] | ||||||
|   # See beforeSendSingleMsg comment. |   # See beforeSendSingleMsg comment. | ||||||
| @ -36,7 +36,7 @@ beforeMsgModify: | |||||||
| afterSendGroupMsg: | afterSendGroupMsg: | ||||||
|   enable: false |   enable: false | ||||||
|   timeout: 5 |   timeout: 5 | ||||||
|   # Only the recvID specified in attentionIds will send the callback |   # Only the GroupIDs specified in attentionIds will send the callback | ||||||
|   # if not set, all user messages will be callback |   # if not set, all user messages will be callback | ||||||
|   attentionIds: [] |   attentionIds: [] | ||||||
|   # See beforeSendSingleMsg comment. |   # See beforeSendSingleMsg comment. | ||||||
|  | |||||||
| @ -55,9 +55,11 @@ func (mc *OnlineHistoryMongoConsumerHandler) webhookAfterSendSingleMsg(ctx conte | |||||||
| 	if msg.ContentType == constant.Typing { | 	if msg.ContentType == constant.Typing { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	if !filterAfterMsg(msg, after) { | 	if !filterAfterMsg(msg, after) { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	cbReq := &cbapi.CallbackAfterSendSingleMsgReq{ | 	cbReq := &cbapi.CallbackAfterSendSingleMsgReq{ | ||||||
| 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendSingleMsgCommand), | 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendSingleMsgCommand), | ||||||
| 		RecvID:            msg.RecvID, | 		RecvID:            msg.RecvID, | ||||||
| @ -69,9 +71,11 @@ func (mc *OnlineHistoryMongoConsumerHandler) webhookAfterSendGroupMsg(ctx contex | |||||||
| 	if msg.ContentType == constant.Typing { | 	if msg.ContentType == constant.Typing { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	if !filterAfterMsg(msg, after) { | 	if !filterAfterMsg(msg, after) { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	cbReq := &cbapi.CallbackAfterSendGroupMsgReq{ | 	cbReq := &cbapi.CallbackAfterSendGroupMsgReq{ | ||||||
| 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendGroupMsgCommand), | 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendGroupMsgCommand), | ||||||
| 		GroupID:           msg.GroupID, | 		GroupID:           msg.GroupID, | ||||||
| @ -98,7 +102,11 @@ func filterAfterMsg(msg *sdkws.MsgData, after *config.AfterConfig) bool { | |||||||
| 
 | 
 | ||||||
| func filterMsg(msg *sdkws.MsgData, attentionIds []string, deniedTypes []int32) bool { | func filterMsg(msg *sdkws.MsgData, attentionIds []string, deniedTypes []int32) bool { | ||||||
| 	// According to the attentionIds configuration, only some users are sent | 	// According to the attentionIds configuration, only some users are sent | ||||||
| 	if len(attentionIds) != 0 && !datautil.Contain(msg.RecvID, attentionIds...) { | 	if len(attentionIds) != 0 && msg.ContentType == constant.SingleChatType && !datautil.Contain(msg.RecvID, attentionIds...) { | ||||||
|  | 		return false | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(attentionIds) != 0 && msg.ContentType == constant.ReadGroupChatType && !datautil.Contain(msg.GroupID, attentionIds...) { | ||||||
| 		return false | 		return false | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,13 +16,10 @@ package msg | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 	"encoding/base64" |  | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/apistruct" |  | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/webhook" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/webhook" | ||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| 	"github.com/openimsdk/tools/utils/stringutil" |  | ||||||
| 
 | 
 | ||||||
| 	cbapi "github.com/openimsdk/open-im-server/v3/pkg/callbackstruct" | 	cbapi "github.com/openimsdk/open-im-server/v3/pkg/callbackstruct" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||||
| @ -89,19 +86,20 @@ func (m *msgServer) webhookBeforeSendSingleMsg(ctx context.Context, before *conf | |||||||
| 	}) | 	}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (m *msgServer) webhookAfterSendSingleMsg(ctx context.Context, after *config.AfterConfig, msg *pbchat.SendMsgReq) { | // Move to msgtransfer | ||||||
| 	if msg.MsgData.ContentType == constant.Typing { | // func (m *msgServer) webhookAfterSendSingleMsg(ctx context.Context, after *config.AfterConfig, msg *pbchat.SendMsgReq) { | ||||||
| 		return | // 	if msg.MsgData.ContentType == constant.Typing { | ||||||
| 	} | // 		return | ||||||
| 	if !filterAfterMsg(msg, after) { | // 	} | ||||||
| 		return | // 	if !filterAfterMsg(msg, after) { | ||||||
| 	} | // 		return | ||||||
| 	cbReq := &cbapi.CallbackAfterSendSingleMsgReq{ | // 	} | ||||||
| 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendSingleMsgCommand), | // 	cbReq := &cbapi.CallbackAfterSendSingleMsgReq{ | ||||||
| 		RecvID:            msg.MsgData.RecvID, | // 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendSingleMsgCommand), | ||||||
| 	} | // 		RecvID:            msg.MsgData.RecvID, | ||||||
| 	m.webhookClient.AsyncPostWithQuery(ctx, cbReq.GetCallbackCommand(), cbReq, &cbapi.CallbackAfterSendSingleMsgResp{}, after, buildKeyMsgDataQuery(msg.MsgData)) | // 	} | ||||||
| } | // 	m.webhookClient.AsyncPostWithQuery(ctx, cbReq.GetCallbackCommand(), cbReq, &cbapi.CallbackAfterSendSingleMsgResp{}, after, buildKeyMsgDataQuery(msg.MsgData)) | ||||||
|  | // } | ||||||
| 
 | 
 | ||||||
| func (m *msgServer) webhookBeforeSendGroupMsg(ctx context.Context, before *config.BeforeConfig, msg *pbchat.SendMsgReq) error { | func (m *msgServer) webhookBeforeSendGroupMsg(ctx context.Context, before *config.BeforeConfig, msg *pbchat.SendMsgReq) error { | ||||||
| 	return webhook.WithCondition(ctx, before, func(ctx context.Context) error { | 	return webhook.WithCondition(ctx, before, func(ctx context.Context) error { | ||||||
| @ -123,20 +121,21 @@ func (m *msgServer) webhookBeforeSendGroupMsg(ctx context.Context, before *confi | |||||||
| 	}) | 	}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (m *msgServer) webhookAfterSendGroupMsg(ctx context.Context, after *config.AfterConfig, msg *pbchat.SendMsgReq) { | // Move to msgtransfer | ||||||
| 	if msg.MsgData.ContentType == constant.Typing { | // func (m *msgServer) webhookAfterSendGroupMsg(ctx context.Context, after *config.AfterConfig, msg *pbchat.SendMsgReq) { | ||||||
| 		return | // 	if msg.MsgData.ContentType == constant.Typing { | ||||||
| 	} | // 		return | ||||||
| 	if !filterAfterMsg(msg, after) { | // 	} | ||||||
| 		return | // 	if !filterAfterMsg(msg, after) { | ||||||
| 	} | // 		return | ||||||
| 	cbReq := &cbapi.CallbackAfterSendGroupMsgReq{ | // 	} | ||||||
| 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendGroupMsgCommand), | // 	cbReq := &cbapi.CallbackAfterSendGroupMsgReq{ | ||||||
| 		GroupID:           msg.MsgData.GroupID, | // 		CommonCallbackReq: toCommonCallback(ctx, msg, cbapi.CallbackAfterSendGroupMsgCommand), | ||||||
| 	} | // 		GroupID:           msg.MsgData.GroupID, | ||||||
|  | // 	} | ||||||
| 
 | 
 | ||||||
| 	m.webhookClient.AsyncPostWithQuery(ctx, cbReq.GetCallbackCommand(), cbReq, &cbapi.CallbackAfterSendGroupMsgResp{}, after, buildKeyMsgDataQuery(msg.MsgData)) | // 	m.webhookClient.AsyncPostWithQuery(ctx, cbReq.GetCallbackCommand(), cbReq, &cbapi.CallbackAfterSendGroupMsgResp{}, after, buildKeyMsgDataQuery(msg.MsgData)) | ||||||
| } | // } | ||||||
| 
 | 
 | ||||||
| func (m *msgServer) webhookBeforeMsgModify(ctx context.Context, before *config.BeforeConfig, msg *pbchat.SendMsgReq, beforeMsgData **sdkws.MsgData) error { | func (m *msgServer) webhookBeforeMsgModify(ctx context.Context, before *config.BeforeConfig, msg *pbchat.SendMsgReq, beforeMsgData **sdkws.MsgData) error { | ||||||
| 	return webhook.WithCondition(ctx, before, func(ctx context.Context) error { | 	return webhook.WithCondition(ctx, before, func(ctx context.Context) error { | ||||||
| @ -205,14 +204,14 @@ func (m *msgServer) webhookAfterRevokeMsg(ctx context.Context, after *config.Aft | |||||||
| 	m.webhookClient.AsyncPost(ctx, callbackReq.GetCallbackCommand(), callbackReq, &cbapi.CallbackAfterRevokeMsgResp{}, after) | 	m.webhookClient.AsyncPost(ctx, callbackReq.GetCallbackCommand(), callbackReq, &cbapi.CallbackAfterRevokeMsgResp{}, after) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func buildKeyMsgDataQuery(msg *sdkws.MsgData) map[string]string { | // func buildKeyMsgDataQuery(msg *sdkws.MsgData) map[string]string { | ||||||
| 	keyMsgData := apistruct.KeyMsgData{ | // 	keyMsgData := apistruct.KeyMsgData{ | ||||||
| 		SendID:  msg.SendID, | // 		SendID:  msg.SendID, | ||||||
| 		RecvID:  msg.RecvID, | // 		RecvID:  msg.RecvID, | ||||||
| 		GroupID: msg.GroupID, | // 		GroupID: msg.GroupID, | ||||||
| 	} | // 	} | ||||||
| 
 | 
 | ||||||
| 	return map[string]string{ | // 	return map[string]string{ | ||||||
| 		webhook.Key: base64.StdEncoding.EncodeToString(stringutil.StructToJsonBytes(keyMsgData)), | // 		webhook.Key: base64.StdEncoding.EncodeToString(stringutil.StructToJsonBytes(keyMsgData)), | ||||||
| 	} | // 	} | ||||||
| } | // } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user