auth.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package auth
  2. import(
  3. "git.qianqiusoft.com/qianqiusoft/light-apiengine/entitys"
  4. sysmodel "git.qianqiusoft.com/qianqiusoft/light-apiengine/models"
  5. sysutils "git.qianqiusoft.com/qianqiusoft/light-apiengine/utils"
  6. "strconv"
  7. "time"
  8. )
  9. type IAuth interface {
  10. Init()
  11. Login(*entitys.CtrlContext)
  12. Logout(*entitys.CtrlContext)
  13. }
  14. var iauthMap map[string]IAuth
  15. func init(){
  16. iauthMap = make(map[string]IAuth)
  17. }
  18. /**
  19. * @brief: 注册自定登录对象, 会调用Init进行初始化
  20. * @param1 t: key
  21. * @param2 a: 认证对象
  22. * @return none
  23. */
  24. func RegisterAuth(t string, a IAuth){
  25. if t == "" || a == nil{
  26. return
  27. }
  28. var ok bool
  29. if _, ok = iauthMap[t]; ok{
  30. return
  31. }else{
  32. a.Init()
  33. iauthMap[t] = a
  34. }
  35. }
  36. /**
  37. * @brief: 获取认证对象
  38. * @param1 t: key
  39. * @return1 认证对象
  40. */
  41. func GetAuth(t string)IAuth{
  42. var iauth IAuth
  43. var ok bool
  44. if iauth, ok = iauthMap[t]; ok{
  45. return iauth
  46. }else{
  47. return nil
  48. }
  49. }
  50. /**
  51. * @brief: 添加token到全局缓存中
  52. * @param1 userInfo: 用户信息
  53. */
  54. func AddToGlobalTokenStore(c *entitys.CtrlContext, userInfo *sysmodel.SysUser)*sysmodel.LoginReturnInfo{
  55. token := &entitys.Token{}
  56. timestamp := uint64(time.Now().UnixNano())
  57. timestamp_str := strconv.FormatUint(timestamp, 10)
  58. sec_tooken := sysutils.GenerateToken(userInfo.LoginId + timestamp_str)
  59. if v := sysutils.GetGlobalTokenStore().Get(sec_tooken); v == nil {
  60. token.AccessToken = sec_tooken
  61. token.RefreshToken = sec_tooken
  62. token.LoginID = userInfo.LoginId
  63. token.UserId = userInfo.Id
  64. token.Result = 200
  65. //token.Password = pwd
  66. token.ServerIp = ""
  67. token.Domain = userInfo.Domain
  68. sysutils.GetGlobalTokenStore().Set(sec_tooken, token)
  69. //sysutils.GetGlobalTokenStore().Set(token.LoginID+user.Domain, token)
  70. } else {
  71. token = v
  72. }
  73. data := sysmodel.LoginReturnInfo{}
  74. data.Id = userInfo.Id
  75. data.LoginId = userInfo.LoginId
  76. data.Name = userInfo.Name
  77. data.Mobile = userInfo.Mobile
  78. data.Email = userInfo.Email
  79. data.Token = token.AccessToken
  80. data.Type = userInfo.Type
  81. data.Domain = userInfo.Domain
  82. // 查找用户对应角色
  83. var roles []sysmodel.SysRole
  84. c.App.GetBusinessDb(userInfo.Domain).SQL("select sys_role.* from sys_user_role, sys_role where sys_user_role.role_id = sys_role.id and sys_role.del_flag = 0 and sys_user_role.user_id = ? order by sys_role.priority asc", userInfo.Id).Find(&roles)
  85. data.Roles = roles
  86. return &data
  87. }