69 lines
1.8 KiB
Go
69 lines
1.8 KiB
Go
package utils
|
||
|
||
import (
|
||
"errors"
|
||
"github.com/golang-jwt/jwt/v4"
|
||
"github.com/kataras/iris/v12"
|
||
"github.com/sirupsen/logrus"
|
||
"main/database"
|
||
"main/model"
|
||
)
|
||
|
||
var UserList []model.Userinfo
|
||
|
||
// GetLoginUser 根据token获取用户,返回用户信息
|
||
func GetLoginUser(ctx iris.Context) model.Userinfo {
|
||
if ctx.Values().Get("jwt") == nil {
|
||
ctx.StatusCode(iris.StatusUnauthorized)
|
||
ctx.SetErr(errors.New("未登录"))
|
||
logrus.Warningln("请求未携带token信息")
|
||
return model.Userinfo{}
|
||
}
|
||
var tokens []model.JwtKeys
|
||
db := database.GetInstance().GetMysqlDb()
|
||
auth := ctx.Values().Get("jwt").(*jwt.Token)
|
||
if err := db.Where("token = ?", auth.Raw).Find(&tokens).Error; err != nil {
|
||
logrus.Errorln("sql执行失败:", err)
|
||
}
|
||
if len(tokens) == 0 {
|
||
ctx.StatusCode(iris.StatusUnauthorized)
|
||
ctx.SetErr(errors.New("未登录"))
|
||
logrus.Warningln("token信息无效")
|
||
return model.Userinfo{}
|
||
}
|
||
foobar := auth.Claims.(jwt.MapClaims)
|
||
for key, value := range foobar {
|
||
if key == "username" {
|
||
return GetUserInfo(value.(string))
|
||
}
|
||
}
|
||
ctx.StatusCode(iris.StatusInternalServerError)
|
||
ctx.SetErr(errors.New("系统错误,请联系管理员"))
|
||
logrus.Errorln("token存在但获取用户信息失败")
|
||
return model.Userinfo{}
|
||
}
|
||
|
||
// GetUserInfo 根据用户名获取用户信息,先更新本地数据
|
||
func GetUserInfo(username string) model.Userinfo {
|
||
if len(UserList) == 0 {
|
||
logrus.Warnln("暂存用户列表为空,刷新数据")
|
||
UpdateUserInfo()
|
||
}
|
||
for _, u := range UserList {
|
||
if u.Username == username {
|
||
return u
|
||
}
|
||
}
|
||
logrus.Warnln("未找到对应的用户信息")
|
||
return model.Userinfo{}
|
||
}
|
||
|
||
// UpdateUserInfo 更新当前用户信息
|
||
func UpdateUserInfo() {
|
||
db := database.GetInstance().GetMysqlDb()
|
||
if err := db.Find(&UserList).Error; err != nil {
|
||
logrus.Errorln("sql执行失败:", err)
|
||
}
|
||
logrus.Infoln("刷新暂存用户列表")
|
||
}
|