SessionPassQueryController.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.response.SessionPassResponse;
import com.deveagles.be15_deveagles_be.features.membership.query.service.SessionPassQueryService;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import java.util.List;
import lombok.RequiredArgsConstructor;
import org.springframework.http.ResponseEntity;
import org.springframework.security.core.annotation.AuthenticationPrincipal;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@Tag(name = "횟수권 조회", description = "횟수권 조회 API")
@RestController
@RequestMapping("/session-pass")
@RequiredArgsConstructor
public class SessionPassQueryController {

  private final SessionPassQueryService sessionPassQueryService;

  @Operation(summary = "횟수권 전체 조회", description = "등록된 모든 횟수권을 조회합니다.")
  @GetMapping
  public ResponseEntity<ApiResponse<List<SessionPassResponse>>> getSessionPasses(
      @AuthenticationPrincipal CustomUser user) {
    List<SessionPassResponse> result = sessionPassQueryService.getAllSessionPass(user.getShopId());
    return ResponseEntity.ok(ApiResponse.success(result));
  }
}