Files
sam-api/app/Http/Controllers/Api/V1/SubscriptionController.php
hskwon a27b1b2091 feat: Phase 5.1-1 사용자 초대 + Phase 5.2 알림 설정 API 연동
- 사용자 초대 API: role 문자열 지원 추가 (React 호환)
- 알림 설정 API: 그룹 기반 계층 구조 구현
  - notification_setting_groups 테이블 추가
  - notification_setting_group_items 테이블 추가
  - notification_setting_group_states 테이블 추가
  - GET/PUT /api/v1/settings/notifications 엔드포인트 추가
- Pint 코드 스타일 정리
2025-12-22 17:42:59 +09:00

141 lines
3.5 KiB
PHP

<?php
namespace App\Http\Controllers\Api\V1;
use App\Helpers\ApiResponse;
use App\Http\Controllers\Controller;
use App\Http\Requests\V1\Subscription\ExportStoreRequest;
use App\Http\Requests\V1\Subscription\SubscriptionCancelRequest;
use App\Http\Requests\V1\Subscription\SubscriptionIndexRequest;
use App\Http\Requests\V1\Subscription\SubscriptionStoreRequest;
use App\Services\SubscriptionService;
use Illuminate\Http\JsonResponse;
class SubscriptionController extends Controller
{
public function __construct(
private readonly SubscriptionService $subscriptionService
) {}
/**
* 구독 목록
*/
public function index(SubscriptionIndexRequest $request): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->index($request->validated()),
__('message.fetched')
);
}
/**
* 현재 활성 구독
*/
public function current(): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->current(),
__('message.fetched')
);
}
/**
* 구독 등록
*/
public function store(SubscriptionStoreRequest $request): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->store($request->validated()),
__('message.created')
);
}
/**
* 구독 상세
*/
public function show(int $id): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->show($id),
__('message.fetched')
);
}
/**
* 구독 취소
*/
public function cancel(SubscriptionCancelRequest $request, int $id): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->cancel($id, $request->validated()['reason'] ?? null),
__('message.subscription.cancelled')
);
}
/**
* 구독 갱신
*/
public function renew(SubscriptionStoreRequest $request, int $id): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->renew($id, $request->validated()),
__('message.subscription.renewed')
);
}
/**
* 구독 일시정지
*/
public function suspend(int $id): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->suspend($id),
__('message.subscription.suspended')
);
}
/**
* 구독 재개
*/
public function resume(int $id): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->resume($id),
__('message.subscription.resumed')
);
}
/**
* 사용량 조회
*/
public function usage(): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->usage(),
__('message.fetched')
);
}
/**
* 내보내기 요청
*/
public function export(ExportStoreRequest $request): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->createExport($request->validated()),
__('message.export.requested')
);
}
/**
* 내보내기 상태 조회
*/
public function exportStatus(int $id): JsonResponse
{
return ApiResponse::handle(
fn () => $this->subscriptionService->getExport($id),
__('message.fetched')
);
}
}