add update restrictions
This commit is contained in:
parent
5ff557c2c2
commit
db372231ff
@ -47,6 +47,10 @@ func (p *PromoCodeController) EditPromoCode(c *fiber.Ctx) error {
|
||||
return c.Status(fiber.StatusBadRequest).JSON(fiber.Map{"error": "Invalid request payload"})
|
||||
}
|
||||
|
||||
if reqEditPromoCode.ID == "" {
|
||||
return c.Status(fiber.StatusBadRequest).JSON(fiber.Map{"error": "promocode ID is required"})
|
||||
}
|
||||
|
||||
editedPromoCode, err := p.promoCodeService.EditPromoCode(c.Context(), &reqEditPromoCode)
|
||||
if err != nil {
|
||||
p.logger.Error("Failed to edit promocode", zap.Error(err))
|
||||
|
@ -31,12 +31,12 @@ type PromoCode struct {
|
||||
}
|
||||
|
||||
type ReqEditPromoCode struct {
|
||||
ID string `json:"id" bson:"_id"` //айдишник промокода, который обновляем
|
||||
Description string `json:"description" bson:"description"` // описание, необходимое менеджеру в админке
|
||||
Greetings string `json:"greetings" bson:"greetings"` // текст, выдаваемый пользователю в ответ на активацию промокода
|
||||
ID string `json:"id" bson:"_id"` //айдишник промокода, который обновляем
|
||||
Description *string `json:"description,omitempty" bson:"description"` // описание, необходимое менеджеру в админке
|
||||
Greetings *string `json:"greetings,omitempty" bson:"greetings"` // текст, выдаваемый пользователю в ответ на активацию промокода
|
||||
|
||||
DueTo int64 `json:"dueTo" bson:"dueTo"` // таймштамп времени окончания работы активации промокода
|
||||
ActivationCount int64 `json:"activationCount" bson:"activationCount"` // предел количества активаций промокода
|
||||
DueTo *int64 `json:"dueTo,omitempty" bson:"dueTo"` // таймштамп времени окончания работы активации промокода
|
||||
ActivationCount *int64 `json:"activationCount,omitempty" bson:"activationCount"` // предел количества активаций промокода
|
||||
|
||||
Delete bool `json:"delete" bson:"delete"`
|
||||
Delete *bool `json:"delete,omitempty" bson:"delete"`
|
||||
}
|
||||
|
@ -56,24 +56,35 @@ func (r *PromoCodeRepository) CreatePromoCode(ctx context.Context, promoCode *mo
|
||||
return promoCode, nil
|
||||
}
|
||||
|
||||
func (r *PromoCodeRepository) EditPromoCode(ctx context.Context, EditPromoCode *models.ReqEditPromoCode) (*models.PromoCode, error) {
|
||||
promoCodeID, err := primitive.ObjectIDFromHex(EditPromoCode.ID)
|
||||
func (r *PromoCodeRepository) EditPromoCode(ctx context.Context, editPromoCode *models.ReqEditPromoCode) (*models.PromoCode, error) {
|
||||
promoCodeID, err := primitive.ObjectIDFromHex(editPromoCode.ID)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
filter := bson.M{"_id": promoCodeID}
|
||||
update := bson.M{
|
||||
"$set": bson.M{
|
||||
"description": EditPromoCode.Description,
|
||||
"greetings": EditPromoCode.Greetings,
|
||||
"dueTo": EditPromoCode.DueTo,
|
||||
"activationCount": EditPromoCode.ActivationCount,
|
||||
"delete": EditPromoCode.Delete,
|
||||
},
|
||||
updateFields := bson.M{}
|
||||
if editPromoCode.Description != nil {
|
||||
updateFields["description"] = *editPromoCode.Description
|
||||
}
|
||||
if editPromoCode.Greetings != nil {
|
||||
updateFields["greetings"] = *editPromoCode.Greetings
|
||||
}
|
||||
if editPromoCode.DueTo != nil {
|
||||
updateFields["dueTo"] = *editPromoCode.DueTo
|
||||
}
|
||||
if editPromoCode.ActivationCount != nil {
|
||||
updateFields["activationCount"] = *editPromoCode.ActivationCount
|
||||
}
|
||||
if editPromoCode.Delete != nil {
|
||||
updateFields["delete"] = *editPromoCode.Delete
|
||||
}
|
||||
|
||||
result, err := r.mdb.UpdateOne(ctx, filter, update)
|
||||
if len(updateFields) == 0 {
|
||||
return r.GetPromoCodeByID(ctx, promoCodeID)
|
||||
}
|
||||
|
||||
update := bson.M{"$set": updateFields}
|
||||
result, err := r.mdb.UpdateOne(ctx, bson.M{"_id": promoCodeID}, update)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user