Files
sam-api/bootstrap/app.php
김보곤 1eb8d2cb01 feat: [demo] 데모 테넌트 운영 자동화 (Phase 2)
- DemoLimitMiddleware: 쇼케이스 읽기전용, 만료 체크, 외부연동 차단
- DemoTenantService: 파트너/체험 테넌트 생성, 기간 연장, 정식 전환
- ResetDemoShowcaseCommand: 매일 자정 데이터 리셋 + 샘플 재시드
- ManufacturingPresetSeeder: 부서/거래처/품목/견적/수주 샘플 데이터
- 스케줄러 등록 (00:00 demo:reset-showcase --seed)
- 미들웨어 별칭 등록 (demo.limit)
2026-03-14 14:41:55 +09:00

55 lines
2.4 KiB
PHP

<?php
use App\Exceptions\Handler;
use App\Http\Middleware\ApiKeyMiddleware;
use App\Http\Middleware\ApiRateLimiter;
use App\Http\Middleware\ApiVersionMiddleware;
use App\Http\Middleware\CheckPermission;
use App\Http\Middleware\CheckSwaggerAuth;
use App\Http\Middleware\CorsMiddleware;
use App\Http\Middleware\LogApiRequest;
use App\Http\Middleware\PermMapper;
use App\Http\Middleware\SetAuditSessionVariables;
use Illuminate\Contracts\Debug\ExceptionHandler;
use Illuminate\Foundation\Application;
use Illuminate\Foundation\Configuration\Exceptions;
use Illuminate\Foundation\Configuration\Middleware;
$app = Application::configure(basePath: dirname(__DIR__))
->withRouting(
web: __DIR__.'/../routes/web.php',
api: __DIR__.'/../routes/api.php',
commands: __DIR__.'/../routes/console.php',
health: '/up',
)
->withMiddleware(function (Middleware $middleware) {
// 글로벌 미들웨어 (모든 요청에 적용, 순서 중요)
$middleware->append(CorsMiddleware::class);
$middleware->append(ApiRateLimiter::class); // 1. Rate Limiting 먼저 체크
$middleware->append(ApiKeyMiddleware::class); // 2. API Key 검증
$middleware->append(ApiVersionMiddleware::class); // 3. API 버전 해석 및 폴백
// API 미들웨어 그룹에 로깅 + 감사 세션변수 추가
$middleware->appendToGroup('api', LogApiRequest::class);
$middleware->appendToGroup('api', SetAuditSessionVariables::class);
$middleware->alias([
'auth.apikey' => ApiKeyMiddleware::class, // 인증: apikey + basic auth (alias 유지)
'api.version' => ApiVersionMiddleware::class, // API 버전 해석 및 폴백
'swagger.auth' => CheckSwaggerAuth::class,
'perm.map' => PermMapper::class, // 전처리: 라우트명 → perm 키 생성/주입
'permission' => CheckPermission::class, // 검사: perm 키로 접근 허용/차단
'log.api' => LogApiRequest::class, // API 요청/응답 로깅 (선택적 사용용)
'demo.limit' => \App\Http\Middleware\DemoLimitMiddleware::class, // 데모 테넌트 제한
]);
})
->withExceptions(function (Exceptions $exceptions) {
// 이건 비워두세요
})
->create();
// 🔥 핵심: create() 이후에 반드시 등록
$app->singleton(ExceptionHandler::class, Handler::class);
return $app;