From 94ade64cd14039ee1d1c013d0f32cbefbb9a9a3f Mon Sep 17 00:00:00 2001 From: CounterFire2023 <136581895+CounterFire2023@users.noreply.github.com> Date: Thu, 18 Apr 2024 21:57:39 +0800 Subject: [PATCH] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E8=BF=94=E5=9B=9E=E7=A4=BC?= =?UTF-8?q?=E5=93=81=E7=A0=81=E7=8A=B6=E6=80=81:=20=E5=B7=B2=E8=A2=AB?= =?UTF-8?q?=E4=BD=BF=E7=94=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/controllers/voucher.controller.ts | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/controllers/voucher.controller.ts b/src/controllers/voucher.controller.ts index 7df696e..b130374 100644 --- a/src/controllers/voucher.controller.ts +++ b/src/controllers/voucher.controller.ts @@ -97,10 +97,16 @@ class VoucherController extends BaseController { if (!id || !isValidVoucherCode(id)) { throw new ZError(10, 'invild voucher code') } - const record = await VoucherRecord.findOne({ code: id, status: VoucherStatusEnum.NORMAL }) + const record = await VoucherRecord.findOne({ code: id }) if (!record) { throw new ZError(11, 'voucher not found') } + if (record.status === VoucherStatusEnum.USED) { + throw new ZError(12, 'voucher already used') + } + if (record.status !== VoucherStatusEnum.NORMAL) { + throw new ZError(11, 'voucher not found') + } record.status = VoucherStatusEnum.USED record.user = user.id if (record.bonusScores.length > 0) {