mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-27 05:52:29 +08:00 
			
		
		
		
	* fix: to start im or chat, ZooKeeper must be started first. * fix: msg gateway start output err info Signed-off-by: Gordon <1432970085@qq.com> * fix: msg gateway start output err info Signed-off-by: Gordon <1432970085@qq.com> * chore: package path changes Signed-off-by: withchao <993506633@qq.com> * fix: go mod update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * chore: package path changes Signed-off-by: withchao <993506633@qq.com> * chore: package path changes Signed-off-by: withchao <993506633@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: get all userID Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: msggateway add online status call Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: log change Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: log change Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * chore: network mode change Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * feat: add api of get server time Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * feat: remove go work sum Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: pull message add isRead field Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: check msg-transfer script Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: start don't kill old process Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: check component Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: pull message set isRead only message come from single. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: add ex field to update group info. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change * cicd: robot automated Change * refactor: change project module name. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: change project module name. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: change project module name. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change --------- Signed-off-by: Gordon <1432970085@qq.com> Signed-off-by: withchao <993506633@qq.com> Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: withchao <993506633@qq.com> Co-authored-by: Xinwei Xiong <3293172751NSS@gmail.com> Co-authored-by: FGadvancer <FGadvancer@users.noreply.github.com>
		
			
				
	
	
		
			142 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright © 2023 OpenIM. All rights reserved.
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package push
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"github.com/OpenIMSDK/protocol/constant"
 | |
| 	"github.com/OpenIMSDK/protocol/sdkws"
 | |
| 	"github.com/OpenIMSDK/tools/errs"
 | |
| 	"github.com/OpenIMSDK/tools/mcontext"
 | |
| 	"github.com/OpenIMSDK/tools/utils"
 | |
| 
 | |
| 	"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/http"
 | |
| )
 | |
| 
 | |
| func url() string {
 | |
| 	return config.Config.Callback.CallbackUrl
 | |
| }
 | |
| 
 | |
