login.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package controllers
  2. import (
  3. "database/sql"
  4. "encoding/json"
  5. log "github.com/sirupsen/logrus"
  6. "io"
  7. "net/http"
  8. "pmail/db"
  9. "pmail/dto/response"
  10. "pmail/i18n"
  11. "pmail/models"
  12. "pmail/session"
  13. "pmail/utils/context"
  14. "pmail/utils/errors"
  15. "pmail/utils/password"
  16. )
  17. type loginRequest struct {
  18. Account string `json:"account"`
  19. Password string `json:"password"`
  20. }
  21. func Login(ctx *context.Context, w http.ResponseWriter, req *http.Request) {
  22. reqBytes, err := io.ReadAll(req.Body)
  23. if err != nil {
  24. log.Errorf("%+v", err)
  25. }
  26. var reqData loginRequest
  27. err = json.Unmarshal(reqBytes, &reqData)
  28. if err != nil {
  29. log.Errorf("%+v", err)
  30. }
  31. var user models.User
  32. encodePwd := password.Encode(reqData.Password)
  33. _, err = db.Instance.Where("account =? and password =? and disabled=0", reqData.Account, encodePwd).Get(&user)
  34. if err != nil && !errors.Is(err, sql.ErrNoRows) {
  35. log.Errorf("%+v", err)
  36. }
  37. if user.ID != 0 {
  38. userStr, _ := json.Marshal(user)
  39. session.Instance.Put(req.Context(), "user", string(userStr))
  40. response.NewSuccessResponse(map[string]any{
  41. "account": user.Account,
  42. "name": user.Name,
  43. "is_admin": user.IsAdmin,
  44. }).FPrint(w)
  45. } else {
  46. response.NewErrorResponse(response.ParamsError, i18n.GetText(ctx.Lang, "aperror"), "").FPrint(w)
  47. }
  48. }
  49. func Logout(ctx *context.Context, w http.ResponseWriter, req *http.Request) {
  50. session.Instance.Clear(ctx.Context)
  51. response.NewSuccessResponse("Success").FPrint(w)
  52. }