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 start | ||||||
|           mage check |           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: |   dockerfile-test: | ||||||
|     name: Build and Test Dockerfile |     name: Build and Test Dockerfile | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  | |||||||
| @ -3,4 +3,4 @@ prometheus: | |||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly |   # 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 |   # 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 or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|   # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup |   # 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 | maxConcurrentWorkers: 3 | ||||||
| #Use geTui for offline push notifications, or choose fcm or jpns; corresponding configuration settings must be specified. | #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 |   - job_name: openimserver-openim-push | ||||||
|     static_configs: |     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 ] | ||||||
| #      - 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: |         labels: | ||||||
|           namespace: default |           namespace: default | ||||||
|   - job_name: openimserver-openim-rpc-auth |   - job_name: openimserver-openim-rpc-auth | ||||||
|  | |||||||
| @ -1,5 +1,3 @@ | |||||||
| version: '3' |  | ||||||
| 
 |  | ||||||
| networks: | networks: | ||||||
|   openim: |   openim: | ||||||
|     driver: bridge |     driver: bridge | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -12,7 +12,7 @@ require ( | |||||||
| 	github.com/gorilla/websocket v1.5.1 | 	github.com/gorilla/websocket v1.5.1 | ||||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||||
| 	github.com/mitchellh/mapstructure v1.5.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/openimsdk/tools v0.0.50-alpha.12 | ||||||
| 	github.com/pkg/errors v0.9.1 // indirect | 	github.com/pkg/errors v0.9.1 // indirect | ||||||
| 	github.com/prometheus/client_golang v1.18.0 | 	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/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 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | ||||||
| github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | 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.25 h1:W8E6gnwt5V6anr/8lYOf5v/Lcsggf7gIAzJbw7YU6So= | ||||||
| github.com/openimsdk/protocol v0.0.72-alpha.24/go.mod h1:OZQA9FR55lseYoN2Ql1XAHYKHJGu7OMNkUbuekrKCM8= | 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 h1:rV3BxgqN+F79vZvdoQ+97Eob8ScsRVEM8D+Wrcl23uo= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.12/go.mod h1:h1cYmfyaVtgFbKmb1Cfsl8XwUOMTt8ubVUQrdGtsUh4= | 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= | 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, | 		CallbackCommand: callbackstruct.CallbackAfterKickGroupCommand, | ||||||
| 		GroupID:         req.GroupID, | 		GroupID:         req.GroupID, | ||||||
| 		KickedUserIDs:   req.KickedUserIDs, | 		KickedUserIDs:   req.KickedUserIDs, | ||||||
|  | 		Reason:          req.Reason, | ||||||
| 	} | 	} | ||||||
| 	s.webhookClient.AsyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, &callbackstruct.CallbackKillGroupMemberResp{}, after) | 	s.webhookClient.AsyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, &callbackstruct.CallbackKillGroupMemberResp{}, after) | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ package user | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/webhook" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/webhook" | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" | 	"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 { | 	return webhook.WithCondition(ctx, before, func(ctx context.Context) error { | ||||||
| 		cbReq := &cbapi.CallbackBeforeUserRegisterReq{ | 		cbReq := &cbapi.CallbackBeforeUserRegisterReq{ | ||||||
| 			CallbackCommand: cbapi.CallbackBeforeUserRegisterCommand, | 			CallbackCommand: cbapi.CallbackBeforeUserRegisterCommand, | ||||||
| 			Secret:          req.Secret, |  | ||||||
| 			Users:           req.Users, | 			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) { | func (s *userServer) webhookAfterUserRegister(ctx context.Context, after *config.AfterConfig, req *pbuser.UserRegisterReq) { | ||||||
| 	cbReq := &cbapi.CallbackAfterUserRegisterReq{ | 	cbReq := &cbapi.CallbackAfterUserRegisterReq{ | ||||||
| 		CallbackCommand: cbapi.CallbackAfterUserRegisterCommand, | 		CallbackCommand: cbapi.CallbackAfterUserRegisterCommand, | ||||||
| 		Secret:          req.Secret, |  | ||||||
| 		Users:           req.Users, | 		Users:           req.Users, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -47,7 +47,6 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/db/pagination" | 	"github.com/openimsdk/tools/db/pagination" | ||||||
| 	registry "github.com/openimsdk/tools/discovery" | 	registry "github.com/openimsdk/tools/discovery" | ||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| 	"github.com/openimsdk/tools/log" |  | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" | 	"github.com/openimsdk/tools/utils/datautil" | ||||||
| 	"google.golang.org/grpc" | 	"google.golang.org/grpc" | ||||||
| ) | ) | ||||||
| @ -263,10 +262,11 @@ func (s *userServer) UserRegister(ctx context.Context, req *pbuser.UserRegisterR | |||||||
| 	if len(req.Users) == 0 { | 	if len(req.Users) == 0 { | ||||||
| 		return nil, errs.ErrArgs.WrapMsg("users is empty") | 		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) | 	if err = authverify.CheckAdmin(ctx, s.config.Share.IMAdminUserID); err != nil { | ||||||
| 		return nil, errs.ErrNoPermission.WrapMsg("secret invalid") | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	if datautil.DuplicateAny(req.Users, func(e *sdkws.UserInfo) string { return e.UserID }) { | 	if datautil.DuplicateAny(req.Users, func(e *sdkws.UserInfo) string { return e.UserID }) { | ||||||
| 		return nil, errs.ErrArgs.WrapMsg("userID repeated") | 		return nil, errs.ErrArgs.WrapMsg("userID repeated") | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -72,7 +72,6 @@ type CallbackAfterUpdateUserInfoExResp struct { | |||||||
| 
 | 
 | ||||||
| type CallbackBeforeUserRegisterReq struct { | type CallbackBeforeUserRegisterReq struct { | ||||||
| 	CallbackCommand `json:"callbackCommand"` | 	CallbackCommand `json:"callbackCommand"` | ||||||
| 	Secret          string            `json:"secret"` |  | ||||||
| 	Users           []*sdkws.UserInfo `json:"users"` | 	Users           []*sdkws.UserInfo `json:"users"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -83,7 +82,6 @@ type CallbackBeforeUserRegisterResp struct { | |||||||
| 
 | 
 | ||||||
| type CallbackAfterUserRegisterReq struct { | type CallbackAfterUserRegisterReq struct { | ||||||
| 	CallbackCommand `json:"callbackCommand"` | 	CallbackCommand `json:"callbackCommand"` | ||||||
| 	Secret          string            `json:"secret"` |  | ||||||
| 	Users           []*sdkws.UserInfo `json:"users"` | 	Users           []*sdkws.UserInfo `json:"users"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -53,8 +53,7 @@ type User struct { | |||||||
| 
 | 
 | ||||||
| // UserRegisterRequest represents a request to register a user. | // UserRegisterRequest represents a request to register a user. | ||||||
| type UserRegisterRequest struct { | type UserRegisterRequest struct { | ||||||
| 	Secret string `json:"secret"` | 	Users []User `json:"users"` | ||||||
| 	Users  []User `json:"users"` |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* func main() { | /* func main() { | ||||||
| @ -109,8 +108,7 @@ func RegisterUser(token, userID, nickname, faceURL string) error { | |||||||
| 		FaceURL:  faceURL, | 		FaceURL:  faceURL, | ||||||
| 	} | 	} | ||||||
| 	reqBody := UserRegisterRequest{ | 	reqBody := UserRegisterRequest{ | ||||||
| 		Secret: SecretKey, | 		Users: []User{user}, | ||||||
| 		Users:  []User{user}, |  | ||||||
| 	} | 	} | ||||||
| 	reqBytes, err := json.Marshal(reqBody) | 	reqBytes, err := json.Marshal(reqBody) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user