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:
@@ -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')
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user