- 시스템 관리자 전용 웹페이지 구현 (system.html) - 깔끔한 흰색 배경의 올드스쿨 스타일 적용 - 반응형 그리드 레이아웃으로 카드 배치 개선 - ES6 모듈 방식으로 JavaScript 구조 개선 - 이벤트 리스너 방식으로 버튼 클릭 처리 변경 - 시스템 상태, 사용자 통계, 계정 관리 기능 구현 - 시스템 로그 조회 기능 추가 - 나머지 관리 기능들 스켈레톤 구현 (개발 중 상태) - 인코딩 문제 해결을 위한 영어 로그 메시지 적용 - hyungi 계정을 system 권한으로 설정 - JWT 토큰에 role 필드 추가 - 시스템 전용 API 엔드포인트 구현 주요 변경사항: - web-ui/pages/dashboard/system.html: 시스템 관리자 전용 페이지 - web-ui/css/system-dashboard.css: 시스템 대시보드 전용 스타일 - web-ui/js/system-dashboard.js: 시스템 대시보드 로직 - api.hyungi.net/controllers/systemController.js: 시스템 API 컨트롤러 - api.hyungi.net/routes/systemRoutes.js: 시스템 API 라우트 - api.hyungi.net/controllers/authController.js: 시스템 권한 로그인 처리 - api.hyungi.net/services/auth.service.js: JWT 토큰에 role 필드 추가
59 lines
1.7 KiB
Bash
59 lines
1.7 KiB
Bash
# .env
|
|
PORT=20005
|
|
|
|
# MariaDB 컨테이너 초기화용 루트 패스워드
|
|
DB_ROOT_PASSWORD=matxAc-jutty1-ruhsoc
|
|
|
|
# MariaDB 접속 정보
|
|
DB_HOST=db_hyungi_net
|
|
DB_PORT=3306
|
|
DB_USER=hyungi
|
|
DB_PASSWORD=tycdoq-Kawcug-8wesfa
|
|
DB_NAME=hyungi
|
|
|
|
# =====================================================
|
|
# JWT 설정 (보안 강화)
|
|
# =====================================================
|
|
JWT_SECRET=uHlUfU0nWEhkRFfOJSSr468lJzss9uC7
|
|
JWT_REFRESH_SECRET=kL9mN3pQ5rT7vX1zA3dF5hJ7kM9nP2qR4sV6wY8 # 새로 추가
|
|
JWT_EXPIRES_IN=15m
|
|
JWT_REFRESH_EXPIRES_IN=7d
|
|
|
|
# =====================================================
|
|
# 보안 설정
|
|
# =====================================================
|
|
# 비밀번호 해싱 라운드
|
|
BCRYPT_ROUNDS=10
|
|
|
|
# 로그인 실패 제한
|
|
MAX_LOGIN_ATTEMPTS=5
|
|
LOCK_TIME=15 # 분 단위
|
|
|
|
# =====================================================
|
|
# CORS 설정
|
|
# =====================================================
|
|
ALLOWED_ORIGINS=http://192.168.0.3:3001,http://192.168.0.3,http://192.168.0.3:3000,http://192.168.0.3:25000
|
|
|
|
# =====================================================
|
|
# API 속도 제한
|
|
# =====================================================
|
|
RATE_LIMIT_WINDOW=15 # 분 단위
|
|
RATE_LIMIT_MAX_REQUESTS=100
|
|
LOGIN_RATE_LIMIT_MAX_REQUESTS=5
|
|
|
|
# =====================================================
|
|
# 파일 업로드 설정
|
|
# =====================================================
|
|
MAX_FILE_SIZE=50 # MB 단위
|
|
UPLOAD_PATH=./uploads
|
|
|
|
# =====================================================
|
|
# 로깅 설정
|
|
# =====================================================
|
|
LOG_LEVEL=info
|
|
LOG_FILE_PATH=./logs
|
|
|
|
# =====================================================
|
|
# 환경 설정
|
|
# =====================================================
|
|
NODE_ENV=production |