- 라우트 파라미터 충돌 수정 (Layer 4 확장) - TenantScope 글로벌 스코프가 테넌트 콘솔에서 올바른 tenant_id 사용하도록 수정 - 감사로그 상세 테넌트 콘솔 레이아웃 적용 - 테넌트 전환: 모달 → 컨텍스트 메뉴로 이동, 스타일 변경 (녹색+전환아이콘) - 테넌트 전환 이벤트를 openTenantConsole 호출로 통일 - 사이드바 스타일 메인과 통일 + 리포트 주의사항 정리
135 lines
3.7 KiB
PHP
135 lines
3.7 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\StorePermissionRequest;
|
|
use App\Http\Requests\UpdatePermissionRequest;
|
|
use App\Services\PermissionService;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
|
|
class PermissionController extends Controller
|
|
{
|
|
public function __construct(
|
|
private PermissionService $permissionService
|
|
) {}
|
|
|
|
/**
|
|
* 권한 목록 조회
|
|
*/
|
|
public function index(Request $request)
|
|
{
|
|
$permissions = $this->permissionService->getPermissions(
|
|
$request->all(),
|
|
$request->input('per_page', 20)
|
|
);
|
|
|
|
// HTMX 요청 시 부분 HTML 반환
|
|
if ($request->header('HX-Request')) {
|
|
$consoleTenantId = $request->get('tenant_console_id');
|
|
$isTenantConsole = ! empty($consoleTenantId);
|
|
|
|
if ($isTenantConsole) {
|
|
$request->attributes->set('tenant_console_id', $consoleTenantId);
|
|
}
|
|
|
|
return view('permissions.partials.table', compact('permissions', 'isTenantConsole', 'consoleTenantId'));
|
|
}
|
|
|
|
// 일반 요청 시 JSON 반환
|
|
return response()->json([
|
|
'success' => true,
|
|
'data' => $permissions->items(),
|
|
'meta' => [
|
|
'current_page' => $permissions->currentPage(),
|
|
'total' => $permissions->total(),
|
|
'per_page' => $permissions->perPage(),
|
|
'last_page' => $permissions->lastPage(),
|
|
],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 권한 생성
|
|
*/
|
|
public function store(StorePermissionRequest $request): JsonResponse
|
|
{
|
|
try {
|
|
$permission = $this->permissionService->createPermission($request->validated());
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '권한이 생성되었습니다.',
|
|
'data' => $permission,
|
|
], 201);
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => $e->getMessage(),
|
|
], 400);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 권한 상세 조회
|
|
*/
|
|
public function show(int $id): JsonResponse
|
|
{
|
|
$permission = $this->permissionService->getPermissionById($id);
|
|
|
|
if (! $permission) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '권한을 찾을 수 없습니다.',
|
|
], 404);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'data' => $permission,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 권한 수정
|
|
*/
|
|
public function update(UpdatePermissionRequest $request, int $id): JsonResponse
|
|
{
|
|
try {
|
|
$permission = $this->permissionService->updatePermission($id, $request->validated());
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '권한이 수정되었습니다.',
|
|
'data' => $permission,
|
|
]);
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => $e->getMessage(),
|
|
], 400);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 권한 삭제
|
|
*/
|
|
public function destroy(int $id): JsonResponse
|
|
{
|
|
try {
|
|
$this->permissionService->deletePermission($id);
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '권한이 삭제되었습니다.',
|
|
]);
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => $e->getMessage(),
|
|
], 400);
|
|
}
|
|
}
|
|
}
|