auth.go 3.7 KB
Newer Older
W
wenxu12345 已提交
1 2 3 4 5 6 7 8
package apiAuth

import (
	api "Open_IM/pkg/base_info"
	"Open_IM/pkg/common/config"
	"Open_IM/pkg/common/log"
	"Open_IM/pkg/grpc-etcdv3/getcdv3"
	rpc "Open_IM/pkg/proto/auth"
W
wenxu12345 已提交
9
	open_im_sdk "Open_IM/pkg/proto/sdk_ws"
W
wenxu12345 已提交
10
	"Open_IM/pkg/utils"
W
wenxu12345 已提交
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
	"context"
	"github.com/gin-gonic/gin"
	"net/http"
	"strings"
)

func UserRegister(c *gin.Context) {
	params := api.UserRegisterReq{}
	if err := c.BindJSON(&params); err != nil {
		log.NewError("0", "BindJSON failed ", err.Error())
		c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
		return
	}

	if params.Secret != config.Config.Secret {
		log.NewError(params.OperationID, "params.Secret != config.Config.Secret", params.Secret, config.Config.Secret)
		c.JSON(http.StatusBadRequest, gin.H{"errCode": 401, "errMsg": "not authorized"})
		return
	}
W
wenxu12345 已提交
30
	req := &rpc.UserRegisterReq{UserInfo: &open_im_sdk.UserInfo{}}
W
wenxu12345 已提交
31
	utils.CopyStructFields(req.UserInfo, &params)
W
wenxu12345 已提交
32
	//copier.Copy(req.UserInfo, &params)
W
wenxu12345 已提交
33
	req.OperationID = params.OperationID
W
wenxu12345 已提交
34
	log.NewInfo(req.OperationID, "UserRegister args ", req.String())
W
wenxu12345 已提交
35 36 37 38
	etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImAuthName)
	client := rpc.NewAuthClient(etcdConn)
	reply, err := client.UserRegister(context.Background(), req)
	if err != nil || reply.CommonResp.ErrCode != 0 {
W
wenxu12345 已提交
39
		log.NewError(req.OperationID, "UserRegister failed ", err, reply.CommonResp.ErrCode)
W
wenxu12345 已提交
40
		c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": reply.CommonResp.ErrMsg})
W
wenxu12345 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53
		return
	}

	pbDataToken := &rpc.UserTokenReq{Platform: params.Platform, FromUserID: params.UserID, OperationID: params.OperationID}
	replyToken, err := client.UserToken(context.Background(), pbDataToken)
	if err != nil {
		log.NewError(req.OperationID, "UserToken failed ", err.Error(), pbDataToken)
		c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": err.Error()})
		return
	}
	resp := api.UserRegisterResp{CommResp: api.CommResp{ErrCode: replyToken.CommonResp.ErrCode, ErrMsg: replyToken.CommonResp.ErrMsg},
		UserToken: api.UserTokenInfo{UserID: req.UserInfo.UserID, Token: replyToken.Token, ExpiredTime: replyToken.ExpiredTime}}
	log.NewInfo(req.OperationID, "UserRegister return ", resp)
W
wenxu12345 已提交
54 55
	c.JSON(http.StatusOK, resp)

W
wenxu12345 已提交
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
}

func UserToken(c *gin.Context) {
	params := api.UserTokenReq{}
	if err := c.BindJSON(&params); err != nil {
		log.NewError("0", "BindJSON failed ", err.Error())
		c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
		return
	}

	if params.Secret != config.Config.Secret {
		log.NewError(params.OperationID, "params.Secret != config.Config.Secret", params.Secret, config.Config.Secret)
		c.JSON(http.StatusBadRequest, gin.H{"errCode": 401, "errMsg": "not authorized"})
		return
	}
	req := &rpc.UserTokenReq{Platform: params.Platform, FromUserID: params.UserID, OperationID: params.OperationID}
W
wenxu12345 已提交
72
	log.NewInfo(req.OperationID, "UserToken args ", req.String())
W
wenxu12345 已提交
73 74 75 76 77 78 79 80 81 82 83
	etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImAuthName)
	client := rpc.NewAuthClient(etcdConn)
	reply, err := client.UserToken(context.Background(), req)
	if err != nil {
		log.NewError(req.OperationID, "UserToken failed ", err.Error(), req.String())
		c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": err.Error()})
		return
	}
	resp := api.UserTokenResp{CommResp: api.CommResp{ErrCode: reply.CommonResp.ErrCode, ErrMsg: reply.CommonResp.ErrMsg},
		UserToken: api.UserTokenInfo{UserID: req.FromUserID, Token: reply.Token, ExpiredTime: reply.ExpiredTime}}
	log.NewInfo(req.OperationID, "UserRegister return ", resp)
W
wenxu12345 已提交
84
	c.JSON(http.StatusOK, resp)
W
wenxu12345 已提交
85
}