- 라우트 파라미터 충돌 수정 (Layer 4 확장) - TenantScope 글로벌 스코프가 테넌트 콘솔에서 올바른 tenant_id 사용하도록 수정 - 감사로그 상세 테넌트 콘솔 레이아웃 적용 - 테넌트 전환: 모달 → 컨텍스트 메뉴로 이동, 스타일 변경 (녹색+전환아이콘) - 테넌트 전환 이벤트를 openTenantConsole 호출로 통일 - 사이드바 스타일 메인과 통일 + 리포트 주의사항 정리
55 lines
2.1 KiB
PHP
55 lines
2.1 KiB
PHP
<?php
|
|
|
|
use Illuminate\Foundation\Application;
|
|
use Illuminate\Foundation\Configuration\Exceptions;
|
|
use Illuminate\Foundation\Configuration\Middleware;
|
|
use Illuminate\Http\Request;
|
|
|
|
return Application::configure(basePath: dirname(__DIR__))
|
|
->withRouting(
|
|
web: __DIR__.'/../routes/web.php',
|
|
api: __DIR__.'/../routes/api.php',
|
|
apiPrefix: 'api',
|
|
commands: __DIR__.'/../routes/console.php',
|
|
health: '/up',
|
|
)
|
|
->withMiddleware(function (Middleware $middleware): void {
|
|
// 미들웨어 별칭 등록
|
|
$middleware->alias([
|
|
'hq.member' => \App\Http\Middleware\EnsureHQMember::class,
|
|
'super.admin' => \App\Http\Middleware\EnsureSuperAdmin::class,
|
|
'password.changed' => \App\Http\Middleware\EnsurePasswordChanged::class,
|
|
'set.tenant.context' => \App\Http\Middleware\SetTenantContext::class,
|
|
]);
|
|
|
|
// CSRF 토큰 검증 예외 (외부 API 호출용)
|
|
$middleware->validateCsrfTokens(except: [
|
|
'menu-sync/*',
|
|
'common-code-sync/*',
|
|
'category-sync/*',
|
|
'esign/sign/*/api/*',
|
|
]);
|
|
|
|
// web 미들웨어 그룹에 자동 재인증 추가
|
|
$middleware->appendToGroup('web', [
|
|
\App\Http\Middleware\AutoLoginViaRemember::class,
|
|
\App\Http\Middleware\SetTenantFromApiRequest::class,
|
|
]);
|
|
})
|
|
->withExceptions(function (Exceptions $exceptions): void {
|
|
// HTMX/AJAX 요청 시 JSON 에러 응답 반환
|
|
$exceptions->render(function (Throwable $e, Request $request) {
|
|
if ($request->header('HX-Request') || $request->expectsJson() || $request->ajax()) {
|
|
$statusCode = method_exists($e, 'getStatusCode') ? $e->getStatusCode() : 500;
|
|
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => $e->getMessage() ?: '서버 오류가 발생했습니다.',
|
|
'exception' => config('app.debug') ? get_class($e) : null,
|
|
], $statusCode);
|
|
}
|
|
|
|
return null; // 기본 핸들러로 위임
|
|
});
|
|
})->create();
|