feat:DB 트리거 기반 데이터 변경 추적 시스템 구현
Phase 1: DB 기반 구축 - trigger_audit_logs 테이블 (RANGE 파티셔닝 15개, 3개 인덱스) - 789개 MySQL AFTER 트리거 (263 테이블 × INSERT/UPDATE/DELETE) - SetAuditSessionVariables 미들웨어 (@sam_actor_id, @sam_session_info) Phase 2: 복구 메커니즘 - TriggerAuditLog 모델, TriggerAuditLogService, AuditRollbackService - 6개 API 엔드포인트 (index, show, stats, history, rollback-preview, rollback) - FormRequest 검증 (TriggerAuditLogIndexRequest, TriggerAuditRollbackRequest) Phase 3: 관리 도구 - v_unified_audit VIEW (APP + TRIGGER 통합, COLLATE 처리) - audit:partitions 커맨드 (파티션 추가/삭제, dry-run) - audit:triggers 커맨드 (트리거 재생성, 테이블별/전체) - 월 1회 파티션 자동 관리 스케줄러 등록 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -9,6 +9,7 @@
|
||||
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;
|
||||
@@ -28,8 +29,9 @@
|
||||
$middleware->append(ApiKeyMiddleware::class); // 2. API Key 검증
|
||||
$middleware->append(ApiVersionMiddleware::class); // 3. API 버전 해석 및 폴백
|
||||
|
||||
// API 미들웨어 그룹에 로깅 추가
|
||||
// API 미들웨어 그룹에 로깅 + 감사 세션변수 추가
|
||||
$middleware->appendToGroup('api', LogApiRequest::class);
|
||||
$middleware->appendToGroup('api', SetAuditSessionVariables::class);
|
||||
|
||||
$middleware->alias([
|
||||
'auth.apikey' => ApiKeyMiddleware::class, // 인증: apikey + basic auth (alias 유지)
|
||||
|
||||
Reference in New Issue
Block a user