mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	
						commit
						c6203c825f
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -163,7 +163,6 @@ go.work | ||||
| 
 | ||||
| # User-specific stuff | ||||
| .idea/ | ||||
| .idea | ||||
| .idea/**/workspace.xml | ||||
| .idea/**/tasks.xml | ||||
| .idea/**/usage.statistics.xml | ||||
|  | ||||
| @ -56,6 +56,7 @@ func startPprof() { | ||||
| } | ||||
| 
 | ||||
| func run(port int) error { | ||||
| 	port = 10002 | ||||
| 	if port == 0 { | ||||
| 		return fmt.Errorf("port is empty") | ||||
| 	} | ||||
|  | ||||
| @ -23,9 +23,9 @@ zookeeper: | ||||
|   password:                               #密码 | ||||
| 
 | ||||
| mysql: | ||||
|   address: [ 127.0.0.1:13306 ]            #目前仅支持单机 | ||||
|   address: [ 127.0.0.1:3306 ]            #目前仅支持单机 | ||||
|   username: root                          #用户名 | ||||
|   password: openIM123                     #密码 | ||||
|   password:                      #密码 | ||||
|   database: openIM_v3                     #不建议修改 | ||||
|   maxOpenConn: 1000                       #最大连接数 | ||||
|   maxIdleConn: 100                        #最大空闲连接数 | ||||
| @ -42,7 +42,7 @@ mongo: | ||||
|   maxPoolSize: 100 | ||||
| 
 | ||||
| redis: | ||||
|   address: [ 127.0.0.1:16379 ]            # | ||||
|   address: [ 127.0.0.1:6379 ]            # | ||||
|   username:                               #only redis version 6.0+ need username | ||||
|   password: openIM123                     #密码 | ||||
| 
 | ||||
|  | ||||
| @ -72,8 +72,9 @@ func StartTransfer(prometheusPort int) error { | ||||
| 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials())) | ||||
| 	msgModel := cache.NewMsgCacheModel(rdb) | ||||
| 	msgDocModel := unrelation.NewMsgMongoDriver(mongo.GetDatabase()) | ||||
| 	chatLogDatabase := controller.NewChatLogDatabase(relation.NewChatLogGorm(db)) | ||||
| 	msgDatabase := controller.NewCommonMsgDatabase(msgDocModel, msgModel) | ||||
| 	msgMysModel := relation.NewChatLogGorm(db) | ||||
| 	chatLogDatabase := controller.NewChatLogDatabase(msgMysModel) | ||||
| 	msgDatabase := controller.NewCommonMsgDatabase(msgDocModel, msgModel, msgMysModel) | ||||
| 	conversationRpcClient := rpcclient.NewConversationRpcClient(client) | ||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client) | ||||
| 	msgTransfer := NewMsgTransfer(chatLogDatabase, msgDatabase, &conversationRpcClient, &groupRpcClient) | ||||
|  | ||||
| @ -81,6 +81,9 @@ func Start(client discoveryregistry.SvcDiscoveryRegistry, server *grpc.Server) e | ||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client) | ||||
| 	friendRpcClient := rpcclient.NewFriendRpcClient(client) | ||||
| 	mysql, err := relation.NewGormDB() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	msgMysModel := relation.NewChatLogGorm(mysql) | ||||
| 	msgDatabase := controller.NewCommonMsgDatabase(msgDocModel, cacheModel, msgMysModel) | ||||
| 	s := &msgServer{ | ||||
|  | ||||
| @ -79,8 +79,12 @@ func InitMsgTool() (*MsgTool, error) { | ||||
| 	} | ||||
| 	discov.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials())) | ||||
| 	userDB := relation.NewUserGorm(db) | ||||
| 	msgDatabase := controller.InitCommonMsgDatabase(rdb, mongo.GetDatabase()) | ||||
| 	userDatabase := controller.NewUserDatabase(userDB, cache.NewUserCacheRedis(rdb, relation.NewUserGorm(db), cache.GetDefaultOpt()), tx.NewGorm(db)) | ||||
| 	msgDatabase := controller.InitCommonMsgDatabase(rdb, mongo.GetDatabase(), db) | ||||
| 	userDatabase := controller.NewUserDatabase( | ||||
| 		userDB, | ||||
| 		cache.NewUserCacheRedis(rdb, relation.NewUserGorm(db), cache.GetDefaultOpt()), | ||||
| 		tx.NewGorm(db), | ||||
| 	) | ||||
| 	groupDatabase := controller.InitGroupDatabase(db, rdb, mongo.GetDatabase()) | ||||
| 	conversationDatabase := controller.NewConversationDatabase(relation.NewConversationGorm(db), cache.NewConversationRedis(rdb, cache.GetDefaultOpt(), relation.NewConversationGorm(db)), tx.NewGorm(db)) | ||||
| 	msgRpcClient := rpcclient.NewMessageRpcClient(discov) | ||||
|  | ||||
| @ -45,6 +45,7 @@ func (a *RpcCmd) StartSvr( | ||||
| 	name string, | ||||
| 	rpcFn func(discov discoveryregistry.SvcDiscoveryRegistry, server *grpc.Server) error, | ||||
| ) error { | ||||
| 	a.port = 10030 | ||||
| 	if a.GetPortFlag() == 0 { | ||||
| 		return errors.New("port is required") | ||||
| 	} | ||||
|  | ||||
| @ -15,6 +15,9 @@ | ||||
| package controller | ||||
| 
 | ||||
| import ( | ||||
| 	relation2 "github.com/OpenIMSDK/Open-IM-Server/pkg/common/db/relation" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/common/db/table/relation" | ||||
| 	"gorm.io/gorm" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/redis/go-redis/v9" | ||||
| @ -92,6 +95,7 @@ type CommonMsgDatabase interface { | ||||
| 	GetConversationMinMaxSeqInMongoAndCache(ctx context.Context, conversationID string) (minSeqMongo, maxSeqMongo, minSeqCache, maxSeqCache int64, err error) | ||||
| 	SetSendMsgStatus(ctx context.Context, id string, status int32) error | ||||
| 	GetSendMsgStatus(ctx context.Context, id string) (int32, error) | ||||
| 	SearchMessage(ctx context.Context, req *pbMsg.SearchMessageReq) (msgData []*sdkws.MsgData, err error) | ||||
| 
 | ||||
| 	// to mq | ||||
| 	MsgToMQ(ctx context.Context, key string, msg2mq *sdkws.MsgData) error | ||||
| @ -103,8 +107,9 @@ type CommonMsgDatabase interface { | ||||
| 	RangeGroupSendCount(ctx context.Context, start time.Time, end time.Time, ase bool, pageNumber int32, showNumber int32) (msgCount int64, userCount int64, groups []*unRelationTb.GroupCount, dateCount map[string]int64, err error) | ||||
| } | ||||
| 
 | ||||
| func NewCommonMsgDatabase(msgDocModel unRelationTb.MsgDocModelInterface, cacheModel cache.MsgModel) CommonMsgDatabase { | ||||
| func NewCommonMsgDatabase(msgDocModel unRelationTb.MsgDocModelInterface, cacheModel cache.MsgModel, msgMyqModel relation.ChatLogModelInterface) CommonMsgDatabase { | ||||
| 	return &commonMsgDatabase{ | ||||
| 		msgMyq:          msgMyqModel, | ||||
| 		msgDocDatabase:  msgDocModel, | ||||
| 		cache:           cacheModel, | ||||
| 		producer:        kafka.NewKafkaProducer(config.Config.Kafka.Addr, config.Config.Kafka.LatestMsgToRedis.Topic), | ||||
| @ -113,16 +118,18 @@ func NewCommonMsgDatabase(msgDocModel unRelationTb.MsgDocModelInterface, cacheMo | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func InitCommonMsgDatabase(rdb redis.UniversalClient, database *mongo.Database) CommonMsgDatabase { | ||||
| func InitCommonMsgDatabase(rdb redis.UniversalClient, database *mongo.Database, dbGrom *gorm.DB) CommonMsgDatabase { | ||||
| 	cacheModel := cache.NewMsgCacheModel(rdb) | ||||
| 	msgDocModel := unrelation.NewMsgMongoDriver(database) | ||||
| 	CommonMsgDatabase := NewCommonMsgDatabase(msgDocModel, cacheModel) | ||||
| 	msgMyqModel := relation2.NewChatLogGorm(dbGrom) | ||||
| 	CommonMsgDatabase := NewCommonMsgDatabase(msgDocModel, cacheModel, msgMyqModel) | ||||
| 	return CommonMsgDatabase | ||||
| } | ||||
| 
 | ||||
| type commonMsgDatabase struct { | ||||
| 	msgDocDatabase   unRelationTb.MsgDocModelInterface | ||||
| 	msg              unRelationTb.MsgDocModel | ||||
| 	msgMyq           relation.ChatLogModelInterface | ||||
| 	cache            cache.MsgModel | ||||
| 	producer         *kafka.Producer | ||||
| 	producerToMongo  *kafka.Producer | ||||
| @ -884,3 +891,15 @@ func (db *commonMsgDatabase) RangeUserSendCount(ctx context.Context, start time. | ||||
| func (db *commonMsgDatabase) RangeGroupSendCount(ctx context.Context, start time.Time, end time.Time, ase bool, pageNumber int32, showNumber int32) (msgCount int64, userCount int64, groups []*unRelationTb.GroupCount, dateCount map[string]int64, err error) { | ||||
| 	return db.msgDocDatabase.RangeGroupSendCount(ctx, start, end, ase, pageNumber, showNumber) | ||||
| } | ||||
| 
 | ||||
| func (db *commonMsgDatabase) SearchMessage(ctx context.Context, req *pbMsg.SearchMessageReq) (msgData []*sdkws.MsgData, err error) { | ||||
| 	var totalMsgs []*sdkws.MsgData | ||||
| 	msgs, err := db.msgDocDatabase.SearchMessage(ctx, req) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	for _, msg := range msgs { | ||||
| 		totalMsgs = append(totalMsgs, convert.MsgDB2Pb(msg.Msg)) | ||||
| 	} | ||||
| 	return totalMsgs, nil | ||||
| } | ||||
|  | ||||
| @ -16,12 +16,15 @@ package relation | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/common/constant" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"gorm.io/gorm" | ||||
| 
 | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/common/db/ormutil" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/common/db/table/relation" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/errs" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/utils" | ||||
| 	"gorm.io/gorm" | ||||
| 	"time" | ||||
| ) | ||||
| 
 | ||||
| var _ relation.GroupModelInterface = (*GroupGorm)(nil) | ||||
| @ -60,9 +63,10 @@ func (g *GroupGorm) Take(ctx context.Context, groupID string) (group *relation.G | ||||
| } | ||||
| 
 | ||||
| func (g *GroupGorm) Search(ctx context.Context, keyword string, pageNumber, showNumber int32) (total uint32, groups []*relation.GroupModel, err error) { | ||||
| 	return ormutil.GormSearch[relation.GroupModel](g.DB, []string{"name"}, keyword, pageNumber, showNumber) | ||||
| 	db := g.DB | ||||
| 	db = db.WithContext(ctx).Where("status!=?", constant.GroupStatusDismissed) | ||||
| 	return ormutil.GormSearch[relation.GroupModel](db, []string{"name"}, keyword, pageNumber, showNumber) | ||||
| } | ||||
| 
 | ||||
| func (g *GroupGorm) GetGroupIDsByGroupType(ctx context.Context, groupType int) (groupIDs []string, err error) { | ||||
| 	return groupIDs, utils.Wrap(g.DB.Model(&relation.GroupModel{}).Where("group_type = ? ", groupType).Pluck("group_id", &groupIDs).Error, "") | ||||
| } | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,14 +22,13 @@ package auth | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,16 +22,14 @@ package conversation | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	wrapperspb "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/wrapperspb" | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	wrapperspb "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/wrapperspb" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -7,11 +21,10 @@ | ||||
| package errinfo | ||||
| 
 | ||||
| import ( | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,16 +22,14 @@ package friend | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,17 +22,15 @@ package group | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	wrapperspb "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/wrapperspb" | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	wrapperspb "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/wrapperspb" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,16 +22,14 @@ package msggateway | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,16 +22,14 @@ package push | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -7,13 +21,11 @@ | ||||
| package sdkws | ||||
| 
 | ||||
| import ( | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	wrapperspb "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/wrapperspb" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	wrapperspb "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/wrapperspb" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -7,10 +21,9 @@ | ||||
| package statistics | ||||
| 
 | ||||
| import ( | ||||
| 	reflect "reflect" | ||||
| 
 | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 	reflect "reflect" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,14 +22,13 @@ package third | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -8,17 +22,15 @@ package user | ||||
| 
 | ||||
| import ( | ||||
| 	context "context" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	conversation "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/conversation" | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	grpc "google.golang.org/grpc" | ||||
| 	codes "google.golang.org/grpc/codes" | ||||
| 	status "google.golang.org/grpc/status" | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 
 | ||||
| 	conversation "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/conversation" | ||||
| 	sdkws "github.com/OpenIMSDK/Open-IM-Server/pkg/proto/sdkws" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -1,3 +1,17 @@ | ||||
| // 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. | ||||
| 
 | ||||
| // Code generated by protoc-gen-go. DO NOT EDIT. | ||||
| // versions: | ||||
| // 	protoc-gen-go v1.29.1 | ||||
| @ -7,11 +21,10 @@ | ||||
| package wrapperspb | ||||
| 
 | ||||
| import ( | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| 
 | ||||
| 	protoreflect "google.golang.org/protobuf/reflect/protoreflect" | ||||
| 	protoimpl "google.golang.org/protobuf/runtime/protoimpl" | ||||
| 	reflect "reflect" | ||||
| 	sync "sync" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
|  | ||||
| @ -17,6 +17,7 @@ package rpcclient | ||||
| import ( | ||||
| 	"context" | ||||
| 	"encoding/json" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/proto/user" | ||||
| 
 | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/common/config" | ||||
| 	"github.com/OpenIMSDK/Open-IM-Server/pkg/common/constant" | ||||
| @ -120,9 +121,10 @@ func newSessionTypeConf() map[int32]int32 { | ||||
| } | ||||
| 
 | ||||
| type Message struct { | ||||
| 	conn   grpc.ClientConnInterface | ||||
| 	Client msg.MsgClient | ||||
| 	discov discoveryregistry.SvcDiscoveryRegistry | ||||
| 	conn       grpc.ClientConnInterface | ||||
| 	Client     msg.MsgClient | ||||
| 	discov     discoveryregistry.SvcDiscoveryRegistry | ||||
| 	userClient user.UserClient | ||||
| } | ||||
| 
 | ||||
| func NewMessage(discov discoveryregistry.SvcDiscoveryRegistry) *Message { | ||||
| @ -131,7 +133,20 @@ func NewMessage(discov discoveryregistry.SvcDiscoveryRegistry) *Message { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 	client := msg.NewMsgClient(conn) | ||||
| 	return &Message{discov: discov, conn: conn, Client: client} | ||||
| 	conn, err = discov.GetConn(context.Background(), config.Config.RpcRegisterName.OpenImUserName) | ||||
| 	if err != nil { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 	userClient := user.NewUserClient(conn) | ||||
| 	return &Message{discov: discov, conn: conn, Client: client, userClient: userClient} | ||||
| } | ||||
| 
 | ||||
| func (m *Message) GetAllUserID(ctx context.Context, req *user.GetAllUserIDReq) (*user.GetAllUserIDResp, error) { | ||||
| 	resp, err := m.userClient.GetAllUserID(ctx, req) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return resp, nil | ||||
| } | ||||
| 
 | ||||
| type MessageRpcClient Message | ||||
|  | ||||
| @ -16,6 +16,9 @@ package rpcclient | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"github.com/minio/minio-go/v7" | ||||
| 	"github.com/minio/minio-go/v7/pkg/credentials" | ||||
| 	"net/url" | ||||
| 
 | ||||
| 	"google.golang.org/grpc" | ||||
| 
 | ||||
| @ -25,9 +28,10 @@ import ( | ||||
| ) | ||||
| 
 | ||||
| type Third struct { | ||||
| 	conn   grpc.ClientConnInterface | ||||
| 	Client third.ThirdClient | ||||
| 	discov discoveryregistry.SvcDiscoveryRegistry | ||||
| 	conn        grpc.ClientConnInterface | ||||
| 	Client      third.ThirdClient | ||||
| 	discov      discoveryregistry.SvcDiscoveryRegistry | ||||
| 	MinioClient *minio.Client | ||||
| } | ||||
| 
 | ||||
| func NewThird(discov discoveryregistry.SvcDiscoveryRegistry) *Third { | ||||
| @ -36,5 +40,30 @@ func NewThird(discov discoveryregistry.SvcDiscoveryRegistry) *Third { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 	client := third.NewThirdClient(conn) | ||||
| 	return &Third{discov: discov, Client: client, conn: conn} | ||||
| 	minioClient, err := minioInit() | ||||
| 	return &Third{discov: discov, Client: client, conn: conn, MinioClient: minioClient} | ||||
| } | ||||
| 
 | ||||
| func minioInit() (*minio.Client, error) { | ||||
| 	minioClient := &minio.Client{} | ||||
| 	var initUrl string | ||||
| 	initUrl = config.Config.Object.Minio.Endpoint | ||||
| 	minioUrl, err := url.Parse(initUrl) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	opts := &minio.Options{ | ||||
| 		Creds: credentials.NewStaticV4(config.Config.Object.Minio.AccessKeyID, config.Config.Object.Minio.SecretAccessKey, ""), | ||||
| 		//Region: config.Config.Credential.Minio.Location, | ||||
| 	} | ||||
| 	if minioUrl.Scheme == "http" { | ||||
| 		opts.Secure = false | ||||
| 	} else if minioUrl.Scheme == "https" { | ||||
| 		opts.Secure = true | ||||
| 	} | ||||
| 	minioClient, err = minio.New(minioUrl.Host, opts) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return minioClient, nil | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user