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 코드 스타일 정리
This commit is contained in:
2025-12-22 17:42:59 +09:00
parent eeca8d3e0f
commit a27b1b2091
43 changed files with 2980 additions and 144 deletions

View File

@@ -2,12 +2,12 @@
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\Http\Response\ApiResponse;
use App\Services\SubscriptionService;
use Illuminate\Http\JsonResponse;
@@ -22,9 +22,10 @@ public function __construct(
*/
public function index(SubscriptionIndexRequest $request): JsonResponse
{
$result = $this->subscriptionService->index($request->validated());
return ApiResponse::handle('message.fetched', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->index($request->validated()),
__('message.fetched')
);
}
/**
@@ -32,9 +33,10 @@ public function index(SubscriptionIndexRequest $request): JsonResponse
*/
public function current(): JsonResponse
{
$result = $this->subscriptionService->current();
return ApiResponse::handle('message.fetched', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->current(),
__('message.fetched')
);
}
/**
@@ -42,9 +44,10 @@ public function current(): JsonResponse
*/
public function store(SubscriptionStoreRequest $request): JsonResponse
{
$result = $this->subscriptionService->store($request->validated());
return ApiResponse::handle('message.created', $result, 201);
return ApiResponse::handle(
fn () => $this->subscriptionService->store($request->validated()),
__('message.created')
);
}
/**
@@ -52,9 +55,10 @@ public function store(SubscriptionStoreRequest $request): JsonResponse
*/
public function show(int $id): JsonResponse
{
$result = $this->subscriptionService->show($id);
return ApiResponse::handle('message.fetched', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->show($id),
__('message.fetched')
);
}
/**
@@ -62,9 +66,10 @@ public function show(int $id): JsonResponse
*/
public function cancel(SubscriptionCancelRequest $request, int $id): JsonResponse
{
$result = $this->subscriptionService->cancel($id, $request->validated()['reason'] ?? null);
return ApiResponse::handle('message.subscription.cancelled', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->cancel($id, $request->validated()['reason'] ?? null),
__('message.subscription.cancelled')
);
}
/**
@@ -72,9 +77,10 @@ public function cancel(SubscriptionCancelRequest $request, int $id): JsonRespons
*/
public function renew(SubscriptionStoreRequest $request, int $id): JsonResponse
{
$result = $this->subscriptionService->renew($id, $request->validated());
return ApiResponse::handle('message.subscription.renewed', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->renew($id, $request->validated()),
__('message.subscription.renewed')
);
}
/**
@@ -82,9 +88,10 @@ public function renew(SubscriptionStoreRequest $request, int $id): JsonResponse
*/
public function suspend(int $id): JsonResponse
{
$result = $this->subscriptionService->suspend($id);
return ApiResponse::handle('message.subscription.suspended', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->suspend($id),
__('message.subscription.suspended')
);
}
/**
@@ -92,9 +99,10 @@ public function suspend(int $id): JsonResponse
*/
public function resume(int $id): JsonResponse
{
$result = $this->subscriptionService->resume($id);
return ApiResponse::handle('message.subscription.resumed', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->resume($id),
__('message.subscription.resumed')
);
}
/**
@@ -102,9 +110,10 @@ public function resume(int $id): JsonResponse
*/
public function usage(): JsonResponse
{
$result = $this->subscriptionService->usage();
return ApiResponse::handle('message.fetched', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->usage(),
__('message.fetched')
);
}
/**
@@ -112,9 +121,10 @@ public function usage(): JsonResponse
*/
public function export(ExportStoreRequest $request): JsonResponse
{
$result = $this->subscriptionService->createExport($request->validated());
return ApiResponse::handle('message.export.requested', $result, 201);
return ApiResponse::handle(
fn () => $this->subscriptionService->createExport($request->validated()),
__('message.export.requested')
);
}
/**
@@ -122,8 +132,9 @@ public function export(ExportStoreRequest $request): JsonResponse
*/
public function exportStatus(int $id): JsonResponse
{
$result = $this->subscriptionService->getExport($id);
return ApiResponse::handle('message.fetched', $result);
return ApiResponse::handle(
fn () => $this->subscriptionService->getExport($id),
__('message.fetched')
);
}
}