Files
cloudreve/service/user/login.go

90 lines
2.7 KiB
Go
Raw Normal View History

2019-11-11 19:13:17 +08:00
package user
import (
2019-11-16 16:11:37 +08:00
"github.com/HFO4/cloudreve/models"
"github.com/HFO4/cloudreve/pkg/serializer"
"github.com/HFO4/cloudreve/pkg/util"
2019-11-11 19:13:17 +08:00
"github.com/gin-gonic/gin"
2019-11-13 17:03:55 +08:00
"github.com/mojocn/base64Captcha"
2020-02-21 13:48:34 +08:00
"github.com/pquerna/otp/totp"
2019-11-11 19:13:17 +08:00
)
// UserLoginService 管理用户登录的服务
type UserLoginService struct {
//TODO 细致调整验证规则
UserName string `form:"userName" json:"userName" binding:"required,email"`
Password string `form:"Password" json:"Password" binding:"required,min=4,max=64"`
CaptchaCode string `form:"captchaCode" json:"captchaCode"`
}
2020-02-21 13:48:34 +08:00
// Login 二步验证继续登录
func (service *Enable2FA) Login(c *gin.Context) serializer.Response {
if uid, ok := util.GetSession(c, "2fa_user_id").(uint); ok {
// 查找用户
expectedUser, err := model.GetActiveUserByID(uid)
if err != nil {
return serializer.Err(serializer.CodeNotFound, "用户不存在", nil)
}
// 验证二步验证代码
if !totp.Validate(service.Code, expectedUser.TwoFactor) {
return serializer.ParamErr("验证代码不正确", nil)
}
//登陆成功清空并设置session
util.DeleteSession(c, "2fa_user_id")
util.SetSession(c, map[string]interface{}{
"user_id": expectedUser.ID,
})
return serializer.BuildUserResponse(expectedUser)
}
return serializer.Err(serializer.CodeNotFound, "登录会话不存在", nil)
}
2019-11-11 19:13:17 +08:00
// Login 用户登录函数
func (service *UserLoginService) Login(c *gin.Context) serializer.Response {
isCaptchaRequired := model.GetSettingByName("login_captcha")
expectedUser, err := model.GetUserByEmail(service.UserName)
if model.IsTrueVal(isCaptchaRequired) {
// TODO 验证码校验
2019-11-13 17:03:55 +08:00
captchaID := util.GetSession(c, "captchaID")
util.DeleteSession(c, "captchaID")
2019-11-13 17:03:55 +08:00
if captchaID == nil || !base64Captcha.VerifyCaptcha(captchaID.(string), service.CaptchaCode) {
return serializer.ParamErr("验证码错误", nil)
}
2019-11-11 19:13:17 +08:00
}
// 一系列校验
if err != nil {
return serializer.Err(401, "用户邮箱或密码错误", err)
}
if authOK, _ := expectedUser.CheckPassword(service.Password); !authOK {
return serializer.Err(401, "用户邮箱或密码错误", nil)
}
2020-02-15 14:02:21 +08:00
if expectedUser.Status == model.Baned || expectedUser.Status == model.OveruseBaned {
2019-11-11 19:13:17 +08:00
return serializer.Err(403, "该账号已被封禁", nil)
}
if expectedUser.Status == model.NotActivicated {
return serializer.Err(403, "该账号未激活", nil)
}
if expectedUser.TwoFactor != "" {
2020-02-21 13:48:34 +08:00
// 需要二步验证
util.SetSession(c, map[string]interface{}{
"2fa_user_id": expectedUser.ID,
})
return serializer.Response{Code: 203}
2019-11-11 19:13:17 +08:00
}
//登陆成功清空并设置session
2019-11-12 16:18:58 +08:00
util.SetSession(c, map[string]interface{}{
2019-11-11 19:13:17 +08:00
"user_id": expectedUser.ID,
})
2019-11-12 15:34:54 +08:00
return serializer.BuildUserResponse(expectedUser)
2019-11-11 19:13:17 +08:00
}