12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- package auth
- import (
- "database/sql"
- "errors"
- "git.dmitriygnatenko.ru/dima/go-common/logger"
- "github.com/go-playground/validator/v10"
- "github.com/gofiber/fiber/v2"
- "git.dmitriygnatenko.ru/dima/homethings/internal/dto"
- "git.dmitriygnatenko.ru/dima/homethings/internal/factory"
- "git.dmitriygnatenko.ru/dima/homethings/internal/mappers"
- )
- // @Router /api/v1/auth/login [post]
- // @Param data body dto.LoginRequest true "Request body"
- // @Success 200 {object} dto.LoginResponse
- // @Failure 400 {object} dto.ErrorResponse
- // @Failure 403 {object} dto.ErrorResponse
- // @Failure 500 {object} dto.ErrorResponse
- // @Summary Log in user
- // @Tags Auth
- // @Accept json
- // @Produce json
- func LoginHandler(
- authService AuthService,
- userRepository UserRepository,
- ) fiber.Handler {
- return func(fctx *fiber.Ctx) error {
- ctx := fctx.Context()
- req := dto.LoginRequest{}
- if err := fctx.BodyParser(&req); err != nil {
- logger.Info(ctx, err.Error())
- return fiber.NewError(fiber.StatusBadRequest, err.Error())
- }
- var validate = validator.New()
- if err := validate.Struct(req); err != nil {
- logger.Info(ctx, err.Error())
- return fctx.Status(fiber.StatusBadRequest).JSON(factory.CreateValidateErrorResponse(err))
- }
- user, err := userRepository.Get(ctx, req.Username)
- if err != nil {
- if errors.Is(err, sql.ErrNoRows) {
- logger.Info(ctx, err.Error())
- return fiber.NewError(fiber.StatusForbidden, "")
- }
- logger.Error(ctx, err.Error())
- return fiber.NewError(fiber.StatusInternalServerError, err.Error())
- }
- if !authService.IsCorrectPassword(req.Password, user.Password) {
- return fiber.NewError(fiber.StatusForbidden, "")
- }
- token, err := authService.GenerateToken(*user)
- if err != nil {
- logger.Error(ctx, err.Error())
- return fiber.NewError(fiber.StatusInternalServerError, err.Error())
- }
- return fctx.JSON(mappers.ToLoginResponse(token))
- }
- }
|