From 048c48d754abce6a44b42e3f8af4a317bbbb1890 Mon Sep 17 00:00:00 2001 From: Klaus Date: Tue, 26 Aug 2025 13:57:02 +0900 Subject: [PATCH] =?UTF-8?q?fix(quota)!:=20AI=20=EC=B1=84=ED=8C=85=20?= =?UTF-8?q?=EC=BF=BC=ED=84=B0(=EB=AC=B4=EB=A3=8C/=EC=9C=A0=EB=A3=8C)=20?= =?UTF-8?q?=EA=B5=AC=EB=A7=A4=20Response=EB=A5=BC=20ChatQuotaStatusRespons?= =?UTF-8?q?e=EC=9C=BC=EB=A1=9C=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../sodalive/chat/quota/ChatQuotaController.kt | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/main/kotlin/kr/co/vividnext/sodalive/chat/quota/ChatQuotaController.kt b/src/main/kotlin/kr/co/vividnext/sodalive/chat/quota/ChatQuotaController.kt index b7fe447..c64992f 100644 --- a/src/main/kotlin/kr/co/vividnext/sodalive/chat/quota/ChatQuotaController.kt +++ b/src/main/kotlin/kr/co/vividnext/sodalive/chat/quota/ChatQuotaController.kt @@ -24,9 +24,7 @@ class ChatQuotaController( ) data class ChatQuotaPurchaseRequest( - val container: String, - val addPaid: Int = 50, - val needCan: Int = 30 + val container: String ) @GetMapping("/me") @@ -44,7 +42,7 @@ class ChatQuotaController( fun purchaseQuota( @AuthenticationPrincipal(expression = "#this == 'anonymousUser' ? null : member") member: Member?, @RequestBody request: ChatQuotaPurchaseRequest - ): ApiResponse = run { + ): ApiResponse = run { if (member == null) throw SodaException("로그인 정보를 확인해주세요.") if (member.auth == null) throw SodaException("본인인증을 하셔야 합니다.") if (request.container.isBlank()) throw SodaException("container를 확인해주세요.") @@ -52,14 +50,16 @@ class ChatQuotaController( // 30캔 차감 처리 (결제 기록 남김) canPaymentService.spendCan( memberId = member.id!!, - needCan = if (request.needCan > 0) request.needCan else 30, + needCan = 30, canUsage = CanUsage.CHAT_QUOTA_PURCHASE, container = request.container ) // 유료 횟수 적립 (기본 50) - val add = if (request.addPaid > 0) request.addPaid else 50 + val add = 50 chatQuotaService.purchase(member.id!!, add) - ApiResponse.ok(true) + + val s = chatQuotaService.getStatus(member.id!!) + ApiResponse.ok(ChatQuotaStatusResponse(s.totalRemaining, s.nextRechargeAtEpochMillis)) } }