CustomerExpiringSessionPassQueryController.java

package com.deveagles.be15_deveagles_be.features.membership.query.controller;

import com.deveagles.be15_deveagles_be.common.dto.ApiResponse;
import com.deveagles.be15_deveagles_be.features.auth.command.application.model.CustomUser;
import com.deveagles.be15_deveagles_be.features.membership.query.dto.request.CustomerExpiringSessionPassFilterRequest;
import com.deveagles.be15_deveagles_be.features.membership.query.dto.response.CustomerExpiringSessionPassResult;
import com.deveagles.be15_deveagles_be.features.membership.query.service.CustomerExpiringSessionPassQueryService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.RequiredArgsConstructor;
import org.springframework.http.ResponseEntity;
import org.springframework.security.core.annotation.AuthenticationPrincipal;
import org.springframework.web.bind.annotation.*;

@Tag(name = "만료 예정 횟수권 조회", description = "만료 예정인 고객의 횟수권 정보 조회 API")
@RestController
@RequestMapping("/customer-expiring-session-passes")
@RequiredArgsConstructor
public class CustomerExpiringSessionPassQueryController {

  private final CustomerExpiringSessionPassQueryService customerExpiringSessionPassQueryService;

  @Operation(summary = "만료 예정 횟수권 조회", description = "조건(잔여 횟수, 만료일 등)에 따라 만료 예정 횟수권을 조회합니다.")
  @GetMapping
  public ResponseEntity<ApiResponse<CustomerExpiringSessionPassResult>> getExpiringSessionPasses(
      @AuthenticationPrincipal CustomUser user,
      @ModelAttribute CustomerExpiringSessionPassFilterRequest filter) {

    filter.setPage(Math.max(filter.getPage(), 1)); // 기본값 보장
    filter.setSize(Math.max(filter.getSize(), 10)); // 기본값 보장

    CustomerExpiringSessionPassResult result =
        customerExpiringSessionPassQueryService.getExpiringSessionPasses(user.getShopId(), filter);

    return ResponseEntity.ok(ApiResponse.success(result));
  }
}