mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-27 05:52:29 +08:00 
			
		
		
		
	Merge branch 'openimsdk:main' into main
This commit is contained in:
		
						commit
						e8863c8636
					
				
							
								
								
									
										59
									
								
								.github/workflows/go-build-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										59
									
								
								.github/workflows/go-build-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -89,6 +89,65 @@ jobs: | ||||
|           mage start | ||||
|           mage check | ||||
| 
 | ||||
|   go-test: | ||||
|     name: Benchmark Test with go ${{ matrix.go_version }} on ${{ matrix.os }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     permissions: | ||||
|       contents: write | ||||
|     env: | ||||
|       SDK_DIR: openim-sdk-core | ||||
|       CONFIG_PATH: config/notification.yml | ||||
|     #   pull-requests: write | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ ubuntu-latest ] | ||||
|         go_version: [ "1.22.x" ] | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout Server repository | ||||
|         uses: actions/checkout@v4 | ||||
| 
 | ||||
|       - name: Checkout SDK repository | ||||
|         uses: actions/checkout@v4 | ||||
|         with: | ||||
|           repository: 'openimsdk/openim-sdk-core' | ||||
|           path: ${{ env.SDK_DIR }} | ||||
| 
 | ||||
|       - name: Set up Go ${{ matrix.go_version }} | ||||
|         uses: actions/setup-go@v5 | ||||
|         with: | ||||
|           go-version: ${{ matrix.go_version }} | ||||
| 
 | ||||
|       - name: Get Server dependencies | ||||
|         run: | | ||||
|           go install github.com/magefile/mage@latest | ||||
|           go mod download | ||||
| 
 | ||||
|       - name: Install yq | ||||
|         run: | | ||||
|           sudo wget https://github.com/mikefarah/yq/releases/download/v4.34.1/yq_linux_amd64 -O /usr/bin/yq | ||||
|           sudo chmod +x /usr/bin/yq | ||||
| 
 | ||||
|       - name: Modify Server Configuration | ||||
|         run: | | ||||
|           yq e '.groupCreated.unreadCount = true' -i ${{ env.CONFIG_PATH }} | ||||
|           yq e '.friendApplicationApproved.unreadCount = true' -i ${{ env.CONFIG_PATH }} | ||||
| 
 | ||||
|       - name: Start Server Services | ||||
|         run: | | ||||
|           docker compose up -d | ||||
|           mage build | ||||
|           mage start | ||||
|           mage check | ||||
| 
 | ||||
|       - name: Build test SDK core | ||||
|         run: | | ||||
|           cd ${{ env.SDK_DIR }} | ||||
|           go mod tidy | ||||
|           cd integration_test | ||||
|           mkdir data | ||||
|           go run main.go -lgr 0.8 -imf -crg -ckgn -ckcon -sem -ckmsn -u 20 -su 5 -lg 2 -cg 2 -cgm 3 -sm 10 -gm 10 -reg | ||||
| 
 | ||||
|   dockerfile-test: | ||||
|     name: Build and Test Dockerfile | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
| @ -3,4 +3,4 @@ prometheus: | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly | ||||
|   # Because four instances have been launched, four ports need to be specified | ||||
|   ports: [ 12020, 12021, 12022, 12023, 12024, 12025, 12026, 12027 ] | ||||
|   ports: [ 12020, 12021, 12022, 12023, 12024, 12025, 12026, 12027, 12028, 12029, 12030, 12031, 12032, 12033, 12034, 12035 ] | ||||
|  | ||||
| @ -10,7 +10,7 @@ prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|   enable: true | ||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup | ||||
|   ports: [ 12170, 12171, 12172, 12173, 12174, 12175, 12176, 12177, 12178, 12179, 12180, 12181, 12182, 12183, 12184, 12185 ] | ||||
|   ports: [ 12170, 12171, 12172, 12173, 12174, 12175, 12176, 12177, 12178, 12179, 12180, 12182, 12183, 12184, 12185, 12186 ] | ||||
| 
 | ||||
| maxConcurrentWorkers: 3 | ||||
| #Use geTui for offline push notifications, or choose fcm or jpns; corresponding configuration settings must be specified. | ||||
|  | ||||
| @ -46,7 +46,7 @@ scrape_configs: | ||||
|   - job_name: openimserver-openim-push | ||||
|     static_configs: | ||||
|       - targets: [ internal_ip:12170, internal_ip:12171, internal_ip:12172, internal_ip:12173, internal_ip:12174, internal_ip:12175, internal_ip:12176, internal_ip:12177 ] | ||||
| #      - targets: [ internal_ip:12170, internal_ip:12171, internal_ip:12172, internal_ip:12173, internal_ip:12174, internal_ip:12175, internal_ip:12176, internal_ip:12177, internal_ip:12178, internal_ip:12179, internal_ip:12180, internal_ip:12181, internal_ip:12182, internal_ip:12183, internal_ip:12184, internal_ip:12185 ] | ||||
| #      - targets: [ internal_ip:12170, internal_ip:12171, internal_ip:12172, internal_ip:12173, internal_ip:12174, internal_ip:12175, internal_ip:12176, internal_ip:12177, internal_ip:12178, internal_ip:12179, internal_ip:12180,  internal_ip:12182, internal_ip:12183, internal_ip:12184, internal_ip:12185, internal_ip:12186 ] | ||||
|         labels: | ||||
|           namespace: default | ||||
|   - job_name: openimserver-openim-rpc-auth | ||||
|  | ||||
| @ -1,5 +1,3 @@ | ||||
| version: '3' | ||||
| 
 | ||||
| networks: | ||||
|   openim: | ||||
|     driver: bridge | ||||
|  | ||||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -12,7 +12,7 @@ require ( | ||||
| 	github.com/gorilla/websocket v1.5.1 | ||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||
| 	github.com/mitchellh/mapstructure v1.5.0 | ||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.24 | ||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.25 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.12 | ||||
| 	github.com/pkg/errors v0.9.1 // indirect | ||||
| 	github.com/prometheus/client_golang v1.18.0 | ||||
|  | ||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -322,8 +322,8 @@ github.com/onsi/gomega v1.25.0 h1:Vw7br2PCDYijJHSfBOWhov+8cAnUf8MfMaIOV323l6Y= | ||||
| github.com/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.24 h1:1Dl8TEZVXhdmve+ewoLkJa2wbFBIHqPgjvr9u/J66JM= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.24/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.25 h1:W8E6gnwt5V6anr/8lYOf5v/Lcsggf7gIAzJbw7YU6So= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.25/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.12 h1:rV3BxgqN+F79vZvdoQ+97Eob8ScsRVEM8D+Wrcl23uo= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.12/go.mod h1:h1cYmfyaVtgFbKmb1Cfsl8XwUOMTt8ubVUQrdGtsUh4= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||
|  | ||||
| @ -218,6 +218,7 @@ func (s *groupServer) webhookAfterKickGroupMember(ctx context.Context, after *co | ||||
| 		CallbackCommand: callbackstruct.CallbackAfterKickGroupCommand, | ||||
| 		GroupID:         req.GroupID, | ||||
| 		KickedUserIDs:   req.KickedUserIDs, | ||||
| 		Reason:          req.Reason, | ||||
| 	} | ||||
| 	s.webhookClient.AsyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, &callbackstruct.CallbackKillGroupMemberResp{}, after) | ||||
| } | ||||
|  | ||||
| @ -16,6 +16,7 @@ package user | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/webhook" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 
 | ||||
