feat: ClientApi.php Swagger 점검 및 개선 (Phase 3-3)
- ClientStoreRequest.php 생성 (검증 로직 분리) - ClientUpdateRequest.php 생성 (검증 로직 분리) - ClientController.php FormRequest 적용 및 패턴 통일 - lang/ko/message.php client 메시지 키 추가 - ApiResponse::handle 패턴 통일 (메시지 두 번째 인자) - SAM API Development Rules 준수 완료
This commit is contained in:
@@ -4,69 +4,55 @@
|
||||
|
||||
use App\Helpers\ApiResponse;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Requests\Client\ClientStoreRequest;
|
||||
use App\Http\Requests\Client\ClientUpdateRequest;
|
||||
use App\Services\ClientService;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class ClientController extends Controller
|
||||
{
|
||||
protected ClientService $service;
|
||||
|
||||
public function __construct(ClientService $service)
|
||||
{
|
||||
$this->service = $service;
|
||||
}
|
||||
public function __construct(private ClientService $service) {}
|
||||
|
||||
public function index(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
$data = $this->service->index($request->all());
|
||||
|
||||
return ['data' => $data, 'message' => __('message.fetched')];
|
||||
});
|
||||
return $this->service->index($request->all());
|
||||
}, __('message.client.fetched'));
|
||||
}
|
||||
|
||||
public function show(int $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
$data = $this->service->show($id);
|
||||
|
||||
return ['data' => $data, 'message' => __('message.fetched')];
|
||||
});
|
||||
return $this->service->show($id);
|
||||
}, __('message.client.fetched'));
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
public function store(ClientStoreRequest $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
$data = $this->service->store($request->all());
|
||||
|
||||
return ['data' => $data, 'message' => __('message.created')];
|
||||
});
|
||||
return $this->service->store($request->validated());
|
||||
}, __('message.client.created'));
|
||||
}
|
||||
|
||||
public function update(Request $request, int $id)
|
||||
public function update(ClientUpdateRequest $request, int $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request, $id) {
|
||||
$data = $this->service->update($id, $request->all());
|
||||
|
||||
return ['data' => $data, 'message' => __('message.updated')];
|
||||
});
|
||||
return $this->service->update($id, $request->validated());
|
||||
}, __('message.client.updated'));
|
||||
}
|
||||
|
||||
public function destroy(int $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
$this->service->destroy($id);
|
||||
|
||||
return ['data' => null, 'message' => __('message.deleted')];
|
||||
});
|
||||
return 'success';
|
||||
}, __('message.client.deleted'));
|
||||
}
|
||||
|
||||
public function toggle(int $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
$data = $this->service->toggle($id);
|
||||
|
||||
return ['data' => $data, 'message' => __('message.updated')];
|
||||
});
|
||||
return $this->service->toggle($id);
|
||||
}, __('message.client.toggled'));
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user