|
|
|
/*
|
|
|
|
** description("").
|
|
|
|
** copyright('open-im,www.open-im.io').
|
|
|
|
** author("fg,Gordon@tuoyun.net").
|
|
|
|
** time(2021/9/15 10:28).
|
|
|
|
*/
|
|
|
|
package manage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"Open_IM/pkg/common/config"
|
|
|
|
"Open_IM/pkg/common/constant"
|
|
|
|
"Open_IM/pkg/common/log"
|
|
|
|
"Open_IM/pkg/common/token_verify"
|
|
|
|
"Open_IM/pkg/grpc-etcdv3/getcdv3"
|
|
|
|
pbRelay "Open_IM/pkg/proto/relay"
|
|
|
|
pbUser "Open_IM/pkg/proto/user"
|
|
|
|
"Open_IM/pkg/utils"
|
|
|
|
"context"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
type paramsDeleteUsers struct {
|
|
|
|
OperationID string `json:"operationID" binding:"required"`
|
|
|
|
DeleteUidList []string `json:"deleteUidList" binding:"required"`
|
|
|
|
}
|
|
|
|
type paramsGetAllUsersUid struct {
|
|
|
|
OperationID string `json:"operationID" binding:"required"`
|
|
|
|
}
|
|
|
|
type paramsGetUsersOnlineStatus struct {
|
|
|
|
OperationID string `json:"operationID" binding:"required"`
|
|
|
|
UserIDList []string `json:"userIDList" binding:"required,lte=200"`
|
|
|
|
}
|
|
|
|
type paramsAccountCheck struct {
|
|
|
|
OperationID string `json:"operationID" binding:"required"`
|
|
|
|
UserIDList []string `json:"userIDList" binding:"required,lte=100"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func DeleteUser(c *gin.Context) {
|
|
|
|
params := paramsDeleteUsers{}
|
|
|
|
if err := c.BindJSON(¶ms); err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.InfoByKv("DeleteUser req come here", params.OperationID, "DeleteUidList", params.DeleteUidList)
|
|
|
|
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImUserName)
|
|
|
|
client := pbUser.NewUserClient(etcdConn)
|
|
|
|
//defer etcdConn.Close()
|
|
|
|
|
|
|
|
req := &pbUser.DeleteUsersReq{
|
|
|
|
OperationID: params.OperationID,
|
|
|
|
DeleteUidList: params.DeleteUidList,
|
|
|
|
Token: c.Request.Header.Get("token"),
|
|
|
|
}
|
|
|
|
RpcResp, err := client.DeleteUsers(context.Background(), req)
|
|
|
|
if err != nil {
|
|
|
|
log.NewError(req.OperationID, "call delete users rpc server failed", err.Error())
|
|
|
|
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": "call delete users rpc server failed"})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
failedUidList := make([]string, 0)
|
|
|
|
for _, v := range RpcResp.FailedUidList {
|
|
|
|
failedUidList = append(failedUidList, v)
|
|
|
|
}
|
|
|
|
log.InfoByKv("call delete user rpc server is success", params.OperationID, "resp args", RpcResp.String())
|
|
|
|
resp := gin.H{"errCode": RpcResp.CommonResp.ErrorCode, "errMsg": RpcResp.CommonResp.ErrorMsg, "failedUidList": RpcResp.FailedUidList}
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
}
|
|
|
|
func GetAllUsersUid(c *gin.Context) {
|
|
|
|
params := paramsGetAllUsersUid{}
|
|
|
|
if err := c.BindJSON(¶ms); err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.InfoByKv("GetAllUsersUid req come here", params.OperationID)
|
|
|
|
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImUserName)
|
|
|
|
client := pbUser.NewUserClient(etcdConn)
|
|
|
|
//defer etcdConn.Close()
|
|
|
|
|
|
|
|
req := &pbUser.GetAllUsersUidReq{
|
|
|
|
OperationID: params.OperationID,
|
|
|
|
Token: c.Request.Header.Get("token"),
|
|
|
|
}
|
|
|
|
RpcResp, err := client.GetAllUsersUid(context.Background(), req)
|
|
|
|
if err != nil {
|
|
|
|
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": err.Error(), "uidList": []string{}})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.InfoByKv("call GetAllUsersUid rpc server is success", params.OperationID, "resp args", RpcResp.String())
|
|
|
|
resp := gin.H{"errCode": RpcResp.CommonResp.ErrorCode, "errMsg": RpcResp.CommonResp.ErrorMsg, "uidList": RpcResp.UidList}
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
|
|
|
}
|
|
|
|
func AccountCheck(c *gin.Context) {
|
|
|
|
params := paramsAccountCheck{}
|
|
|
|
if err := c.BindJSON(¶ms); err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.InfoByKv("AccountCheck req come here", params.OperationID, params.UserIDList)
|
|
|
|
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImUserName)
|
|
|
|
client := pbUser.NewUserClient(etcdConn)
|
|
|
|
//defer etcdConn.Close()
|
|
|
|
|
|
|
|
req := &pbUser.AccountCheckReq{
|
|
|
|
OperationID: params.OperationID,
|
|
|
|
Token: c.Request.Header.Get("token"),
|
|
|
|
UidList: params.UserIDList,
|
|
|
|
}
|
|
|
|
RpcResp, err := client.AccountCheck(context.Background(), req)
|
|
|
|
if err != nil {
|
|
|
|
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.InfoByKv("call AccountCheck rpc server is success", params.OperationID, "resp args", RpcResp.String())
|
|
|
|
resp := gin.H{"errCode": RpcResp.CommonResp.ErrorCode, "errMsg": RpcResp.CommonResp.ErrorMsg, "result": RpcResp.Result}
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
|
|
|
}
|
|
|
|
func GetUsersOnlineStatus(c *gin.Context) {
|
|
|
|
params := paramsGetUsersOnlineStatus{}
|
|
|
|
if err := c.BindJSON(¶ms); err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
claims, err := token_verify.ParseToken(c.Request.Header.Get("token"))
|
|
|
|
if err != nil {
|
|
|
|
log.ErrorByKv("parse token failed", params.OperationID, "err", err.Error())
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{"errCode": 401, "errMsg": err.Error()})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if !utils.IsContain(claims.UID, config.Config.Manager.AppManagerUid) {
|
|
|
|
log.ErrorByKv(" Authentication failed", params.OperationID, "args", c)
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{"errCode": 402, "errMsg": "not authorized"})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
req := &pbRelay.GetUsersOnlineStatusReq{
|
|
|
|
OperationID: params.OperationID,
|
|
|
|
UserIDList: params.UserIDList,
|
|
|
|
}
|
|
|
|
var wsResult []*pbRelay.GetUsersOnlineStatusResp_SuccessResult
|
|
|
|
var respResult []*pbRelay.GetUsersOnlineStatusResp_SuccessResult
|
|
|
|
flag := false
|
|
|
|
log.NewDebug(params.OperationID, "GetUsersOnlineStatus req come here", params.UserIDList)
|
|
|
|
grpcCons := getcdv3.GetConn4Unique(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImOnlineMessageRelayName)
|
|
|
|
for _, v := range grpcCons {
|
|
|
|
client := pbRelay.NewOnlineMessageRelayServiceClient(v)
|
|
|
|
reply, err := client.GetUsersOnlineStatus(context.Background(), req)
|
|
|
|
if err != nil {
|
|
|
|
log.NewError(params.OperationID, "GetUsersOnlineStatus rpc err", req.String(), err.Error())
|
|
|
|
continue
|
|
|
|
} else {
|
|
|
|
if reply.ErrCode == 0 {
|
|
|
|
wsResult = append(wsResult, reply.SuccessResult...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
log.NewDebug(params.OperationID, "call GetUsersOnlineStatus rpc server is success", wsResult)
|
|
|
|
//Online data merge of each node
|
|
|
|
for _, v1 := range params.UserIDList {
|
|
|
|
flag = false
|
|
|
|
temp := new(pbRelay.GetUsersOnlineStatusResp_SuccessResult)
|
|
|
|
for _, v2 := range wsResult {
|
|
|
|
if v2.UserID == v1 {
|
|
|
|
flag = true
|
|
|
|
temp.UserID = v1
|
|
|
|
temp.Status = constant.OnlineStatus
|
|
|
|
temp.DetailPlatformStatus = append(temp.DetailPlatformStatus, v2.DetailPlatformStatus...)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
if !flag {
|
|
|
|
temp.UserID = v1
|
|
|
|
temp.Status = constant.OfflineStatus
|
|
|
|
}
|
|
|
|
respResult = append(respResult, temp)
|
|
|
|
}
|
|
|
|
log.NewDebug(params.OperationID, "Finished merged data", respResult)
|
|
|
|
resp := gin.H{"errCode": 0, "errMsg": "", "successResult": respResult}
|
|
|
|
c.JSON(http.StatusOK, resp)
|
|
|
|
|
|
|
|
}
|