Security hardening release addressing CodeQL and Dependabot alerts: - Fix stack trace exposure in error responses - Add SSRF protection with DNS resolution checking - Implement proper URL hostname validation (replaces substring matching) - Add centralized path sanitization to prevent path traversal - Fix ReDoS vulnerability in email validation regex - Improve HTML sanitization in validation utilities - Fix capability wildcard matching in auth utilities - Update glob dependency to address CVE - Add CodeQL suppression comments for verified false positives 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
71 lines
2.1 KiB
JSON
71 lines
2.1 KiB
JSON
{
|
|
"name": "gt2-control-panel-frontend",
|
|
"version": "2.0.30",
|
|
"description": "GT 2.0 Control Panel Frontend",
|
|
"private": true,
|
|
"scripts": {
|
|
"dev": "next dev",
|
|
"build": "next build",
|
|
"start": "next start",
|
|
"lint": "next lint",
|
|
"typecheck": "tsc --noEmit",
|
|
"test": "jest --maxWorkers=2 --forceExit --detectOpenHandles",
|
|
"test:watch": "jest --watch --maxWorkers=1",
|
|
"test:coverage": "jest --coverage --maxWorkers=2 --forceExit"
|
|
},
|
|
"dependencies": {
|
|
"@hookform/resolvers": "^3.3.2",
|
|
"@radix-ui/react-alert-dialog": "^1.0.5",
|
|
"@radix-ui/react-avatar": "^1.0.4",
|
|
"@radix-ui/react-checkbox": "^1.0.4",
|
|
"@radix-ui/react-dialog": "^1.0.5",
|
|
"@radix-ui/react-dropdown-menu": "^2.0.6",
|
|
"@radix-ui/react-icons": "^1.3.0",
|
|
"@radix-ui/react-label": "^2.0.2",
|
|
"@radix-ui/react-navigation-menu": "^1.1.4",
|
|
"@radix-ui/react-progress": "^1.0.3",
|
|
"@radix-ui/react-select": "^2.0.0",
|
|
"@radix-ui/react-separator": "^1.1.7",
|
|
"@radix-ui/react-switch": "^1.0.3",
|
|
"@radix-ui/react-tabs": "^1.0.4",
|
|
"@radix-ui/react-toast": "^1.1.5",
|
|
"@tanstack/react-query": "^5.90.10",
|
|
"axios": "^1.13.2",
|
|
"class-variance-authority": "^0.7.1",
|
|
"clsx": "^2.0.0",
|
|
"date-fns": "^2.30.0",
|
|
"dotenv": "^17.2.1",
|
|
"lucide-react": "^0.294.0",
|
|
"next": "^14.2.34",
|
|
"react": "^18.2.0",
|
|
"react-dom": "^18.2.0",
|
|
"react-hook-form": "^7.48.2",
|
|
"react-hot-toast": "^2.4.1",
|
|
"recharts": "^2.8.0",
|
|
"tailwind-merge": "^2.1.0",
|
|
"tailwindcss-animate": "^1.0.7",
|
|
"zod": "^3.22.4",
|
|
"zustand": "^4.5.7"
|
|
},
|
|
"devDependencies": {
|
|
"@testing-library/jest-dom": "^6.1.5",
|
|
"@testing-library/react": "^14.1.2",
|
|
"@testing-library/user-event": "^14.5.1",
|
|
"@types/node": "20.19.25",
|
|
"@types/react": "^18.2.45",
|
|
"@types/react-dom": "^18.2.18",
|
|
"autoprefixer": "^10.4.16",
|
|
"eslint": "^8.57.0",
|
|
"eslint-config-next": "^14.2.34",
|
|
"jest": "^29.7.0",
|
|
"jest-environment-jsdom": "^29.7.0",
|
|
"msw": "^2.0.11",
|
|
"postcss": "^8.4.32",
|
|
"tailwindcss": "^3.3.6",
|
|
"typescript": "5.9.3"
|
|
},
|
|
"overrides": {
|
|
"glob": "^11.1.0"
|
|
}
|
|
}
|