mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-06 04:15:46 +08:00
Merge remote-tracking branch 'origin/tuoyun' into tuoyun
This commit is contained in:
commit
20c7fe81dc
@ -75,11 +75,15 @@ func joinTestDepartment(operationID, userID, departmentID string) error {
|
|||||||
}()
|
}()
|
||||||
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImOrganizationName)
|
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImOrganizationName)
|
||||||
client := organizationRpc.NewOrganizationClient(etcdConn)
|
client := organizationRpc.NewOrganizationClient(etcdConn)
|
||||||
req := &organizationRpc.CreateDepartmentMemberReq{DepartmentMember: &commonPb.DepartmentMember{
|
req := &organizationRpc.CreateDepartmentMemberReq{
|
||||||
UserID: userID,
|
DepartmentMember: &commonPb.DepartmentMember{
|
||||||
DepartmentID: departmentID,
|
UserID: userID,
|
||||||
Position: randomPosition(),
|
DepartmentID: departmentID,
|
||||||
}}
|
Position: randomPosition(),
|
||||||
|
},
|
||||||
|
OperationID: operationID,
|
||||||
|
OpUserID: config.Config.Manager.AppManagerUid[0],
|
||||||
|
}
|
||||||
resp, err := client.CreateDepartmentMember(context.Background(), req)
|
resp, err := client.CreateDepartmentMember(context.Background(), req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.NewError(operationID, utils.GetSelfFuncName(), err.Error())
|
log.NewError(operationID, utils.GetSelfFuncName(), err.Error())
|
||||||
|
@ -9,6 +9,7 @@ import (
|
|||||||
imdb "Open_IM/pkg/common/db/mysql_model/im_mysql_model"
|
imdb "Open_IM/pkg/common/db/mysql_model/im_mysql_model"
|
||||||
"Open_IM/pkg/common/log"
|
"Open_IM/pkg/common/log"
|
||||||
"Open_IM/pkg/grpc-etcdv3/getcdv3"
|
"Open_IM/pkg/grpc-etcdv3/getcdv3"
|
||||||
|
pbCache "Open_IM/pkg/proto/cache"
|
||||||
pbOffice "Open_IM/pkg/proto/office"
|
pbOffice "Open_IM/pkg/proto/office"
|
||||||
pbCommon "Open_IM/pkg/proto/sdk_ws"
|
pbCommon "Open_IM/pkg/proto/sdk_ws"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
@ -17,6 +18,7 @@ import (
|
|||||||
"net"
|
"net"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -172,13 +174,27 @@ func (s *officeServer) SendMsg2Tag(_ context.Context, req *pbOffice.SendMsg2TagR
|
|||||||
}
|
}
|
||||||
var groupUserIDList []string
|
var groupUserIDList []string
|
||||||
for _, groupID := range req.GroupList {
|
for _, groupID := range req.GroupList {
|
||||||
userIDList, err := im_mysql_model.GetGroupMemberIDListByGroupID(groupID)
|
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImCacheName)
|
||||||
if err != nil {
|
cacheClient := pbCache.NewCacheClient(etcdConn)
|
||||||
log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetGroupMemberIDListByGroupID failed", err.Error(), groupID)
|
req := pbCache.GetGroupMemberIDListFromCacheReq{
|
||||||
continue
|
OperationID: req.OperationID,
|
||||||
|
GroupID: groupID,
|
||||||
}
|
}
|
||||||
log.NewDebug(req.OperationID, utils.GetSelfFuncName(), userIDList)
|
getGroupMemberIDListFromCacheResp, err := cacheClient.GetGroupMemberIDListFromCache(context.Background(), &req)
|
||||||
groupUserIDList = append(groupUserIDList, userIDList...)
|
if err != nil {
|
||||||
|
log.NewError(req.OperationID, "GetGroupMemberIDListFromCache rpc call failed ", err.Error(), req.String())
|
||||||
|
resp.CommonResp.ErrCode = constant.ErrServer.ErrCode
|
||||||
|
resp.CommonResp.ErrMsg = err.Error()
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
if getGroupMemberIDListFromCacheResp.CommonResp.ErrCode != 0 {
|
||||||
|
log.NewError(req.OperationID, "GetGroupMemberIDListFromCache rpc logic call failed ", getGroupMemberIDListFromCacheResp.CommonResp.ErrCode)
|
||||||
|
resp.CommonResp.ErrCode = getGroupMemberIDListFromCacheResp.CommonResp.ErrCode
|
||||||
|
resp.CommonResp.ErrMsg = getGroupMemberIDListFromCacheResp.CommonResp.ErrMsg
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
log.NewDebug(req.OperationID, utils.GetSelfFuncName(), getGroupMemberIDListFromCacheResp.UserIDList)
|
||||||
|
groupUserIDList = append(groupUserIDList, getGroupMemberIDListFromCacheResp.UserIDList...)
|
||||||
}
|
}
|
||||||
log.NewDebug(req.OperationID, utils.GetSelfFuncName(), groupUserIDList, req.GroupList)
|
log.NewDebug(req.OperationID, utils.GetSelfFuncName(), groupUserIDList, req.GroupList)
|
||||||
var userIDList []string
|
var userIDList []string
|
||||||
@ -195,22 +211,37 @@ func (s *officeServer) SendMsg2Tag(_ context.Context, req *pbOffice.SendMsg2TagR
|
|||||||
user, err := imdb.GetUserByUserID(req.SendID)
|
user, err := imdb.GetUserByUserID(req.SendID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.NewError(req.OperationID, "GetUserByUserID failed ", err.Error(), req.SendID)
|
log.NewError(req.OperationID, "GetUserByUserID failed ", err.Error(), req.SendID)
|
||||||
|
resp.CommonResp.ErrMsg = err.Error()
|
||||||
|
resp.CommonResp.ErrCode = constant.ErrDB.ErrCode
|
||||||
|
return resp, nil
|
||||||
}
|
}
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
wg.Add(len(userIDList))
|
||||||
for _, userID := range userIDList {
|
for _, userID := range userIDList {
|
||||||
msg.TagSendMessage(req.OperationID, user, userID, req.Content, req.SenderPlatformID)
|
go func(userID string) {
|
||||||
|
defer wg.Done()
|
||||||
|
msg.TagSendMessage(req.OperationID, user, userID, req.Content, req.SenderPlatformID)
|
||||||
|
}(userID)
|
||||||
}
|
}
|
||||||
|
wg.Wait()
|
||||||
var tagSendLogs db.TagSendLog
|
var tagSendLogs db.TagSendLog
|
||||||
|
|
||||||
|
wg.Add(len(userIDList))
|
||||||
for _, userID := range userIDList {
|
for _, userID := range userIDList {
|
||||||
userName, err := im_mysql_model.GetUserNameByUserID(userID)
|
go func(userID string) {
|
||||||
if err != nil {
|
defer wg.Done()
|
||||||
log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetUserNameByUserID failed", err.Error())
|
userName, err := im_mysql_model.GetUserNameByUserID(userID)
|
||||||
continue
|
if err != nil {
|
||||||
}
|
log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetUserNameByUserID failed", err.Error())
|
||||||
tagSendLogs.UserList = append(tagSendLogs.UserList, db.TagUser{
|
return
|
||||||
UserID: userID,
|
}
|
||||||
UserName: userName,
|
tagSendLogs.UserList = append(tagSendLogs.UserList, db.TagUser{
|
||||||
})
|
UserID: userID,
|
||||||
|
UserName: userName,
|
||||||
|
})
|
||||||
|
}(userID)
|
||||||
}
|
}
|
||||||
|
wg.Wait()
|
||||||
tagSendLogs.SendID = req.SendID
|
tagSendLogs.SendID = req.SendID
|
||||||
tagSendLogs.Content = req.Content
|
tagSendLogs.Content = req.Content
|
||||||
tagSendLogs.SenderPlatformID = req.SenderPlatformID
|
tagSendLogs.SenderPlatformID = req.SenderPlatformID
|
||||||
|
@ -252,7 +252,7 @@ func getDepartmentParent(departmentID string, dbConn *gorm.DB) (*db.Department,
|
|||||||
var parentID string
|
var parentID string
|
||||||
dbConn.LogMode(true)
|
dbConn.LogMode(true)
|
||||||
// select * from departments where department_id = (select parent_id from departments where department_id= zx234fd);
|
// select * from departments where department_id = (select parent_id from departments where department_id= zx234fd);
|
||||||
err := dbConn.Table("departments").Where("department_id=?", dbConn.Table("departments").Where("department_id=?", departmentID).Pluck("parent_id", parentID)).Error
|
err := dbConn.Table("departments").Where("department_id=?", dbConn.Table("departments").Where("department_id=?", departmentID).Pluck("parent_id", parentID)).Find(&department).Error
|
||||||
return &department, err
|
return &department, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user