Files
open-im-server/internal/cms_api/admin/admin.go
T

129 lines
4.5 KiB
Go
Raw Normal View History

2022-01-21 18:39:57 +08:00
package admin
import (
2022-05-10 10:44:43 +08:00
apiStruct "Open_IM/pkg/cms_api_struct"
2022-02-12 17:13:31 +08:00
"Open_IM/pkg/common/config"
2022-09-14 15:34:09 +08:00
"Open_IM/pkg/common/constant"
2022-02-12 17:13:31 +08:00
"Open_IM/pkg/common/log"
2023-01-11 11:24:38 +08:00
"Open_IM/pkg/getcdv3"
2022-02-12 17:13:31 +08:00
pbAdmin "Open_IM/pkg/proto/admin_cms"
2022-08-12 18:37:51 +08:00
pbCommon "Open_IM/pkg/proto/sdk_ws"
2022-02-12 17:13:31 +08:00
"Open_IM/pkg/utils"
"context"
2022-06-16 15:09:37 +08:00
"net/http"
2022-02-12 17:13:31 +08:00
"strings"
2022-01-21 18:39:57 +08:00
2022-08-21 21:59:28 +08:00
"github.com/minio/minio-go/v7"
"github.com/minio/minio-go/v7/pkg/credentials"
2022-05-10 17:39:27 +08:00
url2 "net/url"
2022-08-21 21:59:28 +08:00
"github.com/gin-gonic/gin"
2022-01-21 18:39:57 +08:00
)
2022-05-10 17:39:27 +08:00
var (
minioClient *minio.Client
)
func init() {
2022-09-14 15:34:09 +08:00
log.NewPrivateLog(constant.LogFileName)
2022-05-10 17:39:27 +08:00
operationID := utils.OperationIDGenerator()
log.NewInfo(operationID, utils.GetSelfFuncName(), "minio config: ", config.Config.Credential.Minio)
var initUrl string
if config.Config.Credential.Minio.EndpointInnerEnable {
initUrl = config.Config.Credential.Minio.EndpointInner
} else {
initUrl = config.Config.Credential.Minio.Endpoint
}
log.NewInfo(operationID, utils.GetSelfFuncName(), "use initUrl: ", initUrl)
minioUrl, err := url2.Parse(initUrl)
if err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), "parse failed, please check config/config.yaml", err.Error())
return
}
opts := &minio.Options{
Creds: credentials.NewStaticV4(config.Config.Credential.Minio.AccessKeyID, config.Config.Credential.Minio.SecretAccessKey, ""),
}
if minioUrl.Scheme == "http" {
opts.Secure = false
} else if minioUrl.Scheme == "https" {
opts.Secure = true
}
log.NewInfo(operationID, utils.GetSelfFuncName(), "Parse ok ", config.Config.Credential.Minio)
minioClient, err = minio.New(minioUrl.Host, opts)
log.NewInfo(operationID, utils.GetSelfFuncName(), "new ok ", config.Config.Credential.Minio)
if err != nil {
log.NewError(operationID, utils.GetSelfFuncName(), "init minio client failed", err.Error())
return
}
}
2022-11-23 11:08:44 +08:00
func GetUserToken(c *gin.Context) {
var (
req apiStruct.GetUserTokenRequest
resp apiStruct.GetUserTokenResponse
reqPb pbAdmin.GetUserTokenReq
respPb *pbAdmin.GetUserTokenResp
)
if err := c.BindJSON(&req); err != nil {
log.NewError(req.OperationID, utils.GetSelfFuncName(), err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
return
}
reqPb.OperationID = req.OperationID
reqPb.UserID = req.UserID
reqPb.PlatformID = req.PlatFormID
etcdConn := getcdv3.GetDefaultConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImAdminCMSName, reqPb.OperationID)
if etcdConn == nil {
errMsg := reqPb.OperationID + "getcdv3.GetDefaultConn == nil"
log.NewError(reqPb.OperationID, errMsg)
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": errMsg})
return
}
client := pbAdmin.NewAdminCMSClient(etcdConn)
respPb, err := client.GetUserToken(context.Background(), &reqPb)
if err != nil {
log.NewError(reqPb.OperationID, utils.GetSelfFuncName(), "rpc failed", err.Error())
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": err.Error()})
return
}
resp.Token = respPb.Token
resp.ExpTime = respPb.ExpTime
c.JSON(http.StatusOK, gin.H{"errCode": respPb.CommonResp.ErrCode, "errMsg": respPb.CommonResp.ErrMsg, "data": resp})
}
2022-01-21 18:39:57 +08:00
// register
2022-01-27 18:31:31 +08:00
func AdminLogin(c *gin.Context) {
2022-02-12 17:13:31 +08:00
var (
2022-05-10 10:44:43 +08:00
req apiStruct.AdminLoginRequest
resp apiStruct.AdminLoginResponse
2022-02-12 17:13:31 +08:00
reqPb pbAdmin.AdminLoginReq
)
if err := c.BindJSON(&req); err != nil {
2022-08-29 17:16:54 +08:00
log.NewError(req.OperationID, utils.GetSelfFuncName(), err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
2022-02-12 17:13:31 +08:00
return
}
reqPb.Secret = req.Secret
reqPb.AdminID = req.AdminName
2022-06-16 15:09:37 +08:00
reqPb.OperationID = utils.OperationIDGenerator()
2022-08-17 12:12:54 +08:00
etcdConn := getcdv3.GetDefaultConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImAdminCMSName, reqPb.OperationID)
2022-06-16 15:09:37 +08:00
if etcdConn == nil {
2022-08-17 12:12:54 +08:00
errMsg := reqPb.OperationID + "getcdv3.GetDefaultConn == nil"
2022-06-16 15:09:37 +08:00
log.NewError(reqPb.OperationID, errMsg)
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": errMsg})
return
}
2022-02-12 17:13:31 +08:00
client := pbAdmin.NewAdminCMSClient(etcdConn)
respPb, err := client.AdminLogin(context.Background(), &reqPb)
if err != nil {
log.NewError(reqPb.OperationID, utils.GetSelfFuncName(), "rpc failed", err.Error())
2022-08-29 17:16:54 +08:00
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": err.Error()})
2022-02-12 17:13:31 +08:00
return
}
2022-09-06 17:19:13 +08:00
resp.FaceURL = respPb.FaceURL
resp.UserName = respPb.UserName
2022-02-12 17:13:31 +08:00
resp.Token = respPb.Token
2022-08-29 17:16:54 +08:00
c.JSON(http.StatusOK, gin.H{"errCode": respPb.CommonResp.ErrCode, "errMsg": respPb.CommonResp.ErrMsg, "data": resp})
2022-01-21 18:39:57 +08:00
}