70 lines
1.4 KiB
Go
70 lines
1.4 KiB
Go
package auth
|
|
|
|
import (
|
|
"fmt"
|
|
"net/url"
|
|
"nixcn-cms/data"
|
|
"nixcn-cms/pkgs/authcode"
|
|
"nixcn-cms/utils"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/google/uuid"
|
|
)
|
|
|
|
const ()
|
|
|
|
func Exchange(c *gin.Context) {
|
|
var exchangeReq struct {
|
|
ClientId string `json:"client_id"`
|
|
RedirectUri string `json:"redirect_uri"`
|
|
State string `json:"state"`
|
|
}
|
|
|
|
err := c.ShouldBindJSON(&exchangeReq)
|
|
if err != nil {
|
|
fmt.Println(err)
|
|
utils.HttpResponse(c, 400, "", "invalid request")
|
|
return
|
|
}
|
|
|
|
userIdOrig, ok := c.Get("user_id")
|
|
if !ok {
|
|
utils.HttpResponse(c, 401, "", "unauthorized")
|
|
return
|
|
}
|
|
|
|
userId, err := uuid.Parse(userIdOrig.(string))
|
|
if err != nil {
|
|
utils.HttpResponse(c, 500, "", "failed to parse uuid")
|
|
return
|
|
}
|
|
|
|
userData := new(data.User)
|
|
user, err := userData.GetByUserId(userId)
|
|
if err != nil {
|
|
utils.HttpResponse(c, 500, "", "failed to get user id")
|
|
return
|
|
}
|
|
|
|
code, err := authcode.NewAuthCode(exchangeReq.ClientId, user.Email)
|
|
if err != nil {
|
|
utils.HttpResponse(c, 500, "", "code gen failed")
|
|
return
|
|
}
|
|
|
|
url, err := url.Parse(exchangeReq.RedirectUri)
|
|
if err != nil {
|
|
utils.HttpResponse(c, 400, "", "invalid redirect uri")
|
|
return
|
|
}
|
|
query := url.Query()
|
|
query.Set("code", code)
|
|
url.RawQuery = query.Encode()
|
|
|
|
exchangeResp := struct {
|
|
RedirectUri string `json:"redirect_uri"`
|
|
}{url.String()}
|
|
|
|
utils.HttpResponse(c, 200, "", "success", exchangeResp)
|
|
}
|