1 Star 4 Fork 0

jingshanccc/course

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
oauth.go 5.97 KB
一键复制 编辑 原始数据 按行查看 历史
micahchen 提交于 2021-05-03 15:56 . [feature] #268
package middleware
import (
"context"
"encoding/json"
"gitee.com/jingshanccc/course/public"
"gitee.com/jingshanccc/course/public/config"
"gitee.com/jingshanccc/course/public/middleware/redis"
"gitee.com/jingshanccc/course/user/proto/dto"
"gitee.com/jingshanccc/course/user/proto/user"
"github.com/dgrijalva/jwt-go"
"github.com/gin-gonic/gin"
"github.com/go-oauth2/oauth2/v4"
"github.com/go-oauth2/oauth2/v4/generates"
"github.com/go-oauth2/oauth2/v4/manage"
"github.com/go-oauth2/oauth2/v4/models"
"github.com/go-oauth2/oauth2/v4/server"
oredis "github.com/go-oauth2/redis/v4"
"github.com/micro/go-micro/v2/errors"
"net/http"
"strings"
"time"
)
var (
Services map[string]interface{}
AuthServer *server.Server
)
type ClientStore struct {
}
func (c *ClientStore) GetByID(ctx context.Context, id string) (oauth2.ClientInfo, error) {
if id == "" {
return nil, nil
}
res := &models.Client{}
err := public.DB.Raw("select * from oauth_client where id = ?", id).Scan(res).Error
if err != nil {
return nil, err
}
return res, nil
}
func init() {
// 初始化services map
Services = make(map[string]interface{})
// 初始化authServer
manager := manage.NewDefaultManager()
// use redis token store
manager.MapTokenStorage(oredis.NewRedisStoreWithCli(redis.RedisClient))
// use mysql client store
manager.MapClientStorage(&ClientStore{})
// use jwt token
manager.MapAccessGenerate(
generates.NewJWTAccessGenerate("", []byte(config.Conf.Services["user"].Others["jwtKey"].(string)), jwt.SigningMethodHS512))
AuthServer = server.NewDefaultServer(manager)
AuthServer.SetAccessTokenExpHandler(TokenExpHandler)
AuthServer.SetAllowGetAccessRequest(true)
AuthServer.SetClientInfoHandler(server.ClientFormHandler)
// 授权码式授权
AuthServer.SetUserAuthorizationHandler(UserAuthorizeHandler)
// 密码式授权
AuthServer.SetPasswordAuthorizationHandler(ValidPasswordHandler)
}
//SaveServices : 将服务实例存放到gin中
func SaveServices(service []interface{}) gin.HandlerFunc {
Services[config.Conf.BasicConfig.BasicName+config.Conf.Services["user"].Name] = service[0]
Services[config.Conf.BasicConfig.BasicName+config.Conf.Services["course"].Name] = service[1]
Services[config.Conf.BasicConfig.BasicName+config.Conf.Services["file"].Name] = service[2]
return func(context *gin.Context) {
//将实例存到gin.Keys里
context.Keys = make(map[string]interface{})
context.Keys[config.Conf.BasicConfig.BasicName+config.Conf.Services["user"].Name] = service[0]
context.Keys[config.Conf.BasicConfig.BasicName+config.Conf.Services["course"].Name] = service[1]
context.Keys[config.Conf.BasicConfig.BasicName+config.Conf.Services["file"].Name] = service[2]
context.Next()
}
}
//GetCurrentUser: 获取当前请求登陆的用户(admin)
func GetCurrentUser(ctx *gin.Context) (string, *dto.UserDto) {
token := strings.Split(ctx.Request.Header.Get("Authorization"), " ")[1]
info, err := AuthServer.Manager.LoadAccessToken(context.Background(), token)
if err != nil {
ctx.AbortWithError(http.StatusUnauthorized, err)
return "", nil
} else if usrStr, e := redis.RedisClient.Get(context.Background(), config.Conf.Services["user"].Others["userInfoKey"].(string)+info.GetUserID()).Result(); e == nil {
var usr dto.UserDto
_ = json.Unmarshal([]byte(usrStr), &usr)
return info.GetUserID(), &usr
} else {
return info.GetUserID(), nil
}
}
//GetCurrentMember: 获取当前请求登陆的用户(web)
func GetCurrentMember(ctx *gin.Context) (string, *dto.MemberDto) {
token := strings.Split(ctx.Request.Header.Get("Authorization"), " ")[1]
info, err := AuthServer.Manager.LoadAccessToken(context.Background(), token)
if err != nil {
ctx.AbortWithError(http.StatusUnauthorized, err)
return "", nil
} else if usrStr, e := redis.RedisClient.Get(context.Background(), config.Conf.Services["user"].Others["userInfoKey"].(string)+info.GetUserID()).Result(); e == nil {
var usr dto.MemberDto
_ = json.Unmarshal([]byte(usrStr), &usr)
return info.GetUserID(), &usr
} else {
return info.GetUserID(), nil
}
}
//ValidPasswordHandler: 密码式授权-校验密码
func ValidPasswordHandler(username, password string) (userID string, err error) {
userService := Services[config.Conf.BasicConfig.BasicName+config.Conf.Services["user"].Name].(user.UserService)
loginUserDto, err := userService.Login(context.Background(), &dto.LoginUserDto{
LoginName: username,
Password: password,
})
if err != nil {
return "", err
}
return loginUserDto.Id, nil
}
//UserAuthorizeHandler: 授权码式授权-用户授权环节-从请求中解析出userID
func UserAuthorizeHandler(w http.ResponseWriter, r *http.Request) (userID string, err error) {
defer func() {
if err != nil {
errs := err.(*errors.Error)
w.WriteHeader(http.StatusOK)
resp := &public.Response{Success: false, Code: errs.GetCode(), Message: errs.GetDetail(), Content: nil}
bytes, _ := json.Marshal(resp)
w.Write(bytes)
}
}()
// 获取参数
userDto := &dto.LoginUserDto{
Id: r.FormValue("id"),
Name: r.FormValue("code"),
LoginName: r.FormValue("login_name"),
Password: r.FormValue("password"),
}
exception := public.VerifyCaptcha(userDto.Id, userDto.Name)
if exception != nil {
err = errors.New(config.Conf.BasicConfig.BasicName+config.Conf.Services["user"].Name, exception.Error(), exception.Code()).(*errors.Error)
return "", err
}
// 登录接口
userService := Services[config.Conf.BasicConfig.BasicName+config.Conf.Services["user"].Name].(user.UserService)
if r.FormValue("type") == "member" {
login, err := userService.MemberLogin(r.Context(), userDto)
if err == nil {
userID = login.Str
}
} else {
loginUserDto, _ := userService.Login(r.Context(), userDto)
if loginUserDto != nil {
userID = loginUserDto.Id
}
}
// 返回userID
return userID, err
}
//TokenExpHandler: 令牌过期时间 默认两天
func TokenExpHandler(w http.ResponseWriter, r *http.Request) (exp time.Duration, err error) {
return time.Duration(config.Conf.Services["user"].Others["tokenExpire"].(int)) * time.Hour, nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/jingshanccc/course.git
git@gitee.com:jingshanccc/course.git
jingshanccc
course
course
23f538baa694

搜索帮助