2025-11-12 21:42:52 +01:00
{
"name" : "spotlightcam-backend" ,
"version" : "1.0.0" ,
"lockfileVersion" : 3 ,
"requires" : true ,
"packages" : {
"" : {
"name" : "spotlightcam-backend" ,
"version" : "1.0.0" ,
"license" : "ISC" ,
"dependencies" : {
2025-11-12 21:56:11 +01:00
"@prisma/client" : "^5.8.0" ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"bcryptjs" : "^2.4.3" ,
2025-11-12 21:42:52 +01:00
"cors" : "^2.8.5" ,
"dotenv" : "^16.3.1" ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"express" : "^4.18.2" ,
"express-validator" : "^7.3.0" ,
"jsonwebtoken" : "^9.0.2"
2025-11-12 21:42:52 +01:00
} ,
"devDependencies" : {
"jest" : "^29.7.0" ,
"nodemon" : "^3.0.2" ,
2025-11-12 21:56:11 +01:00
"prisma" : "^5.8.0" ,
2025-11-12 21:42:52 +01:00
"supertest" : "^6.3.3"
}
} ,
"node_modules/@babel/code-frame" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.27.1.tgz" ,
"integrity" : "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-validator-identifier" : "^7.27.1" ,
"js-tokens" : "^4.0.0" ,
"picocolors" : "^1.1.1"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/compat-data" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.28.5.tgz" ,
"integrity" : "sha512-6uFXyCayocRbqhZOB+6XcuZbkMNimwfVGFji8CTZnCzOHVGvDqzvitu1re2AU5LROliz7eQPhB8CpAMvnx9EjA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/core" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/core/-/core-7.28.5.tgz" ,
"integrity" : "sha512-e7jT4DxYvIDLk1ZHmU/m/mB19rex9sv0c2ftBtjSBv+kVM/902eh0fINUzD7UwLLNR+jU585GxUJ8/EBfAM5fw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/code-frame" : "^7.27.1" ,
"@babel/generator" : "^7.28.5" ,
"@babel/helper-compilation-targets" : "^7.27.2" ,
"@babel/helper-module-transforms" : "^7.28.3" ,
"@babel/helpers" : "^7.28.4" ,
"@babel/parser" : "^7.28.5" ,
"@babel/template" : "^7.27.2" ,
"@babel/traverse" : "^7.28.5" ,
"@babel/types" : "^7.28.5" ,
"@jridgewell/remapping" : "^2.3.5" ,
"convert-source-map" : "^2.0.0" ,
"debug" : "^4.1.0" ,
"gensync" : "^1.0.0-beta.2" ,
"json5" : "^2.2.3" ,
"semver" : "^6.3.1"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"funding" : {
"type" : "opencollective" ,
"url" : "https://opencollective.com/babel"
}
} ,
"node_modules/@babel/core/node_modules/debug" : {
"version" : "4.4.3" ,
"resolved" : "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz" ,
"integrity" : "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ms" : "^2.1.3"
} ,
"engines" : {
"node" : ">=6.0"
} ,
"peerDependenciesMeta" : {
"supports-color" : {
"optional" : true
}
}
} ,
"node_modules/@babel/core/node_modules/ms" : {
"version" : "2.1.3" ,
"resolved" : "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" ,
"integrity" : "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@babel/core/node_modules/semver" : {
"version" : "6.3.1" ,
"resolved" : "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz" ,
"integrity" : "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==" ,
"dev" : true ,
"license" : "ISC" ,
"bin" : {
"semver" : "bin/semver.js"
}
} ,
"node_modules/@babel/generator" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/generator/-/generator-7.28.5.tgz" ,
"integrity" : "sha512-3EwLFhZ38J4VyIP6WNtt2kUdW9dokXA9Cr4IVIFHuCpZ3H8/YFOl5JjZHisrn1fATPBmKKqXzDFvh9fUwHz6CQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/parser" : "^7.28.5" ,
"@babel/types" : "^7.28.5" ,
"@jridgewell/gen-mapping" : "^0.3.12" ,
"@jridgewell/trace-mapping" : "^0.3.28" ,
"jsesc" : "^3.0.2"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-compilation-targets" : {
"version" : "7.27.2" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.27.2.tgz" ,
"integrity" : "sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/compat-data" : "^7.27.2" ,
"@babel/helper-validator-option" : "^7.27.1" ,
"browserslist" : "^4.24.0" ,
"lru-cache" : "^5.1.1" ,
"semver" : "^6.3.1"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-compilation-targets/node_modules/semver" : {
"version" : "6.3.1" ,
"resolved" : "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz" ,
"integrity" : "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==" ,
"dev" : true ,
"license" : "ISC" ,
"bin" : {
"semver" : "bin/semver.js"
}
} ,
"node_modules/@babel/helper-globals" : {
"version" : "7.28.0" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz" ,
"integrity" : "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-module-imports" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.27.1.tgz" ,
"integrity" : "sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/traverse" : "^7.27.1" ,
"@babel/types" : "^7.27.1"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-module-transforms" : {
"version" : "7.28.3" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.3.tgz" ,
"integrity" : "sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-module-imports" : "^7.27.1" ,
"@babel/helper-validator-identifier" : "^7.27.1" ,
"@babel/traverse" : "^7.28.3"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0"
}
} ,
"node_modules/@babel/helper-plugin-utils" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.27.1.tgz" ,
"integrity" : "sha512-1gn1Up5YXka3YYAHGKpbideQ5Yjf1tDa9qYcgysz+cNCXukyLl6DjPXhD3VRwSb8c0J9tA4b2+rHEZtc6R0tlw==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-string-parser" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz" ,
"integrity" : "sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-validator-identifier" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.28.5.tgz" ,
"integrity" : "sha512-qSs4ifwzKJSV39ucNjsvc6WVHs6b7S03sOh2OcHF9UHfVPqWWALUsNUVzhSBiItjRZoLHx7nIarVjqKVusUZ1Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helper-validator-option" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.27.1.tgz" ,
"integrity" : "sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/helpers" : {
"version" : "7.28.4" ,
"resolved" : "https://registry.npmjs.org/@babel/helpers/-/helpers-7.28.4.tgz" ,
"integrity" : "sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/template" : "^7.27.2" ,
"@babel/types" : "^7.28.4"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/parser" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/parser/-/parser-7.28.5.tgz" ,
"integrity" : "sha512-KKBU1VGYR7ORr3At5HAtUQ+TV3SzRCXmA/8OdDZiLDBIZxVyzXuztPjfLd3BV1PRAQGCMWWSHYhL0F8d5uHBDQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/types" : "^7.28.5"
} ,
"bin" : {
"parser" : "bin/babel-parser.js"
} ,
"engines" : {
"node" : ">=6.0.0"
}
} ,
"node_modules/@babel/plugin-syntax-async-generators" : {
"version" : "7.8.4" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz" ,
"integrity" : "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-bigint" : {
"version" : "7.8.3" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz" ,
"integrity" : "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-class-properties" : {
"version" : "7.12.13" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz" ,
"integrity" : "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.12.13"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-class-static-block" : {
"version" : "7.14.5" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz" ,
"integrity" : "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.14.5"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-import-attributes" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.27.1.tgz" ,
"integrity" : "sha512-oFT0FrKHgF53f4vOsZGi2Hh3I35PfSmVs4IBFLFj4dnafP+hIWDLg3VyKmUHfLoLHlyxY4C7DGtmHuJgn+IGww==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.27.1"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-import-meta" : {
"version" : "7.10.4" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz" ,
"integrity" : "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.10.4"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-json-strings" : {
"version" : "7.8.3" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz" ,
"integrity" : "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-jsx" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.27.1.tgz" ,
"integrity" : "sha512-y8YTNIeKoyhGd9O0Jiyzyyqk8gdjnumGTQPsz0xOZOQ2RmkVJeZ1vmmfIvFEKqucBG6axJGBZDE/7iI5suUI/w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.27.1"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-logical-assignment-operators" : {
"version" : "7.10.4" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz" ,
"integrity" : "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.10.4"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-nullish-coalescing-operator" : {
"version" : "7.8.3" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz" ,
"integrity" : "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-numeric-separator" : {
"version" : "7.10.4" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz" ,
"integrity" : "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.10.4"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-object-rest-spread" : {
"version" : "7.8.3" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz" ,
"integrity" : "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-optional-catch-binding" : {
"version" : "7.8.3" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz" ,
"integrity" : "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-optional-chaining" : {
"version" : "7.8.3" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz" ,
"integrity" : "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.8.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-private-property-in-object" : {
"version" : "7.14.5" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz" ,
"integrity" : "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.14.5"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-top-level-await" : {
"version" : "7.14.5" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz" ,
"integrity" : "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.14.5"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/plugin-syntax-typescript" : {
"version" : "7.27.1" ,
"resolved" : "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.27.1.tgz" ,
"integrity" : "sha512-xfYCBMxveHrRMnAWl1ZlPXOZjzkN82THFvLhQhFXFt81Z5HnN+EtUkZhv/zcKpmT3fzmWZB0ywiBrbC3vogbwQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.27.1"
} ,
"engines" : {
"node" : ">=6.9.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0-0"
}
} ,
"node_modules/@babel/template" : {
"version" : "7.27.2" ,
"resolved" : "https://registry.npmjs.org/@babel/template/-/template-7.27.2.tgz" ,
"integrity" : "sha512-LPDZ85aEJyYSd18/DkjNh4/y1ntkE5KwUHWTiqgRxruuZL2F1yuHligVHLvcHY2vMHXttKFpJn6LwfI7cw7ODw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/code-frame" : "^7.27.1" ,
"@babel/parser" : "^7.27.2" ,
"@babel/types" : "^7.27.1"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/traverse" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/traverse/-/traverse-7.28.5.tgz" ,
"integrity" : "sha512-TCCj4t55U90khlYkVV/0TfkJkAkUg3jZFA3Neb7unZT8CPok7iiRfaX0F+WnqWqt7OxhOn0uBKXCw4lbL8W0aQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/code-frame" : "^7.27.1" ,
"@babel/generator" : "^7.28.5" ,
"@babel/helper-globals" : "^7.28.0" ,
"@babel/parser" : "^7.28.5" ,
"@babel/template" : "^7.27.2" ,
"@babel/types" : "^7.28.5" ,
"debug" : "^4.3.1"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@babel/traverse/node_modules/debug" : {
"version" : "4.4.3" ,
"resolved" : "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz" ,
"integrity" : "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ms" : "^2.1.3"
} ,
"engines" : {
"node" : ">=6.0"
} ,
"peerDependenciesMeta" : {
"supports-color" : {
"optional" : true
}
}
} ,
"node_modules/@babel/traverse/node_modules/ms" : {
"version" : "2.1.3" ,
"resolved" : "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" ,
"integrity" : "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@babel/types" : {
"version" : "7.28.5" ,
"resolved" : "https://registry.npmjs.org/@babel/types/-/types-7.28.5.tgz" ,
"integrity" : "sha512-qQ5m48eI/MFLQ5PxQj4PFaprjyCTLI37ElWMmNs0K8Lk3dVeOdNpB3ks8jc7yM5CDmVC73eMVk/trk3fgmrUpA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/helper-string-parser" : "^7.27.1" ,
"@babel/helper-validator-identifier" : "^7.28.5"
} ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/@bcoe/v8-coverage" : {
"version" : "0.2.3" ,
"resolved" : "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz" ,
"integrity" : "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@istanbuljs/load-nyc-config" : {
"version" : "1.1.0" ,
"resolved" : "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz" ,
"integrity" : "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"camelcase" : "^5.3.1" ,
"find-up" : "^4.1.0" ,
"get-package-type" : "^0.1.0" ,
"js-yaml" : "^3.13.1" ,
"resolve-from" : "^5.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/@istanbuljs/schema" : {
"version" : "0.1.3" ,
"resolved" : "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz" ,
"integrity" : "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/@jest/console" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/console/-/console-29.7.0.tgz" ,
"integrity" : "sha512-5Ni4CU7XHQi32IJ398EEP4RrB8eV09sXP2ROqD4bksHrnTree52PsxvX8tpL8LvTZ3pFzXyPbNQReSN41CAhOg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"chalk" : "^4.0.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"slash" : "^3.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/core" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/core/-/core-29.7.0.tgz" ,
"integrity" : "sha512-n7aeXWKMnGtDA48y8TLWJPJmLmmZ642Ceo78cYWEpiD7FzDgmNDV/GCVRorPABdXLJZ/9wzzgZAlHjXjxDHGsg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/console" : "^29.7.0" ,
"@jest/reporters" : "^29.7.0" ,
"@jest/test-result" : "^29.7.0" ,
"@jest/transform" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"ansi-escapes" : "^4.2.1" ,
"chalk" : "^4.0.0" ,
"ci-info" : "^3.2.0" ,
"exit" : "^0.1.2" ,
"graceful-fs" : "^4.2.9" ,
"jest-changed-files" : "^29.7.0" ,
"jest-config" : "^29.7.0" ,
"jest-haste-map" : "^29.7.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-regex-util" : "^29.6.3" ,
"jest-resolve" : "^29.7.0" ,
"jest-resolve-dependencies" : "^29.7.0" ,
"jest-runner" : "^29.7.0" ,
"jest-runtime" : "^29.7.0" ,
"jest-snapshot" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"jest-validate" : "^29.7.0" ,
"jest-watcher" : "^29.7.0" ,
"micromatch" : "^4.0.4" ,
"pretty-format" : "^29.7.0" ,
"slash" : "^3.0.0" ,
"strip-ansi" : "^6.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"node-notifier" : "^8.0.1 || ^9.0.0 || ^10.0.0"
} ,
"peerDependenciesMeta" : {
"node-notifier" : {
"optional" : true
}
}
} ,
"node_modules/@jest/environment" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/environment/-/environment-29.7.0.tgz" ,
"integrity" : "sha512-aQIfHDq33ExsN4jP1NWGXhxgQ/wixs60gDiKO+XVMd8Mn0NWPWgc34ZQDTb2jKaUWQ7MuwoitXAsN2XVXNMpAw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/fake-timers" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"jest-mock" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/expect" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz" ,
"integrity" : "sha512-8uMeAMycttpva3P1lBHB8VciS9V0XAr3GymPpipdyQXbBcuhkLQOSe8E/p92RyAdToS6ZD1tFkX+CkhoECE0dQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"expect" : "^29.7.0" ,
"jest-snapshot" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/expect-utils" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.7.0.tgz" ,
"integrity" : "sha512-GlsNBWiFQFCVi9QVSx7f5AgMeLxe9YCCs5PuP2O2LdjDAA8Jh9eX7lA1Jq/xdXw3Wb3hyvlFNfZIfcRetSzYcA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"jest-get-type" : "^29.6.3"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/fake-timers" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.7.0.tgz" ,
"integrity" : "sha512-q4DH1Ha4TTFPdxLsqDXK1d3+ioSL7yL5oCMJZgDYm6i+6CygW5E5xVr/D1HdsGxjt1ZWSfUAs9OxSB/BNelWrQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"@sinonjs/fake-timers" : "^10.0.2" ,
"@types/node" : "*" ,
"jest-message-util" : "^29.7.0" ,
"jest-mock" : "^29.7.0" ,
"jest-util" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/globals" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/globals/-/globals-29.7.0.tgz" ,
"integrity" : "sha512-mpiz3dutLbkW2MNFubUGUEVLkTGiqW6yLVTA+JbP6fI6J5iL9Y0Nlg8k95pcF8ctKwCS7WVxteBs29hhfAotzQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/environment" : "^29.7.0" ,
"@jest/expect" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"jest-mock" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/reporters" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz" ,
"integrity" : "sha512-DApq0KJbJOEzAFYjHADNNxAE3KbhxQB1y5Kplb5Waqw6zVbuWatSnMjE5gs8FUgEPmNsnZA3NCWl9NG0ia04Pg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@bcoe/v8-coverage" : "^0.2.3" ,
"@jest/console" : "^29.7.0" ,
"@jest/test-result" : "^29.7.0" ,
"@jest/transform" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@jridgewell/trace-mapping" : "^0.3.18" ,
"@types/node" : "*" ,
"chalk" : "^4.0.0" ,
"collect-v8-coverage" : "^1.0.0" ,
"exit" : "^0.1.2" ,
"glob" : "^7.1.3" ,
"graceful-fs" : "^4.2.9" ,
"istanbul-lib-coverage" : "^3.0.0" ,
"istanbul-lib-instrument" : "^6.0.0" ,
"istanbul-lib-report" : "^3.0.0" ,
"istanbul-lib-source-maps" : "^4.0.0" ,
"istanbul-reports" : "^3.1.3" ,
"jest-message-util" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"jest-worker" : "^29.7.0" ,
"slash" : "^3.0.0" ,
"string-length" : "^4.0.1" ,
"strip-ansi" : "^6.0.0" ,
"v8-to-istanbul" : "^9.0.1"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"node-notifier" : "^8.0.1 || ^9.0.0 || ^10.0.0"
} ,
"peerDependenciesMeta" : {
"node-notifier" : {
"optional" : true
}
}
} ,
"node_modules/@jest/schemas" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz" ,
"integrity" : "sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@sinclair/typebox" : "^0.27.8"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/source-map" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/@jest/source-map/-/source-map-29.6.3.tgz" ,
"integrity" : "sha512-MHjT95QuipcPrpLM+8JMSzFx6eHp5Bm+4XeFDJlwsvVBjmKNiIAvasGK2fxz2WbGRlnvqehFbh07MMa7n3YJnw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jridgewell/trace-mapping" : "^0.3.18" ,
"callsites" : "^3.0.0" ,
"graceful-fs" : "^4.2.9"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/test-result" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/test-result/-/test-result-29.7.0.tgz" ,
"integrity" : "sha512-Fdx+tv6x1zlkJPcWXmMDAG2HBnaR9XPSd5aDWQVsfrZmLVT3lU1cwyxLgRmXR9yrq4NBoEm9BMsfgFzTQAbJYA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/console" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/istanbul-lib-coverage" : "^2.0.0" ,
"collect-v8-coverage" : "^1.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/test-sequencer" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.7.0.tgz" ,
"integrity" : "sha512-GQwJ5WZVrKnOJuiYiAF52UNUJXgTZx1NHjFSEB0qEMmSZKAkdMoIzw/Cj6x6NF4AvV23AUqDpFzQkN/eYCYTxw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/test-result" : "^29.7.0" ,
"graceful-fs" : "^4.2.9" ,
"jest-haste-map" : "^29.7.0" ,
"slash" : "^3.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/transform" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/@jest/transform/-/transform-29.7.0.tgz" ,
"integrity" : "sha512-ok/BTPFzFKVMwO5eOHRrvnBVHdRy9IrsrW1GpMaQ9MCnilNLXQKmAX8s1YXDFaai9xJpac2ySzV0YeRRECr2Vw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/core" : "^7.11.6" ,
"@jest/types" : "^29.6.3" ,
"@jridgewell/trace-mapping" : "^0.3.18" ,
"babel-plugin-istanbul" : "^6.1.1" ,
"chalk" : "^4.0.0" ,
"convert-source-map" : "^2.0.0" ,
"fast-json-stable-stringify" : "^2.1.0" ,
"graceful-fs" : "^4.2.9" ,
"jest-haste-map" : "^29.7.0" ,
"jest-regex-util" : "^29.6.3" ,
"jest-util" : "^29.7.0" ,
"micromatch" : "^4.0.4" ,
"pirates" : "^4.0.4" ,
"slash" : "^3.0.0" ,
"write-file-atomic" : "^4.0.2"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jest/types" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/@jest/types/-/types-29.6.3.tgz" ,
"integrity" : "sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/schemas" : "^29.6.3" ,
"@types/istanbul-lib-coverage" : "^2.0.0" ,
"@types/istanbul-reports" : "^3.0.0" ,
"@types/node" : "*" ,
"@types/yargs" : "^17.0.8" ,
"chalk" : "^4.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/@jridgewell/gen-mapping" : {
"version" : "0.3.13" ,
"resolved" : "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz" ,
"integrity" : "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jridgewell/sourcemap-codec" : "^1.5.0" ,
"@jridgewell/trace-mapping" : "^0.3.24"
}
} ,
"node_modules/@jridgewell/remapping" : {
"version" : "2.3.5" ,
"resolved" : "https://registry.npmjs.org/@jridgewell/remapping/-/remapping-2.3.5.tgz" ,
"integrity" : "sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jridgewell/gen-mapping" : "^0.3.5" ,
"@jridgewell/trace-mapping" : "^0.3.24"
}
} ,
"node_modules/@jridgewell/resolve-uri" : {
"version" : "3.1.2" ,
"resolved" : "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz" ,
"integrity" : "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.0.0"
}
} ,
"node_modules/@jridgewell/sourcemap-codec" : {
"version" : "1.5.5" ,
"resolved" : "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz" ,
"integrity" : "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@jridgewell/trace-mapping" : {
"version" : "0.3.31" ,
"resolved" : "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz" ,
"integrity" : "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jridgewell/resolve-uri" : "^3.1.0" ,
"@jridgewell/sourcemap-codec" : "^1.4.14"
}
} ,
"node_modules/@noble/hashes" : {
"version" : "1.8.0" ,
"resolved" : "https://registry.npmjs.org/@noble/hashes/-/hashes-1.8.0.tgz" ,
"integrity" : "sha512-jCs9ldd7NwzpgXDIf6P3+NrHh9/sD6CQdxHyjQI+h/6rDNo88ypBxxz45UDuZHz9r3tNz7N/VInSVoVdtXEI4A==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : "^14.21.3 || >=16"
} ,
"funding" : {
"url" : "https://paulmillr.com/funding/"
}
} ,
"node_modules/@paralleldrive/cuid2" : {
"version" : "2.3.1" ,
"resolved" : "https://registry.npmjs.org/@paralleldrive/cuid2/-/cuid2-2.3.1.tgz" ,
"integrity" : "sha512-XO7cAxhnTZl0Yggq6jOgjiOHhbgcO4NqFqwSmQpjK3b6TEE6Uj/jfSk6wzYyemh3+I0sHirKSetjQwn5cZktFw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@noble/hashes" : "^1.1.5"
}
} ,
2025-11-12 21:56:11 +01:00
"node_modules/@prisma/client" : {
"version" : "5.22.0" ,
"resolved" : "https://registry.npmjs.org/@prisma/client/-/client-5.22.0.tgz" ,
"integrity" : "sha512-M0SVXfyHnQREBKxCgyo7sffrKttwE6R8PMq330MIUF0pTwjUhLbW84pFDlf06B27XyCR++VtjugEnIHdr07SVA==" ,
"hasInstallScript" : true ,
"license" : "Apache-2.0" ,
"engines" : {
"node" : ">=16.13"
} ,
"peerDependencies" : {
"prisma" : "*"
} ,
"peerDependenciesMeta" : {
"prisma" : {
"optional" : true
}
}
} ,
"node_modules/@prisma/debug" : {
"version" : "5.22.0" ,
"resolved" : "https://registry.npmjs.org/@prisma/debug/-/debug-5.22.0.tgz" ,
"integrity" : "sha512-AUt44v3YJeggO2ZU5BkXI7M4hu9BF2zzH2iF2V5pyXT/lRTyWiElZ7It+bRH1EshoMRxHgpYg4VB6rCM+mG5jQ==" ,
"devOptional" : true ,
"license" : "Apache-2.0"
} ,
"node_modules/@prisma/engines" : {
"version" : "5.22.0" ,
"resolved" : "https://registry.npmjs.org/@prisma/engines/-/engines-5.22.0.tgz" ,
"integrity" : "sha512-UNjfslWhAt06kVL3CjkuYpHAWSO6L4kDCVPegV6itt7nD1kSJavd3vhgAEhjglLJJKEdJ7oIqDJ+yHk6qO8gPA==" ,
"devOptional" : true ,
"hasInstallScript" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"@prisma/debug" : "5.22.0" ,
"@prisma/engines-version" : "5.22.0-44.605197351a3c8bdd595af2d2a9bc3025bca48ea2" ,
"@prisma/fetch-engine" : "5.22.0" ,
"@prisma/get-platform" : "5.22.0"
}
} ,
"node_modules/@prisma/engines-version" : {
"version" : "5.22.0-44.605197351a3c8bdd595af2d2a9bc3025bca48ea2" ,
"resolved" : "https://registry.npmjs.org/@prisma/engines-version/-/engines-version-5.22.0-44.605197351a3c8bdd595af2d2a9bc3025bca48ea2.tgz" ,
"integrity" : "sha512-2PTmxFR2yHW/eB3uqWtcgRcgAbG1rwG9ZriSvQw+nnb7c4uCr3RAcGMb6/zfE88SKlC1Nj2ziUvc96Z379mHgQ==" ,
"devOptional" : true ,
"license" : "Apache-2.0"
} ,
"node_modules/@prisma/fetch-engine" : {
"version" : "5.22.0" ,
"resolved" : "https://registry.npmjs.org/@prisma/fetch-engine/-/fetch-engine-5.22.0.tgz" ,
"integrity" : "sha512-bkrD/Mc2fSvkQBV5EpoFcZ87AvOgDxbG99488a5cexp5Ccny+UM6MAe/UFkUC0wLYD9+9befNOqGiIJhhq+HbA==" ,
"devOptional" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"@prisma/debug" : "5.22.0" ,
"@prisma/engines-version" : "5.22.0-44.605197351a3c8bdd595af2d2a9bc3025bca48ea2" ,
"@prisma/get-platform" : "5.22.0"
}
} ,
"node_modules/@prisma/get-platform" : {
"version" : "5.22.0" ,
"resolved" : "https://registry.npmjs.org/@prisma/get-platform/-/get-platform-5.22.0.tgz" ,
"integrity" : "sha512-pHhpQdr1UPFpt+zFfnPazhulaZYCUqeIcPpJViYoq9R+D/yw4fjE+CtnsnKzPYm0ddUbeXUzjGVGIRVgPDCk4Q==" ,
"devOptional" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"@prisma/debug" : "5.22.0"
}
} ,
2025-11-12 21:42:52 +01:00
"node_modules/@sinclair/typebox" : {
"version" : "0.27.8" ,
"resolved" : "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz" ,
"integrity" : "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@sinonjs/commons" : {
"version" : "3.0.1" ,
"resolved" : "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz" ,
"integrity" : "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"type-detect" : "4.0.8"
}
} ,
"node_modules/@sinonjs/fake-timers" : {
"version" : "10.3.0" ,
"resolved" : "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.3.0.tgz" ,
"integrity" : "sha512-V4BG07kuYSUkTCSBHG8G8TNhM+F19jXFWnQtzj+we8DrkpSBCee9Z3Ms8yiGer/dlmhe35/Xdgyo3/0rQKg7YA==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"@sinonjs/commons" : "^3.0.0"
}
} ,
"node_modules/@types/babel__core" : {
"version" : "7.20.5" ,
"resolved" : "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz" ,
"integrity" : "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/parser" : "^7.20.7" ,
"@babel/types" : "^7.20.7" ,
"@types/babel__generator" : "*" ,
"@types/babel__template" : "*" ,
"@types/babel__traverse" : "*"
}
} ,
"node_modules/@types/babel__generator" : {
"version" : "7.27.0" ,
"resolved" : "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.27.0.tgz" ,
"integrity" : "sha512-ufFd2Xi92OAVPYsy+P4n7/U7e68fex0+Ee8gSG9KX7eo084CWiQ4sdxktvdl0bOPupXtVJPY19zk6EwWqUQ8lg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/types" : "^7.0.0"
}
} ,
"node_modules/@types/babel__template" : {
"version" : "7.4.4" ,
"resolved" : "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz" ,
"integrity" : "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/parser" : "^7.1.0" ,
"@babel/types" : "^7.0.0"
}
} ,
"node_modules/@types/babel__traverse" : {
"version" : "7.28.0" ,
"resolved" : "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.28.0.tgz" ,
"integrity" : "sha512-8PvcXf70gTDZBgt9ptxJ8elBeBjcLOAcOtoO/mPJjtji1+CdGbHgm77om1GrsPxsiE+uXIpNSK64UYaIwQXd4Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/types" : "^7.28.2"
}
} ,
"node_modules/@types/graceful-fs" : {
"version" : "4.1.9" ,
"resolved" : "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.9.tgz" ,
"integrity" : "sha512-olP3sd1qOEe5dXTSaFvQG+02VdRXcdytWLAZsAq1PecU8uqQAhkrnbli7DagjtXKW/Bl7YJbUsa8MPcuc8LHEQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@types/node" : "*"
}
} ,
"node_modules/@types/istanbul-lib-coverage" : {
"version" : "2.0.6" ,
"resolved" : "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz" ,
"integrity" : "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@types/istanbul-lib-report" : {
"version" : "3.0.3" ,
"resolved" : "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.3.tgz" ,
"integrity" : "sha512-NQn7AHQnk/RSLOxrBbGyJM/aVQ+pjj5HCgasFxc0K/KhoATfQ/47AyUl15I2yBUpihjmas+a+VJBOqecrFH+uA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@types/istanbul-lib-coverage" : "*"
}
} ,
"node_modules/@types/istanbul-reports" : {
"version" : "3.0.4" ,
"resolved" : "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.4.tgz" ,
"integrity" : "sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@types/istanbul-lib-report" : "*"
}
} ,
"node_modules/@types/node" : {
"version" : "24.10.1" ,
"resolved" : "https://registry.npmjs.org/@types/node/-/node-24.10.1.tgz" ,
"integrity" : "sha512-GNWcUTRBgIRJD5zj+Tq0fKOJ5XZajIiBroOF0yvj2bSU1WvNdYS/dn9UxwsujGW4JX06dnHyjV2y9rRaybH0iQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"undici-types" : "~7.16.0"
}
} ,
"node_modules/@types/stack-utils" : {
"version" : "2.0.3" ,
"resolved" : "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.3.tgz" ,
"integrity" : "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/@types/yargs" : {
"version" : "17.0.34" ,
"resolved" : "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.34.tgz" ,
"integrity" : "sha512-KExbHVa92aJpw9WDQvzBaGVE2/Pz+pLZQloT2hjL8IqsZnV62rlPOYvNnLmf/L2dyllfVUOVBj64M0z/46eR2A==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@types/yargs-parser" : "*"
}
} ,
"node_modules/@types/yargs-parser" : {
"version" : "21.0.3" ,
"resolved" : "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz" ,
"integrity" : "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/accepts" : {
"version" : "1.3.8" ,
"license" : "MIT" ,
"dependencies" : {
"mime-types" : "~2.1.34" ,
"negotiator" : "0.6.3"
} ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/ansi-escapes" : {
"version" : "4.3.2" ,
"resolved" : "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz" ,
"integrity" : "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"type-fest" : "^0.21.3"
} ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/ansi-regex" : {
"version" : "5.0.1" ,
"resolved" : "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz" ,
"integrity" : "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/ansi-styles" : {
"version" : "4.3.0" ,
"resolved" : "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz" ,
"integrity" : "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"color-convert" : "^2.0.1"
} ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/chalk/ansi-styles?sponsor=1"
}
} ,
"node_modules/anymatch" : {
"version" : "3.1.3" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"normalize-path" : "^3.0.0" ,
"picomatch" : "^2.0.4"
} ,
"engines" : {
"node" : ">= 8"
}
} ,
"node_modules/argparse" : {
"version" : "1.0.10" ,
"resolved" : "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz" ,
"integrity" : "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"sprintf-js" : "~1.0.2"
}
} ,
"node_modules/array-flatten" : {
"version" : "1.1.1" ,
"license" : "MIT"
} ,
"node_modules/asap" : {
"version" : "2.0.6" ,
"resolved" : "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz" ,
"integrity" : "sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/asynckit" : {
"version" : "0.4.0" ,
"resolved" : "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz" ,
"integrity" : "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/babel-jest" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz" ,
"integrity" : "sha512-BrvGY3xZSwEcCzKvKsCi2GgHqDqsYkOP4/by5xCgIwGXQxIEh+8ew3gmrE1y7XRR6LHZIj6yLYnUi/mm2KXKBg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/transform" : "^29.7.0" ,
"@types/babel__core" : "^7.1.14" ,
"babel-plugin-istanbul" : "^6.1.1" ,
"babel-preset-jest" : "^29.6.3" ,
"chalk" : "^4.0.0" ,
"graceful-fs" : "^4.2.9" ,
"slash" : "^3.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.8.0"
}
} ,
"node_modules/babel-plugin-istanbul" : {
"version" : "6.1.1" ,
"resolved" : "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz" ,
"integrity" : "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"@babel/helper-plugin-utils" : "^7.0.0" ,
"@istanbuljs/load-nyc-config" : "^1.0.0" ,
"@istanbuljs/schema" : "^0.1.2" ,
"istanbul-lib-instrument" : "^5.0.4" ,
"test-exclude" : "^6.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/babel-plugin-istanbul/node_modules/istanbul-lib-instrument" : {
"version" : "5.2.1" ,
"resolved" : "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz" ,
"integrity" : "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"@babel/core" : "^7.12.3" ,
"@babel/parser" : "^7.14.7" ,
"@istanbuljs/schema" : "^0.1.2" ,
"istanbul-lib-coverage" : "^3.2.0" ,
"semver" : "^6.3.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/babel-plugin-istanbul/node_modules/semver" : {
"version" : "6.3.1" ,
"resolved" : "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz" ,
"integrity" : "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==" ,
"dev" : true ,
"license" : "ISC" ,
"bin" : {
"semver" : "bin/semver.js"
}
} ,
"node_modules/babel-plugin-jest-hoist" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.6.3.tgz" ,
"integrity" : "sha512-ESAc/RJvGTFEzRwOTT4+lNDk/GNHMkKbNzsvT0qKRfDyyYTskxB5rnU2njIDYVxXCBHHEI1c0YwHob3WaYujOg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/template" : "^7.3.3" ,
"@babel/types" : "^7.3.3" ,
"@types/babel__core" : "^7.1.14" ,
"@types/babel__traverse" : "^7.0.6"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/babel-preset-current-node-syntax" : {
"version" : "1.2.0" ,
"resolved" : "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.2.0.tgz" ,
"integrity" : "sha512-E/VlAEzRrsLEb2+dv8yp3bo4scof3l9nR4lrld+Iy5NyVqgVYUJnDAmunkhPMisRI32Qc4iRiz425d8vM++2fg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/plugin-syntax-async-generators" : "^7.8.4" ,
"@babel/plugin-syntax-bigint" : "^7.8.3" ,
"@babel/plugin-syntax-class-properties" : "^7.12.13" ,
"@babel/plugin-syntax-class-static-block" : "^7.14.5" ,
"@babel/plugin-syntax-import-attributes" : "^7.24.7" ,
"@babel/plugin-syntax-import-meta" : "^7.10.4" ,
"@babel/plugin-syntax-json-strings" : "^7.8.3" ,
"@babel/plugin-syntax-logical-assignment-operators" : "^7.10.4" ,
"@babel/plugin-syntax-nullish-coalescing-operator" : "^7.8.3" ,
"@babel/plugin-syntax-numeric-separator" : "^7.10.4" ,
"@babel/plugin-syntax-object-rest-spread" : "^7.8.3" ,
"@babel/plugin-syntax-optional-catch-binding" : "^7.8.3" ,
"@babel/plugin-syntax-optional-chaining" : "^7.8.3" ,
"@babel/plugin-syntax-private-property-in-object" : "^7.14.5" ,
"@babel/plugin-syntax-top-level-await" : "^7.14.5"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0 || ^8.0.0-0"
}
} ,
"node_modules/babel-preset-jest" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.6.3.tgz" ,
"integrity" : "sha512-0B3bhxR6snWXJZtR/RliHTDPRgn1sNHOR0yVtq/IiQFyuOVjFS+wuio/R4gSNkyYmKmJB4wGZv2NZanmKmTnNA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"babel-plugin-jest-hoist" : "^29.6.3" ,
"babel-preset-current-node-syntax" : "^1.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"@babel/core" : "^7.0.0"
}
} ,
"node_modules/balanced-match" : {
"version" : "1.0.2" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/baseline-browser-mapping" : {
"version" : "2.8.27" ,
"resolved" : "https://registry.npmjs.org/baseline-browser-mapping/-/baseline-browser-mapping-2.8.27.tgz" ,
"integrity" : "sha512-2CXFpkjVnY2FT+B6GrSYxzYf65BJWEqz5tIRHCvNsZZ2F3CmsCB37h8SpYgKG7y9C4YAeTipIPWG7EmFmhAeXA==" ,
"dev" : true ,
"license" : "Apache-2.0" ,
"bin" : {
"baseline-browser-mapping" : "dist/cli.js"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/bcryptjs" : {
"version" : "2.4.3" ,
"resolved" : "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz" ,
"integrity" : "sha512-V/Hy/X9Vt7f3BbPJEi8BdVFMByHi+jNXrYkW3huaybV/kQ0KJg0Y6PkEMbn+zeT+i+SiKZ/HMqJGIIt4LZDqNQ==" ,
"license" : "MIT"
} ,
2025-11-12 21:42:52 +01:00
"node_modules/binary-extensions" : {
"version" : "2.3.0" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/body-parser" : {
"version" : "1.20.3" ,
"license" : "MIT" ,
"dependencies" : {
"bytes" : "3.1.2" ,
"content-type" : "~1.0.5" ,
"debug" : "2.6.9" ,
"depd" : "2.0.0" ,
"destroy" : "1.2.0" ,
"http-errors" : "2.0.0" ,
"iconv-lite" : "0.4.24" ,
"on-finished" : "2.4.1" ,
"qs" : "6.13.0" ,
"raw-body" : "2.5.2" ,
"type-is" : "~1.6.18" ,
"unpipe" : "1.0.0"
} ,
"engines" : {
"node" : ">= 0.8" ,
"npm" : "1.2.8000 || >= 1.4.16"
}
} ,
"node_modules/brace-expansion" : {
"version" : "1.1.12" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"balanced-match" : "^1.0.0" ,
"concat-map" : "0.0.1"
}
} ,
"node_modules/braces" : {
"version" : "3.0.3" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"fill-range" : "^7.1.1"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/browserslist" : {
"version" : "4.28.0" ,
"resolved" : "https://registry.npmjs.org/browserslist/-/browserslist-4.28.0.tgz" ,
"integrity" : "sha512-tbydkR/CxfMwelN0vwdP/pLkDwyAASZ+VfWm4EOwlB6SWhx1sYnWLqo8N5j0rAzPfzfRaxt0mM/4wPU/Su84RQ==" ,
"dev" : true ,
"funding" : [
{
"type" : "opencollective" ,
"url" : "https://opencollective.com/browserslist"
} ,
{
"type" : "tidelift" ,
"url" : "https://tidelift.com/funding/github/npm/browserslist"
} ,
{
"type" : "github" ,
"url" : "https://github.com/sponsors/ai"
}
] ,
"license" : "MIT" ,
"dependencies" : {
"baseline-browser-mapping" : "^2.8.25" ,
"caniuse-lite" : "^1.0.30001754" ,
"electron-to-chromium" : "^1.5.249" ,
"node-releases" : "^2.0.27" ,
"update-browserslist-db" : "^1.1.4"
} ,
"bin" : {
"browserslist" : "cli.js"
} ,
"engines" : {
"node" : "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
}
} ,
"node_modules/bser" : {
"version" : "2.1.1" ,
"resolved" : "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz" ,
"integrity" : "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==" ,
"dev" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"node-int64" : "^0.4.0"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/buffer-equal-constant-time" : {
"version" : "1.0.1" ,
"resolved" : "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz" ,
"integrity" : "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" ,
"license" : "BSD-3-Clause"
} ,
2025-11-12 21:42:52 +01:00
"node_modules/buffer-from" : {
"version" : "1.1.2" ,
"resolved" : "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz" ,
"integrity" : "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/bytes" : {
"version" : "3.1.2" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/call-bind-apply-helpers" : {
"version" : "1.0.2" ,
"license" : "MIT" ,
"dependencies" : {
"es-errors" : "^1.3.0" ,
"function-bind" : "^1.1.2"
} ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/call-bound" : {
"version" : "1.0.4" ,
"license" : "MIT" ,
"dependencies" : {
"call-bind-apply-helpers" : "^1.0.2" ,
"get-intrinsic" : "^1.3.0"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/callsites" : {
"version" : "3.1.0" ,
"resolved" : "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz" ,
"integrity" : "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/camelcase" : {
"version" : "5.3.1" ,
"resolved" : "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz" ,
"integrity" : "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/caniuse-lite" : {
"version" : "1.0.30001754" ,
"resolved" : "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001754.tgz" ,
"integrity" : "sha512-x6OeBXueoAceOmotzx3PO4Zpt4rzpeIFsSr6AAePTZxSkXiYDUmpypEl7e2+8NCd9bD7bXjqyef8CJYPC1jfxg==" ,
"dev" : true ,
"funding" : [
{
"type" : "opencollective" ,
"url" : "https://opencollective.com/browserslist"
} ,
{
"type" : "tidelift" ,
"url" : "https://tidelift.com/funding/github/npm/caniuse-lite"
} ,
{
"type" : "github" ,
"url" : "https://github.com/sponsors/ai"
}
] ,
"license" : "CC-BY-4.0"
} ,
"node_modules/chalk" : {
"version" : "4.1.2" ,
"resolved" : "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" ,
"integrity" : "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ansi-styles" : "^4.1.0" ,
"supports-color" : "^7.1.0"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/chalk/chalk?sponsor=1"
}
} ,
"node_modules/chalk/node_modules/has-flag" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz" ,
"integrity" : "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/chalk/node_modules/supports-color" : {
"version" : "7.2.0" ,
"resolved" : "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz" ,
"integrity" : "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"has-flag" : "^4.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/char-regex" : {
"version" : "1.0.2" ,
"resolved" : "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz" ,
"integrity" : "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/chokidar" : {
"version" : "3.6.0" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"anymatch" : "~3.1.2" ,
"braces" : "~3.0.2" ,
"glob-parent" : "~5.1.2" ,
"is-binary-path" : "~2.1.0" ,
"is-glob" : "~4.0.1" ,
"normalize-path" : "~3.0.0" ,
"readdirp" : "~3.6.0"
} ,
"engines" : {
"node" : ">= 8.10.0"
} ,
"funding" : {
"url" : "https://paulmillr.com/funding/"
} ,
"optionalDependencies" : {
"fsevents" : "~2.3.2"
}
} ,
"node_modules/ci-info" : {
"version" : "3.9.0" ,
"resolved" : "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz" ,
"integrity" : "sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==" ,
"dev" : true ,
"funding" : [
{
"type" : "github" ,
"url" : "https://github.com/sponsors/sibiraj-s"
}
] ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/cjs-module-lexer" : {
"version" : "1.4.3" ,
"resolved" : "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.4.3.tgz" ,
"integrity" : "sha512-9z8TZaGM1pfswYeXrUpzPrkx8UnWYdhJclsiYMm6x/w5+nN+8Tf/LnAgfLGQCm59qAOxU8WwHEq2vNwF6i4j+Q==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/cliui" : {
"version" : "8.0.1" ,
"resolved" : "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz" ,
"integrity" : "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"string-width" : "^4.2.0" ,
"strip-ansi" : "^6.0.1" ,
"wrap-ansi" : "^7.0.0"
} ,
"engines" : {
"node" : ">=12"
}
} ,
"node_modules/co" : {
"version" : "4.6.0" ,
"resolved" : "https://registry.npmjs.org/co/-/co-4.6.0.tgz" ,
"integrity" : "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"iojs" : ">= 1.0.0" ,
"node" : ">= 0.12.0"
}
} ,
"node_modules/collect-v8-coverage" : {
"version" : "1.0.3" ,
"resolved" : "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.3.tgz" ,
"integrity" : "sha512-1L5aqIkwPfiodaMgQunkF1zRhNqifHBmtbbbxcr6yVxxBnliw4TDOW6NxpO8DJLgJ16OT+Y4ztZqP6p/FtXnAw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/color-convert" : {
"version" : "2.0.1" ,
"resolved" : "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz" ,
"integrity" : "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"color-name" : "~1.1.4"
} ,
"engines" : {
"node" : ">=7.0.0"
}
} ,
"node_modules/color-name" : {
"version" : "1.1.4" ,
"resolved" : "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" ,
"integrity" : "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/combined-stream" : {
"version" : "1.0.8" ,
"resolved" : "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz" ,
"integrity" : "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"delayed-stream" : "~1.0.0"
} ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/component-emitter" : {
"version" : "1.3.1" ,
"resolved" : "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.1.tgz" ,
"integrity" : "sha512-T0+barUSQRTUQASh8bx02dl+DhF54GtIDY13Y3m9oWTklKbb3Wv974meRpeZ3lp1JpLVECWWNHC4vaG2XHXouQ==" ,
"dev" : true ,
"license" : "MIT" ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/concat-map" : {
"version" : "0.0.1" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/content-disposition" : {
"version" : "0.5.4" ,
"license" : "MIT" ,
"dependencies" : {
"safe-buffer" : "5.2.1"
} ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/content-type" : {
"version" : "1.0.5" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/convert-source-map" : {
"version" : "2.0.0" ,
"resolved" : "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz" ,
"integrity" : "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/cookie" : {
"version" : "0.7.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/cookie-signature" : {
"version" : "1.0.6" ,
"license" : "MIT"
} ,
"node_modules/cookiejar" : {
"version" : "2.1.4" ,
"resolved" : "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.4.tgz" ,
"integrity" : "sha512-LDx6oHrK+PhzLKJU9j5S7/Y3jM/mUHvD/DeI1WQmJn652iPC5Y4TBzC9l+5OMOXlyTTA+SmVUPm0HQUwpD5Jqw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/cors" : {
"version" : "2.8.5" ,
"license" : "MIT" ,
"dependencies" : {
"object-assign" : "^4" ,
"vary" : "^1"
} ,
"engines" : {
"node" : ">= 0.10"
}
} ,
"node_modules/create-jest" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz" ,
"integrity" : "sha512-Adz2bdH0Vq3F53KEMJOoftQFutWCukm6J24wbPWRO4k1kMY7gS7ds/uoJkNuV8wDCtWWnuwGcJwpWcih+zEW1Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"chalk" : "^4.0.0" ,
"exit" : "^0.1.2" ,
"graceful-fs" : "^4.2.9" ,
"jest-config" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"prompts" : "^2.0.1"
} ,
"bin" : {
"create-jest" : "bin/create-jest.js"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/cross-spawn" : {
"version" : "7.0.6" ,
"resolved" : "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz" ,
"integrity" : "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"path-key" : "^3.1.0" ,
"shebang-command" : "^2.0.0" ,
"which" : "^2.0.1"
} ,
"engines" : {
"node" : ">= 8"
}
} ,
"node_modules/debug" : {
"version" : "2.6.9" ,
"license" : "MIT" ,
"dependencies" : {
"ms" : "2.0.0"
}
} ,
"node_modules/dedent" : {
"version" : "1.7.0" ,
"resolved" : "https://registry.npmjs.org/dedent/-/dedent-1.7.0.tgz" ,
"integrity" : "sha512-HGFtf8yhuhGhqO07SV79tRp+br4MnbdjeVxotpn1QBl30pcLLCQjX5b2295ll0fv8RKDKsmWYrl05usHM9CewQ==" ,
"dev" : true ,
"license" : "MIT" ,
"peerDependencies" : {
"babel-plugin-macros" : "^3.1.0"
} ,
"peerDependenciesMeta" : {
"babel-plugin-macros" : {
"optional" : true
}
}
} ,
"node_modules/deepmerge" : {
"version" : "4.3.1" ,
"resolved" : "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz" ,
"integrity" : "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/delayed-stream" : {
"version" : "1.0.0" ,
"resolved" : "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz" ,
"integrity" : "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.4.0"
}
} ,
"node_modules/depd" : {
"version" : "2.0.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/destroy" : {
"version" : "1.2.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8" ,
"npm" : "1.2.8000 || >= 1.4.16"
}
} ,
"node_modules/detect-newline" : {
"version" : "3.1.0" ,
"resolved" : "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz" ,
"integrity" : "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/dezalgo" : {
"version" : "1.0.4" ,
"resolved" : "https://registry.npmjs.org/dezalgo/-/dezalgo-1.0.4.tgz" ,
"integrity" : "sha512-rXSP0bf+5n0Qonsb+SVVfNfIsimO4HEtmnIpPHY8Q1UCzKlQrDMfdobr8nJOOsRgWCyMRqeSBQzmWUMq7zvVig==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"asap" : "^2.0.0" ,
"wrappy" : "1"
}
} ,
"node_modules/diff-sequences" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz" ,
"integrity" : "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/dotenv" : {
"version" : "16.6.1" ,
"license" : "BSD-2-Clause" ,
"engines" : {
"node" : ">=12"
} ,
"funding" : {
"url" : "https://dotenvx.com"
}
} ,
"node_modules/dunder-proto" : {
"version" : "1.0.1" ,
"license" : "MIT" ,
"dependencies" : {
"call-bind-apply-helpers" : "^1.0.1" ,
"es-errors" : "^1.3.0" ,
"gopd" : "^1.2.0"
} ,
"engines" : {
"node" : ">= 0.4"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/ecdsa-sig-formatter" : {
"version" : "1.0.11" ,
"resolved" : "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz" ,
"integrity" : "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==" ,
"license" : "Apache-2.0" ,
"dependencies" : {
"safe-buffer" : "^5.0.1"
}
} ,
2025-11-12 21:42:52 +01:00
"node_modules/ee-first" : {
"version" : "1.1.1" ,
"license" : "MIT"
} ,
"node_modules/electron-to-chromium" : {
"version" : "1.5.250" ,
"resolved" : "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.250.tgz" ,
"integrity" : "sha512-/5UMj9IiGDMOFBnN4i7/Ry5onJrAGSbOGo3s9FEKmwobGq6xw832ccET0CE3CkkMBZ8GJSlUIesZofpyurqDXw==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/emittery" : {
"version" : "0.13.1" ,
"resolved" : "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz" ,
"integrity" : "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=12"
} ,
"funding" : {
"url" : "https://github.com/sindresorhus/emittery?sponsor=1"
}
} ,
"node_modules/emoji-regex" : {
"version" : "8.0.0" ,
"resolved" : "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz" ,
"integrity" : "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/encodeurl" : {
"version" : "2.0.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/error-ex" : {
"version" : "1.3.4" ,
"resolved" : "https://registry.npmjs.org/error-ex/-/error-ex-1.3.4.tgz" ,
"integrity" : "sha512-sqQamAnR14VgCr1A618A3sGrygcpK+HEbenA/HiEAkkUwcZIIB/tgWqHFxWgOyDh4nB4JCRimh79dR5Ywc9MDQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"is-arrayish" : "^0.2.1"
}
} ,
"node_modules/es-define-property" : {
"version" : "1.0.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/es-errors" : {
"version" : "1.3.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/es-object-atoms" : {
"version" : "1.1.1" ,
"license" : "MIT" ,
"dependencies" : {
"es-errors" : "^1.3.0"
} ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/es-set-tostringtag" : {
"version" : "2.1.0" ,
"resolved" : "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.1.0.tgz" ,
"integrity" : "sha512-j6vWzfrGVfyXxge+O0x5sh6cvxAog0a/4Rdd2K36zCMV5eJ+/+tOAngRO8cODMNWbVRdVlmGZQL2YS3yR8bIUA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"es-errors" : "^1.3.0" ,
"get-intrinsic" : "^1.2.6" ,
"has-tostringtag" : "^1.0.2" ,
"hasown" : "^2.0.2"
} ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/escalade" : {
"version" : "3.2.0" ,
"resolved" : "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz" ,
"integrity" : "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/escape-html" : {
"version" : "1.0.3" ,
"license" : "MIT"
} ,
"node_modules/escape-string-regexp" : {
"version" : "2.0.0" ,
"resolved" : "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz" ,
"integrity" : "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/esprima" : {
"version" : "4.0.1" ,
"resolved" : "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz" ,
"integrity" : "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" ,
"dev" : true ,
"license" : "BSD-2-Clause" ,
"bin" : {
"esparse" : "bin/esparse.js" ,
"esvalidate" : "bin/esvalidate.js"
} ,
"engines" : {
"node" : ">=4"
}
} ,
"node_modules/etag" : {
"version" : "1.8.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/execa" : {
"version" : "5.1.1" ,
"resolved" : "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz" ,
"integrity" : "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"cross-spawn" : "^7.0.3" ,
"get-stream" : "^6.0.0" ,
"human-signals" : "^2.1.0" ,
"is-stream" : "^2.0.0" ,
"merge-stream" : "^2.0.0" ,
"npm-run-path" : "^4.0.1" ,
"onetime" : "^5.1.2" ,
"signal-exit" : "^3.0.3" ,
"strip-final-newline" : "^2.0.0"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sindresorhus/execa?sponsor=1"
}
} ,
"node_modules/exit" : {
"version" : "0.1.2" ,
"resolved" : "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz" ,
"integrity" : "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==" ,
"dev" : true ,
"engines" : {
"node" : ">= 0.8.0"
}
} ,
"node_modules/expect" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/expect/-/expect-29.7.0.tgz" ,
"integrity" : "sha512-2Zks0hf1VLFYI1kbh0I5jP3KHHyCHpkfyHBzsSXRFgl/Bg9mWYfMW8oD+PdMPlEwy5HNsR9JutYy6pMeOh61nw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/expect-utils" : "^29.7.0" ,
"jest-get-type" : "^29.6.3" ,
"jest-matcher-utils" : "^29.7.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-util" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/express" : {
"version" : "4.21.2" ,
"license" : "MIT" ,
"dependencies" : {
"accepts" : "~1.3.8" ,
"array-flatten" : "1.1.1" ,
"body-parser" : "1.20.3" ,
"content-disposition" : "0.5.4" ,
"content-type" : "~1.0.4" ,
"cookie" : "0.7.1" ,
"cookie-signature" : "1.0.6" ,
"debug" : "2.6.9" ,
"depd" : "2.0.0" ,
"encodeurl" : "~2.0.0" ,
"escape-html" : "~1.0.3" ,
"etag" : "~1.8.1" ,
"finalhandler" : "1.3.1" ,
"fresh" : "0.5.2" ,
"http-errors" : "2.0.0" ,
"merge-descriptors" : "1.0.3" ,
"methods" : "~1.1.2" ,
"on-finished" : "2.4.1" ,
"parseurl" : "~1.3.3" ,
"path-to-regexp" : "0.1.12" ,
"proxy-addr" : "~2.0.7" ,
"qs" : "6.13.0" ,
"range-parser" : "~1.2.1" ,
"safe-buffer" : "5.2.1" ,
"send" : "0.19.0" ,
"serve-static" : "1.16.2" ,
"setprototypeof" : "1.2.0" ,
"statuses" : "2.0.1" ,
"type-is" : "~1.6.18" ,
"utils-merge" : "1.0.1" ,
"vary" : "~1.1.2"
} ,
"engines" : {
"node" : ">= 0.10.0"
} ,
"funding" : {
"type" : "opencollective" ,
"url" : "https://opencollective.com/express"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/express-validator" : {
"version" : "7.3.0" ,
"resolved" : "https://registry.npmjs.org/express-validator/-/express-validator-7.3.0.tgz" ,
"integrity" : "sha512-ujK2BX5JUun5NR4JuBo83YSXoDDIpoGz3QxgHTzQcHFevkKnwV1in4K7YNuuXQ1W3a2ObXB/P4OTnTZpUyGWiw==" ,
"license" : "MIT" ,
"dependencies" : {
"lodash" : "^4.17.21" ,
"validator" : "~13.15.15"
} ,
"engines" : {
"node" : ">= 8.0.0"
}
} ,
2025-11-12 21:42:52 +01:00
"node_modules/fast-json-stable-stringify" : {
"version" : "2.1.0" ,
"resolved" : "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz" ,
"integrity" : "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/fast-safe-stringify" : {
"version" : "2.1.1" ,
"resolved" : "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz" ,
"integrity" : "sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/fb-watchman" : {
"version" : "2.0.2" ,
"resolved" : "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz" ,
"integrity" : "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==" ,
"dev" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"bser" : "2.1.1"
}
} ,
"node_modules/fill-range" : {
"version" : "7.1.1" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"to-regex-range" : "^5.0.1"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/finalhandler" : {
"version" : "1.3.1" ,
"license" : "MIT" ,
"dependencies" : {
"debug" : "2.6.9" ,
"encodeurl" : "~2.0.0" ,
"escape-html" : "~1.0.3" ,
"on-finished" : "2.4.1" ,
"parseurl" : "~1.3.3" ,
"statuses" : "2.0.1" ,
"unpipe" : "~1.0.0"
} ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/find-up" : {
"version" : "4.1.0" ,
"resolved" : "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz" ,
"integrity" : "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"locate-path" : "^5.0.0" ,
"path-exists" : "^4.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/form-data" : {
"version" : "4.0.4" ,
"resolved" : "https://registry.npmjs.org/form-data/-/form-data-4.0.4.tgz" ,
"integrity" : "sha512-KrGhL9Q4zjj0kiUt5OO4Mr/A/jlI2jDYs5eHBpYHPcBEVSiipAvn2Ko2HnPe20rmcuuvMHNdZFp+4IlGTMF0Ow==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"asynckit" : "^0.4.0" ,
"combined-stream" : "^1.0.8" ,
"es-set-tostringtag" : "^2.1.0" ,
"hasown" : "^2.0.2" ,
"mime-types" : "^2.1.12"
} ,
"engines" : {
"node" : ">= 6"
}
} ,
"node_modules/formidable" : {
"version" : "2.1.5" ,
"resolved" : "https://registry.npmjs.org/formidable/-/formidable-2.1.5.tgz" ,
"integrity" : "sha512-Oz5Hwvwak/DCaXVVUtPn4oLMLLy1CdclLKO1LFgU7XzDpVMUU5UjlSLpGMocyQNNk8F6IJW9M/YdooSn2MRI+Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@paralleldrive/cuid2" : "^2.2.2" ,
"dezalgo" : "^1.0.4" ,
"once" : "^1.4.0" ,
"qs" : "^6.11.0"
} ,
"funding" : {
"url" : "https://ko-fi.com/tunnckoCore/commissions"
}
} ,
"node_modules/forwarded" : {
"version" : "0.2.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/fresh" : {
"version" : "0.5.2" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/fs.realpath" : {
"version" : "1.0.0" ,
"resolved" : "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz" ,
"integrity" : "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/fsevents" : {
"version" : "2.3.3" ,
"resolved" : "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz" ,
"integrity" : "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==" ,
"dev" : true ,
"hasInstallScript" : true ,
"license" : "MIT" ,
"optional" : true ,
"os" : [
"darwin"
] ,
"engines" : {
"node" : "^8.16.0 || ^10.6.0 || >=11.0.0"
}
} ,
"node_modules/function-bind" : {
"version" : "1.1.2" ,
"license" : "MIT" ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/gensync" : {
"version" : "1.0.0-beta.2" ,
"resolved" : "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz" ,
"integrity" : "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6.9.0"
}
} ,
"node_modules/get-caller-file" : {
"version" : "2.0.5" ,
"resolved" : "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz" ,
"integrity" : "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" ,
"dev" : true ,
"license" : "ISC" ,
"engines" : {
"node" : "6.* || 8.* || >= 10.*"
}
} ,
"node_modules/get-intrinsic" : {
"version" : "1.3.0" ,
"license" : "MIT" ,
"dependencies" : {
"call-bind-apply-helpers" : "^1.0.2" ,
"es-define-property" : "^1.0.1" ,
"es-errors" : "^1.3.0" ,
"es-object-atoms" : "^1.1.1" ,
"function-bind" : "^1.1.2" ,
"get-proto" : "^1.0.1" ,
"gopd" : "^1.2.0" ,
"has-symbols" : "^1.1.0" ,
"hasown" : "^2.0.2" ,
"math-intrinsics" : "^1.1.0"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/get-package-type" : {
"version" : "0.1.0" ,
"resolved" : "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz" ,
"integrity" : "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8.0.0"
}
} ,
"node_modules/get-proto" : {
"version" : "1.0.1" ,
"license" : "MIT" ,
"dependencies" : {
"dunder-proto" : "^1.0.1" ,
"es-object-atoms" : "^1.0.0"
} ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/get-stream" : {
"version" : "6.0.1" ,
"resolved" : "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz" ,
"integrity" : "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/glob" : {
"version" : "7.2.3" ,
"resolved" : "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz" ,
"integrity" : "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==" ,
"deprecated" : "Glob versions prior to v9 are no longer supported" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"fs.realpath" : "^1.0.0" ,
"inflight" : "^1.0.4" ,
"inherits" : "2" ,
"minimatch" : "^3.1.1" ,
"once" : "^1.3.0" ,
"path-is-absolute" : "^1.0.0"
} ,
"engines" : {
"node" : "*"
} ,
"funding" : {
"url" : "https://github.com/sponsors/isaacs"
}
} ,
"node_modules/glob-parent" : {
"version" : "5.1.2" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"is-glob" : "^4.0.1"
} ,
"engines" : {
"node" : ">= 6"
}
} ,
"node_modules/gopd" : {
"version" : "1.2.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/graceful-fs" : {
"version" : "4.2.11" ,
"resolved" : "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz" ,
"integrity" : "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/has-flag" : {
"version" : "3.0.0" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=4"
}
} ,
"node_modules/has-symbols" : {
"version" : "1.1.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/has-tostringtag" : {
"version" : "1.0.2" ,
"resolved" : "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz" ,
"integrity" : "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"has-symbols" : "^1.0.3"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/hasown" : {
"version" : "2.0.2" ,
"license" : "MIT" ,
"dependencies" : {
"function-bind" : "^1.1.2"
} ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/html-escaper" : {
"version" : "2.0.2" ,
"resolved" : "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz" ,
"integrity" : "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/http-errors" : {
"version" : "2.0.0" ,
"license" : "MIT" ,
"dependencies" : {
"depd" : "2.0.0" ,
"inherits" : "2.0.4" ,
"setprototypeof" : "1.2.0" ,
"statuses" : "2.0.1" ,
"toidentifier" : "1.0.1"
} ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/human-signals" : {
"version" : "2.1.0" ,
"resolved" : "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz" ,
"integrity" : "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==" ,
"dev" : true ,
"license" : "Apache-2.0" ,
"engines" : {
"node" : ">=10.17.0"
}
} ,
"node_modules/iconv-lite" : {
"version" : "0.4.24" ,
"license" : "MIT" ,
"dependencies" : {
"safer-buffer" : ">= 2.1.2 < 3"
} ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/ignore-by-default" : {
"version" : "1.0.1" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/import-local" : {
"version" : "3.2.0" ,
"resolved" : "https://registry.npmjs.org/import-local/-/import-local-3.2.0.tgz" ,
"integrity" : "sha512-2SPlun1JUPWoM6t3F0dw0FkCF/jWY8kttcY4f599GLTSjh2OCuuhdTkJQsEcZzBqbXZGKMK2OqW1oZsjtf/gQA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"pkg-dir" : "^4.2.0" ,
"resolve-cwd" : "^3.0.0"
} ,
"bin" : {
"import-local-fixture" : "fixtures/cli.js"
} ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/imurmurhash" : {
"version" : "0.1.4" ,
"resolved" : "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz" ,
"integrity" : "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.8.19"
}
} ,
"node_modules/inflight" : {
"version" : "1.0.6" ,
"resolved" : "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz" ,
"integrity" : "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==" ,
"deprecated" : "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful." ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"once" : "^1.3.0" ,
"wrappy" : "1"
}
} ,
"node_modules/inherits" : {
"version" : "2.0.4" ,
"license" : "ISC"
} ,
"node_modules/ipaddr.js" : {
"version" : "1.9.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.10"
}
} ,
"node_modules/is-arrayish" : {
"version" : "0.2.1" ,
"resolved" : "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz" ,
"integrity" : "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/is-binary-path" : {
"version" : "2.1.0" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"binary-extensions" : "^2.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/is-core-module" : {
"version" : "2.16.1" ,
"resolved" : "https://registry.npmjs.org/is-core-module/-/is-core-module-2.16.1.tgz" ,
"integrity" : "sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"hasown" : "^2.0.2"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/is-extglob" : {
"version" : "2.1.1" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/is-fullwidth-code-point" : {
"version" : "3.0.0" ,
"resolved" : "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz" ,
"integrity" : "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/is-generator-fn" : {
"version" : "2.1.0" ,
"resolved" : "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz" ,
"integrity" : "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/is-glob" : {
"version" : "4.0.3" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"is-extglob" : "^2.1.1"
} ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/is-number" : {
"version" : "7.0.0" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.12.0"
}
} ,
"node_modules/is-stream" : {
"version" : "2.0.1" ,
"resolved" : "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz" ,
"integrity" : "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/isexe" : {
"version" : "2.0.0" ,
"resolved" : "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz" ,
"integrity" : "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/istanbul-lib-coverage" : {
"version" : "3.2.2" ,
"resolved" : "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz" ,
"integrity" : "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/istanbul-lib-instrument" : {
"version" : "6.0.3" ,
"resolved" : "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.3.tgz" ,
"integrity" : "sha512-Vtgk7L/R2JHyyGW07spoFlB8/lpjiOLTjMdms6AFMraYt3BaJauod/NGrfnVG/y4Ix1JEuMRPDPEj2ua+zz1/Q==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"@babel/core" : "^7.23.9" ,
"@babel/parser" : "^7.23.9" ,
"@istanbuljs/schema" : "^0.1.3" ,
"istanbul-lib-coverage" : "^3.2.0" ,
"semver" : "^7.5.4"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/istanbul-lib-report" : {
"version" : "3.0.1" ,
"resolved" : "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz" ,
"integrity" : "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"istanbul-lib-coverage" : "^3.0.0" ,
"make-dir" : "^4.0.0" ,
"supports-color" : "^7.1.0"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/istanbul-lib-report/node_modules/has-flag" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz" ,
"integrity" : "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/istanbul-lib-report/node_modules/supports-color" : {
"version" : "7.2.0" ,
"resolved" : "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz" ,
"integrity" : "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"has-flag" : "^4.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/istanbul-lib-source-maps" : {
"version" : "4.0.1" ,
"resolved" : "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz" ,
"integrity" : "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"debug" : "^4.1.1" ,
"istanbul-lib-coverage" : "^3.0.0" ,
"source-map" : "^0.6.1"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/istanbul-lib-source-maps/node_modules/debug" : {
"version" : "4.4.3" ,
"resolved" : "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz" ,
"integrity" : "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ms" : "^2.1.3"
} ,
"engines" : {
"node" : ">=6.0"
} ,
"peerDependenciesMeta" : {
"supports-color" : {
"optional" : true
}
}
} ,
"node_modules/istanbul-lib-source-maps/node_modules/ms" : {
"version" : "2.1.3" ,
"resolved" : "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" ,
"integrity" : "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/istanbul-reports" : {
"version" : "3.2.0" ,
"resolved" : "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.2.0.tgz" ,
"integrity" : "sha512-HGYWWS/ehqTV3xN10i23tkPkpH46MLCIMFNCaaKNavAXTF1RkqxawEPtnjnGZ6XKSInBKkiOA5BKS+aZiY3AvA==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"html-escaper" : "^2.0.0" ,
"istanbul-lib-report" : "^3.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/jest" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz" ,
"integrity" : "sha512-NIy3oAFp9shda19hy4HK0HRTWKtPJmGdnvywu01nOqNC2vZg+Z+fvJDxpMQA88eb2I9EcafcdjYgsDthnYTvGw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/core" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"import-local" : "^3.0.2" ,
"jest-cli" : "^29.7.0"
} ,
"bin" : {
"jest" : "bin/jest.js"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"node-notifier" : "^8.0.1 || ^9.0.0 || ^10.0.0"
} ,
"peerDependenciesMeta" : {
"node-notifier" : {
"optional" : true
}
}
} ,
"node_modules/jest-changed-files" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz" ,
"integrity" : "sha512-fEArFiwf1BpQ+4bXSprcDc3/x4HSzL4al2tozwVpDFpsxALjLYdyiIK4e5Vz66GQJIbXJ82+35PtysofptNX2w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"execa" : "^5.0.0" ,
"jest-util" : "^29.7.0" ,
"p-limit" : "^3.1.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-circus" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-circus/-/jest-circus-29.7.0.tgz" ,
"integrity" : "sha512-3E1nCMgipcTkCocFwM90XXQab9bS+GMsjdpmPrlelaxwD93Ad8iVEjX/vvHPdLPnFf+L40u+5+iutRdA1N9myw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/environment" : "^29.7.0" ,
"@jest/expect" : "^29.7.0" ,
"@jest/test-result" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"chalk" : "^4.0.0" ,
"co" : "^4.6.0" ,
"dedent" : "^1.0.0" ,
"is-generator-fn" : "^2.0.0" ,
"jest-each" : "^29.7.0" ,
"jest-matcher-utils" : "^29.7.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-runtime" : "^29.7.0" ,
"jest-snapshot" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"p-limit" : "^3.1.0" ,
"pretty-format" : "^29.7.0" ,
"pure-rand" : "^6.0.0" ,
"slash" : "^3.0.0" ,
"stack-utils" : "^2.0.3"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-cli" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-cli/-/jest-cli-29.7.0.tgz" ,
"integrity" : "sha512-OVVobw2IubN/GSYsxETi+gOe7Ka59EFMR/twOU3Jb2GnKKeMGJB5SGUUrEz3SFVmJASUdZUzy83sLNNQ2gZslg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/core" : "^29.7.0" ,
"@jest/test-result" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"chalk" : "^4.0.0" ,
"create-jest" : "^29.7.0" ,
"exit" : "^0.1.2" ,
"import-local" : "^3.0.2" ,
"jest-config" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"jest-validate" : "^29.7.0" ,
"yargs" : "^17.3.1"
} ,
"bin" : {
"jest" : "bin/jest.js"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"node-notifier" : "^8.0.1 || ^9.0.0 || ^10.0.0"
} ,
"peerDependenciesMeta" : {
"node-notifier" : {
"optional" : true
}
}
} ,
"node_modules/jest-config" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-config/-/jest-config-29.7.0.tgz" ,
"integrity" : "sha512-uXbpfeQ7R6TZBqI3/TxCU4q4ttk3u0PJeC+E0zbfSoSjq6bJ7buBPxzQPL0ifrkY4DNu4JUdk0ImlBUYi840eQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/core" : "^7.11.6" ,
"@jest/test-sequencer" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"babel-jest" : "^29.7.0" ,
"chalk" : "^4.0.0" ,
"ci-info" : "^3.2.0" ,
"deepmerge" : "^4.2.2" ,
"glob" : "^7.1.3" ,
"graceful-fs" : "^4.2.9" ,
"jest-circus" : "^29.7.0" ,
"jest-environment-node" : "^29.7.0" ,
"jest-get-type" : "^29.6.3" ,
"jest-regex-util" : "^29.6.3" ,
"jest-resolve" : "^29.7.0" ,
"jest-runner" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"jest-validate" : "^29.7.0" ,
"micromatch" : "^4.0.4" ,
"parse-json" : "^5.2.0" ,
"pretty-format" : "^29.7.0" ,
"slash" : "^3.0.0" ,
"strip-json-comments" : "^3.1.1"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"peerDependencies" : {
"@types/node" : "*" ,
"ts-node" : ">=9.0.0"
} ,
"peerDependenciesMeta" : {
"@types/node" : {
"optional" : true
} ,
"ts-node" : {
"optional" : true
}
}
} ,
"node_modules/jest-diff" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-diff/-/jest-diff-29.7.0.tgz" ,
"integrity" : "sha512-LMIgiIrhigmPrs03JHpxUh2yISK3vLFPkAodPeo0+BuF7wA2FoQbkEg1u8gBYBThncu7e1oEDUfIXVuTqLRUjw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"chalk" : "^4.0.0" ,
"diff-sequences" : "^29.6.3" ,
"jest-get-type" : "^29.6.3" ,
"pretty-format" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-docblock" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz" ,
"integrity" : "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"detect-newline" : "^3.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-each" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-each/-/jest-each-29.7.0.tgz" ,
"integrity" : "sha512-gns+Er14+ZrEoC5fhOfYCY1LOHHr0TI+rQUHZS8Ttw2l7gl+80eHc/gFf2Ktkw0+SIACDTeWvpFcv3B04VembQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"chalk" : "^4.0.0" ,
"jest-get-type" : "^29.6.3" ,
"jest-util" : "^29.7.0" ,
"pretty-format" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-environment-node" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.7.0.tgz" ,
"integrity" : "sha512-DOSwCRqXirTOyheM+4d5YZOrWcdu0LNZ87ewUoywbcb2XR4wKgqiG8vNeYwhjFMbEkfju7wx2GYH0P2gevGvFw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/environment" : "^29.7.0" ,
"@jest/fake-timers" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"jest-mock" : "^29.7.0" ,
"jest-util" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-get-type" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.6.3.tgz" ,
"integrity" : "sha512-zrteXnqYxfQh7l5FHyL38jL39di8H8rHoecLH3JNxH3BwOrBsNeabdap5e0I23lD4HHI8W5VFBZqG4Eaq5LNcw==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-haste-map" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.7.0.tgz" ,
"integrity" : "sha512-fP8u2pyfqx0K1rGn1R9pyE0/KTn+G7PxktWidOBTqFPLYX0b9ksaMFkhK5vrS3DVun09pckLdlx90QthlW7AmA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"@types/graceful-fs" : "^4.1.3" ,
"@types/node" : "*" ,
"anymatch" : "^3.0.3" ,
"fb-watchman" : "^2.0.0" ,
"graceful-fs" : "^4.2.9" ,
"jest-regex-util" : "^29.6.3" ,
"jest-util" : "^29.7.0" ,
"jest-worker" : "^29.7.0" ,
"micromatch" : "^4.0.4" ,
"walker" : "^1.0.8"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
} ,
"optionalDependencies" : {
"fsevents" : "^2.3.2"
}
} ,
"node_modules/jest-leak-detector" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.7.0.tgz" ,
"integrity" : "sha512-kYA8IJcSYtST2BY9I+SMC32nDpBT3J2NvWJx8+JCuCdl/CR1I4EKUJROiP8XtCcxqgTTBGJNdbB1A8XRKbTetw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"jest-get-type" : "^29.6.3" ,
"pretty-format" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-matcher-utils" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.7.0.tgz" ,
"integrity" : "sha512-sBkD+Xi9DtcChsI3L3u0+N0opgPYnCRPtGcQYrgXmR+hmt/fYfWAL0xRXYU8eWOdfuLgBe0YCW3AFtnRLagq/g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"chalk" : "^4.0.0" ,
"jest-diff" : "^29.7.0" ,
"jest-get-type" : "^29.6.3" ,
"pretty-format" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-message-util" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.7.0.tgz" ,
"integrity" : "sha512-GBEV4GRADeP+qtB2+6u61stea8mGcOT4mCtrYISZwfu9/ISHFJ/5zOMXYbpBE9RsS5+Gb63DW4FgmnKJ79Kf6w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/code-frame" : "^7.12.13" ,
"@jest/types" : "^29.6.3" ,
"@types/stack-utils" : "^2.0.0" ,
"chalk" : "^4.0.0" ,
"graceful-fs" : "^4.2.9" ,
"micromatch" : "^4.0.4" ,
"pretty-format" : "^29.7.0" ,
"slash" : "^3.0.0" ,
"stack-utils" : "^2.0.3"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-mock" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-mock/-/jest-mock-29.7.0.tgz" ,
"integrity" : "sha512-ITOMZn+UkYS4ZFh83xYAOzWStloNzJFO2s8DWrE4lhtGD+AorgnbkiKERe4wQVBydIGPx059g6riW5Btp6Llnw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"jest-util" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-pnp-resolver" : {
"version" : "1.2.3" ,
"resolved" : "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz" ,
"integrity" : "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
} ,
"peerDependencies" : {
"jest-resolve" : "*"
} ,
"peerDependenciesMeta" : {
"jest-resolve" : {
"optional" : true
}
}
} ,
"node_modules/jest-regex-util" : {
"version" : "29.6.3" ,
"resolved" : "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.6.3.tgz" ,
"integrity" : "sha512-KJJBsRCyyLNWCNBOvZyRDnAIfUiRJ8v+hOBQYGn8gDyF3UegwiP4gwRR3/SDa42g1YbVycTidUF3rKjyLFDWbg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-resolve" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.7.0.tgz" ,
"integrity" : "sha512-IOVhZSrg+UvVAshDSDtHyFCCBUl/Q3AAJv8iZ6ZjnZ74xzvwuzLXid9IIIPgTnY62SJjfuupMKZsZQRsCvxEgA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"chalk" : "^4.0.0" ,
"graceful-fs" : "^4.2.9" ,
"jest-haste-map" : "^29.7.0" ,
"jest-pnp-resolver" : "^1.2.2" ,
"jest-util" : "^29.7.0" ,
"jest-validate" : "^29.7.0" ,
"resolve" : "^1.20.0" ,
"resolve.exports" : "^2.0.0" ,
"slash" : "^3.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-resolve-dependencies" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.7.0.tgz" ,
"integrity" : "sha512-un0zD/6qxJ+S0et7WxeI3H5XSe9lTBBR7bOHCHXkKR6luG5mwDDlIzVQ0V5cZCuoTgEdcdwzTghYkTWfubi+nA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"jest-regex-util" : "^29.6.3" ,
"jest-snapshot" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-runner" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-runner/-/jest-runner-29.7.0.tgz" ,
"integrity" : "sha512-fsc4N6cPCAahybGBfTRcq5wFR6fpLznMg47sY5aDpsoejOcVYFb07AHuSnR0liMcPTgBsA3ZJL6kFOjPdoNipQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/console" : "^29.7.0" ,
"@jest/environment" : "^29.7.0" ,
"@jest/test-result" : "^29.7.0" ,
"@jest/transform" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"chalk" : "^4.0.0" ,
"emittery" : "^0.13.1" ,
"graceful-fs" : "^4.2.9" ,
"jest-docblock" : "^29.7.0" ,
"jest-environment-node" : "^29.7.0" ,
"jest-haste-map" : "^29.7.0" ,
"jest-leak-detector" : "^29.7.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-resolve" : "^29.7.0" ,
"jest-runtime" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"jest-watcher" : "^29.7.0" ,
"jest-worker" : "^29.7.0" ,
"p-limit" : "^3.1.0" ,
"source-map-support" : "0.5.13"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-runtime" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.7.0.tgz" ,
"integrity" : "sha512-gUnLjgwdGqW7B4LvOIkbKs9WGbn+QLqRQQ9juC6HndeDiezIwhDP+mhMwHWCEcfQ5RUXa6OPnFF8BJh5xegwwQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/environment" : "^29.7.0" ,
"@jest/fake-timers" : "^29.7.0" ,
"@jest/globals" : "^29.7.0" ,
"@jest/source-map" : "^29.6.3" ,
"@jest/test-result" : "^29.7.0" ,
"@jest/transform" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"chalk" : "^4.0.0" ,
"cjs-module-lexer" : "^1.0.0" ,
"collect-v8-coverage" : "^1.0.0" ,
"glob" : "^7.1.3" ,
"graceful-fs" : "^4.2.9" ,
"jest-haste-map" : "^29.7.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-mock" : "^29.7.0" ,
"jest-regex-util" : "^29.6.3" ,
"jest-resolve" : "^29.7.0" ,
"jest-snapshot" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"slash" : "^3.0.0" ,
"strip-bom" : "^4.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-snapshot" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.7.0.tgz" ,
"integrity" : "sha512-Rm0BMWtxBcioHr1/OX5YCP8Uov4riHvKPknOGs804Zg9JGZgmIBkbtlxJC/7Z4msKYVbIJtfU+tKb8xlYNfdkw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/core" : "^7.11.6" ,
"@babel/generator" : "^7.7.2" ,
"@babel/plugin-syntax-jsx" : "^7.7.2" ,
"@babel/plugin-syntax-typescript" : "^7.7.2" ,
"@babel/types" : "^7.3.3" ,
"@jest/expect-utils" : "^29.7.0" ,
"@jest/transform" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"babel-preset-current-node-syntax" : "^1.0.0" ,
"chalk" : "^4.0.0" ,
"expect" : "^29.7.0" ,
"graceful-fs" : "^4.2.9" ,
"jest-diff" : "^29.7.0" ,
"jest-get-type" : "^29.6.3" ,
"jest-matcher-utils" : "^29.7.0" ,
"jest-message-util" : "^29.7.0" ,
"jest-util" : "^29.7.0" ,
"natural-compare" : "^1.4.0" ,
"pretty-format" : "^29.7.0" ,
"semver" : "^7.5.3"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-util" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-util/-/jest-util-29.7.0.tgz" ,
"integrity" : "sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"chalk" : "^4.0.0" ,
"ci-info" : "^3.2.0" ,
"graceful-fs" : "^4.2.9" ,
"picomatch" : "^2.2.3"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-validate" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-validate/-/jest-validate-29.7.0.tgz" ,
"integrity" : "sha512-ZB7wHqaRGVw/9hST/OuFUReG7M8vKeq0/J2egIGLdvjHCmYqGARhzXmtgi+gVeZ5uXFF219aOc3Ls2yLg27tkw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/types" : "^29.6.3" ,
"camelcase" : "^6.2.0" ,
"chalk" : "^4.0.0" ,
"jest-get-type" : "^29.6.3" ,
"leven" : "^3.1.0" ,
"pretty-format" : "^29.7.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-validate/node_modules/camelcase" : {
"version" : "6.3.0" ,
"resolved" : "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz" ,
"integrity" : "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/jest-watcher" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.7.0.tgz" ,
"integrity" : "sha512-49Fg7WXkU3Vl2h6LbLtMQ/HyB6rXSIX7SqvBLQmssRBGN9I0PNvPmAmCWSOY6SOvrjhI/F7/bGAv9RtnsPA03g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/test-result" : "^29.7.0" ,
"@jest/types" : "^29.6.3" ,
"@types/node" : "*" ,
"ansi-escapes" : "^4.2.1" ,
"chalk" : "^4.0.0" ,
"emittery" : "^0.13.1" ,
"jest-util" : "^29.7.0" ,
"string-length" : "^4.0.1"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-worker" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/jest-worker/-/jest-worker-29.7.0.tgz" ,
"integrity" : "sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@types/node" : "*" ,
"jest-util" : "^29.7.0" ,
"merge-stream" : "^2.0.0" ,
"supports-color" : "^8.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/jest-worker/node_modules/has-flag" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz" ,
"integrity" : "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/jest-worker/node_modules/supports-color" : {
"version" : "8.1.1" ,
"resolved" : "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz" ,
"integrity" : "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"has-flag" : "^4.0.0"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/chalk/supports-color?sponsor=1"
}
} ,
"node_modules/js-tokens" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz" ,
"integrity" : "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/js-yaml" : {
"version" : "3.14.1" ,
"resolved" : "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz" ,
"integrity" : "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"argparse" : "^1.0.7" ,
"esprima" : "^4.0.0"
} ,
"bin" : {
"js-yaml" : "bin/js-yaml.js"
}
} ,
"node_modules/jsesc" : {
"version" : "3.1.0" ,
"resolved" : "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz" ,
"integrity" : "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==" ,
"dev" : true ,
"license" : "MIT" ,
"bin" : {
"jsesc" : "bin/jsesc"
} ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/json-parse-even-better-errors" : {
"version" : "2.3.1" ,
"resolved" : "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz" ,
"integrity" : "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/json5" : {
"version" : "2.2.3" ,
"resolved" : "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz" ,
"integrity" : "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==" ,
"dev" : true ,
"license" : "MIT" ,
"bin" : {
"json5" : "lib/cli.js"
} ,
"engines" : {
"node" : ">=6"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/jsonwebtoken" : {
"version" : "9.0.2" ,
"resolved" : "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz" ,
"integrity" : "sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ==" ,
"license" : "MIT" ,
"dependencies" : {
"jws" : "^3.2.2" ,
"lodash.includes" : "^4.3.0" ,
"lodash.isboolean" : "^3.0.3" ,
"lodash.isinteger" : "^4.0.4" ,
"lodash.isnumber" : "^3.0.3" ,
"lodash.isplainobject" : "^4.0.6" ,
"lodash.isstring" : "^4.0.1" ,
"lodash.once" : "^4.0.0" ,
"ms" : "^2.1.1" ,
"semver" : "^7.5.4"
} ,
"engines" : {
"node" : ">=12" ,
"npm" : ">=6"
}
} ,
"node_modules/jsonwebtoken/node_modules/ms" : {
"version" : "2.1.3" ,
"resolved" : "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" ,
"integrity" : "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" ,
"license" : "MIT"
} ,
"node_modules/jwa" : {
"version" : "1.4.2" ,
"resolved" : "https://registry.npmjs.org/jwa/-/jwa-1.4.2.tgz" ,
"integrity" : "sha512-eeH5JO+21J78qMvTIDdBXidBd6nG2kZjg5Ohz/1fpa28Z4CcsWUzJ1ZZyFq/3z3N17aZy+ZuBoHljASbL1WfOw==" ,
"license" : "MIT" ,
"dependencies" : {
"buffer-equal-constant-time" : "^1.0.1" ,
"ecdsa-sig-formatter" : "1.0.11" ,
"safe-buffer" : "^5.0.1"
}
} ,
"node_modules/jws" : {
"version" : "3.2.2" ,
"resolved" : "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz" ,
"integrity" : "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==" ,
"license" : "MIT" ,
"dependencies" : {
"jwa" : "^1.4.1" ,
"safe-buffer" : "^5.0.1"
}
} ,
2025-11-12 21:42:52 +01:00
"node_modules/kleur" : {
"version" : "3.0.3" ,
"resolved" : "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" ,
"integrity" : "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/leven" : {
"version" : "3.1.0" ,
"resolved" : "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz" ,
"integrity" : "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/lines-and-columns" : {
"version" : "1.2.4" ,
"resolved" : "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz" ,
"integrity" : "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/locate-path" : {
"version" : "5.0.0" ,
"resolved" : "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz" ,
"integrity" : "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"p-locate" : "^4.1.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/lodash" : {
"version" : "4.17.21" ,
"resolved" : "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz" ,
"integrity" : "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" ,
"license" : "MIT"
} ,
"node_modules/lodash.includes" : {
"version" : "4.3.0" ,
"resolved" : "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz" ,
"integrity" : "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" ,
"license" : "MIT"
} ,
"node_modules/lodash.isboolean" : {
"version" : "3.0.3" ,
"resolved" : "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz" ,
"integrity" : "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" ,
"license" : "MIT"
} ,
"node_modules/lodash.isinteger" : {
"version" : "4.0.4" ,
"resolved" : "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz" ,
"integrity" : "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" ,
"license" : "MIT"
} ,
"node_modules/lodash.isnumber" : {
"version" : "3.0.3" ,
"resolved" : "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz" ,
"integrity" : "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" ,
"license" : "MIT"
} ,
"node_modules/lodash.isplainobject" : {
"version" : "4.0.6" ,
"resolved" : "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz" ,
"integrity" : "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" ,
"license" : "MIT"
} ,
"node_modules/lodash.isstring" : {
"version" : "4.0.1" ,
"resolved" : "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz" ,
"integrity" : "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" ,
"license" : "MIT"
} ,
"node_modules/lodash.once" : {
"version" : "4.1.1" ,
"resolved" : "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz" ,
"integrity" : "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" ,
"license" : "MIT"
} ,
2025-11-12 21:42:52 +01:00
"node_modules/lru-cache" : {
"version" : "5.1.1" ,
"resolved" : "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz" ,
"integrity" : "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"yallist" : "^3.0.2"
}
} ,
"node_modules/make-dir" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz" ,
"integrity" : "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"semver" : "^7.5.3"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/makeerror" : {
"version" : "1.0.12" ,
"resolved" : "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz" ,
"integrity" : "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"tmpl" : "1.0.5"
}
} ,
"node_modules/math-intrinsics" : {
"version" : "1.1.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
}
} ,
"node_modules/media-typer" : {
"version" : "0.3.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/merge-descriptors" : {
"version" : "1.0.3" ,
"license" : "MIT" ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/merge-stream" : {
"version" : "2.0.0" ,
"resolved" : "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz" ,
"integrity" : "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/methods" : {
"version" : "1.1.2" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/micromatch" : {
"version" : "4.0.8" ,
"resolved" : "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz" ,
"integrity" : "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"braces" : "^3.0.3" ,
"picomatch" : "^2.3.1"
} ,
"engines" : {
"node" : ">=8.6"
}
} ,
"node_modules/mime" : {
"version" : "1.6.0" ,
"license" : "MIT" ,
"bin" : {
"mime" : "cli.js"
} ,
"engines" : {
"node" : ">=4"
}
} ,
"node_modules/mime-db" : {
"version" : "1.52.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/mime-types" : {
"version" : "2.1.35" ,
"license" : "MIT" ,
"dependencies" : {
"mime-db" : "1.52.0"
} ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/mimic-fn" : {
"version" : "2.1.0" ,
"resolved" : "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz" ,
"integrity" : "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/minimatch" : {
"version" : "3.1.2" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"brace-expansion" : "^1.1.7"
} ,
"engines" : {
"node" : "*"
}
} ,
"node_modules/ms" : {
"version" : "2.0.0" ,
"license" : "MIT"
} ,
"node_modules/natural-compare" : {
"version" : "1.4.0" ,
"resolved" : "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz" ,
"integrity" : "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/negotiator" : {
"version" : "0.6.3" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/node-int64" : {
"version" : "0.4.0" ,
"resolved" : "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz" ,
"integrity" : "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/node-releases" : {
"version" : "2.0.27" ,
"resolved" : "https://registry.npmjs.org/node-releases/-/node-releases-2.0.27.tgz" ,
"integrity" : "sha512-nmh3lCkYZ3grZvqcCH+fjmQ7X+H0OeZgP40OierEaAptX4XofMh5kwNbWh7lBduUzCcV/8kZ+NDLCwm2iorIlA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/nodemon" : {
"version" : "3.1.11" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"chokidar" : "^3.5.2" ,
"debug" : "^4" ,
"ignore-by-default" : "^1.0.1" ,
"minimatch" : "^3.1.2" ,
"pstree.remy" : "^1.1.8" ,
"semver" : "^7.5.3" ,
"simple-update-notifier" : "^2.0.0" ,
"supports-color" : "^5.5.0" ,
"touch" : "^3.1.0" ,
"undefsafe" : "^2.0.5"
} ,
"bin" : {
"nodemon" : "bin/nodemon.js"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"type" : "opencollective" ,
"url" : "https://opencollective.com/nodemon"
}
} ,
"node_modules/nodemon/node_modules/debug" : {
"version" : "4.4.3" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ms" : "^2.1.3"
} ,
"engines" : {
"node" : ">=6.0"
} ,
"peerDependenciesMeta" : {
"supports-color" : {
"optional" : true
}
}
} ,
"node_modules/nodemon/node_modules/ms" : {
"version" : "2.1.3" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/normalize-path" : {
"version" : "3.0.0" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/npm-run-path" : {
"version" : "4.0.1" ,
"resolved" : "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz" ,
"integrity" : "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"path-key" : "^3.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/object-assign" : {
"version" : "4.1.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/object-inspect" : {
"version" : "1.13.4" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/on-finished" : {
"version" : "2.4.1" ,
"license" : "MIT" ,
"dependencies" : {
"ee-first" : "1.1.1"
} ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/once" : {
"version" : "1.4.0" ,
"resolved" : "https://registry.npmjs.org/once/-/once-1.4.0.tgz" ,
"integrity" : "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"wrappy" : "1"
}
} ,
"node_modules/onetime" : {
"version" : "5.1.2" ,
"resolved" : "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz" ,
"integrity" : "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"mimic-fn" : "^2.1.0"
} ,
"engines" : {
"node" : ">=6"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/p-limit" : {
"version" : "3.1.0" ,
"resolved" : "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz" ,
"integrity" : "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"yocto-queue" : "^0.1.0"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/p-locate" : {
"version" : "4.1.0" ,
"resolved" : "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz" ,
"integrity" : "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"p-limit" : "^2.2.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/p-locate/node_modules/p-limit" : {
"version" : "2.3.0" ,
"resolved" : "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz" ,
"integrity" : "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"p-try" : "^2.0.0"
} ,
"engines" : {
"node" : ">=6"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/p-try" : {
"version" : "2.2.0" ,
"resolved" : "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz" ,
"integrity" : "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/parse-json" : {
"version" : "5.2.0" ,
"resolved" : "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz" ,
"integrity" : "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@babel/code-frame" : "^7.0.0" ,
"error-ex" : "^1.3.1" ,
"json-parse-even-better-errors" : "^2.3.0" ,
"lines-and-columns" : "^1.1.6"
} ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/parseurl" : {
"version" : "1.3.3" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/path-exists" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz" ,
"integrity" : "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/path-is-absolute" : {
"version" : "1.0.1" ,
"resolved" : "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz" ,
"integrity" : "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/path-key" : {
"version" : "3.1.1" ,
"resolved" : "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz" ,
"integrity" : "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/path-parse" : {
"version" : "1.0.7" ,
"resolved" : "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz" ,
"integrity" : "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/path-to-regexp" : {
"version" : "0.1.12" ,
"license" : "MIT"
} ,
"node_modules/picocolors" : {
"version" : "1.1.1" ,
"resolved" : "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz" ,
"integrity" : "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/picomatch" : {
"version" : "2.3.1" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8.6"
} ,
"funding" : {
"url" : "https://github.com/sponsors/jonschlinkert"
}
} ,
"node_modules/pirates" : {
"version" : "4.0.7" ,
"resolved" : "https://registry.npmjs.org/pirates/-/pirates-4.0.7.tgz" ,
"integrity" : "sha512-TfySrs/5nm8fQJDcBDuUng3VOUKsd7S+zqvbOTiGXHfxX4wK31ard+hoNuvkicM/2YFzlpDgABOevKSsB4G/FA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 6"
}
} ,
"node_modules/pkg-dir" : {
"version" : "4.2.0" ,
"resolved" : "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz" ,
"integrity" : "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"find-up" : "^4.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/pretty-format" : {
"version" : "29.7.0" ,
"resolved" : "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz" ,
"integrity" : "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"@jest/schemas" : "^29.6.3" ,
"ansi-styles" : "^5.0.0" ,
"react-is" : "^18.0.0"
} ,
"engines" : {
"node" : "^14.15.0 || ^16.10.0 || >=18.0.0"
}
} ,
"node_modules/pretty-format/node_modules/ansi-styles" : {
"version" : "5.2.0" ,
"resolved" : "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz" ,
"integrity" : "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/chalk/ansi-styles?sponsor=1"
}
} ,
2025-11-12 21:56:11 +01:00
"node_modules/prisma" : {
"version" : "5.22.0" ,
"resolved" : "https://registry.npmjs.org/prisma/-/prisma-5.22.0.tgz" ,
"integrity" : "sha512-vtpjW3XuYCSnMsNVBjLMNkTj6OZbudcPPTPYHqX0CJfpcdWciI1dM8uHETwmDxxiqEwCIE6WvXucWUetJgfu/A==" ,
"devOptional" : true ,
"hasInstallScript" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"@prisma/engines" : "5.22.0"
} ,
"bin" : {
"prisma" : "build/index.js"
} ,
"engines" : {
"node" : ">=16.13"
} ,
"optionalDependencies" : {
"fsevents" : "2.3.3"
}
} ,
2025-11-12 21:42:52 +01:00
"node_modules/prompts" : {
"version" : "2.4.2" ,
"resolved" : "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz" ,
"integrity" : "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"kleur" : "^3.0.3" ,
"sisteransi" : "^1.0.5"
} ,
"engines" : {
"node" : ">= 6"
}
} ,
"node_modules/proxy-addr" : {
"version" : "2.0.7" ,
"license" : "MIT" ,
"dependencies" : {
"forwarded" : "0.2.0" ,
"ipaddr.js" : "1.9.1"
} ,
"engines" : {
"node" : ">= 0.10"
}
} ,
"node_modules/pstree.remy" : {
"version" : "1.1.8" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/pure-rand" : {
"version" : "6.1.0" ,
"resolved" : "https://registry.npmjs.org/pure-rand/-/pure-rand-6.1.0.tgz" ,
"integrity" : "sha512-bVWawvoZoBYpp6yIoQtQXHZjmz35RSVHnUOTefl8Vcjr8snTPY1wnpSPMWekcFwbxI6gtmT7rSYPFvz71ldiOA==" ,
"dev" : true ,
"funding" : [
{
"type" : "individual" ,
"url" : "https://github.com/sponsors/dubzzz"
} ,
{
"type" : "opencollective" ,
"url" : "https://opencollective.com/fast-check"
}
] ,
"license" : "MIT"
} ,
"node_modules/qs" : {
"version" : "6.13.0" ,
"license" : "BSD-3-Clause" ,
"dependencies" : {
"side-channel" : "^1.0.6"
} ,
"engines" : {
"node" : ">=0.6"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/range-parser" : {
"version" : "1.2.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/raw-body" : {
"version" : "2.5.2" ,
"license" : "MIT" ,
"dependencies" : {
"bytes" : "3.1.2" ,
"http-errors" : "2.0.0" ,
"iconv-lite" : "0.4.24" ,
"unpipe" : "1.0.0"
} ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/react-is" : {
"version" : "18.3.1" ,
"resolved" : "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz" ,
"integrity" : "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/readdirp" : {
"version" : "3.6.0" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"picomatch" : "^2.2.1"
} ,
"engines" : {
"node" : ">=8.10.0"
}
} ,
"node_modules/require-directory" : {
"version" : "2.1.1" ,
"resolved" : "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz" ,
"integrity" : "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/resolve" : {
"version" : "1.22.11" ,
"resolved" : "https://registry.npmjs.org/resolve/-/resolve-1.22.11.tgz" ,
"integrity" : "sha512-RfqAvLnMl313r7c9oclB1HhUEAezcpLjz95wFH4LVuhk9JF/r22qmVP9AMmOU4vMX7Q8pN8jwNg/CSpdFnMjTQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"is-core-module" : "^2.16.1" ,
"path-parse" : "^1.0.7" ,
"supports-preserve-symlinks-flag" : "^1.0.0"
} ,
"bin" : {
"resolve" : "bin/resolve"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/resolve-cwd" : {
"version" : "3.0.0" ,
"resolved" : "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz" ,
"integrity" : "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"resolve-from" : "^5.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/resolve-from" : {
"version" : "5.0.0" ,
"resolved" : "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz" ,
"integrity" : "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/resolve.exports" : {
"version" : "2.0.3" ,
"resolved" : "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.3.tgz" ,
"integrity" : "sha512-OcXjMsGdhL4XnbShKpAcSqPMzQoYkYyhbEaeSko47MjRP9NfEQMhZkXL1DoFlt9LWQn4YttrdnV6X2OiyzBi+A==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/safe-buffer" : {
"version" : "5.2.1" ,
"funding" : [
{
"type" : "github" ,
"url" : "https://github.com/sponsors/feross"
} ,
{
"type" : "patreon" ,
"url" : "https://www.patreon.com/feross"
} ,
{
"type" : "consulting" ,
"url" : "https://feross.org/support"
}
] ,
"license" : "MIT"
} ,
"node_modules/safer-buffer" : {
"version" : "2.1.2" ,
"license" : "MIT"
} ,
"node_modules/semver" : {
"version" : "7.7.3" ,
"license" : "ISC" ,
"bin" : {
"semver" : "bin/semver.js"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/send" : {
"version" : "0.19.0" ,
"license" : "MIT" ,
"dependencies" : {
"debug" : "2.6.9" ,
"depd" : "2.0.0" ,
"destroy" : "1.2.0" ,
"encodeurl" : "~1.0.2" ,
"escape-html" : "~1.0.3" ,
"etag" : "~1.8.1" ,
"fresh" : "0.5.2" ,
"http-errors" : "2.0.0" ,
"mime" : "1.6.0" ,
"ms" : "2.1.3" ,
"on-finished" : "2.4.1" ,
"range-parser" : "~1.2.1" ,
"statuses" : "2.0.1"
} ,
"engines" : {
"node" : ">= 0.8.0"
}
} ,
"node_modules/send/node_modules/encodeurl" : {
"version" : "1.0.2" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/send/node_modules/ms" : {
"version" : "2.1.3" ,
"license" : "MIT"
} ,
"node_modules/serve-static" : {
"version" : "1.16.2" ,
"license" : "MIT" ,
"dependencies" : {
"encodeurl" : "~2.0.0" ,
"escape-html" : "~1.0.3" ,
"parseurl" : "~1.3.3" ,
"send" : "0.19.0"
} ,
"engines" : {
"node" : ">= 0.8.0"
}
} ,
"node_modules/setprototypeof" : {
"version" : "1.2.0" ,
"license" : "ISC"
} ,
"node_modules/shebang-command" : {
"version" : "2.0.0" ,
"resolved" : "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz" ,
"integrity" : "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"shebang-regex" : "^3.0.0"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/shebang-regex" : {
"version" : "3.0.0" ,
"resolved" : "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz" ,
"integrity" : "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/side-channel" : {
"version" : "1.1.0" ,
"license" : "MIT" ,
"dependencies" : {
"es-errors" : "^1.3.0" ,
"object-inspect" : "^1.13.3" ,
"side-channel-list" : "^1.0.0" ,
"side-channel-map" : "^1.0.1" ,
"side-channel-weakmap" : "^1.0.2"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/side-channel-list" : {
"version" : "1.0.0" ,
"license" : "MIT" ,
"dependencies" : {
"es-errors" : "^1.3.0" ,
"object-inspect" : "^1.13.3"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/side-channel-map" : {
"version" : "1.0.1" ,
"license" : "MIT" ,
"dependencies" : {
"call-bound" : "^1.0.2" ,
"es-errors" : "^1.3.0" ,
"get-intrinsic" : "^1.2.5" ,
"object-inspect" : "^1.13.3"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/side-channel-weakmap" : {
"version" : "1.0.2" ,
"license" : "MIT" ,
"dependencies" : {
"call-bound" : "^1.0.2" ,
"es-errors" : "^1.3.0" ,
"get-intrinsic" : "^1.2.5" ,
"object-inspect" : "^1.13.3" ,
"side-channel-map" : "^1.0.1"
} ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/signal-exit" : {
"version" : "3.0.7" ,
"resolved" : "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz" ,
"integrity" : "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/simple-update-notifier" : {
"version" : "2.0.0" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"semver" : "^7.5.3"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/sisteransi" : {
"version" : "1.0.5" ,
"resolved" : "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz" ,
"integrity" : "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/slash" : {
"version" : "3.0.0" ,
"resolved" : "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz" ,
"integrity" : "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/source-map" : {
"version" : "0.6.1" ,
"resolved" : "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" ,
"integrity" : "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" ,
"dev" : true ,
"license" : "BSD-3-Clause" ,
"engines" : {
"node" : ">=0.10.0"
}
} ,
"node_modules/source-map-support" : {
"version" : "0.5.13" ,
"resolved" : "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz" ,
"integrity" : "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"buffer-from" : "^1.0.0" ,
"source-map" : "^0.6.0"
}
} ,
"node_modules/sprintf-js" : {
"version" : "1.0.3" ,
"resolved" : "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz" ,
"integrity" : "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==" ,
"dev" : true ,
"license" : "BSD-3-Clause"
} ,
"node_modules/stack-utils" : {
"version" : "2.0.6" ,
"resolved" : "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz" ,
"integrity" : "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"escape-string-regexp" : "^2.0.0"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/statuses" : {
"version" : "2.0.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/string-length" : {
"version" : "4.0.2" ,
"resolved" : "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz" ,
"integrity" : "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"char-regex" : "^1.0.2" ,
"strip-ansi" : "^6.0.0"
} ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/string-width" : {
"version" : "4.2.3" ,
"resolved" : "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz" ,
"integrity" : "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"emoji-regex" : "^8.0.0" ,
"is-fullwidth-code-point" : "^3.0.0" ,
"strip-ansi" : "^6.0.1"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/strip-ansi" : {
"version" : "6.0.1" ,
"resolved" : "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz" ,
"integrity" : "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ansi-regex" : "^5.0.1"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/strip-bom" : {
"version" : "4.0.0" ,
"resolved" : "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz" ,
"integrity" : "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/strip-final-newline" : {
"version" : "2.0.0" ,
"resolved" : "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz" ,
"integrity" : "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=6"
}
} ,
"node_modules/strip-json-comments" : {
"version" : "3.1.1" ,
"resolved" : "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz" ,
"integrity" : "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=8"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/superagent" : {
"version" : "8.1.2" ,
"resolved" : "https://registry.npmjs.org/superagent/-/superagent-8.1.2.tgz" ,
"integrity" : "sha512-6WTxW1EB6yCxV5VFOIPQruWGHqc3yI7hEmZK6h+pyk69Lk/Ut7rLUY6W/ONF2MjBuGjvmMiIpsrVJ2vjrHlslA==" ,
"deprecated" : "Please upgrade to superagent v10.2.2+, see release notes at https://github.com/forwardemail/superagent/releases/tag/v10.2.2 - maintenance is supported by Forward Email @ https://forwardemail.net" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"component-emitter" : "^1.3.0" ,
"cookiejar" : "^2.1.4" ,
"debug" : "^4.3.4" ,
"fast-safe-stringify" : "^2.1.1" ,
"form-data" : "^4.0.0" ,
"formidable" : "^2.1.2" ,
"methods" : "^1.1.2" ,
"mime" : "2.6.0" ,
"qs" : "^6.11.0" ,
"semver" : "^7.3.8"
} ,
"engines" : {
"node" : ">=6.4.0 <13 || >=14"
}
} ,
"node_modules/superagent/node_modules/debug" : {
"version" : "4.4.3" ,
"resolved" : "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz" ,
"integrity" : "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ms" : "^2.1.3"
} ,
"engines" : {
"node" : ">=6.0"
} ,
"peerDependenciesMeta" : {
"supports-color" : {
"optional" : true
}
}
} ,
"node_modules/superagent/node_modules/mime" : {
"version" : "2.6.0" ,
"resolved" : "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz" ,
"integrity" : "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==" ,
"dev" : true ,
"license" : "MIT" ,
"bin" : {
"mime" : "cli.js"
} ,
"engines" : {
"node" : ">=4.0.0"
}
} ,
"node_modules/superagent/node_modules/ms" : {
"version" : "2.1.3" ,
"resolved" : "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" ,
"integrity" : "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/supertest" : {
"version" : "6.3.4" ,
"resolved" : "https://registry.npmjs.org/supertest/-/supertest-6.3.4.tgz" ,
"integrity" : "sha512-erY3HFDG0dPnhw4U+udPfrzXa4xhSG+n4rxfRuZWCUvjFWwKl+OxWf/7zk50s84/fAAs7vf5QAb9uRa0cCykxw==" ,
"deprecated" : "Please upgrade to supertest v7.1.3+, see release notes at https://github.com/forwardemail/supertest/releases/tag/v7.1.3 - maintenance is supported by Forward Email @ https://forwardemail.net" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"methods" : "^1.1.2" ,
"superagent" : "^8.1.2"
} ,
"engines" : {
"node" : ">=6.4.0"
}
} ,
"node_modules/supports-color" : {
"version" : "5.5.0" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"has-flag" : "^3.0.0"
} ,
"engines" : {
"node" : ">=4"
}
} ,
"node_modules/supports-preserve-symlinks-flag" : {
"version" : "1.0.0" ,
"resolved" : "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz" ,
"integrity" : "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4"
} ,
"funding" : {
"url" : "https://github.com/sponsors/ljharb"
}
} ,
"node_modules/test-exclude" : {
"version" : "6.0.0" ,
"resolved" : "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz" ,
"integrity" : "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"@istanbuljs/schema" : "^0.1.2" ,
"glob" : "^7.1.4" ,
"minimatch" : "^3.0.4"
} ,
"engines" : {
"node" : ">=8"
}
} ,
"node_modules/tmpl" : {
"version" : "1.0.5" ,
"resolved" : "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz" ,
"integrity" : "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==" ,
"dev" : true ,
"license" : "BSD-3-Clause"
} ,
"node_modules/to-regex-range" : {
"version" : "5.0.1" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"is-number" : "^7.0.0"
} ,
"engines" : {
"node" : ">=8.0"
}
} ,
"node_modules/toidentifier" : {
"version" : "1.0.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">=0.6"
}
} ,
"node_modules/touch" : {
"version" : "3.1.1" ,
"dev" : true ,
"license" : "ISC" ,
"bin" : {
"nodetouch" : "bin/nodetouch.js"
}
} ,
"node_modules/type-detect" : {
"version" : "4.0.8" ,
"resolved" : "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz" ,
"integrity" : "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=4"
}
} ,
"node_modules/type-fest" : {
"version" : "0.21.3" ,
"resolved" : "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz" ,
"integrity" : "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==" ,
"dev" : true ,
"license" : "(MIT OR CC0-1.0)" ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
} ,
"node_modules/type-is" : {
"version" : "1.6.18" ,
"license" : "MIT" ,
"dependencies" : {
"media-typer" : "0.3.0" ,
"mime-types" : "~2.1.24"
} ,
"engines" : {
"node" : ">= 0.6"
}
} ,
"node_modules/undefsafe" : {
"version" : "2.0.5" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/undici-types" : {
"version" : "7.16.0" ,
"resolved" : "https://registry.npmjs.org/undici-types/-/undici-types-7.16.0.tgz" ,
"integrity" : "sha512-Zz+aZWSj8LE6zoxD+xrjh4VfkIG8Ya6LvYkZqtUQGJPZjYl53ypCaUwWqo7eI0x66KBGeRo+mlBEkMSeSZ38Nw==" ,
"dev" : true ,
"license" : "MIT"
} ,
"node_modules/unpipe" : {
"version" : "1.0.0" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/update-browserslist-db" : {
"version" : "1.1.4" ,
"resolved" : "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.4.tgz" ,
"integrity" : "sha512-q0SPT4xyU84saUX+tomz1WLkxUbuaJnR1xWt17M7fJtEJigJeWUNGUqrauFXsHnqev9y9JTRGwk13tFBuKby4A==" ,
"dev" : true ,
"funding" : [
{
"type" : "opencollective" ,
"url" : "https://opencollective.com/browserslist"
} ,
{
"type" : "tidelift" ,
"url" : "https://tidelift.com/funding/github/npm/browserslist"
} ,
{
"type" : "github" ,
"url" : "https://github.com/sponsors/ai"
}
] ,
"license" : "MIT" ,
"dependencies" : {
"escalade" : "^3.2.0" ,
"picocolors" : "^1.1.1"
} ,
"bin" : {
"update-browserslist-db" : "cli.js"
} ,
"peerDependencies" : {
"browserslist" : ">= 4.21.0"
}
} ,
"node_modules/utils-merge" : {
"version" : "1.0.1" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.4.0"
}
} ,
"node_modules/v8-to-istanbul" : {
"version" : "9.3.0" ,
"resolved" : "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.3.0.tgz" ,
"integrity" : "sha512-kiGUalWN+rgBJ/1OHZsBtU4rXZOfj/7rKQxULKlIzwzQSvMJUUNgPwJEEh7gU6xEVxC0ahoOBvN2YI8GH6FNgA==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"@jridgewell/trace-mapping" : "^0.3.12" ,
"@types/istanbul-lib-coverage" : "^2.0.1" ,
"convert-source-map" : "^2.0.0"
} ,
"engines" : {
"node" : ">=10.12.0"
}
} ,
feat: add JWT authentication with complete test coverage
Phase 1 - Step 3: Authentication API
**Backend Authentication:**
- bcryptjs for password hashing (salt rounds: 10)
- JWT tokens with 24h expiration
- Secure password storage (never expose passwordHash)
**API Endpoints:**
- POST /api/auth/register - User registration
- Username validation (3-50 chars, alphanumeric + underscore)
- Email validation and normalization
- Password validation (min 6 chars)
- Duplicate email/username detection
- Auto-generated avatar (ui-avatars.com)
- POST /api/auth/login - User authentication
- Email + password credentials
- Returns JWT token + user data
- Invalid credentials protection
- GET /api/users/me - Get current user (protected)
- Requires valid JWT token
- Returns user data + stats (matches, ratings)
- Token validation via middleware
**Security Features:**
- express-validator for input sanitization
- Auth middleware for protected routes
- Token verification (Bearer token)
- Password never returned in responses
- Proper error messages (no information leakage)
**Frontend Integration:**
- API service layer (frontend/src/services/api.js)
- Updated AuthContext to use real API
- Token storage in localStorage
- Automatic token inclusion in requests
- Error handling for expired/invalid tokens
**Unit Tests (30 tests, 78.26% coverage):**
Auth Endpoints (14 tests):
- ✅ Register: success, duplicate email, duplicate username
- ✅ Register validation: invalid email, short password, short username
- ✅ Login: success, wrong password, non-existent user, invalid format
- ✅ Protected route: valid token, no token, invalid token, malformed header
Auth Utils (9 tests):
- ✅ Password hashing and comparison
- ✅ Different hashes for same password
- ✅ JWT generation and verification
- ✅ Token expiration validation
- ✅ Invalid token handling
All tests passing ✅
Coverage: 78.26% ✅
2025-11-12 22:16:14 +01:00
"node_modules/validator" : {
"version" : "13.15.23" ,
"resolved" : "https://registry.npmjs.org/validator/-/validator-13.15.23.tgz" ,
"integrity" : "sha512-4yoz1kEWqUjzi5zsPbAS/903QXSYp0UOtHsPpp7p9rHAw/W+dkInskAE386Fat3oKRROwO98d9ZB0G4cObgUyw==" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.10"
}
} ,
2025-11-12 21:42:52 +01:00
"node_modules/vary" : {
"version" : "1.1.2" ,
"license" : "MIT" ,
"engines" : {
"node" : ">= 0.8"
}
} ,
"node_modules/walker" : {
"version" : "1.0.8" ,
"resolved" : "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz" ,
"integrity" : "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==" ,
"dev" : true ,
"license" : "Apache-2.0" ,
"dependencies" : {
"makeerror" : "1.0.12"
}
} ,
"node_modules/which" : {
"version" : "2.0.2" ,
"resolved" : "https://registry.npmjs.org/which/-/which-2.0.2.tgz" ,
"integrity" : "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"isexe" : "^2.0.0"
} ,
"bin" : {
"node-which" : "bin/node-which"
} ,
"engines" : {
"node" : ">= 8"
}
} ,
"node_modules/wrap-ansi" : {
"version" : "7.0.0" ,
"resolved" : "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz" ,
"integrity" : "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"ansi-styles" : "^4.0.0" ,
"string-width" : "^4.1.0" ,
"strip-ansi" : "^6.0.0"
} ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/chalk/wrap-ansi?sponsor=1"
}
} ,
"node_modules/wrappy" : {
"version" : "1.0.2" ,
"resolved" : "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz" ,
"integrity" : "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/write-file-atomic" : {
"version" : "4.0.2" ,
"resolved" : "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz" ,
"integrity" : "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==" ,
"dev" : true ,
"license" : "ISC" ,
"dependencies" : {
"imurmurhash" : "^0.1.4" ,
"signal-exit" : "^3.0.7"
} ,
"engines" : {
"node" : "^12.13.0 || ^14.15.0 || >=16.0.0"
}
} ,
"node_modules/y18n" : {
"version" : "5.0.8" ,
"resolved" : "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz" ,
"integrity" : "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==" ,
"dev" : true ,
"license" : "ISC" ,
"engines" : {
"node" : ">=10"
}
} ,
"node_modules/yallist" : {
"version" : "3.1.1" ,
"resolved" : "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz" ,
"integrity" : "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" ,
"dev" : true ,
"license" : "ISC"
} ,
"node_modules/yargs" : {
"version" : "17.7.2" ,
"resolved" : "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz" ,
"integrity" : "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==" ,
"dev" : true ,
"license" : "MIT" ,
"dependencies" : {
"cliui" : "^8.0.1" ,
"escalade" : "^3.1.1" ,
"get-caller-file" : "^2.0.5" ,
"require-directory" : "^2.1.1" ,
"string-width" : "^4.2.3" ,
"y18n" : "^5.0.5" ,
"yargs-parser" : "^21.1.1"
} ,
"engines" : {
"node" : ">=12"
}
} ,
"node_modules/yargs-parser" : {
"version" : "21.1.1" ,
"resolved" : "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz" ,
"integrity" : "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==" ,
"dev" : true ,
"license" : "ISC" ,
"engines" : {
"node" : ">=12"
}
} ,
"node_modules/yocto-queue" : {
"version" : "0.1.0" ,
"resolved" : "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz" ,
"integrity" : "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==" ,
"dev" : true ,
"license" : "MIT" ,
"engines" : {
"node" : ">=10"
} ,
"funding" : {
"url" : "https://github.com/sponsors/sindresorhus"
}
}
}
}