mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-23 18:00:32 +08:00
Merge branch 'errcode' of github.com:OpenIMSDK/Open-IM-Server into errcode
This commit is contained in:
commit
ebe689324b
@ -6,7 +6,6 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"github.com/gin-gonic/gin"
|
"github.com/gin-gonic/gin"
|
||||||
"google.golang.org/grpc"
|
"google.golang.org/grpc"
|
||||||
"net/http"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func Call[A, B, C any](
|
func Call[A, B, C any](
|
||||||
@ -14,30 +13,26 @@ func Call[A, B, C any](
|
|||||||
client func() (C, error),
|
client func() (C, error),
|
||||||
c *gin.Context,
|
c *gin.Context,
|
||||||
) {
|
) {
|
||||||
var resp *apiresp.ApiResponse
|
|
||||||
defer func() {
|
|
||||||
c.JSON(http.StatusOK, resp)
|
|
||||||
}()
|
|
||||||
var req A
|
var req A
|
||||||
if err := c.BindJSON(&req); err != nil {
|
if err := c.BindJSON(&req); err != nil {
|
||||||
resp = apiresp.Error(constant.ErrArgs.Wrap(err.Error())) // 参数错误
|
apiresp.GinError(c, constant.ErrArgs.Wrap(err.Error())) // 参数错误
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if check, ok := any(&req).(interface{ Check() error }); ok {
|
if check, ok := any(&req).(interface{ Check() error }); ok {
|
||||||
if err := check.Check(); err != nil {
|
if err := check.Check(); err != nil {
|
||||||
resp = apiresp.Error(constant.ErrArgs.Wrap(err.Error())) // 参数校验失败
|
apiresp.GinError(c, constant.ErrArgs.Wrap(err.Error())) // 参数校验失败
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cli, err := client()
|
cli, err := client()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
resp = apiresp.Error(constant.ErrInternalServer.Wrap(err.Error())) // 参数校验失败
|
apiresp.GinError(c, constant.ErrInternalServer.Wrap(err.Error())) // 获取RPC连接失败
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
data, err := rpc(cli, c, &req)
|
data, err := rpc(cli, c, &req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
resp = apiresp.Error(err) // 参数校验失败
|
apiresp.GinError(c, err) // RPC调用失败
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
resp = apiresp.Success(data) // 成功
|
apiresp.GinSuccess(c, data) // 成功
|
||||||
}
|
}
|
||||||
|
@ -19,22 +19,26 @@ type Auth struct {
|
|||||||
zk *openKeeper.ZkClient
|
zk *openKeeper.ZkClient
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Auth) getGroupClient() (auth.AuthClient, error) {
|
func (o *Auth) client() (auth.AuthClient, error) {
|
||||||
conn, err := a.zk.GetConn(config.Config.RpcRegisterName.OpenImGroupName)
|
conn, err := o.zk.GetConn(config.Config.RpcRegisterName.OpenImGroupName, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return auth.NewAuthClient(conn), nil
|
return auth.NewAuthClient(conn), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Auth) UserToken(c *gin.Context) {
|
func (o *Auth) UserRegister(c *gin.Context) {
|
||||||
a2r.Call(auth.AuthClient.UserToken, a.getGroupClient, c)
|
a2r.Call(auth.AuthClient.UserRegister, o.client, c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Auth) ParseToken(c *gin.Context) {
|
func (o *Auth) UserToken(c *gin.Context) {
|
||||||
a2r.Call(auth.AuthClient.ParseToken, a.getGroupClient, c)
|
a2r.Call(auth.AuthClient.UserToken, o.client, c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Auth) ForceLogout(c *gin.Context) {
|
func (o *Auth) ParseToken(c *gin.Context) {
|
||||||
a2r.Call(auth.AuthClient.ForceLogout, a.getGroupClient, c)
|
a2r.Call(auth.AuthClient.ParseToken, o.client, c)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *Auth) ForceLogout(c *gin.Context) {
|
||||||
|
a2r.Call(auth.AuthClient.ForceLogout, o.client, c)
|
||||||
}
|
}
|
||||||
|
18
internal/apiresp/gin.go
Normal file
18
internal/apiresp/gin.go
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package apiresp
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
func GinError(c *gin.Context, err error) {
|
||||||
|
if err == nil {
|
||||||
|
GinSuccess(c, nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
c.JSON(http.StatusOK, apiError(err))
|
||||||
|
}
|
||||||
|
|
||||||
|
func GinSuccess(c *gin.Context, data any) {
|
||||||
|
c.JSON(http.StatusOK, apiSuccess(data))
|
||||||
|
}
|
@ -7,12 +7,12 @@ type ApiResponse struct {
|
|||||||
Data any `json:"data"`
|
Data any `json:"data"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func Success(data any) *ApiResponse {
|
func apiSuccess(data any) *ApiResponse {
|
||||||
return &ApiResponse{
|
return &ApiResponse{
|
||||||
Data: data,
|
Data: data,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func Error(err error) *ApiResponse {
|
func apiError(err error) *ApiResponse {
|
||||||
return &ApiResponse{}
|
return &ApiResponse{ErrCode: 10000, ErrMsg: err.Error()}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user