c_login.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. package controllers
  2. import (
  3. "github.com/LyricTian/captcha"
  4. "github.com/gogf/gf/v2/net/ghttp"
  5. "yx-dataset-server/app/bll"
  6. "yx-dataset-server/app/errors"
  7. "yx-dataset-server/app/schema"
  8. "yx-dataset-server/library/gplus"
  9. "yx-dataset-server/library/logger"
  10. "yx-dataset-server/library/utils"
  11. )
  12. func NewLogin(
  13. bLogin bll.ILogin,
  14. bVerify bll.IVerifyCode,
  15. bUser bll.IUser,
  16. ) *Login {
  17. return &Login{
  18. bLogin: bLogin,
  19. bVerify: bVerify,
  20. bUser: bUser,
  21. }
  22. }
  23. type Login struct {
  24. bLogin bll.ILogin
  25. bVerify bll.IVerifyCode
  26. bUser bll.IUser
  27. }
  28. // GetCaptchaID 获取验证码ID
  29. // @Summary 获取验证码ID
  30. // @Success 200 schema.LoginCaptcha
  31. // @Router GET /web/v1/login/captchaid
  32. func (a *Login) GetCaptchaID(r *ghttp.Request) {
  33. ctx := gplus.NewContext(r)
  34. item, err := a.bLogin.GetCaptchaID(ctx, utils.GetConfig("captcha.length").Int())
  35. if err != nil {
  36. ResError(r, err)
  37. return
  38. }
  39. ResSuccess(r, item)
  40. }
  41. // GetCaptcha 获取图形验证码
  42. // @Summary 获取图形验证码
  43. // @Param id query string true "验证码ID"
  44. // @Param reload query string false "重新加载"
  45. // @Success 200 file "图形验证码"
  46. // @Failure 400 schema.HTTPError "{error:{code:0,message:无效的请求参数}}"
  47. // @Failure 500 schema.HTTPError "{error:{code:0,message:服务器错误}}"
  48. // @Router GET /web/v1/login/captcha
  49. func (a *Login) GetCaptcha(r *ghttp.Request) {
  50. ctx := gplus.NewContext(r)
  51. captchaID := r.Get("id").String()
  52. if captchaID == "" {
  53. ResError(r, errors.ErrBadRequest)
  54. return
  55. }
  56. if r.Get("reload").String() != "" {
  57. if !captcha.Reload(captchaID) {
  58. ResError(r, errors.ErrBadRequest)
  59. return
  60. }
  61. }
  62. err := a.bLogin.ResCaptcha(ctx, r.Response.ResponseWriter, captchaID, utils.GetConfig("captcha.width").Int(), utils.GetConfig("captcha.height").Int())
  63. if err != nil {
  64. ResError(r, err)
  65. }
  66. }
  67. // Login 用户登录
  68. // @Summary 用户登录
  69. // @Param body schema.LoginParam true
  70. // @Success 200 schema.LoginTokenInfo "{access_token:访问令牌,token_type:令牌类型,expires_in:过期时长(单位秒)}"
  71. // @Failure 400 schema.HTTPError "{error:{code:0,message:无效的请求参数}}"
  72. // @Failure 500 schema.HTTPError "{error:{code:0,message:服务器错误}}"
  73. // @Router POST /web/v1/login
  74. func (a *Login) Login(r *ghttp.Request) {
  75. var item schema.LoginParam
  76. ctx := gplus.NewContext(r)
  77. if err := gplus.ParseJson(r, &item); err != nil {
  78. ResError(r, err)
  79. return
  80. }
  81. if !captcha.VerifyString(item.CaptchaID, item.CaptchaCode) {
  82. ResError(r, errors.New400Response("无效的验证码"))
  83. return
  84. }
  85. user, err := a.bLogin.Verify(ctx, item.UserName, item.Password)
  86. if err != nil {
  87. ResError(r, err)
  88. return
  89. }
  90. // 将用户ID放入上下文
  91. gplus.SetUserId(r, user.RecordID)
  92. tokenInfo, err := a.bLogin.GenerateToken(ctx, user.RecordID)
  93. if err != nil {
  94. ResError(r, err)
  95. return
  96. }
  97. logger.StartSpan(gplus.NewContext(r), logger.SetSpanTitle("用户登录"), logger.SetSpanFuncName("Login")).Infof(ctx, "登入系统")
  98. ResSuccess(r, tokenInfo)
  99. }
  100. // Logout 用户登出
  101. // @Summary 用户登出
  102. // @Success 200 schema.HTTPStatus "{status:OK}"
  103. // @Router POST /web/v1/login/exit
  104. func (a *Login) Logout(r *ghttp.Request) {
  105. // 检查用户是否处于登录状态,如果是则执行销毁
  106. userID := gplus.GetUserID(r)
  107. ctx := gplus.NewContext(r)
  108. if userID != "" {
  109. err := a.bLogin.DestroyToken(ctx, gplus.GetToken(r))
  110. if err != nil {
  111. logger.Errorf(ctx, err.Error())
  112. }
  113. logger.StartSpan(gplus.NewContext(r), logger.SetSpanTitle("用户登出"), logger.SetSpanFuncName("Logout")).Infof(ctx, "登出系统")
  114. }
  115. ResSuccess(r, nil)
  116. }
  117. // GetUserInfo 获取当前用户信息
  118. // @Router GET /web/v1/current/user
  119. func (a *Login) GetUserInfo(r *ghttp.Request) {
  120. ctx := gplus.NewContext(r)
  121. userId := gplus.GetUserID(r)
  122. info, err := a.bUser.Get(ctx, userId)
  123. if err != nil {
  124. ResError(r, err)
  125. return
  126. }
  127. ResSuccess(r, info)
  128. }
  129. // UpdatePassword 更新个人密码
  130. // @Summary 更新个人密码
  131. // @Param body schema.UpdatePasswordParam true
  132. // @Success 200 schema.HTTPStatus "{status:OK}"
  133. // @Failure 400 schema.HTTPError "{error:{code:0,message:无效的请求参数}}"
  134. // @Failure 401 schema.HTTPError "{error:{code:0,message:未授权}}"
  135. // @Failure 500 schema.HTTPError "{error:{code:0,message:服务器错误}}"
  136. // @Router PUT /web/v1/current/password
  137. func (a *Login) UpdatePassword(r *ghttp.Request) {
  138. ctx := gplus.NewContext(r)
  139. var item schema.UpdatePasswordParam
  140. if err := gplus.ParseJson(r, &item); err != nil {
  141. ResError(r, err)
  142. return
  143. }
  144. err := a.bLogin.UpdatePassword(ctx, item)
  145. if err != nil {
  146. ResError(r, err)
  147. return
  148. }
  149. ResSuccess(r, nil)
  150. }
  151. // @Router POST /api/v1/login/code
  152. func (a *Login) Send(r *ghttp.Request) {
  153. req := schema.VerifyCodeRequest{}
  154. if err := gplus.ParseJson(r, &req); err != nil {
  155. ResError(r, err)
  156. }
  157. ctx := gplus.NewContext(r)
  158. item, err := a.bVerify.ALiYunSendSms(ctx, req)
  159. if err != nil {
  160. ResError(r, err)
  161. }
  162. ResSuccess(r, item)
  163. }
  164. // @Router POST /api/v1/login/sms
  165. func (a *Login) LoginBySms(r *ghttp.Request) {
  166. var params schema.SmsLoginParam
  167. params.BusinessType = 1
  168. ctx := gplus.NewContext(r)
  169. if err := gplus.ParseJson(r, &params); err != nil {
  170. ResError(r, err)
  171. }
  172. err := a.bLogin.LoginBySms(ctx, params)
  173. if err != nil {
  174. ResError(r, err)
  175. }
  176. ResSuccess(r, nil)
  177. }