small fixes

This commit is contained in:
nquidox 2025-10-28 20:29:14 +03:00
parent 844561ef70
commit f7ec1bce1e
5 changed files with 40 additions and 32 deletions

View file

@ -2,7 +2,6 @@ package merch
import (
"context"
"errors"
"github.com/gin-gonic/gin"
log "github.com/sirupsen/logrus"
"merch-parser-api/internal/interfaces"
@ -45,8 +44,8 @@ func (h *Handler) RegisterRoutes(r *gin.RouterGroup, authMW gin.HandlerFunc, ref
imagesGroup.DELETE("/:uuid", h.controller.deleteMerchImage)
labelsGroup := merchGroup.Group("/labels")
labelsGroup.POST("/", h.controller.createLabel)
labelsGroup.GET("/", h.controller.getLabels)
labelsGroup.POST("", h.controller.createLabel)
labelsGroup.GET("", h.controller.getLabels)
labelsGroup.PUT("/:uuid", h.controller.updateLabel)
labelsGroup.DELETE("/:uuid", h.controller.deleteLabel)
labelsGroup.POST("/attach", h.controller.attachLabel)
@ -464,7 +463,7 @@ func (co *controller) createLabel(c *gin.Context) {
// @Description Получить все метки товаров
// @Tags Merch labels
// @Security BearerAuth
// @Success 200 {array} LabelDTO
// @Success 200 {array} LabelsList
// @Failure 400 {object} responses.ErrorResponse400
// @Failure 500 {object} responses.ErrorResponse500
// @Router /merch/labels [get]
@ -522,14 +521,7 @@ func (co *controller) updateLabel(c *gin.Context) {
return
}
if labelUuid != payload.LabelUuid {
err = errors.New("label uuid is different")
c.JSON(http.StatusBadRequest, responses.ErrorResponse400{Error: err.Error()})
log.WithError(err).Error(logMsg)
return
}
if err = co.service.updateLabel(userUuid, payload); err != nil {
if err = co.service.updateLabel(userUuid, labelUuid, payload); err != nil {
c.JSON(http.StatusInternalServerError, responses.ErrorResponse500{Error: err.Error()})
log.WithError(err).Error(logMsg)
return

View file

@ -60,10 +60,16 @@ type ImageLink struct {
}
type LabelDTO struct {
Name string `json:"name"`
Color string `json:"color,omitempty"`
BgColor string `json:"bg_color,omitempty"`
}
type LabelsList struct {
LabelUuid string `json:"label_uuid"`
Name string `json:"name"`
Color string `json:"color"`
BgColor string `json:"bg_color"`
Color string `json:"color,omitempty"`
BgColor string `json:"bg_color,omitempty"`
}
type LabelLink struct {

View file

@ -63,8 +63,16 @@ type Label struct {
BgColor string `json:"bg_color" gorm:"column:bg_color"`
}
func (Label) TableName() string {
return "labels"
}
type CardLabel struct {
LabelUuid string `json:"label_uuid"`
UserUuid string `json:"user_uuid"`
MerchUuid string `json:"merch_uuid"`
}
func (CardLabel) TableName() string {
return "card_labels"
}

View file

@ -43,7 +43,7 @@ type prices interface {
type labels interface {
createLabel(label Label) error
getLabels(userUuid string) ([]Label, error)
updateLabel(userUuid, labelUuid string, label map[string]string) error
updateLabel(userUuid, labelUuid string, label map[string]any) error
deleteLabel(userUuid, labelUuid string) error
attachLabel(label CardLabel) error
detachLabel(label CardLabel) error
@ -251,22 +251,24 @@ func (r *Repo) upsertOrigin(model any) error {
}
func (r *Repo) createLabel(label Label) error {
return r.db.Model(&Label{}).Create(label).Error
return r.db.Model(&Label{}).Create(&label).Error
}
func (r *Repo) getLabels(userUuid string) ([]Label, error) {
var labels []Label
var labelsList []Label
if err := r.db.
Model(&Label{}).
Where("user_uuid = ?", userUuid).
Where("deleted_at IS NULL").
Find(labels).Error; err != nil {
Find(&labelsList).Error; err != nil {
return nil, err
}
return labels, nil
return labelsList, nil
}
func (r *Repo) updateLabel(userUuid, labelUuid string, label map[string]string) error {
func (r *Repo) updateLabel(userUuid, labelUuid string, label map[string]any) error {
return r.db.Model(&Label{}).
Where("user_uuid =? AND label_uuid = ?", userUuid, labelUuid).
Updates(label).Error
@ -284,6 +286,6 @@ func (r *Repo) attachLabel(label CardLabel) error {
func (r *Repo) detachLabel(label CardLabel) error {
return r.db.
Where("userUuid = ? AND label_uuid = ? AND merch_uuid = ?", label.UserUuid, label.LabelUuid, label.MerchUuid).
Where("user_uuid = ? AND label_uuid = ? AND merch_uuid = ?", label.UserUuid, label.LabelUuid, label.MerchUuid).
Delete(&CardLabel{}).Error
}

View file

@ -504,15 +504,15 @@ func (s *service) createLabel(label LabelDTO, userUuid string) error {
return s.repo.createLabel(newLabel)
}
func (s *service) getLabels(userUuid string) ([]LabelDTO, error) {
func (s *service) getLabels(userUuid string) ([]LabelsList, error) {
stored, err := s.repo.getLabels(userUuid)
if err != nil {
return nil, err
}
response := make([]LabelDTO, 0, len(stored))
response := make([]LabelsList, 0, len(stored))
for _, label := range stored {
response = append(response, LabelDTO{
response = append(response, LabelsList{
LabelUuid: label.LabelUuid,
Name: label.Name,
Color: label.Color,
@ -522,8 +522,8 @@ func (s *service) getLabels(userUuid string) ([]LabelDTO, error) {
return response, nil
}
func (s *service) updateLabel(userUuid string, label LabelDTO) error {
updateMap := make(map[string]string, 3)
func (s *service) updateLabel(userUuid, labelUuid string, label LabelDTO) error {
updateMap := make(map[string]any, 3)
if label.Name != "" {
updateMap["name"] = label.Name
@ -537,7 +537,7 @@ func (s *service) updateLabel(userUuid string, label LabelDTO) error {
updateMap["bgcolor"] = label.BgColor
}
return s.repo.updateLabel(userUuid, label.LabelUuid, updateMap)
return s.repo.updateLabel(userUuid, labelUuid, updateMap)
}
func (s *service) deleteLabel(userUuid, labelUuid string) error {