// /js/auth-check.js // auth.js의 함수들을 직접 구현 (모듈 의존성 제거) function isLoggedIn() { const token = localStorage.getItem('token'); return token && token !== 'undefined' && token !== 'null'; } function getUser() { const user = localStorage.getItem('user'); return user ? JSON.parse(user) : null; } function clearAuthData() { localStorage.removeItem('token'); localStorage.removeItem('user'); } // 즉시 실행 함수로 스코프를 보호하고 로직을 실행 (function() { if (!isLoggedIn()) { console.log('🚨 인증되지 않은 사용자. 로그인 페이지로 이동합니다.'); clearAuthData(); // 만약을 위해 한번 더 정리 window.location.href = '/index.html'; return; // 이후 코드 실행 방지 } const currentUser = getUser(); // 사용자 정보가 유효한지 확인 (토큰은 있지만 유저 정보가 깨졌을 경우) if (!currentUser || !currentUser.username) { console.error('🚨 사용자 정보가 유효하지 않습니다. 강제 로그아웃 처리합니다.'); clearAuthData(); window.location.href = '/index.html'; return; } const userRole = currentUser.role || currentUser.access_level || '사용자'; console.log(`✅ ${currentUser.username}(${userRole})님 인증 성공.`); // 역할 기반 메뉴 제어 로직은 각 컴포넌트 로더(load-navbar.js 등)로 이전함. // 전역 변수 할당(window.currentUser) 제거. })();