fix: fix user pin response structure

This commit is contained in:
pahmiudahgede 2024-12-10 14:39:23 +07:00
parent 96f85fce0b
commit 8945080477
4 changed files with 36 additions and 10 deletions

View File

@ -6,6 +6,9 @@ import (
"github.com/go-playground/validator/v10"
)
type PinResponse struct {
CreatedAt string `json:"createdAt"`
}
type PinInput struct {
Pin string `json:"pin" validate:"required,len=6,numeric"`
}

View File

@ -45,10 +45,13 @@ func CreatePin(c *fiber.Ctx) error {
))
}
pinResponse := map[string]interface{}{
"id": pin.ID,
"createdAt": pin.CreatedAt,
"updatedAt": pin.UpdatedAt,
formattedCreatedAt := utils.FormatDateToIndonesianFormat(pin.CreatedAt)
// formattedUpdatedAt := utils.FormatDateToIndonesianFormat(pin.UpdatedAt)
pinResponse := dto.PinResponse{
// ID: pin.ID,
CreatedAt: formattedCreatedAt,
// UpdatedAt: formattedUpdatedAt,
}
return c.Status(fiber.StatusOK).JSON(utils.FormatResponse(
@ -81,10 +84,17 @@ func GetPin(c *fiber.Ctx) error {
isPinValid := services.CheckPin(pin.Pin, input.Pin)
if isPinValid {
formattedCreatedAt := utils.FormatDateToIndonesianFormat(pin.CreatedAt)
formattedUpdatedAt := utils.FormatDateToIndonesianFormat(pin.UpdatedAt)
return c.Status(fiber.StatusOK).JSON(utils.FormatResponse(
fiber.StatusOK,
"PIN benar",
true,
map[string]interface{}{
"createdAt": formattedCreatedAt,
"updatedAt": formattedUpdatedAt,
},
))
}
@ -117,6 +127,15 @@ func UpdatePin(c *fiber.Ctx) error {
updatedPin, err := services.UpdatePin(userID, input.OldPin, input.NewPin)
if err != nil {
if err.Error() == "PIN lama salah" {
return c.Status(fiber.StatusUnauthorized).JSON(utils.FormatResponse(
fiber.StatusUnauthorized,
"PIN lama salah",
nil,
))
}
return c.Status(fiber.StatusInternalServerError).JSON(utils.FormatResponse(
fiber.StatusInternalServerError,
"Failed to update PIN",
@ -124,9 +143,14 @@ func UpdatePin(c *fiber.Ctx) error {
))
}
formattedUpdatedAt := utils.FormatDateToIndonesianFormat(updatedPin.UpdatedAt)
return c.Status(fiber.StatusOK).JSON(utils.FormatResponse(
fiber.StatusOK,
"PIN updated successfully",
updatedPin,
map[string]interface{}{
"id": updatedPin.ID,
"updatedAt": formattedUpdatedAt,
},
))
}

View File

@ -38,14 +38,13 @@ func CreatePin(userID string, input dto.PinInput) (domain.UserPin, error) {
}
func UpdatePin(userID string, oldPin string, newPin string) (domain.UserPin, error) {
pin, err := repositories.GetPinByUserID(userID)
if err != nil {
return pin, errors.New("PIN tidak ditemukan")
}
if err := bcrypt.CompareHashAndPassword([]byte(pin.Pin), []byte(oldPin)); err != nil {
return pin, errors.New("PIN lama tidak cocok")
return pin, errors.New("PIN lama salah")
}
updatedPin, err := repositories.UpdatePin(userID, newPin)