123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223 |
- package controllers
- import (
- "encoding/json"
- "eta/eta_mini_crm_ht/models"
- "eta/eta_mini_crm_ht/models/request"
- "eta/eta_mini_crm_ht/models/response"
- "eta/eta_mini_crm_ht/services"
- "eta/eta_mini_crm_ht/utils"
- "fmt"
- "time"
- )
- type UserLoginController struct {
- BaseCommonController
- }
- func ssoLogin(req request.UserLoginReq, br *models.BaseResponse) {
- if req.Code == "" {
- br.Msg = "code不能为空"
- return
- }
- ssoResp, err := services.SSOLogin(req.Code)
- if err != nil {
- br.Msg = "登录失败"
- br.ErrMsg = "sso登录失败, Err:" + err.Error()
- return
- }
- utils.FileLog.Info(fmt.Sprintf("sso 登录请求结果:%s", ssoResp))
- sysUser, err := models.GetSysUserBySysUserName(ssoResp.UserName)
- if err != nil || sysUser.SysUserName == "" {
- br.ErrMsg = err.Error()
- br.Msg = "sso登录失败,获取用户信息失败"
- return
- }
- sysRole, err := models.GetSysRoleById(sysUser.SysRoleId)
- if err != nil {
- br.Msg = "登录失败"
- br.ErrMsg = "查询角色失败, Err:" + err.Error()
- return
- }
- account := utils.MD5(sysUser.SysUserName)
- token := utils.GenToken(account)
- sysSession := new(models.SysSession)
- sysSession.UserName = sysUser.SysUserName
- sysSession.SysUserId = sysUser.SysUserId
- sysSession.ExpiredTime = time.Now().AddDate(0, 0, 60)
- sysSession.CreatedTime = time.Now()
- sysSession.LastUpdatedTime = time.Now()
- sysSession.AccessToken = token
- err = sysSession.AddSysSession()
- if err != nil {
- br.Msg = "登录失败"
- br.ErrMsg = "新增session信息失败, Err:" + err.Error()
- return
- }
- resp := new(response.LoginResp)
- resp.Authorization = "authorization=" + token
- resp.SysUserName = sysUser.SysUserName
- resp.SysRealName = sysUser.SysRealName
- resp.SysUserId = sysUser.SysUserId
- resp.RoleName = sysRole.SysRoleName
- resp.RoleId = sysUser.SysRoleId
- //获取不可信的登录态,并将该登录态重置掉,不允许多次登录
- noTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN_NO_TRUST, sysUser.SysUserId)
- noTrustLoginId, _ := utils.Rc.RedisString(noTrustLoginKey)
- fmt.Println("noTrustLoginId:", noTrustLoginId)
- if noTrustLoginId != `` { // 如果存在不可信设备,那么将其下架
- oldNoTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, noTrustLoginId)
- utils.Rc.Put(oldNoTrustLoginKey, "0", time.Hour*24)
- }
- // 设置redis缓存,记录用户登录态
- loginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, sysSession.SysSessionId)
- utils.Rc.Put(loginKey, "1", time.Hour*24)
- utils.Rc.Put(noTrustLoginKey, sysSession.SysSessionId, time.Hour*24*60)
- br.Data = resp
- br.Ret = 200
- br.Success = true
- br.Msg = "登录成功"
- }
- // Login
- // @Title 用户登录
- // @Description 用户登录
- // @Param request body UserLoginReq true "type json string"
- // @Success 200 {object} models.LoginResp
- // @router /login [post]
- func (this *UserLoginController) Login() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- var req request.UserLoginReq
- err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
- if err != nil {
- br.Msg = "参数错误"
- br.ErrMsg = "解析参数失败:" + err.Error()
- return
- }
- switch req.LoginType {
- case "sso":
- ssoLogin(req, br)
- case "password":
- login(req, br)
- default:
- ssoLogin(req, br)
- }
- }
- func login(req request.UserLoginReq, br *models.BaseResponse) {
- if req.UserName == "" {
- br.Msg = "请输入账号"
- return
- }
- if req.Password == "" {
- br.Msg = "请输入密码"
- return
- }
- sysUser, err := models.GetSysUserBySysUserName(req.UserName)
- if err != nil {
- if err.Error() == utils.ErrNoRow() {
- br.Msg = "登录失败, 账号或密码错误"
- return
- } else {
- br.Msg = "系统错误"
- br.ErrMsg = "系统错误" + err.Error()
- return
- }
- }
- sysRole, err := models.GetSysRoleById(sysUser.SysRoleId)
- if err != nil {
- br.Msg = "登录失败"
- br.ErrMsg = "查询角色失败, Err:" + err.Error()
- return
- }
- dbPass := utils.MD5(fmt.Sprintf("%s%s%s", sysUser.Password, utils.UserLoginSalt, req.ReqTime))
- if req.Password != dbPass {
- br.Msg = "登录失败, 账号或密码错误"
- return
- }
- account := utils.MD5(sysUser.SysUserName)
- token := utils.GenToken(account)
- sysSession := new(models.SysSession)
- sysSession.UserName = sysUser.SysUserName
- sysSession.SysUserId = sysUser.SysUserId
- sysSession.ExpiredTime = time.Now().AddDate(0, 0, 60)
- sysSession.CreatedTime = time.Now()
- sysSession.LastUpdatedTime = time.Now()
- sysSession.AccessToken = token
- err = sysSession.AddSysSession()
- if err != nil {
- br.Msg = "登录失败"
- br.ErrMsg = "新增session信息失败, Err:" + err.Error()
- return
- }
- resp := new(response.LoginResp)
- resp.Authorization = "authorization=" + token
- resp.SysUserName = sysUser.SysUserName
- resp.SysRealName = sysUser.SysRealName
- resp.SysUserId = sysUser.SysUserId
- resp.RoleName = sysRole.SysRoleName
- resp.RoleId = sysUser.SysRoleId
- // 获取不可信的登录态,并将该登录态重置掉,不允许多次登录
- noTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN_NO_TRUST, sysUser.SysUserId)
- noTrustLoginId, _ := utils.Rc.RedisString(noTrustLoginKey)
- fmt.Println("noTrustLoginId:", noTrustLoginId)
- if noTrustLoginId != `` { // 如果存在不可信设备,那么将其下架
- oldNoTrustLoginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, noTrustLoginId)
- utils.Rc.Put(oldNoTrustLoginKey, "0", time.Hour*24)
- }
- // 设置redis缓存,记录用户登录态
- loginKey := fmt.Sprint(utils.CACHE_ACCESS_TOKEN_LOGIN, sysSession.SysSessionId)
- utils.Rc.Put(loginKey, "1", time.Hour*24)
- utils.Rc.Put(noTrustLoginKey, sysSession.SysSessionId, time.Hour*24*60)
- br.Data = resp
- br.Ret = 200
- br.Success = true
- br.Msg = "登录成功"
- }
- // AreaCodeList
- // @Title 手机号区号列表
- // @Description 手机号区号列表
- // @Success 200 Ret=200 获取成功
- // @router /area_code/list [get]
- func (this *UserLoginController) AreaCodeList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- if br.ErrMsg == "" {
- br.IsSendEmail = false
- }
- this.Data["json"] = br
- this.ServeJSON()
- }()
- resp := make([]response.AreaCodeListResp, 0)
- confAuth, e := models.GetConfigDetailByCode(models.ConfAreaCodeListKey)
- if e != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取手机号区号配置失败, Err: " + e.Error()
- return
- }
- if confAuth.ConfigValue == "" {
- br.Msg = "获取失败"
- br.ErrMsg = "手机号区号配置为空"
- return
- }
- if e := json.Unmarshal([]byte(confAuth.ConfigValue), &resp); e != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "手机号区号配置有误"
- return
- }
- br.Data = resp
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- }
|