| func callbackOfflinePush(
 | |
| 	ctx context.Context,
 | |
| 	userIDs []string,
 | |
| 	msg *sdkws.MsgData,
 | |
| 	offlinePushUserIDs *[]string,
 | |
| ) error {
 | |
| 	if !config.Config.Callback.CallbackOfflinePush.Enable {
 | |
| 		return nil
 | |
| 	}
 | |
| 	req := &callbackstruct.CallbackBeforePushReq{
 | |
| 		UserStatusBatchCallbackReq: callbackstruct.UserStatusBatchCallbackReq{
 | |
| 			UserStatusBaseCallback: callbackstruct.UserStatusBaseCallback{
 | |
| 				CallbackCommand: constant.CallbackOfflinePushCommand,
 | |
| 				OperationID:     mcontext.GetOperationID(ctx),
 | |
| 				PlatformID:      int(msg.SenderPlatformID),
 | |
| 				Platform:        constant.PlatformIDToName(int(msg.SenderPlatformID)),
 | |
| 			},
 | |
| 			UserIDList: userIDs,
 | |
| 		},
 | |
| 		OfflinePushInfo: msg.OfflinePushInfo,
 | |
| 		ClientMsgID:     msg.ClientMsgID,
 | |
| 		SendID:          msg.SendID,
 | |
| 		GroupID:         msg.GroupID,
 | |
| 		ContentType:     msg.ContentType,
 | |
| 		SessionType:     msg.SessionType,
 | |
| 		AtUserIDs:       msg.AtUserIDList,
 | |
| 		Content:         GetContent(msg),
 | |
| 	}
 | |
| 	resp := &callbackstruct.CallbackBeforePushResp{}
 | |
| 	if err := http.CallBackPostReturn(ctx, url(), req, resp, config.Config.Callback.CallbackOfflinePush); err != nil {
 | |
| 		if err == errs.ErrCallbackContinue {
 | |
| 			return nil
 | |
| 		}
 | |
| 		return err
 | |
| 	}
 | |
| 	if len(resp.UserIDs) != 0 {
 | |
| 		*offlinePushUserIDs = resp.UserIDs
 | |
| 	}
 | |
| 	if resp.OfflinePushInfo != nil {
 | |
| 		msg.OfflinePushInfo = resp.OfflinePushInfo
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func callbackOnlinePush(ctx context.Context, userIDs []string, msg *sdkws.MsgData) error {
 | |
| 	if !config.Config.Callback.CallbackOnlinePush.Enable || utils.Contain(msg.SendID, userIDs...) {
 | |
| 		return nil
 | |
| 	}
 | |
| 	req := callbackstruct.CallbackBeforePushReq{
 | |
| 		UserStatusBatchCallbackReq: callbackstruct.UserStatusBatchCallbackReq{
 | |
| 			UserStatusBaseCallback: callbackstruct.UserStatusBaseCallback{
 | |
| 				CallbackCommand: constant.CallbackOnlinePushCommand,
 | |
| 				OperationID:     mcontext.GetOperationID(ctx),
 | |
| 				PlatformID:      int(msg.SenderPlatformID),
 | |
| 				Platform:        constant.PlatformIDToName(int(msg.SenderPlatformID)),
 | |
| 			},
 | |
| 			UserIDList: userIDs,
 | |
| 		},
 | |
| 		ClientMsgID: msg.ClientMsgID,
 | |
| 		SendID:      msg.SendID,
 | |
| 		GroupID:     msg.GroupID,
 | |
| 		ContentType: msg.ContentType,
 | |
| 		SessionType: msg.SessionType,
 | |
| 		AtUserIDs:   msg.AtUserIDList,
 | |
| 		Content:     GetContent(msg),
 | |
| 	}
 | |
| 	resp := &callbackstruct.CallbackBeforePushResp{}
 | |
| 	return http.CallBackPostReturn(ctx, url(), req, resp, config.Config.Callback.CallbackOnlinePush)
 | |
| }
 | |
| 
 | |
| func callbackBeforeSuperGroupOnlinePush(
 | |
| 	ctx context.Context,
 | |
| 	groupID string,
 | |
| 	msg *sdkws.MsgData,
 | |
| 	pushToUserIDs *[]string,
 | |
| ) error {
 | |
| 	if !config.Config.Callback.CallbackBeforeSuperGroupOnlinePush.Enable {
 | |
| 		return nil
 | |
| 	}
 | |
| 	req := callbackstruct.CallbackBeforeSuperGroupOnlinePushReq{
 | |
| 		UserStatusBaseCallback: callbackstruct.UserStatusBaseCallback{
 | |
| 			CallbackCommand: constant.CallbackSuperGroupOnlinePushCommand,
 | |
| 			OperationID:     mcontext.GetOperationID(ctx),
 | |
| 			PlatformID:      int(msg.SenderPlatformID),
 | |
| 			Platform:        constant.PlatformIDToName(int(msg.SenderPlatformID)),
 | |
| 		},
 | |
| 		ClientMsgID: msg.ClientMsgID,
 | |
| 		SendID:      msg.SendID,
 | |
| 		GroupID:     groupID,
 | |
| 		ContentType: msg.ContentType,
 | |
| 		SessionType: msg.SessionType,
 | |
| 		AtUserIDs:   msg.AtUserIDList,
 | |
| 		Content:     GetContent(msg),
 | |
| 		Seq:         msg.Seq,
 | |
| 	}
 | |
| 	resp := &callbackstruct.CallbackBeforeSuperGroupOnlinePushResp{}
 | |
| 	if err := http.CallBackPostReturn(ctx, config.Config.Callback.CallbackUrl, req, resp, config.Config.Callback.CallbackBeforeSuperGroupOnlinePush); err != nil {
 | |
| 		if err == errs.ErrCallbackContinue {
 | |
| 			return nil
 | |
| 		}
 | |
| 		return err
 | |
| 	}
 | |
| 	if len(resp.UserIDs) != 0 {
 | |
| 		*pushToUserIDs = resp.UserIDs
 | |
| 	}
 | |
| 	return nil
 | |
| }
 |