| @ -88,7 +89,6 @@ func (s *userServer) webhookBeforeUserRegister(ctx context.Context, before *conf | ||||
| 	return webhook.WithCondition(ctx, before, func(ctx context.Context) error { | ||||
| 		cbReq := &cbapi.CallbackBeforeUserRegisterReq{ | ||||
| 			CallbackCommand: cbapi.CallbackBeforeUserRegisterCommand, | ||||
| 			Secret:          req.Secret, | ||||
| 			Users:           req.Users, | ||||
| 		} | ||||
| 
 | ||||
| @ -108,7 +108,6 @@ func (s *userServer) webhookBeforeUserRegister(ctx context.Context, before *conf | ||||
| func (s *userServer) webhookAfterUserRegister(ctx context.Context, after *config.AfterConfig, req *pbuser.UserRegisterReq) { | ||||
| 	cbReq := &cbapi.CallbackAfterUserRegisterReq{ | ||||
| 		CallbackCommand: cbapi.CallbackAfterUserRegisterCommand, | ||||
| 		Secret:          req.Secret, | ||||
| 		Users:           req.Users, | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
| @ -47,7 +47,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/db/pagination" | ||||
| 	registry "github.com/openimsdk/tools/discovery" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"google.golang.org/grpc" | ||||
| ) | ||||
| @ -263,10 +262,11 @@ func (s *userServer) UserRegister(ctx context.Context, req *pbuser.UserRegisterR | ||||
| 	if len(req.Users) == 0 { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("users is empty") | ||||
| 	} | ||||
| 	if req.Secret != s.config.Share.Secret { | ||||
| 		log.ZDebug(ctx, "UserRegister", s.config.Share.Secret, req.Secret) | ||||
| 		return nil, errs.ErrNoPermission.WrapMsg("secret invalid") | ||||
| 
 | ||||
| 	if err = authverify.CheckAdmin(ctx, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	if datautil.DuplicateAny(req.Users, func(e *sdkws.UserInfo) string { return e.UserID }) { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("userID repeated") | ||||
| 	} | ||||
|  | ||||
| @ -72,7 +72,6 @@ type CallbackAfterUpdateUserInfoExResp struct { | ||||
| 
 | ||||
| type CallbackBeforeUserRegisterReq struct { | ||||
| 	CallbackCommand `json:"callbackCommand"` | ||||
| 	Secret          string            `json:"secret"` | ||||
| 	Users           []*sdkws.UserInfo `json:"users"` | ||||
| } | ||||
| 
 | ||||
| @ -83,7 +82,6 @@ type CallbackBeforeUserRegisterResp struct { | ||||
| 
 | ||||
| type CallbackAfterUserRegisterReq struct { | ||||
| 	CallbackCommand `json:"callbackCommand"` | ||||
| 	Secret          string            `json:"secret"` | ||||
| 	Users           []*sdkws.UserInfo `json:"users"` | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -53,7 +53,6 @@ type User struct { | ||||
| 
 | ||||
| // UserRegisterRequest represents a request to register a user. | ||||
| type UserRegisterRequest struct { | ||||
| 	Secret string `json:"secret"` | ||||
| 	Users []User `json:"users"` | ||||
| } | ||||
| 
 | ||||
| @ -109,7 +108,6 @@ func RegisterUser(token, userID, nickname, faceURL string) error { | ||||
| 		FaceURL:  faceURL, | ||||
| 	} | ||||
| 	reqBody := UserRegisterRequest{ | ||||
| 		Secret: SecretKey, | ||||
| 		Users: []User{user}, | ||||
| 	} | ||||
| 	reqBytes, err := json.Marshal(reqBody) | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user