login.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package api
  2. import (
  3. "github.com/torkelo/grafana-pro/pkg/api/dtos"
  4. "github.com/torkelo/grafana-pro/pkg/bus"
  5. "github.com/torkelo/grafana-pro/pkg/log"
  6. "github.com/torkelo/grafana-pro/pkg/middleware"
  7. m "github.com/torkelo/grafana-pro/pkg/models"
  8. "github.com/torkelo/grafana-pro/pkg/util"
  9. )
  10. type loginJsonModel struct {
  11. Email string `json:"email" binding:"required"`
  12. Password string `json:"password" binding:"required"`
  13. Remember bool `json:"remember"`
  14. }
  15. func LoginPost(c *middleware.Context) {
  16. var loginModel loginJsonModel
  17. if !c.JsonBody(&loginModel) {
  18. c.JSON(400, util.DynMap{"message": "bad request"})
  19. return
  20. }
  21. userQuery := m.GetAccountByLoginQuery{LoginOrEmail: loginModel.Email}
  22. err := bus.Dispatch(&userQuery)
  23. if err != nil {
  24. c.JsonApiErr(401, "Invalid username or password", err)
  25. return
  26. }
  27. account := userQuery.Result
  28. passwordHashed := util.EncodePassword(loginModel.Password, account.Salt)
  29. if passwordHashed != account.Password {
  30. c.JsonApiErr(401, "Invalid username or password", err)
  31. return
  32. }
  33. loginUserWithAccount(account, c)
  34. var resp = &dtos.LoginResult{}
  35. resp.Status = "Logged in"
  36. resp.User.Login = account.Login
  37. c.JSON(200, resp)
  38. }
  39. func loginUserWithAccount(account *m.Account, c *middleware.Context) {
  40. if account == nil {
  41. log.Error(3, "Account login with nil account")
  42. }
  43. c.Session.Set("accountId", account.Id)
  44. }
  45. func LogoutPost(c *middleware.Context) {
  46. c.Session.Delete("accountId")
  47. c.JSON(200, util.DynMap{"status": "logged out"})
  48. }