├── .github └── workflows │ ├── publish.yml │ └── test.yml ├── .gitignore ├── .npmignore ├── CHANGELOG.md ├── README.md ├── SECURITY.md ├── example ├── README.md ├── claude_desktop_config.json └── config.json ├── jest.config.ts ├── package-lock.json ├── package.json ├── src ├── __tests__ │ └── index.test.ts ├── client │ ├── __tests__ │ │ └── figma.test.ts │ └── figma.ts ├── index.ts └── types │ └── figma.ts └── tsconfig.json /.github/workflows/publish.yml: -------------------------------------------------------------------------------- 1 | name: Publish Package 2 | 3 | on: 4 | push: 5 | tags: 6 | - 'v*' 7 | 8 | jobs: 9 | publish: 10 | runs-on: ubuntu-latest 11 | steps: 12 | - uses: actions/checkout@v4 13 | 14 | - name: Use Node.js 15 | uses: actions/setup-node@v4 16 | with: 17 | node-version: '20.x' 18 | registry-url: 'https://registry.npmjs.org' 19 | cache: 'npm' 20 | 21 | - name: Install dependencies 22 | run: npm ci 23 | 24 | - name: Build 25 | run: npm run build 26 | 27 | - name: Run tests 28 | run: npm test 29 | 30 | - name: Publish to npm 31 | run: npm publish --access public 32 | env: 33 | NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} 34 | -------------------------------------------------------------------------------- /.github/workflows/test.yml: -------------------------------------------------------------------------------- 1 | name: Test 2 | 3 | on: 4 | push: 5 | branches: [main] 6 | pull_request: 7 | branches: [main] 8 | 9 | jobs: 10 | test: 11 | runs-on: ubuntu-latest 12 | 13 | strategy: 14 | matrix: 15 | node-version: [18.x, 20.x] 16 | 17 | steps: 18 | - uses: actions/checkout@v4 19 | 20 | - name: Use Node.js ${{ matrix.node-version }} 21 | uses: actions/setup-node@v4 22 | with: 23 | node-version: ${{ matrix.node-version }} 24 | cache: 'npm' 25 | 26 | - name: Install dependencies 27 | run: npm ci 28 | 29 | - name: Build 30 | run: npm run build 31 | 32 | - name: Run tests 33 | run: npm test 34 | 35 | - name: Upload coverage 36 | uses: actions/upload-artifact@v4 37 | with: 38 | name: coverage-report 39 | path: coverage/ 40 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Dependencies 2 | node_modules/ 3 | 4 | # Build output 5 | build/ 6 | 7 | # Environment variables 8 | .env 9 | 10 | # IDE 11 | .vscode/ 12 | .idea/ 13 | 14 | # OS 15 | .DS_Store 16 | 17 | # Instructions 18 | instructions/ 19 | 20 | # Test coverage 21 | coverage/ 22 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | # Source files 2 | src/ 3 | !build/ 4 | tsconfig.json 5 | .gitignore 6 | .github/ 7 | .vscode/ 8 | 9 | # Documentation and examples 10 | execute_0104.md 11 | example/ 12 | *.md 13 | !README.md 14 | 15 | # Development files 16 | *.log 17 | **/*.test.js 18 | **/*.test.ts 19 | **/__tests__/ 20 | jest.config.js 21 | coverage/ 22 | 23 | # Dependencies 24 | node_modules/ 25 | 26 | # IDE files 27 | .idea/ 28 | *.swp 29 | *.swo 30 | 31 | # OS files 32 | .DS_Store 33 | Thumbs.db 34 | 35 | # Source maps (will be included via files field in package.json) 36 | *.map 37 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Changelog 2 | 3 | ## [0.1.2] - 2024-03-14 4 | 5 | ### Changed 6 | 7 | - Update examples to use npx with -y option 8 | 9 | ## [0.1.1] - 2024-03-14 10 | 11 | ### Fixed 12 | 13 | - Support ESM imports in production and tests 14 | 15 | All notable changes to this project will be documented in this file. 16 | 17 | The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), 18 | and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). 19 | 20 | ## [0.1.0] - 2024-01-04 21 | 22 | ### Added 23 | 24 | - Initial release 25 | - Figma API integration through MCP server 26 | - Support for listing files, getting file info, components, and styles 27 | - Environment variable and config file support 28 | - TypeScript support with type definitions 29 | - Comprehensive test suite 30 | - CI/CD with GitHub Actions 31 | - Documentation with examples 32 | 33 | ### Features 34 | 35 | - `list_files`: List files in a project or team 36 | - `get_file_versions`: Get version history of a file 37 | - `get_file_comments`: Get comments on a file 38 | - `get_file_info`: Get detailed file information 39 | - `get_components`: Get components from a file 40 | - `get_styles`: Get styles from a file 41 | - `get_file_nodes`: Get specific nodes from a file 42 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # @hapins/figma-mcp 2 | 3 | A Model Context Protocol server for Figma API integration. This package provides a set of tools to interact with the Figma API through the Model Context Protocol. 4 | 5 | > **Note**: This package was implemented by [Cline](https://github.com/cursor-ai/cline), an open-source CLI tool for Claude AI. All code in this repository was written by Claude through Cline. 6 | 7 | ## Installation 8 | 9 | ```bash 10 | npm install -g @hapins/figma-mcp 11 | ``` 12 | 13 | ## Quick Start 14 | 15 | 1. Get your Figma access token: 16 | 17 | - Go to your [Figma account settings](https://www.figma.com/settings) 18 | - Navigate to Personal access tokens 19 | - Create a new access token 20 | 21 | 2. Run the server: 22 | 23 | ```bash 24 | # Using environment variable 25 | FIGMA_ACCESS_TOKEN=your-token npx @hapins/figma-mcp 26 | 27 | # Or using config file 28 | npx @hapins/figma-mcp --config=config.json 29 | ``` 30 | 31 | Example config.json: 32 | 33 | ```json 34 | { 35 | "mcpServers": { 36 | "figma": { 37 | "command": "npx", 38 | "args": ["-y", "@hapins/figma-mcp"], 39 | "env": { 40 | "FIGMA_ACCESS_TOKEN": "your-figma-access-token" 41 | } 42 | } 43 | } 44 | } 45 | ``` 46 | 47 | ## Features 48 | 49 | - List Figma files in a project or team 50 | - Get file versions and comments 51 | - Retrieve file information and components 52 | - Access file nodes and styles 53 | - Full TypeScript support 54 | - Easy integration with Claude AI 55 | 56 | ## Usage 57 | 58 | ### With Cline 59 | 60 | 1. Install the package: 61 | 62 | ```bash 63 | npm install -g @hapins/figma-mcp 64 | ``` 65 | 66 | 2. Add the following to your Cline settings file (`~/.config/cline/settings.json` or platform equivalent): 67 | 68 | ```json 69 | { 70 | "mcpServers": { 71 | "figma": { 72 | "command": "npx", 73 | "args": ["@hapins/figma-mcp"], 74 | "env": { 75 | "FIGMA_ACCESS_TOKEN": "your-figma-access-token" 76 | } 77 | } 78 | } 79 | } 80 | ``` 81 | 82 | ### With Claude Desktop 83 | 84 | Add the following to your Claude Desktop settings file: 85 | 86 | ```json 87 | { 88 | "mcpServers": { 89 | "figma": { 90 | "command": "npx", 91 | "args": ["@hapins/figma-mcp"], 92 | "env": { 93 | "FIGMA_ACCESS_TOKEN": "your-figma-access-token" 94 | } 95 | } 96 | } 97 | } 98 | ``` 99 | 100 | ### Available MCP Tools 101 | 102 | The server provides the following tools through the Model Context Protocol: 103 | 104 | - `list_files`: List files in a project or team 105 | 106 | - Parameters: 107 | - `project_id`: (optional) Project ID to list files from 108 | - `team_id`: (optional) Team ID to list files from 109 | 110 | - `get_file_versions`: Get version history of a file 111 | 112 | - Parameters: 113 | - `file_key`: (required) Figma file key 114 | 115 | - `get_file_comments`: Get comments on a file 116 | 117 | - Parameters: 118 | - `file_key`: (required) Figma file key 119 | 120 | - `get_file_info`: Get detailed file information 121 | 122 | - Parameters: 123 | - `file_key`: (required) Figma file key 124 | - `depth`: (optional) Maximum depth to traverse the node tree (1-4 recommended) 125 | - `node_id`: (optional) ID of a specific node to fetch 126 | 127 | - `get_components`: Get components from a file 128 | 129 | - Parameters: 130 | - `file_key`: (required) Figma file key 131 | 132 | - `get_styles`: Get styles from a file 133 | 134 | - Parameters: 135 | - `file_key`: (required) Figma file key 136 | 137 | - `get_file_nodes`: Get specific nodes from a file 138 | - Parameters: 139 | - `file_key`: (required) Figma file key 140 | - `ids`: (required) Array of node IDs to retrieve 141 | 142 | ## Environment Variables 143 | 144 | - `FIGMA_ACCESS_TOKEN`: Your Figma access token (required) 145 | 146 | ## Development 147 | 148 | ```bash 149 | # Install dependencies 150 | npm install 151 | 152 | # Build the package 153 | npm run build 154 | 155 | # Watch mode 156 | npm run watch 157 | 158 | # Run tests 159 | npm test 160 | ``` 161 | 162 | ## License 163 | 164 | MIT 165 | 166 | ## Contributing 167 | 168 | Contributions are welcome! Please feel free to submit a Pull Request. 169 | -------------------------------------------------------------------------------- /SECURITY.md: -------------------------------------------------------------------------------- 1 | # Security Policy 2 | 3 | ## Supported Versions 4 | 5 | | Version | Supported | 6 | | ------- | ------------------ | 7 | | 0.1.x | :white_check_mark: | 8 | 9 | ## Reporting a Vulnerability 10 | 11 | If you discover a security vulnerability within this project, please send an email to [security contact email]. All security vulnerabilities will be promptly addressed. 12 | 13 | Please include the following information in your report: 14 | 15 | 1. Description of the vulnerability 16 | 2. Steps to reproduce the issue 17 | 3. Potential impact 18 | 4. Suggested fix (if any) 19 | 20 | ## Security Measures 21 | 22 | This project follows these security practices: 23 | 24 | 1. Dependencies are regularly updated and monitored for vulnerabilities using GitHub's Dependabot 25 | 2. Access tokens and sensitive information are handled securely through environment variables 26 | 3. All code changes go through review before being merged 27 | 4. Regular security audits of dependencies using `npm audit` 28 | 29 | ## Security Updates 30 | 31 | Security updates will be released as soon as possible after a vulnerability is confirmed. Updates will be published as new versions following semantic versioning guidelines. 32 | 33 | ## Best Practices for Users 34 | 35 | 1. Always use the latest version of the package 36 | 2. Keep your Figma access token secure and never commit it to version control 37 | 3. Use environment variables or secure configuration management for storing sensitive information 38 | 4. Regularly update dependencies in your projects that use this package 39 | -------------------------------------------------------------------------------- /example/README.md: -------------------------------------------------------------------------------- 1 | # Figma MCP Server Example 2 | 3 | This directory contains example configuration and usage of the Figma MCP server. 4 | 5 | ## Setup 6 | 7 | 1. Install the package globally: 8 | 9 | ```bash 10 | npm install -g @hapins/figma-mcp 11 | ``` 12 | 13 | 2. Get your Figma access token: 14 | 15 | - Go to your Figma account settings 16 | - Navigate to Personal access tokens 17 | - Create a new access token 18 | 19 | 3. Configure the MCP server: 20 | 21 | - Copy `claude_desktop_config.json` to your Claude Desktop config directory 22 | - Replace `your-figma-access-token` with your actual Figma access token 23 | 24 | ## Running the Server 25 | 26 | ### Using Claude Desktop 27 | 28 | 1. Open Claude Desktop 29 | 2. The Figma MCP server will automatically start with your configuration 30 | 31 | ### Using Command Line 32 | 33 | You can also run the server directly: 34 | 35 | ```bash 36 | # Using environment variable 37 | FIGMA_ACCESS_TOKEN=your-token npx figma-mcp 38 | 39 | # Or using config file 40 | npx figma-mcp --config path/to/claude_desktop_config.json 41 | ``` 42 | 43 | ## Testing the Connection 44 | 45 | Once the server is running, you can use Claude to: 46 | 47 | - List your Figma files 48 | - Get file information 49 | - Access components and styles 50 | - And more! 51 | 52 | Example prompts: 53 | 54 | - "Show me the list of files in my Figma project" 55 | - "Get information about a specific Figma file" 56 | - "What components are available in this file?" 57 | -------------------------------------------------------------------------------- /example/claude_desktop_config.json: -------------------------------------------------------------------------------- 1 | { 2 | "mcpServers": { 3 | "figma": { 4 | "command": "npx", 5 | "args": ["-y", "@hapins/figma-mcp"], 6 | "env": { 7 | "FIGMA_ACCESS_TOKEN": "your-figma-access-token" 8 | } 9 | } 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /example/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "mcpServers": { 3 | "figma": { 4 | "command": "npx", 5 | "args": ["-y", "@hapins/figma-mcp"], 6 | "env": { 7 | "FIGMA_ACCESS_TOKEN": "your-figma-access-token" 8 | } 9 | } 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /jest.config.ts: -------------------------------------------------------------------------------- 1 | import type { Config } from '@jest/types'; 2 | 3 | const config: Config.InitialOptions = { 4 | preset: 'ts-jest/presets/default-esm', 5 | moduleNameMapper: { 6 | '^(\\.{1,2}/.*)\\.js$': '$1', 7 | }, 8 | testEnvironment: 'node', 9 | testMatch: ['/src/**/__tests__/**/*.test.ts'], 10 | testPathIgnorePatterns: ['/node_modules/', '/build/'], 11 | clearMocks: true, 12 | collectCoverage: process.env.NODE_ENV !== 'test', 13 | coverageDirectory: 'coverage', 14 | coveragePathIgnorePatterns: ['/node_modules/', '/build/'], 15 | silent: true, 16 | }; 17 | 18 | export default config; 19 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@hapins/figma-mcp", 3 | "version": "0.1.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "@hapins/figma-mcp", 9 | "version": "0.1.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "axios": "^1.7.9" 13 | }, 14 | "bin": { 15 | "figma-mcp": "build/index.js" 16 | }, 17 | "devDependencies": { 18 | "@modelcontextprotocol/sdk": "0.6.0", 19 | "@types/jest": "^29.5.14", 20 | "@types/node": "^20.11.24", 21 | "jest": "^29.7.0", 22 | "ts-jest": "^29.2.5", 23 | "ts-node": "^10.9.2", 24 | "typescript": "^5.3.3" 25 | }, 26 | "peerDependencies": { 27 | "@modelcontextprotocol/sdk": "0.6.0" 28 | } 29 | }, 30 | "node_modules/@ampproject/remapping": { 31 | "version": "2.3.0", 32 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", 33 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", 34 | "dev": true, 35 | "dependencies": { 36 | "@jridgewell/gen-mapping": "^0.3.5", 37 | "@jridgewell/trace-mapping": "^0.3.24" 38 | }, 39 | "engines": { 40 | "node": ">=6.0.0" 41 | } 42 | }, 43 | "node_modules/@babel/code-frame": { 44 | "version": "7.26.2", 45 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz", 46 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==", 47 | "dev": true, 48 | "dependencies": { 49 | "@babel/helper-validator-identifier": "^7.25.9", 50 | "js-tokens": "^4.0.0", 51 | "picocolors": "^1.0.0" 52 | }, 53 | "engines": { 54 | "node": ">=6.9.0" 55 | } 56 | }, 57 | "node_modules/@babel/compat-data": { 58 | "version": "7.26.3", 59 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.26.3.tgz", 60 | "integrity": "sha512-nHIxvKPniQXpmQLb0vhY3VaFb3S0YrTAwpOWJZh1wn3oJPjJk9Asva204PsBdmAE8vpzfHudT8DB0scYvy9q0g==", 61 | "dev": true, 62 | "engines": { 63 | "node": ">=6.9.0" 64 | } 65 | }, 66 | "node_modules/@babel/core": { 67 | "version": "7.26.0", 68 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.26.0.tgz", 69 | "integrity": "sha512-i1SLeK+DzNnQ3LL/CswPCa/E5u4lh1k6IAEphON8F+cXt0t9euTshDru0q7/IqMa1PMPz5RnHuHscF8/ZJsStg==", 70 | "dev": true, 71 | "dependencies": { 72 | "@ampproject/remapping": "^2.2.0", 73 | "@babel/code-frame": "^7.26.0", 74 | "@babel/generator": "^7.26.0", 75 | "@babel/helper-compilation-targets": "^7.25.9", 76 | "@babel/helper-module-transforms": "^7.26.0", 77 | "@babel/helpers": "^7.26.0", 78 | "@babel/parser": "^7.26.0", 79 | "@babel/template": "^7.25.9", 80 | "@babel/traverse": "^7.25.9", 81 | "@babel/types": "^7.26.0", 82 | "convert-source-map": "^2.0.0", 83 | "debug": "^4.1.0", 84 | "gensync": "^1.0.0-beta.2", 85 | "json5": "^2.2.3", 86 | "semver": "^6.3.1" 87 | }, 88 | "engines": { 89 | "node": ">=6.9.0" 90 | }, 91 | "funding": { 92 | "type": "opencollective", 93 | "url": "https://opencollective.com/babel" 94 | } 95 | }, 96 | "node_modules/@babel/generator": { 97 | "version": "7.26.3", 98 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.26.3.tgz", 99 | "integrity": "sha512-6FF/urZvD0sTeO7k6/B15pMLC4CHUv1426lzr3N01aHJTl046uCAh9LXW/fzeXXjPNCJ6iABW5XaWOsIZB93aQ==", 100 | "dev": true, 101 | "dependencies": { 102 | "@babel/parser": "^7.26.3", 103 | "@babel/types": "^7.26.3", 104 | "@jridgewell/gen-mapping": "^0.3.5", 105 | "@jridgewell/trace-mapping": "^0.3.25", 106 | "jsesc": "^3.0.2" 107 | }, 108 | "engines": { 109 | "node": ">=6.9.0" 110 | } 111 | }, 112 | "node_modules/@babel/helper-compilation-targets": { 113 | "version": "7.25.9", 114 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.9.tgz", 115 | "integrity": "sha512-j9Db8Suy6yV/VHa4qzrj9yZfZxhLWQdVnRlXxmKLYlhWUVB1sB2G5sxuWYXk/whHD9iW76PmNzxZ4UCnTQTVEQ==", 116 | "dev": true, 117 | "dependencies": { 118 | "@babel/compat-data": "^7.25.9", 119 | "@babel/helper-validator-option": "^7.25.9", 120 | "browserslist": "^4.24.0", 121 | "lru-cache": "^5.1.1", 122 | "semver": "^6.3.1" 123 | }, 124 | "engines": { 125 | "node": ">=6.9.0" 126 | } 127 | }, 128 | "node_modules/@babel/helper-module-imports": { 129 | "version": "7.25.9", 130 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz", 131 | "integrity": "sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==", 132 | "dev": true, 133 | "dependencies": { 134 | "@babel/traverse": "^7.25.9", 135 | "@babel/types": "^7.25.9" 136 | }, 137 | "engines": { 138 | "node": ">=6.9.0" 139 | } 140 | }, 141 | "node_modules/@babel/helper-module-transforms": { 142 | "version": "7.26.0", 143 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.26.0.tgz", 144 | "integrity": "sha512-xO+xu6B5K2czEnQye6BHA7DolFFmS3LB7stHZFaOLb1pAwO1HWLS8fXA+eh0A2yIvltPVmx3eNNDBJA2SLHXFw==", 145 | "dev": true, 146 | "dependencies": { 147 | "@babel/helper-module-imports": "^7.25.9", 148 | "@babel/helper-validator-identifier": "^7.25.9", 149 | "@babel/traverse": "^7.25.9" 150 | }, 151 | "engines": { 152 | "node": ">=6.9.0" 153 | }, 154 | "peerDependencies": { 155 | "@babel/core": "^7.0.0" 156 | } 157 | }, 158 | "node_modules/@babel/helper-plugin-utils": { 159 | "version": "7.25.9", 160 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.25.9.tgz", 161 | "integrity": "sha512-kSMlyUVdWe25rEsRGviIgOWnoT/nfABVWlqt9N19/dIPWViAOW2s9wznP5tURbs/IDuNk4gPy3YdYRgH3uxhBw==", 162 | "dev": true, 163 | "engines": { 164 | "node": ">=6.9.0" 165 | } 166 | }, 167 | "node_modules/@babel/helper-string-parser": { 168 | "version": "7.25.9", 169 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz", 170 | "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==", 171 | "dev": true, 172 | "engines": { 173 | "node": ">=6.9.0" 174 | } 175 | }, 176 | "node_modules/@babel/helper-validator-identifier": { 177 | "version": "7.25.9", 178 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz", 179 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==", 180 | "dev": true, 181 | "engines": { 182 | "node": ">=6.9.0" 183 | } 184 | }, 185 | "node_modules/@babel/helper-validator-option": { 186 | "version": "7.25.9", 187 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.9.tgz", 188 | "integrity": "sha512-e/zv1co8pp55dNdEcCynfj9X7nyUKUXoUEwfXqaZt0omVOmDe9oOTdKStH4GmAw6zxMFs50ZayuMfHDKlO7Tfw==", 189 | "dev": true, 190 | "engines": { 191 | "node": ">=6.9.0" 192 | } 193 | }, 194 | "node_modules/@babel/helpers": { 195 | "version": "7.26.0", 196 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.26.0.tgz", 197 | "integrity": "sha512-tbhNuIxNcVb21pInl3ZSjksLCvgdZy9KwJ8brv993QtIVKJBBkYXz4q4ZbAv31GdnC+R90np23L5FbEBlthAEw==", 198 | "dev": true, 199 | "dependencies": { 200 | "@babel/template": "^7.25.9", 201 | "@babel/types": "^7.26.0" 202 | }, 203 | "engines": { 204 | "node": ">=6.9.0" 205 | } 206 | }, 207 | "node_modules/@babel/parser": { 208 | "version": "7.26.3", 209 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.3.tgz", 210 | "integrity": "sha512-WJ/CvmY8Mea8iDXo6a7RK2wbmJITT5fN3BEkRuFlxVyNx8jOKIIhmC4fSkTcPcf8JyavbBwIe6OpiCOBXt/IcA==", 211 | "dev": true, 212 | "dependencies": { 213 | "@babel/types": "^7.26.3" 214 | }, 215 | "bin": { 216 | "parser": "bin/babel-parser.js" 217 | }, 218 | "engines": { 219 | "node": ">=6.0.0" 220 | } 221 | }, 222 | "node_modules/@babel/plugin-syntax-async-generators": { 223 | "version": "7.8.4", 224 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", 225 | "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", 226 | "dev": true, 227 | "dependencies": { 228 | "@babel/helper-plugin-utils": "^7.8.0" 229 | }, 230 | "peerDependencies": { 231 | "@babel/core": "^7.0.0-0" 232 | } 233 | }, 234 | "node_modules/@babel/plugin-syntax-bigint": { 235 | "version": "7.8.3", 236 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", 237 | "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", 238 | "dev": true, 239 | "dependencies": { 240 | "@babel/helper-plugin-utils": "^7.8.0" 241 | }, 242 | "peerDependencies": { 243 | "@babel/core": "^7.0.0-0" 244 | } 245 | }, 246 | "node_modules/@babel/plugin-syntax-class-properties": { 247 | "version": "7.12.13", 248 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", 249 | "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", 250 | "dev": true, 251 | "dependencies": { 252 | "@babel/helper-plugin-utils": "^7.12.13" 253 | }, 254 | "peerDependencies": { 255 | "@babel/core": "^7.0.0-0" 256 | } 257 | }, 258 | "node_modules/@babel/plugin-syntax-class-static-block": { 259 | "version": "7.14.5", 260 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", 261 | "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", 262 | "dev": true, 263 | "dependencies": { 264 | "@babel/helper-plugin-utils": "^7.14.5" 265 | }, 266 | "engines": { 267 | "node": ">=6.9.0" 268 | }, 269 | "peerDependencies": { 270 | "@babel/core": "^7.0.0-0" 271 | } 272 | }, 273 | "node_modules/@babel/plugin-syntax-import-attributes": { 274 | "version": "7.26.0", 275 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.26.0.tgz", 276 | "integrity": "sha512-e2dttdsJ1ZTpi3B9UYGLw41hifAubg19AtCu/2I/F1QNVclOBr1dYpTdmdyZ84Xiz43BS/tCUkMAZNLv12Pi+A==", 277 | "dev": true, 278 | "dependencies": { 279 | "@babel/helper-plugin-utils": "^7.25.9" 280 | }, 281 | "engines": { 282 | "node": ">=6.9.0" 283 | }, 284 | "peerDependencies": { 285 | "@babel/core": "^7.0.0-0" 286 | } 287 | }, 288 | "node_modules/@babel/plugin-syntax-import-meta": { 289 | "version": "7.10.4", 290 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", 291 | "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", 292 | "dev": true, 293 | "dependencies": { 294 | "@babel/helper-plugin-utils": "^7.10.4" 295 | }, 296 | "peerDependencies": { 297 | "@babel/core": "^7.0.0-0" 298 | } 299 | }, 300 | "node_modules/@babel/plugin-syntax-json-strings": { 301 | "version": "7.8.3", 302 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", 303 | "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", 304 | "dev": true, 305 | "dependencies": { 306 | "@babel/helper-plugin-utils": "^7.8.0" 307 | }, 308 | "peerDependencies": { 309 | "@babel/core": "^7.0.0-0" 310 | } 311 | }, 312 | "node_modules/@babel/plugin-syntax-jsx": { 313 | "version": "7.25.9", 314 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.25.9.tgz", 315 | "integrity": "sha512-ld6oezHQMZsZfp6pWtbjaNDF2tiiCYYDqQszHt5VV437lewP9aSi2Of99CK0D0XB21k7FLgnLcmQKyKzynfeAA==", 316 | "dev": true, 317 | "dependencies": { 318 | "@babel/helper-plugin-utils": "^7.25.9" 319 | }, 320 | "engines": { 321 | "node": ">=6.9.0" 322 | }, 323 | "peerDependencies": { 324 | "@babel/core": "^7.0.0-0" 325 | } 326 | }, 327 | "node_modules/@babel/plugin-syntax-logical-assignment-operators": { 328 | "version": "7.10.4", 329 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", 330 | "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", 331 | "dev": true, 332 | "dependencies": { 333 | "@babel/helper-plugin-utils": "^7.10.4" 334 | }, 335 | "peerDependencies": { 336 | "@babel/core": "^7.0.0-0" 337 | } 338 | }, 339 | "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { 340 | "version": "7.8.3", 341 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", 342 | "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", 343 | "dev": true, 344 | "dependencies": { 345 | "@babel/helper-plugin-utils": "^7.8.0" 346 | }, 347 | "peerDependencies": { 348 | "@babel/core": "^7.0.0-0" 349 | } 350 | }, 351 | "node_modules/@babel/plugin-syntax-numeric-separator": { 352 | "version": "7.10.4", 353 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", 354 | "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", 355 | "dev": true, 356 | "dependencies": { 357 | "@babel/helper-plugin-utils": "^7.10.4" 358 | }, 359 | "peerDependencies": { 360 | "@babel/core": "^7.0.0-0" 361 | } 362 | }, 363 | "node_modules/@babel/plugin-syntax-object-rest-spread": { 364 | "version": "7.8.3", 365 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", 366 | "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", 367 | "dev": true, 368 | "dependencies": { 369 | "@babel/helper-plugin-utils": "^7.8.0" 370 | }, 371 | "peerDependencies": { 372 | "@babel/core": "^7.0.0-0" 373 | } 374 | }, 375 | "node_modules/@babel/plugin-syntax-optional-catch-binding": { 376 | "version": "7.8.3", 377 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", 378 | "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", 379 | "dev": true, 380 | "dependencies": { 381 | "@babel/helper-plugin-utils": "^7.8.0" 382 | }, 383 | "peerDependencies": { 384 | "@babel/core": "^7.0.0-0" 385 | } 386 | }, 387 | "node_modules/@babel/plugin-syntax-optional-chaining": { 388 | "version": "7.8.3", 389 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", 390 | "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", 391 | "dev": true, 392 | "dependencies": { 393 | "@babel/helper-plugin-utils": "^7.8.0" 394 | }, 395 | "peerDependencies": { 396 | "@babel/core": "^7.0.0-0" 397 | } 398 | }, 399 | "node_modules/@babel/plugin-syntax-private-property-in-object": { 400 | "version": "7.14.5", 401 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", 402 | "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", 403 | "dev": true, 404 | "dependencies": { 405 | "@babel/helper-plugin-utils": "^7.14.5" 406 | }, 407 | "engines": { 408 | "node": ">=6.9.0" 409 | }, 410 | "peerDependencies": { 411 | "@babel/core": "^7.0.0-0" 412 | } 413 | }, 414 | "node_modules/@babel/plugin-syntax-top-level-await": { 415 | "version": "7.14.5", 416 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", 417 | "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", 418 | "dev": true, 419 | "dependencies": { 420 | "@babel/helper-plugin-utils": "^7.14.5" 421 | }, 422 | "engines": { 423 | "node": ">=6.9.0" 424 | }, 425 | "peerDependencies": { 426 | "@babel/core": "^7.0.0-0" 427 | } 428 | }, 429 | "node_modules/@babel/plugin-syntax-typescript": { 430 | "version": "7.25.9", 431 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.25.9.tgz", 432 | "integrity": "sha512-hjMgRy5hb8uJJjUcdWunWVcoi9bGpJp8p5Ol1229PoN6aytsLwNMgmdftO23wnCLMfVmTwZDWMPNq/D1SY60JQ==", 433 | "dev": true, 434 | "dependencies": { 435 | "@babel/helper-plugin-utils": "^7.25.9" 436 | }, 437 | "engines": { 438 | "node": ">=6.9.0" 439 | }, 440 | "peerDependencies": { 441 | "@babel/core": "^7.0.0-0" 442 | } 443 | }, 444 | "node_modules/@babel/template": { 445 | "version": "7.25.9", 446 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.9.tgz", 447 | "integrity": "sha512-9DGttpmPvIxBb/2uwpVo3dqJ+O6RooAFOS+lB+xDqoE2PVCE8nfoHMdZLpfCQRLwvohzXISPZcgxt80xLfsuwg==", 448 | "dev": true, 449 | "dependencies": { 450 | "@babel/code-frame": "^7.25.9", 451 | "@babel/parser": "^7.25.9", 452 | "@babel/types": "^7.25.9" 453 | }, 454 | "engines": { 455 | "node": ">=6.9.0" 456 | } 457 | }, 458 | "node_modules/@babel/traverse": { 459 | "version": "7.26.4", 460 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.26.4.tgz", 461 | "integrity": "sha512-fH+b7Y4p3yqvApJALCPJcwb0/XaOSgtK4pzV6WVjPR5GLFQBRI7pfoX2V2iM48NXvX07NUxxm1Vw98YjqTcU5w==", 462 | "dev": true, 463 | "dependencies": { 464 | "@babel/code-frame": "^7.26.2", 465 | "@babel/generator": "^7.26.3", 466 | "@babel/parser": "^7.26.3", 467 | "@babel/template": "^7.25.9", 468 | "@babel/types": "^7.26.3", 469 | "debug": "^4.3.1", 470 | "globals": "^11.1.0" 471 | }, 472 | "engines": { 473 | "node": ">=6.9.0" 474 | } 475 | }, 476 | "node_modules/@babel/types": { 477 | "version": "7.26.3", 478 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.3.tgz", 479 | "integrity": "sha512-vN5p+1kl59GVKMvTHt55NzzmYVxprfJD+ql7U9NFIfKCBkYE55LYtS+WtPlaYOyzydrKI8Nezd+aZextrd+FMA==", 480 | "dev": true, 481 | "dependencies": { 482 | "@babel/helper-string-parser": "^7.25.9", 483 | "@babel/helper-validator-identifier": "^7.25.9" 484 | }, 485 | "engines": { 486 | "node": ">=6.9.0" 487 | } 488 | }, 489 | "node_modules/@bcoe/v8-coverage": { 490 | "version": "0.2.3", 491 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 492 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 493 | "dev": true 494 | }, 495 | "node_modules/@cspotcode/source-map-support": { 496 | "version": "0.8.1", 497 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 498 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 499 | "dev": true, 500 | "dependencies": { 501 | "@jridgewell/trace-mapping": "0.3.9" 502 | }, 503 | "engines": { 504 | "node": ">=12" 505 | } 506 | }, 507 | "node_modules/@cspotcode/source-map-support/node_modules/@jridgewell/trace-mapping": { 508 | "version": "0.3.9", 509 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 510 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 511 | "dev": true, 512 | "dependencies": { 513 | "@jridgewell/resolve-uri": "^3.0.3", 514 | "@jridgewell/sourcemap-codec": "^1.4.10" 515 | } 516 | }, 517 | "node_modules/@istanbuljs/load-nyc-config": { 518 | "version": "1.1.0", 519 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 520 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 521 | "dev": true, 522 | "dependencies": { 523 | "camelcase": "^5.3.1", 524 | "find-up": "^4.1.0", 525 | "get-package-type": "^0.1.0", 526 | "js-yaml": "^3.13.1", 527 | "resolve-from": "^5.0.0" 528 | }, 529 | "engines": { 530 | "node": ">=8" 531 | } 532 | }, 533 | "node_modules/@istanbuljs/schema": { 534 | "version": "0.1.3", 535 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 536 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 537 | "dev": true, 538 | "engines": { 539 | "node": ">=8" 540 | } 541 | }, 542 | "node_modules/@jest/console": { 543 | "version": "29.7.0", 544 | "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.7.0.tgz", 545 | "integrity": "sha512-5Ni4CU7XHQi32IJ398EEP4RrB8eV09sXP2ROqD4bksHrnTree52PsxvX8tpL8LvTZ3pFzXyPbNQReSN41CAhOg==", 546 | "dev": true, 547 | "dependencies": { 548 | "@jest/types": "^29.6.3", 549 | "@types/node": "*", 550 | "chalk": "^4.0.0", 551 | "jest-message-util": "^29.7.0", 552 | "jest-util": "^29.7.0", 553 | "slash": "^3.0.0" 554 | }, 555 | "engines": { 556 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 557 | } 558 | }, 559 | "node_modules/@jest/core": { 560 | "version": "29.7.0", 561 | "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.7.0.tgz", 562 | "integrity": "sha512-n7aeXWKMnGtDA48y8TLWJPJmLmmZ642Ceo78cYWEpiD7FzDgmNDV/GCVRorPABdXLJZ/9wzzgZAlHjXjxDHGsg==", 563 | "dev": true, 564 | "dependencies": { 565 | "@jest/console": "^29.7.0", 566 | "@jest/reporters": "^29.7.0", 567 | "@jest/test-result": "^29.7.0", 568 | "@jest/transform": "^29.7.0", 569 | "@jest/types": "^29.6.3", 570 | "@types/node": "*", 571 | "ansi-escapes": "^4.2.1", 572 | "chalk": "^4.0.0", 573 | "ci-info": "^3.2.0", 574 | "exit": "^0.1.2", 575 | "graceful-fs": "^4.2.9", 576 | "jest-changed-files": "^29.7.0", 577 | "jest-config": "^29.7.0", 578 | "jest-haste-map": "^29.7.0", 579 | "jest-message-util": "^29.7.0", 580 | "jest-regex-util": "^29.6.3", 581 | "jest-resolve": "^29.7.0", 582 | "jest-resolve-dependencies": "^29.7.0", 583 | "jest-runner": "^29.7.0", 584 | "jest-runtime": "^29.7.0", 585 | "jest-snapshot": "^29.7.0", 586 | "jest-util": "^29.7.0", 587 | "jest-validate": "^29.7.0", 588 | "jest-watcher": "^29.7.0", 589 | "micromatch": "^4.0.4", 590 | "pretty-format": "^29.7.0", 591 | "slash": "^3.0.0", 592 | "strip-ansi": "^6.0.0" 593 | }, 594 | "engines": { 595 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 596 | }, 597 | "peerDependencies": { 598 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 599 | }, 600 | "peerDependenciesMeta": { 601 | "node-notifier": { 602 | "optional": true 603 | } 604 | } 605 | }, 606 | "node_modules/@jest/environment": { 607 | "version": "29.7.0", 608 | "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.7.0.tgz", 609 | "integrity": "sha512-aQIfHDq33ExsN4jP1NWGXhxgQ/wixs60gDiKO+XVMd8Mn0NWPWgc34ZQDTb2jKaUWQ7MuwoitXAsN2XVXNMpAw==", 610 | "dev": true, 611 | "dependencies": { 612 | "@jest/fake-timers": "^29.7.0", 613 | "@jest/types": "^29.6.3", 614 | "@types/node": "*", 615 | "jest-mock": "^29.7.0" 616 | }, 617 | "engines": { 618 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 619 | } 620 | }, 621 | "node_modules/@jest/expect": { 622 | "version": "29.7.0", 623 | "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.7.0.tgz", 624 | "integrity": "sha512-8uMeAMycttpva3P1lBHB8VciS9V0XAr3GymPpipdyQXbBcuhkLQOSe8E/p92RyAdToS6ZD1tFkX+CkhoECE0dQ==", 625 | "dev": true, 626 | "dependencies": { 627 | "expect": "^29.7.0", 628 | "jest-snapshot": "^29.7.0" 629 | }, 630 | "engines": { 631 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 632 | } 633 | }, 634 | "node_modules/@jest/expect-utils": { 635 | "version": "29.7.0", 636 | "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.7.0.tgz", 637 | "integrity": "sha512-GlsNBWiFQFCVi9QVSx7f5AgMeLxe9YCCs5PuP2O2LdjDAA8Jh9eX7lA1Jq/xdXw3Wb3hyvlFNfZIfcRetSzYcA==", 638 | "dev": true, 639 | "dependencies": { 640 | "jest-get-type": "^29.6.3" 641 | }, 642 | "engines": { 643 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 644 | } 645 | }, 646 | "node_modules/@jest/fake-timers": { 647 | "version": "29.7.0", 648 | "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.7.0.tgz", 649 | "integrity": "sha512-q4DH1Ha4TTFPdxLsqDXK1d3+ioSL7yL5oCMJZgDYm6i+6CygW5E5xVr/D1HdsGxjt1ZWSfUAs9OxSB/BNelWrQ==", 650 | "dev": true, 651 | "dependencies": { 652 | "@jest/types": "^29.6.3", 653 | "@sinonjs/fake-timers": "^10.0.2", 654 | "@types/node": "*", 655 | "jest-message-util": "^29.7.0", 656 | "jest-mock": "^29.7.0", 657 | "jest-util": "^29.7.0" 658 | }, 659 | "engines": { 660 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 661 | } 662 | }, 663 | "node_modules/@jest/globals": { 664 | "version": "29.7.0", 665 | "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.7.0.tgz", 666 | "integrity": "sha512-mpiz3dutLbkW2MNFubUGUEVLkTGiqW6yLVTA+JbP6fI6J5iL9Y0Nlg8k95pcF8ctKwCS7WVxteBs29hhfAotzQ==", 667 | "dev": true, 668 | "dependencies": { 669 | "@jest/environment": "^29.7.0", 670 | "@jest/expect": "^29.7.0", 671 | "@jest/types": "^29.6.3", 672 | "jest-mock": "^29.7.0" 673 | }, 674 | "engines": { 675 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 676 | } 677 | }, 678 | "node_modules/@jest/reporters": { 679 | "version": "29.7.0", 680 | "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.7.0.tgz", 681 | "integrity": "sha512-DApq0KJbJOEzAFYjHADNNxAE3KbhxQB1y5Kplb5Waqw6zVbuWatSnMjE5gs8FUgEPmNsnZA3NCWl9NG0ia04Pg==", 682 | "dev": true, 683 | "dependencies": { 684 | "@bcoe/v8-coverage": "^0.2.3", 685 | "@jest/console": "^29.7.0", 686 | "@jest/test-result": "^29.7.0", 687 | "@jest/transform": "^29.7.0", 688 | "@jest/types": "^29.6.3", 689 | "@jridgewell/trace-mapping": "^0.3.18", 690 | "@types/node": "*", 691 | "chalk": "^4.0.0", 692 | "collect-v8-coverage": "^1.0.0", 693 | "exit": "^0.1.2", 694 | "glob": "^7.1.3", 695 | "graceful-fs": "^4.2.9", 696 | "istanbul-lib-coverage": "^3.0.0", 697 | "istanbul-lib-instrument": "^6.0.0", 698 | "istanbul-lib-report": "^3.0.0", 699 | "istanbul-lib-source-maps": "^4.0.0", 700 | "istanbul-reports": "^3.1.3", 701 | "jest-message-util": "^29.7.0", 702 | "jest-util": "^29.7.0", 703 | "jest-worker": "^29.7.0", 704 | "slash": "^3.0.0", 705 | "string-length": "^4.0.1", 706 | "strip-ansi": "^6.0.0", 707 | "v8-to-istanbul": "^9.0.1" 708 | }, 709 | "engines": { 710 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 711 | }, 712 | "peerDependencies": { 713 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 714 | }, 715 | "peerDependenciesMeta": { 716 | "node-notifier": { 717 | "optional": true 718 | } 719 | } 720 | }, 721 | "node_modules/@jest/schemas": { 722 | "version": "29.6.3", 723 | "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz", 724 | "integrity": "sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==", 725 | "dev": true, 726 | "dependencies": { 727 | "@sinclair/typebox": "^0.27.8" 728 | }, 729 | "engines": { 730 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 731 | } 732 | }, 733 | "node_modules/@jest/source-map": { 734 | "version": "29.6.3", 735 | "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.6.3.tgz", 736 | "integrity": "sha512-MHjT95QuipcPrpLM+8JMSzFx6eHp5Bm+4XeFDJlwsvVBjmKNiIAvasGK2fxz2WbGRlnvqehFbh07MMa7n3YJnw==", 737 | "dev": true, 738 | "dependencies": { 739 | "@jridgewell/trace-mapping": "^0.3.18", 740 | "callsites": "^3.0.0", 741 | "graceful-fs": "^4.2.9" 742 | }, 743 | "engines": { 744 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 745 | } 746 | }, 747 | "node_modules/@jest/test-result": { 748 | "version": "29.7.0", 749 | "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.7.0.tgz", 750 | "integrity": "sha512-Fdx+tv6x1zlkJPcWXmMDAG2HBnaR9XPSd5aDWQVsfrZmLVT3lU1cwyxLgRmXR9yrq4NBoEm9BMsfgFzTQAbJYA==", 751 | "dev": true, 752 | "dependencies": { 753 | "@jest/console": "^29.7.0", 754 | "@jest/types": "^29.6.3", 755 | "@types/istanbul-lib-coverage": "^2.0.0", 756 | "collect-v8-coverage": "^1.0.0" 757 | }, 758 | "engines": { 759 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 760 | } 761 | }, 762 | "node_modules/@jest/test-sequencer": { 763 | "version": "29.7.0", 764 | "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.7.0.tgz", 765 | "integrity": "sha512-GQwJ5WZVrKnOJuiYiAF52UNUJXgTZx1NHjFSEB0qEMmSZKAkdMoIzw/Cj6x6NF4AvV23AUqDpFzQkN/eYCYTxw==", 766 | "dev": true, 767 | "dependencies": { 768 | "@jest/test-result": "^29.7.0", 769 | "graceful-fs": "^4.2.9", 770 | "jest-haste-map": "^29.7.0", 771 | "slash": "^3.0.0" 772 | }, 773 | "engines": { 774 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 775 | } 776 | }, 777 | "node_modules/@jest/transform": { 778 | "version": "29.7.0", 779 | "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.7.0.tgz", 780 | "integrity": "sha512-ok/BTPFzFKVMwO5eOHRrvnBVHdRy9IrsrW1GpMaQ9MCnilNLXQKmAX8s1YXDFaai9xJpac2ySzV0YeRRECr2Vw==", 781 | "dev": true, 782 | "dependencies": { 783 | "@babel/core": "^7.11.6", 784 | "@jest/types": "^29.6.3", 785 | "@jridgewell/trace-mapping": "^0.3.18", 786 | "babel-plugin-istanbul": "^6.1.1", 787 | "chalk": "^4.0.0", 788 | "convert-source-map": "^2.0.0", 789 | "fast-json-stable-stringify": "^2.1.0", 790 | "graceful-fs": "^4.2.9", 791 | "jest-haste-map": "^29.7.0", 792 | "jest-regex-util": "^29.6.3", 793 | "jest-util": "^29.7.0", 794 | "micromatch": "^4.0.4", 795 | "pirates": "^4.0.4", 796 | "slash": "^3.0.0", 797 | "write-file-atomic": "^4.0.2" 798 | }, 799 | "engines": { 800 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 801 | } 802 | }, 803 | "node_modules/@jest/types": { 804 | "version": "29.6.3", 805 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.6.3.tgz", 806 | "integrity": "sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw==", 807 | "dev": true, 808 | "dependencies": { 809 | "@jest/schemas": "^29.6.3", 810 | "@types/istanbul-lib-coverage": "^2.0.0", 811 | "@types/istanbul-reports": "^3.0.0", 812 | "@types/node": "*", 813 | "@types/yargs": "^17.0.8", 814 | "chalk": "^4.0.0" 815 | }, 816 | "engines": { 817 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 818 | } 819 | }, 820 | "node_modules/@jridgewell/gen-mapping": { 821 | "version": "0.3.8", 822 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz", 823 | "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==", 824 | "dev": true, 825 | "dependencies": { 826 | "@jridgewell/set-array": "^1.2.1", 827 | "@jridgewell/sourcemap-codec": "^1.4.10", 828 | "@jridgewell/trace-mapping": "^0.3.24" 829 | }, 830 | "engines": { 831 | "node": ">=6.0.0" 832 | } 833 | }, 834 | "node_modules/@jridgewell/resolve-uri": { 835 | "version": "3.1.2", 836 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 837 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 838 | "dev": true, 839 | "engines": { 840 | "node": ">=6.0.0" 841 | } 842 | }, 843 | "node_modules/@jridgewell/set-array": { 844 | "version": "1.2.1", 845 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 846 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 847 | "dev": true, 848 | "engines": { 849 | "node": ">=6.0.0" 850 | } 851 | }, 852 | "node_modules/@jridgewell/sourcemap-codec": { 853 | "version": "1.5.0", 854 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", 855 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", 856 | "dev": true 857 | }, 858 | "node_modules/@jridgewell/trace-mapping": { 859 | "version": "0.3.25", 860 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 861 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 862 | "dev": true, 863 | "dependencies": { 864 | "@jridgewell/resolve-uri": "^3.1.0", 865 | "@jridgewell/sourcemap-codec": "^1.4.14" 866 | } 867 | }, 868 | "node_modules/@modelcontextprotocol/sdk": { 869 | "version": "0.6.0", 870 | "resolved": "https://registry.npmjs.org/@modelcontextprotocol/sdk/-/sdk-0.6.0.tgz", 871 | "integrity": "sha512-9rsDudGhDtMbvxohPoMMyAUOmEzQsOK+XFchh6gZGqo8sx9sBuZQs+CUttXqa8RZXKDaJRCN2tUtgGof7jRkkw==", 872 | "dev": true, 873 | "dependencies": { 874 | "content-type": "^1.0.5", 875 | "raw-body": "^3.0.0", 876 | "zod": "^3.23.8" 877 | } 878 | }, 879 | "node_modules/@sinclair/typebox": { 880 | "version": "0.27.8", 881 | "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", 882 | "integrity": "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==", 883 | "dev": true 884 | }, 885 | "node_modules/@sinonjs/commons": { 886 | "version": "3.0.1", 887 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", 888 | "integrity": "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==", 889 | "dev": true, 890 | "dependencies": { 891 | "type-detect": "4.0.8" 892 | } 893 | }, 894 | "node_modules/@sinonjs/fake-timers": { 895 | "version": "10.3.0", 896 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.3.0.tgz", 897 | "integrity": "sha512-V4BG07kuYSUkTCSBHG8G8TNhM+F19jXFWnQtzj+we8DrkpSBCee9Z3Ms8yiGer/dlmhe35/Xdgyo3/0rQKg7YA==", 898 | "dev": true, 899 | "dependencies": { 900 | "@sinonjs/commons": "^3.0.0" 901 | } 902 | }, 903 | "node_modules/@tsconfig/node10": { 904 | "version": "1.0.11", 905 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.11.tgz", 906 | "integrity": "sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==", 907 | "dev": true 908 | }, 909 | "node_modules/@tsconfig/node12": { 910 | "version": "1.0.11", 911 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 912 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 913 | "dev": true 914 | }, 915 | "node_modules/@tsconfig/node14": { 916 | "version": "1.0.3", 917 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 918 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 919 | "dev": true 920 | }, 921 | "node_modules/@tsconfig/node16": { 922 | "version": "1.0.4", 923 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", 924 | "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", 925 | "dev": true 926 | }, 927 | "node_modules/@types/babel__core": { 928 | "version": "7.20.5", 929 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 930 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 931 | "dev": true, 932 | "dependencies": { 933 | "@babel/parser": "^7.20.7", 934 | "@babel/types": "^7.20.7", 935 | "@types/babel__generator": "*", 936 | "@types/babel__template": "*", 937 | "@types/babel__traverse": "*" 938 | } 939 | }, 940 | "node_modules/@types/babel__generator": { 941 | "version": "7.6.8", 942 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", 943 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", 944 | "dev": true, 945 | "dependencies": { 946 | "@babel/types": "^7.0.0" 947 | } 948 | }, 949 | "node_modules/@types/babel__template": { 950 | "version": "7.4.4", 951 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 952 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 953 | "dev": true, 954 | "dependencies": { 955 | "@babel/parser": "^7.1.0", 956 | "@babel/types": "^7.0.0" 957 | } 958 | }, 959 | "node_modules/@types/babel__traverse": { 960 | "version": "7.20.6", 961 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.6.tgz", 962 | "integrity": "sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==", 963 | "dev": true, 964 | "dependencies": { 965 | "@babel/types": "^7.20.7" 966 | } 967 | }, 968 | "node_modules/@types/graceful-fs": { 969 | "version": "4.1.9", 970 | "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.9.tgz", 971 | "integrity": "sha512-olP3sd1qOEe5dXTSaFvQG+02VdRXcdytWLAZsAq1PecU8uqQAhkrnbli7DagjtXKW/Bl7YJbUsa8MPcuc8LHEQ==", 972 | "dev": true, 973 | "dependencies": { 974 | "@types/node": "*" 975 | } 976 | }, 977 | "node_modules/@types/istanbul-lib-coverage": { 978 | "version": "2.0.6", 979 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.6.tgz", 980 | "integrity": "sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==", 981 | "dev": true 982 | }, 983 | "node_modules/@types/istanbul-lib-report": { 984 | "version": "3.0.3", 985 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.3.tgz", 986 | "integrity": "sha512-NQn7AHQnk/RSLOxrBbGyJM/aVQ+pjj5HCgasFxc0K/KhoATfQ/47AyUl15I2yBUpihjmas+a+VJBOqecrFH+uA==", 987 | "dev": true, 988 | "dependencies": { 989 | "@types/istanbul-lib-coverage": "*" 990 | } 991 | }, 992 | "node_modules/@types/istanbul-reports": { 993 | "version": "3.0.4", 994 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.4.tgz", 995 | "integrity": "sha512-pk2B1NWalF9toCRu6gjBzR69syFjP4Od8WRAX+0mmf9lAjCRicLOWc+ZrxZHx/0XRjotgkF9t6iaMJ+aXcOdZQ==", 996 | "dev": true, 997 | "dependencies": { 998 | "@types/istanbul-lib-report": "*" 999 | } 1000 | }, 1001 | "node_modules/@types/jest": { 1002 | "version": "29.5.14", 1003 | "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.14.tgz", 1004 | "integrity": "sha512-ZN+4sdnLUbo8EVvVc2ao0GFW6oVrQRPn4K2lglySj7APvSrgzxHiNNK99us4WDMi57xxA2yggblIAMNhXOotLQ==", 1005 | "dev": true, 1006 | "dependencies": { 1007 | "expect": "^29.0.0", 1008 | "pretty-format": "^29.0.0" 1009 | } 1010 | }, 1011 | "node_modules/@types/node": { 1012 | "version": "20.17.11", 1013 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.11.tgz", 1014 | "integrity": "sha512-Ept5glCK35R8yeyIeYlRIZtX6SLRyqMhOFTgj5SOkMpLTdw3SEHI9fHx60xaUZ+V1aJxQJODE+7/j5ocZydYTg==", 1015 | "dev": true, 1016 | "dependencies": { 1017 | "undici-types": "~6.19.2" 1018 | } 1019 | }, 1020 | "node_modules/@types/stack-utils": { 1021 | "version": "2.0.3", 1022 | "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.3.tgz", 1023 | "integrity": "sha512-9aEbYZ3TbYMznPdcdr3SmIrLXwC/AKZXQeCf9Pgao5CKb8CyHuEX5jzWPTkvregvhRJHcpRO6BFoGW9ycaOkYw==", 1024 | "dev": true 1025 | }, 1026 | "node_modules/@types/yargs": { 1027 | "version": "17.0.33", 1028 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.33.tgz", 1029 | "integrity": "sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==", 1030 | "dev": true, 1031 | "dependencies": { 1032 | "@types/yargs-parser": "*" 1033 | } 1034 | }, 1035 | "node_modules/@types/yargs-parser": { 1036 | "version": "21.0.3", 1037 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", 1038 | "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", 1039 | "dev": true 1040 | }, 1041 | "node_modules/acorn": { 1042 | "version": "8.14.0", 1043 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", 1044 | "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", 1045 | "dev": true, 1046 | "bin": { 1047 | "acorn": "bin/acorn" 1048 | }, 1049 | "engines": { 1050 | "node": ">=0.4.0" 1051 | } 1052 | }, 1053 | "node_modules/acorn-walk": { 1054 | "version": "8.3.4", 1055 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.4.tgz", 1056 | "integrity": "sha512-ueEepnujpqee2o5aIYnvHU6C0A42MNdsIDeqy5BydrkuC5R1ZuUFnm27EeFJGoEHJQgn3uleRvmTXaJgfXbt4g==", 1057 | "dev": true, 1058 | "dependencies": { 1059 | "acorn": "^8.11.0" 1060 | }, 1061 | "engines": { 1062 | "node": ">=0.4.0" 1063 | } 1064 | }, 1065 | "node_modules/ansi-escapes": { 1066 | "version": "4.3.2", 1067 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 1068 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 1069 | "dev": true, 1070 | "dependencies": { 1071 | "type-fest": "^0.21.3" 1072 | }, 1073 | "engines": { 1074 | "node": ">=8" 1075 | }, 1076 | "funding": { 1077 | "url": "https://github.com/sponsors/sindresorhus" 1078 | } 1079 | }, 1080 | "node_modules/ansi-regex": { 1081 | "version": "5.0.1", 1082 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1083 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1084 | "dev": true, 1085 | "engines": { 1086 | "node": ">=8" 1087 | } 1088 | }, 1089 | "node_modules/ansi-styles": { 1090 | "version": "4.3.0", 1091 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1092 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1093 | "dev": true, 1094 | "dependencies": { 1095 | "color-convert": "^2.0.1" 1096 | }, 1097 | "engines": { 1098 | "node": ">=8" 1099 | }, 1100 | "funding": { 1101 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1102 | } 1103 | }, 1104 | "node_modules/anymatch": { 1105 | "version": "3.1.3", 1106 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1107 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1108 | "dev": true, 1109 | "dependencies": { 1110 | "normalize-path": "^3.0.0", 1111 | "picomatch": "^2.0.4" 1112 | }, 1113 | "engines": { 1114 | "node": ">= 8" 1115 | } 1116 | }, 1117 | "node_modules/arg": { 1118 | "version": "4.1.3", 1119 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 1120 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 1121 | "dev": true 1122 | }, 1123 | "node_modules/argparse": { 1124 | "version": "1.0.10", 1125 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1126 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1127 | "dev": true, 1128 | "dependencies": { 1129 | "sprintf-js": "~1.0.2" 1130 | } 1131 | }, 1132 | "node_modules/async": { 1133 | "version": "3.2.6", 1134 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.6.tgz", 1135 | "integrity": "sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==", 1136 | "dev": true 1137 | }, 1138 | "node_modules/asynckit": { 1139 | "version": "0.4.0", 1140 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1141 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 1142 | }, 1143 | "node_modules/axios": { 1144 | "version": "1.7.9", 1145 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.9.tgz", 1146 | "integrity": "sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw==", 1147 | "dependencies": { 1148 | "follow-redirects": "^1.15.6", 1149 | "form-data": "^4.0.0", 1150 | "proxy-from-env": "^1.1.0" 1151 | } 1152 | }, 1153 | "node_modules/babel-jest": { 1154 | "version": "29.7.0", 1155 | "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz", 1156 | "integrity": "sha512-BrvGY3xZSwEcCzKvKsCi2GgHqDqsYkOP4/by5xCgIwGXQxIEh+8ew3gmrE1y7XRR6LHZIj6yLYnUi/mm2KXKBg==", 1157 | "dev": true, 1158 | "dependencies": { 1159 | "@jest/transform": "^29.7.0", 1160 | "@types/babel__core": "^7.1.14", 1161 | "babel-plugin-istanbul": "^6.1.1", 1162 | "babel-preset-jest": "^29.6.3", 1163 | "chalk": "^4.0.0", 1164 | "graceful-fs": "^4.2.9", 1165 | "slash": "^3.0.0" 1166 | }, 1167 | "engines": { 1168 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1169 | }, 1170 | "peerDependencies": { 1171 | "@babel/core": "^7.8.0" 1172 | } 1173 | }, 1174 | "node_modules/babel-plugin-istanbul": { 1175 | "version": "6.1.1", 1176 | "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", 1177 | "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", 1178 | "dev": true, 1179 | "dependencies": { 1180 | "@babel/helper-plugin-utils": "^7.0.0", 1181 | "@istanbuljs/load-nyc-config": "^1.0.0", 1182 | "@istanbuljs/schema": "^0.1.2", 1183 | "istanbul-lib-instrument": "^5.0.4", 1184 | "test-exclude": "^6.0.0" 1185 | }, 1186 | "engines": { 1187 | "node": ">=8" 1188 | } 1189 | }, 1190 | "node_modules/babel-plugin-istanbul/node_modules/istanbul-lib-instrument": { 1191 | "version": "5.2.1", 1192 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", 1193 | "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", 1194 | "dev": true, 1195 | "dependencies": { 1196 | "@babel/core": "^7.12.3", 1197 | "@babel/parser": "^7.14.7", 1198 | "@istanbuljs/schema": "^0.1.2", 1199 | "istanbul-lib-coverage": "^3.2.0", 1200 | "semver": "^6.3.0" 1201 | }, 1202 | "engines": { 1203 | "node": ">=8" 1204 | } 1205 | }, 1206 | "node_modules/babel-plugin-jest-hoist": { 1207 | "version": "29.6.3", 1208 | "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.6.3.tgz", 1209 | "integrity": "sha512-ESAc/RJvGTFEzRwOTT4+lNDk/GNHMkKbNzsvT0qKRfDyyYTskxB5rnU2njIDYVxXCBHHEI1c0YwHob3WaYujOg==", 1210 | "dev": true, 1211 | "dependencies": { 1212 | "@babel/template": "^7.3.3", 1213 | "@babel/types": "^7.3.3", 1214 | "@types/babel__core": "^7.1.14", 1215 | "@types/babel__traverse": "^7.0.6" 1216 | }, 1217 | "engines": { 1218 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1219 | } 1220 | }, 1221 | "node_modules/babel-preset-current-node-syntax": { 1222 | "version": "1.1.0", 1223 | "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.1.0.tgz", 1224 | "integrity": "sha512-ldYss8SbBlWva1bs28q78Ju5Zq1F+8BrqBZZ0VFhLBvhh6lCpC2o3gDJi/5DRLs9FgYZCnmPYIVFU4lRXCkyUw==", 1225 | "dev": true, 1226 | "dependencies": { 1227 | "@babel/plugin-syntax-async-generators": "^7.8.4", 1228 | "@babel/plugin-syntax-bigint": "^7.8.3", 1229 | "@babel/plugin-syntax-class-properties": "^7.12.13", 1230 | "@babel/plugin-syntax-class-static-block": "^7.14.5", 1231 | "@babel/plugin-syntax-import-attributes": "^7.24.7", 1232 | "@babel/plugin-syntax-import-meta": "^7.10.4", 1233 | "@babel/plugin-syntax-json-strings": "^7.8.3", 1234 | "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", 1235 | "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", 1236 | "@babel/plugin-syntax-numeric-separator": "^7.10.4", 1237 | "@babel/plugin-syntax-object-rest-spread": "^7.8.3", 1238 | "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", 1239 | "@babel/plugin-syntax-optional-chaining": "^7.8.3", 1240 | "@babel/plugin-syntax-private-property-in-object": "^7.14.5", 1241 | "@babel/plugin-syntax-top-level-await": "^7.14.5" 1242 | }, 1243 | "peerDependencies": { 1244 | "@babel/core": "^7.0.0" 1245 | } 1246 | }, 1247 | "node_modules/babel-preset-jest": { 1248 | "version": "29.6.3", 1249 | "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.6.3.tgz", 1250 | "integrity": "sha512-0B3bhxR6snWXJZtR/RliHTDPRgn1sNHOR0yVtq/IiQFyuOVjFS+wuio/R4gSNkyYmKmJB4wGZv2NZanmKmTnNA==", 1251 | "dev": true, 1252 | "dependencies": { 1253 | "babel-plugin-jest-hoist": "^29.6.3", 1254 | "babel-preset-current-node-syntax": "^1.0.0" 1255 | }, 1256 | "engines": { 1257 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1258 | }, 1259 | "peerDependencies": { 1260 | "@babel/core": "^7.0.0" 1261 | } 1262 | }, 1263 | "node_modules/balanced-match": { 1264 | "version": "1.0.2", 1265 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1266 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1267 | "dev": true 1268 | }, 1269 | "node_modules/brace-expansion": { 1270 | "version": "1.1.11", 1271 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1272 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1273 | "dev": true, 1274 | "dependencies": { 1275 | "balanced-match": "^1.0.0", 1276 | "concat-map": "0.0.1" 1277 | } 1278 | }, 1279 | "node_modules/braces": { 1280 | "version": "3.0.3", 1281 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 1282 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 1283 | "dev": true, 1284 | "dependencies": { 1285 | "fill-range": "^7.1.1" 1286 | }, 1287 | "engines": { 1288 | "node": ">=8" 1289 | } 1290 | }, 1291 | "node_modules/browserslist": { 1292 | "version": "4.24.3", 1293 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.24.3.tgz", 1294 | "integrity": "sha512-1CPmv8iobE2fyRMV97dAcMVegvvWKxmq94hkLiAkUGwKVTyDLw33K+ZxiFrREKmmps4rIw6grcCFCnTMSZ/YiA==", 1295 | "dev": true, 1296 | "funding": [ 1297 | { 1298 | "type": "opencollective", 1299 | "url": "https://opencollective.com/browserslist" 1300 | }, 1301 | { 1302 | "type": "tidelift", 1303 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1304 | }, 1305 | { 1306 | "type": "github", 1307 | "url": "https://github.com/sponsors/ai" 1308 | } 1309 | ], 1310 | "dependencies": { 1311 | "caniuse-lite": "^1.0.30001688", 1312 | "electron-to-chromium": "^1.5.73", 1313 | "node-releases": "^2.0.19", 1314 | "update-browserslist-db": "^1.1.1" 1315 | }, 1316 | "bin": { 1317 | "browserslist": "cli.js" 1318 | }, 1319 | "engines": { 1320 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1321 | } 1322 | }, 1323 | "node_modules/bs-logger": { 1324 | "version": "0.2.6", 1325 | "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz", 1326 | "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==", 1327 | "dev": true, 1328 | "dependencies": { 1329 | "fast-json-stable-stringify": "2.x" 1330 | }, 1331 | "engines": { 1332 | "node": ">= 6" 1333 | } 1334 | }, 1335 | "node_modules/bser": { 1336 | "version": "2.1.1", 1337 | "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", 1338 | "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", 1339 | "dev": true, 1340 | "dependencies": { 1341 | "node-int64": "^0.4.0" 1342 | } 1343 | }, 1344 | "node_modules/buffer-from": { 1345 | "version": "1.1.2", 1346 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1347 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1348 | "dev": true 1349 | }, 1350 | "node_modules/bytes": { 1351 | "version": "3.1.2", 1352 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 1353 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 1354 | "dev": true, 1355 | "engines": { 1356 | "node": ">= 0.8" 1357 | } 1358 | }, 1359 | "node_modules/callsites": { 1360 | "version": "3.1.0", 1361 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1362 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1363 | "dev": true, 1364 | "engines": { 1365 | "node": ">=6" 1366 | } 1367 | }, 1368 | "node_modules/camelcase": { 1369 | "version": "5.3.1", 1370 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 1371 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 1372 | "dev": true, 1373 | "engines": { 1374 | "node": ">=6" 1375 | } 1376 | }, 1377 | "node_modules/caniuse-lite": { 1378 | "version": "1.0.30001690", 1379 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001690.tgz", 1380 | "integrity": "sha512-5ExiE3qQN6oF8Clf8ifIDcMRCRE/dMGcETG/XGMD8/XiXm6HXQgQTh1yZYLXXpSOsEUlJm1Xr7kGULZTuGtP/w==", 1381 | "dev": true, 1382 | "funding": [ 1383 | { 1384 | "type": "opencollective", 1385 | "url": "https://opencollective.com/browserslist" 1386 | }, 1387 | { 1388 | "type": "tidelift", 1389 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1390 | }, 1391 | { 1392 | "type": "github", 1393 | "url": "https://github.com/sponsors/ai" 1394 | } 1395 | ] 1396 | }, 1397 | "node_modules/chalk": { 1398 | "version": "4.1.2", 1399 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1400 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1401 | "dev": true, 1402 | "dependencies": { 1403 | "ansi-styles": "^4.1.0", 1404 | "supports-color": "^7.1.0" 1405 | }, 1406 | "engines": { 1407 | "node": ">=10" 1408 | }, 1409 | "funding": { 1410 | "url": "https://github.com/chalk/chalk?sponsor=1" 1411 | } 1412 | }, 1413 | "node_modules/char-regex": { 1414 | "version": "1.0.2", 1415 | "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", 1416 | "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", 1417 | "dev": true, 1418 | "engines": { 1419 | "node": ">=10" 1420 | } 1421 | }, 1422 | "node_modules/ci-info": { 1423 | "version": "3.9.0", 1424 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz", 1425 | "integrity": "sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==", 1426 | "dev": true, 1427 | "funding": [ 1428 | { 1429 | "type": "github", 1430 | "url": "https://github.com/sponsors/sibiraj-s" 1431 | } 1432 | ], 1433 | "engines": { 1434 | "node": ">=8" 1435 | } 1436 | }, 1437 | "node_modules/cjs-module-lexer": { 1438 | "version": "1.4.1", 1439 | "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.4.1.tgz", 1440 | "integrity": "sha512-cuSVIHi9/9E/+821Qjdvngor+xpnlwnuwIyZOaLmHBVdXL+gP+I6QQB9VkO7RI77YIcTV+S1W9AreJ5eN63JBA==", 1441 | "dev": true 1442 | }, 1443 | "node_modules/cliui": { 1444 | "version": "8.0.1", 1445 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 1446 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 1447 | "dev": true, 1448 | "dependencies": { 1449 | "string-width": "^4.2.0", 1450 | "strip-ansi": "^6.0.1", 1451 | "wrap-ansi": "^7.0.0" 1452 | }, 1453 | "engines": { 1454 | "node": ">=12" 1455 | } 1456 | }, 1457 | "node_modules/co": { 1458 | "version": "4.6.0", 1459 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 1460 | "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", 1461 | "dev": true, 1462 | "engines": { 1463 | "iojs": ">= 1.0.0", 1464 | "node": ">= 0.12.0" 1465 | } 1466 | }, 1467 | "node_modules/collect-v8-coverage": { 1468 | "version": "1.0.2", 1469 | "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.2.tgz", 1470 | "integrity": "sha512-lHl4d5/ONEbLlJvaJNtsF/Lz+WvB07u2ycqTYbdrq7UypDXailES4valYb2eWiJFxZlVmpGekfqoxQhzyFdT4Q==", 1471 | "dev": true 1472 | }, 1473 | "node_modules/color-convert": { 1474 | "version": "2.0.1", 1475 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1476 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1477 | "dev": true, 1478 | "dependencies": { 1479 | "color-name": "~1.1.4" 1480 | }, 1481 | "engines": { 1482 | "node": ">=7.0.0" 1483 | } 1484 | }, 1485 | "node_modules/color-name": { 1486 | "version": "1.1.4", 1487 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1488 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1489 | "dev": true 1490 | }, 1491 | "node_modules/combined-stream": { 1492 | "version": "1.0.8", 1493 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1494 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1495 | "dependencies": { 1496 | "delayed-stream": "~1.0.0" 1497 | }, 1498 | "engines": { 1499 | "node": ">= 0.8" 1500 | } 1501 | }, 1502 | "node_modules/concat-map": { 1503 | "version": "0.0.1", 1504 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1505 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1506 | "dev": true 1507 | }, 1508 | "node_modules/content-type": { 1509 | "version": "1.0.5", 1510 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 1511 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 1512 | "dev": true, 1513 | "engines": { 1514 | "node": ">= 0.6" 1515 | } 1516 | }, 1517 | "node_modules/convert-source-map": { 1518 | "version": "2.0.0", 1519 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1520 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1521 | "dev": true 1522 | }, 1523 | "node_modules/create-jest": { 1524 | "version": "29.7.0", 1525 | "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz", 1526 | "integrity": "sha512-Adz2bdH0Vq3F53KEMJOoftQFutWCukm6J24wbPWRO4k1kMY7gS7ds/uoJkNuV8wDCtWWnuwGcJwpWcih+zEW1Q==", 1527 | "dev": true, 1528 | "dependencies": { 1529 | "@jest/types": "^29.6.3", 1530 | "chalk": "^4.0.0", 1531 | "exit": "^0.1.2", 1532 | "graceful-fs": "^4.2.9", 1533 | "jest-config": "^29.7.0", 1534 | "jest-util": "^29.7.0", 1535 | "prompts": "^2.0.1" 1536 | }, 1537 | "bin": { 1538 | "create-jest": "bin/create-jest.js" 1539 | }, 1540 | "engines": { 1541 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1542 | } 1543 | }, 1544 | "node_modules/create-require": { 1545 | "version": "1.1.1", 1546 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 1547 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 1548 | "dev": true 1549 | }, 1550 | "node_modules/cross-spawn": { 1551 | "version": "7.0.6", 1552 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", 1553 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", 1554 | "dev": true, 1555 | "dependencies": { 1556 | "path-key": "^3.1.0", 1557 | "shebang-command": "^2.0.0", 1558 | "which": "^2.0.1" 1559 | }, 1560 | "engines": { 1561 | "node": ">= 8" 1562 | } 1563 | }, 1564 | "node_modules/debug": { 1565 | "version": "4.4.0", 1566 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", 1567 | "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", 1568 | "dev": true, 1569 | "dependencies": { 1570 | "ms": "^2.1.3" 1571 | }, 1572 | "engines": { 1573 | "node": ">=6.0" 1574 | }, 1575 | "peerDependenciesMeta": { 1576 | "supports-color": { 1577 | "optional": true 1578 | } 1579 | } 1580 | }, 1581 | "node_modules/dedent": { 1582 | "version": "1.5.3", 1583 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.3.tgz", 1584 | "integrity": "sha512-NHQtfOOW68WD8lgypbLA5oT+Bt0xXJhiYvoR6SmmNXZfpzOGXwdKWmcwG8N7PwVVWV3eF/68nmD9BaJSsTBhyQ==", 1585 | "dev": true, 1586 | "peerDependencies": { 1587 | "babel-plugin-macros": "^3.1.0" 1588 | }, 1589 | "peerDependenciesMeta": { 1590 | "babel-plugin-macros": { 1591 | "optional": true 1592 | } 1593 | } 1594 | }, 1595 | "node_modules/deepmerge": { 1596 | "version": "4.3.1", 1597 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", 1598 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", 1599 | "dev": true, 1600 | "engines": { 1601 | "node": ">=0.10.0" 1602 | } 1603 | }, 1604 | "node_modules/delayed-stream": { 1605 | "version": "1.0.0", 1606 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1607 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 1608 | "engines": { 1609 | "node": ">=0.4.0" 1610 | } 1611 | }, 1612 | "node_modules/depd": { 1613 | "version": "2.0.0", 1614 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 1615 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 1616 | "dev": true, 1617 | "engines": { 1618 | "node": ">= 0.8" 1619 | } 1620 | }, 1621 | "node_modules/detect-newline": { 1622 | "version": "3.1.0", 1623 | "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", 1624 | "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", 1625 | "dev": true, 1626 | "engines": { 1627 | "node": ">=8" 1628 | } 1629 | }, 1630 | "node_modules/diff": { 1631 | "version": "4.0.2", 1632 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 1633 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 1634 | "dev": true, 1635 | "engines": { 1636 | "node": ">=0.3.1" 1637 | } 1638 | }, 1639 | "node_modules/diff-sequences": { 1640 | "version": "29.6.3", 1641 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz", 1642 | "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==", 1643 | "dev": true, 1644 | "engines": { 1645 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1646 | } 1647 | }, 1648 | "node_modules/ejs": { 1649 | "version": "3.1.10", 1650 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz", 1651 | "integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==", 1652 | "dev": true, 1653 | "dependencies": { 1654 | "jake": "^10.8.5" 1655 | }, 1656 | "bin": { 1657 | "ejs": "bin/cli.js" 1658 | }, 1659 | "engines": { 1660 | "node": ">=0.10.0" 1661 | } 1662 | }, 1663 | "node_modules/electron-to-chromium": { 1664 | "version": "1.5.76", 1665 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.76.tgz", 1666 | "integrity": "sha512-CjVQyG7n7Sr+eBXE86HIulnL5N8xZY1sgmOPGuq/F0Rr0FJq63lg0kEtOIDfZBk44FnDLf6FUJ+dsJcuiUDdDQ==", 1667 | "dev": true 1668 | }, 1669 | "node_modules/emittery": { 1670 | "version": "0.13.1", 1671 | "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", 1672 | "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", 1673 | "dev": true, 1674 | "engines": { 1675 | "node": ">=12" 1676 | }, 1677 | "funding": { 1678 | "url": "https://github.com/sindresorhus/emittery?sponsor=1" 1679 | } 1680 | }, 1681 | "node_modules/emoji-regex": { 1682 | "version": "8.0.0", 1683 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1684 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1685 | "dev": true 1686 | }, 1687 | "node_modules/error-ex": { 1688 | "version": "1.3.2", 1689 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 1690 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 1691 | "dev": true, 1692 | "dependencies": { 1693 | "is-arrayish": "^0.2.1" 1694 | } 1695 | }, 1696 | "node_modules/escalade": { 1697 | "version": "3.2.0", 1698 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 1699 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", 1700 | "dev": true, 1701 | "engines": { 1702 | "node": ">=6" 1703 | } 1704 | }, 1705 | "node_modules/escape-string-regexp": { 1706 | "version": "2.0.0", 1707 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 1708 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 1709 | "dev": true, 1710 | "engines": { 1711 | "node": ">=8" 1712 | } 1713 | }, 1714 | "node_modules/esprima": { 1715 | "version": "4.0.1", 1716 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1717 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1718 | "dev": true, 1719 | "bin": { 1720 | "esparse": "bin/esparse.js", 1721 | "esvalidate": "bin/esvalidate.js" 1722 | }, 1723 | "engines": { 1724 | "node": ">=4" 1725 | } 1726 | }, 1727 | "node_modules/execa": { 1728 | "version": "5.1.1", 1729 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 1730 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 1731 | "dev": true, 1732 | "dependencies": { 1733 | "cross-spawn": "^7.0.3", 1734 | "get-stream": "^6.0.0", 1735 | "human-signals": "^2.1.0", 1736 | "is-stream": "^2.0.0", 1737 | "merge-stream": "^2.0.0", 1738 | "npm-run-path": "^4.0.1", 1739 | "onetime": "^5.1.2", 1740 | "signal-exit": "^3.0.3", 1741 | "strip-final-newline": "^2.0.0" 1742 | }, 1743 | "engines": { 1744 | "node": ">=10" 1745 | }, 1746 | "funding": { 1747 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 1748 | } 1749 | }, 1750 | "node_modules/exit": { 1751 | "version": "0.1.2", 1752 | "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", 1753 | "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", 1754 | "dev": true, 1755 | "engines": { 1756 | "node": ">= 0.8.0" 1757 | } 1758 | }, 1759 | "node_modules/expect": { 1760 | "version": "29.7.0", 1761 | "resolved": "https://registry.npmjs.org/expect/-/expect-29.7.0.tgz", 1762 | "integrity": "sha512-2Zks0hf1VLFYI1kbh0I5jP3KHHyCHpkfyHBzsSXRFgl/Bg9mWYfMW8oD+PdMPlEwy5HNsR9JutYy6pMeOh61nw==", 1763 | "dev": true, 1764 | "dependencies": { 1765 | "@jest/expect-utils": "^29.7.0", 1766 | "jest-get-type": "^29.6.3", 1767 | "jest-matcher-utils": "^29.7.0", 1768 | "jest-message-util": "^29.7.0", 1769 | "jest-util": "^29.7.0" 1770 | }, 1771 | "engines": { 1772 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1773 | } 1774 | }, 1775 | "node_modules/fast-json-stable-stringify": { 1776 | "version": "2.1.0", 1777 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1778 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1779 | "dev": true 1780 | }, 1781 | "node_modules/fb-watchman": { 1782 | "version": "2.0.2", 1783 | "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", 1784 | "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", 1785 | "dev": true, 1786 | "dependencies": { 1787 | "bser": "2.1.1" 1788 | } 1789 | }, 1790 | "node_modules/filelist": { 1791 | "version": "1.0.4", 1792 | "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz", 1793 | "integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==", 1794 | "dev": true, 1795 | "dependencies": { 1796 | "minimatch": "^5.0.1" 1797 | } 1798 | }, 1799 | "node_modules/filelist/node_modules/brace-expansion": { 1800 | "version": "2.0.1", 1801 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1802 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1803 | "dev": true, 1804 | "dependencies": { 1805 | "balanced-match": "^1.0.0" 1806 | } 1807 | }, 1808 | "node_modules/filelist/node_modules/minimatch": { 1809 | "version": "5.1.6", 1810 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 1811 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 1812 | "dev": true, 1813 | "dependencies": { 1814 | "brace-expansion": "^2.0.1" 1815 | }, 1816 | "engines": { 1817 | "node": ">=10" 1818 | } 1819 | }, 1820 | "node_modules/fill-range": { 1821 | "version": "7.1.1", 1822 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 1823 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 1824 | "dev": true, 1825 | "dependencies": { 1826 | "to-regex-range": "^5.0.1" 1827 | }, 1828 | "engines": { 1829 | "node": ">=8" 1830 | } 1831 | }, 1832 | "node_modules/find-up": { 1833 | "version": "4.1.0", 1834 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1835 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1836 | "dev": true, 1837 | "dependencies": { 1838 | "locate-path": "^5.0.0", 1839 | "path-exists": "^4.0.0" 1840 | }, 1841 | "engines": { 1842 | "node": ">=8" 1843 | } 1844 | }, 1845 | "node_modules/follow-redirects": { 1846 | "version": "1.15.9", 1847 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", 1848 | "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", 1849 | "funding": [ 1850 | { 1851 | "type": "individual", 1852 | "url": "https://github.com/sponsors/RubenVerborgh" 1853 | } 1854 | ], 1855 | "engines": { 1856 | "node": ">=4.0" 1857 | }, 1858 | "peerDependenciesMeta": { 1859 | "debug": { 1860 | "optional": true 1861 | } 1862 | } 1863 | }, 1864 | "node_modules/form-data": { 1865 | "version": "4.0.1", 1866 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", 1867 | "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==", 1868 | "dependencies": { 1869 | "asynckit": "^0.4.0", 1870 | "combined-stream": "^1.0.8", 1871 | "mime-types": "^2.1.12" 1872 | }, 1873 | "engines": { 1874 | "node": ">= 6" 1875 | } 1876 | }, 1877 | "node_modules/fs.realpath": { 1878 | "version": "1.0.0", 1879 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1880 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1881 | "dev": true 1882 | }, 1883 | "node_modules/fsevents": { 1884 | "version": "2.3.3", 1885 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1886 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1887 | "dev": true, 1888 | "hasInstallScript": true, 1889 | "optional": true, 1890 | "os": [ 1891 | "darwin" 1892 | ], 1893 | "engines": { 1894 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1895 | } 1896 | }, 1897 | "node_modules/function-bind": { 1898 | "version": "1.1.2", 1899 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1900 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1901 | "dev": true, 1902 | "funding": { 1903 | "url": "https://github.com/sponsors/ljharb" 1904 | } 1905 | }, 1906 | "node_modules/gensync": { 1907 | "version": "1.0.0-beta.2", 1908 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 1909 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 1910 | "dev": true, 1911 | "engines": { 1912 | "node": ">=6.9.0" 1913 | } 1914 | }, 1915 | "node_modules/get-caller-file": { 1916 | "version": "2.0.5", 1917 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1918 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1919 | "dev": true, 1920 | "engines": { 1921 | "node": "6.* || 8.* || >= 10.*" 1922 | } 1923 | }, 1924 | "node_modules/get-package-type": { 1925 | "version": "0.1.0", 1926 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 1927 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 1928 | "dev": true, 1929 | "engines": { 1930 | "node": ">=8.0.0" 1931 | } 1932 | }, 1933 | "node_modules/get-stream": { 1934 | "version": "6.0.1", 1935 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1936 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1937 | "dev": true, 1938 | "engines": { 1939 | "node": ">=10" 1940 | }, 1941 | "funding": { 1942 | "url": "https://github.com/sponsors/sindresorhus" 1943 | } 1944 | }, 1945 | "node_modules/glob": { 1946 | "version": "7.2.3", 1947 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1948 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1949 | "deprecated": "Glob versions prior to v9 are no longer supported", 1950 | "dev": true, 1951 | "dependencies": { 1952 | "fs.realpath": "^1.0.0", 1953 | "inflight": "^1.0.4", 1954 | "inherits": "2", 1955 | "minimatch": "^3.1.1", 1956 | "once": "^1.3.0", 1957 | "path-is-absolute": "^1.0.0" 1958 | }, 1959 | "engines": { 1960 | "node": "*" 1961 | }, 1962 | "funding": { 1963 | "url": "https://github.com/sponsors/isaacs" 1964 | } 1965 | }, 1966 | "node_modules/globals": { 1967 | "version": "11.12.0", 1968 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1969 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1970 | "dev": true, 1971 | "engines": { 1972 | "node": ">=4" 1973 | } 1974 | }, 1975 | "node_modules/graceful-fs": { 1976 | "version": "4.2.11", 1977 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1978 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1979 | "dev": true 1980 | }, 1981 | "node_modules/has-flag": { 1982 | "version": "4.0.0", 1983 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1984 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1985 | "dev": true, 1986 | "engines": { 1987 | "node": ">=8" 1988 | } 1989 | }, 1990 | "node_modules/hasown": { 1991 | "version": "2.0.2", 1992 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 1993 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 1994 | "dev": true, 1995 | "dependencies": { 1996 | "function-bind": "^1.1.2" 1997 | }, 1998 | "engines": { 1999 | "node": ">= 0.4" 2000 | } 2001 | }, 2002 | "node_modules/html-escaper": { 2003 | "version": "2.0.2", 2004 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 2005 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 2006 | "dev": true 2007 | }, 2008 | "node_modules/http-errors": { 2009 | "version": "2.0.0", 2010 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 2011 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 2012 | "dev": true, 2013 | "dependencies": { 2014 | "depd": "2.0.0", 2015 | "inherits": "2.0.4", 2016 | "setprototypeof": "1.2.0", 2017 | "statuses": "2.0.1", 2018 | "toidentifier": "1.0.1" 2019 | }, 2020 | "engines": { 2021 | "node": ">= 0.8" 2022 | } 2023 | }, 2024 | "node_modules/human-signals": { 2025 | "version": "2.1.0", 2026 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 2027 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 2028 | "dev": true, 2029 | "engines": { 2030 | "node": ">=10.17.0" 2031 | } 2032 | }, 2033 | "node_modules/iconv-lite": { 2034 | "version": "0.6.3", 2035 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 2036 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 2037 | "dev": true, 2038 | "dependencies": { 2039 | "safer-buffer": ">= 2.1.2 < 3.0.0" 2040 | }, 2041 | "engines": { 2042 | "node": ">=0.10.0" 2043 | } 2044 | }, 2045 | "node_modules/import-local": { 2046 | "version": "3.2.0", 2047 | "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.2.0.tgz", 2048 | "integrity": "sha512-2SPlun1JUPWoM6t3F0dw0FkCF/jWY8kttcY4f599GLTSjh2OCuuhdTkJQsEcZzBqbXZGKMK2OqW1oZsjtf/gQA==", 2049 | "dev": true, 2050 | "dependencies": { 2051 | "pkg-dir": "^4.2.0", 2052 | "resolve-cwd": "^3.0.0" 2053 | }, 2054 | "bin": { 2055 | "import-local-fixture": "fixtures/cli.js" 2056 | }, 2057 | "engines": { 2058 | "node": ">=8" 2059 | }, 2060 | "funding": { 2061 | "url": "https://github.com/sponsors/sindresorhus" 2062 | } 2063 | }, 2064 | "node_modules/imurmurhash": { 2065 | "version": "0.1.4", 2066 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2067 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2068 | "dev": true, 2069 | "engines": { 2070 | "node": ">=0.8.19" 2071 | } 2072 | }, 2073 | "node_modules/inflight": { 2074 | "version": "1.0.6", 2075 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2076 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2077 | "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.", 2078 | "dev": true, 2079 | "dependencies": { 2080 | "once": "^1.3.0", 2081 | "wrappy": "1" 2082 | } 2083 | }, 2084 | "node_modules/inherits": { 2085 | "version": "2.0.4", 2086 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2087 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2088 | "dev": true 2089 | }, 2090 | "node_modules/is-arrayish": { 2091 | "version": "0.2.1", 2092 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2093 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", 2094 | "dev": true 2095 | }, 2096 | "node_modules/is-core-module": { 2097 | "version": "2.16.1", 2098 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.16.1.tgz", 2099 | "integrity": "sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w==", 2100 | "dev": true, 2101 | "dependencies": { 2102 | "hasown": "^2.0.2" 2103 | }, 2104 | "engines": { 2105 | "node": ">= 0.4" 2106 | }, 2107 | "funding": { 2108 | "url": "https://github.com/sponsors/ljharb" 2109 | } 2110 | }, 2111 | "node_modules/is-fullwidth-code-point": { 2112 | "version": "3.0.0", 2113 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2114 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2115 | "dev": true, 2116 | "engines": { 2117 | "node": ">=8" 2118 | } 2119 | }, 2120 | "node_modules/is-generator-fn": { 2121 | "version": "2.1.0", 2122 | "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", 2123 | "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", 2124 | "dev": true, 2125 | "engines": { 2126 | "node": ">=6" 2127 | } 2128 | }, 2129 | "node_modules/is-number": { 2130 | "version": "7.0.0", 2131 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2132 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2133 | "dev": true, 2134 | "engines": { 2135 | "node": ">=0.12.0" 2136 | } 2137 | }, 2138 | "node_modules/is-stream": { 2139 | "version": "2.0.1", 2140 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 2141 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 2142 | "dev": true, 2143 | "engines": { 2144 | "node": ">=8" 2145 | }, 2146 | "funding": { 2147 | "url": "https://github.com/sponsors/sindresorhus" 2148 | } 2149 | }, 2150 | "node_modules/isexe": { 2151 | "version": "2.0.0", 2152 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2153 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2154 | "dev": true 2155 | }, 2156 | "node_modules/istanbul-lib-coverage": { 2157 | "version": "3.2.2", 2158 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", 2159 | "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", 2160 | "dev": true, 2161 | "engines": { 2162 | "node": ">=8" 2163 | } 2164 | }, 2165 | "node_modules/istanbul-lib-instrument": { 2166 | "version": "6.0.3", 2167 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.3.tgz", 2168 | "integrity": "sha512-Vtgk7L/R2JHyyGW07spoFlB8/lpjiOLTjMdms6AFMraYt3BaJauod/NGrfnVG/y4Ix1JEuMRPDPEj2ua+zz1/Q==", 2169 | "dev": true, 2170 | "dependencies": { 2171 | "@babel/core": "^7.23.9", 2172 | "@babel/parser": "^7.23.9", 2173 | "@istanbuljs/schema": "^0.1.3", 2174 | "istanbul-lib-coverage": "^3.2.0", 2175 | "semver": "^7.5.4" 2176 | }, 2177 | "engines": { 2178 | "node": ">=10" 2179 | } 2180 | }, 2181 | "node_modules/istanbul-lib-instrument/node_modules/semver": { 2182 | "version": "7.6.3", 2183 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2184 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2185 | "dev": true, 2186 | "bin": { 2187 | "semver": "bin/semver.js" 2188 | }, 2189 | "engines": { 2190 | "node": ">=10" 2191 | } 2192 | }, 2193 | "node_modules/istanbul-lib-report": { 2194 | "version": "3.0.1", 2195 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", 2196 | "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", 2197 | "dev": true, 2198 | "dependencies": { 2199 | "istanbul-lib-coverage": "^3.0.0", 2200 | "make-dir": "^4.0.0", 2201 | "supports-color": "^7.1.0" 2202 | }, 2203 | "engines": { 2204 | "node": ">=10" 2205 | } 2206 | }, 2207 | "node_modules/istanbul-lib-source-maps": { 2208 | "version": "4.0.1", 2209 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", 2210 | "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", 2211 | "dev": true, 2212 | "dependencies": { 2213 | "debug": "^4.1.1", 2214 | "istanbul-lib-coverage": "^3.0.0", 2215 | "source-map": "^0.6.1" 2216 | }, 2217 | "engines": { 2218 | "node": ">=10" 2219 | } 2220 | }, 2221 | "node_modules/istanbul-reports": { 2222 | "version": "3.1.7", 2223 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", 2224 | "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", 2225 | "dev": true, 2226 | "dependencies": { 2227 | "html-escaper": "^2.0.0", 2228 | "istanbul-lib-report": "^3.0.0" 2229 | }, 2230 | "engines": { 2231 | "node": ">=8" 2232 | } 2233 | }, 2234 | "node_modules/jake": { 2235 | "version": "10.9.2", 2236 | "resolved": "https://registry.npmjs.org/jake/-/jake-10.9.2.tgz", 2237 | "integrity": "sha512-2P4SQ0HrLQ+fw6llpLnOaGAvN2Zu6778SJMrCUwns4fOoG9ayrTiZk3VV8sCPkVZF8ab0zksVpS8FDY5pRCNBA==", 2238 | "dev": true, 2239 | "dependencies": { 2240 | "async": "^3.2.3", 2241 | "chalk": "^4.0.2", 2242 | "filelist": "^1.0.4", 2243 | "minimatch": "^3.1.2" 2244 | }, 2245 | "bin": { 2246 | "jake": "bin/cli.js" 2247 | }, 2248 | "engines": { 2249 | "node": ">=10" 2250 | } 2251 | }, 2252 | "node_modules/jest": { 2253 | "version": "29.7.0", 2254 | "resolved": "https://registry.npmjs.org/jest/-/jest-29.7.0.tgz", 2255 | "integrity": "sha512-NIy3oAFp9shda19hy4HK0HRTWKtPJmGdnvywu01nOqNC2vZg+Z+fvJDxpMQA88eb2I9EcafcdjYgsDthnYTvGw==", 2256 | "dev": true, 2257 | "dependencies": { 2258 | "@jest/core": "^29.7.0", 2259 | "@jest/types": "^29.6.3", 2260 | "import-local": "^3.0.2", 2261 | "jest-cli": "^29.7.0" 2262 | }, 2263 | "bin": { 2264 | "jest": "bin/jest.js" 2265 | }, 2266 | "engines": { 2267 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2268 | }, 2269 | "peerDependencies": { 2270 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 2271 | }, 2272 | "peerDependenciesMeta": { 2273 | "node-notifier": { 2274 | "optional": true 2275 | } 2276 | } 2277 | }, 2278 | "node_modules/jest-changed-files": { 2279 | "version": "29.7.0", 2280 | "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.7.0.tgz", 2281 | "integrity": "sha512-fEArFiwf1BpQ+4bXSprcDc3/x4HSzL4al2tozwVpDFpsxALjLYdyiIK4e5Vz66GQJIbXJ82+35PtysofptNX2w==", 2282 | "dev": true, 2283 | "dependencies": { 2284 | "execa": "^5.0.0", 2285 | "jest-util": "^29.7.0", 2286 | "p-limit": "^3.1.0" 2287 | }, 2288 | "engines": { 2289 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2290 | } 2291 | }, 2292 | "node_modules/jest-circus": { 2293 | "version": "29.7.0", 2294 | "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.7.0.tgz", 2295 | "integrity": "sha512-3E1nCMgipcTkCocFwM90XXQab9bS+GMsjdpmPrlelaxwD93Ad8iVEjX/vvHPdLPnFf+L40u+5+iutRdA1N9myw==", 2296 | "dev": true, 2297 | "dependencies": { 2298 | "@jest/environment": "^29.7.0", 2299 | "@jest/expect": "^29.7.0", 2300 | "@jest/test-result": "^29.7.0", 2301 | "@jest/types": "^29.6.3", 2302 | "@types/node": "*", 2303 | "chalk": "^4.0.0", 2304 | "co": "^4.6.0", 2305 | "dedent": "^1.0.0", 2306 | "is-generator-fn": "^2.0.0", 2307 | "jest-each": "^29.7.0", 2308 | "jest-matcher-utils": "^29.7.0", 2309 | "jest-message-util": "^29.7.0", 2310 | "jest-runtime": "^29.7.0", 2311 | "jest-snapshot": "^29.7.0", 2312 | "jest-util": "^29.7.0", 2313 | "p-limit": "^3.1.0", 2314 | "pretty-format": "^29.7.0", 2315 | "pure-rand": "^6.0.0", 2316 | "slash": "^3.0.0", 2317 | "stack-utils": "^2.0.3" 2318 | }, 2319 | "engines": { 2320 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2321 | } 2322 | }, 2323 | "node_modules/jest-cli": { 2324 | "version": "29.7.0", 2325 | "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.7.0.tgz", 2326 | "integrity": "sha512-OVVobw2IubN/GSYsxETi+gOe7Ka59EFMR/twOU3Jb2GnKKeMGJB5SGUUrEz3SFVmJASUdZUzy83sLNNQ2gZslg==", 2327 | "dev": true, 2328 | "dependencies": { 2329 | "@jest/core": "^29.7.0", 2330 | "@jest/test-result": "^29.7.0", 2331 | "@jest/types": "^29.6.3", 2332 | "chalk": "^4.0.0", 2333 | "create-jest": "^29.7.0", 2334 | "exit": "^0.1.2", 2335 | "import-local": "^3.0.2", 2336 | "jest-config": "^29.7.0", 2337 | "jest-util": "^29.7.0", 2338 | "jest-validate": "^29.7.0", 2339 | "yargs": "^17.3.1" 2340 | }, 2341 | "bin": { 2342 | "jest": "bin/jest.js" 2343 | }, 2344 | "engines": { 2345 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2346 | }, 2347 | "peerDependencies": { 2348 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 2349 | }, 2350 | "peerDependenciesMeta": { 2351 | "node-notifier": { 2352 | "optional": true 2353 | } 2354 | } 2355 | }, 2356 | "node_modules/jest-config": { 2357 | "version": "29.7.0", 2358 | "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.7.0.tgz", 2359 | "integrity": "sha512-uXbpfeQ7R6TZBqI3/TxCU4q4ttk3u0PJeC+E0zbfSoSjq6bJ7buBPxzQPL0ifrkY4DNu4JUdk0ImlBUYi840eQ==", 2360 | "dev": true, 2361 | "dependencies": { 2362 | "@babel/core": "^7.11.6", 2363 | "@jest/test-sequencer": "^29.7.0", 2364 | "@jest/types": "^29.6.3", 2365 | "babel-jest": "^29.7.0", 2366 | "chalk": "^4.0.0", 2367 | "ci-info": "^3.2.0", 2368 | "deepmerge": "^4.2.2", 2369 | "glob": "^7.1.3", 2370 | "graceful-fs": "^4.2.9", 2371 | "jest-circus": "^29.7.0", 2372 | "jest-environment-node": "^29.7.0", 2373 | "jest-get-type": "^29.6.3", 2374 | "jest-regex-util": "^29.6.3", 2375 | "jest-resolve": "^29.7.0", 2376 | "jest-runner": "^29.7.0", 2377 | "jest-util": "^29.7.0", 2378 | "jest-validate": "^29.7.0", 2379 | "micromatch": "^4.0.4", 2380 | "parse-json": "^5.2.0", 2381 | "pretty-format": "^29.7.0", 2382 | "slash": "^3.0.0", 2383 | "strip-json-comments": "^3.1.1" 2384 | }, 2385 | "engines": { 2386 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2387 | }, 2388 | "peerDependencies": { 2389 | "@types/node": "*", 2390 | "ts-node": ">=9.0.0" 2391 | }, 2392 | "peerDependenciesMeta": { 2393 | "@types/node": { 2394 | "optional": true 2395 | }, 2396 | "ts-node": { 2397 | "optional": true 2398 | } 2399 | } 2400 | }, 2401 | "node_modules/jest-diff": { 2402 | "version": "29.7.0", 2403 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.7.0.tgz", 2404 | "integrity": "sha512-LMIgiIrhigmPrs03JHpxUh2yISK3vLFPkAodPeo0+BuF7wA2FoQbkEg1u8gBYBThncu7e1oEDUfIXVuTqLRUjw==", 2405 | "dev": true, 2406 | "dependencies": { 2407 | "chalk": "^4.0.0", 2408 | "diff-sequences": "^29.6.3", 2409 | "jest-get-type": "^29.6.3", 2410 | "pretty-format": "^29.7.0" 2411 | }, 2412 | "engines": { 2413 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2414 | } 2415 | }, 2416 | "node_modules/jest-docblock": { 2417 | "version": "29.7.0", 2418 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.7.0.tgz", 2419 | "integrity": "sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==", 2420 | "dev": true, 2421 | "dependencies": { 2422 | "detect-newline": "^3.0.0" 2423 | }, 2424 | "engines": { 2425 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2426 | } 2427 | }, 2428 | "node_modules/jest-each": { 2429 | "version": "29.7.0", 2430 | "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.7.0.tgz", 2431 | "integrity": "sha512-gns+Er14+ZrEoC5fhOfYCY1LOHHr0TI+rQUHZS8Ttw2l7gl+80eHc/gFf2Ktkw0+SIACDTeWvpFcv3B04VembQ==", 2432 | "dev": true, 2433 | "dependencies": { 2434 | "@jest/types": "^29.6.3", 2435 | "chalk": "^4.0.0", 2436 | "jest-get-type": "^29.6.3", 2437 | "jest-util": "^29.7.0", 2438 | "pretty-format": "^29.7.0" 2439 | }, 2440 | "engines": { 2441 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2442 | } 2443 | }, 2444 | "node_modules/jest-environment-node": { 2445 | "version": "29.7.0", 2446 | "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.7.0.tgz", 2447 | "integrity": "sha512-DOSwCRqXirTOyheM+4d5YZOrWcdu0LNZ87ewUoywbcb2XR4wKgqiG8vNeYwhjFMbEkfju7wx2GYH0P2gevGvFw==", 2448 | "dev": true, 2449 | "dependencies": { 2450 | "@jest/environment": "^29.7.0", 2451 | "@jest/fake-timers": "^29.7.0", 2452 | "@jest/types": "^29.6.3", 2453 | "@types/node": "*", 2454 | "jest-mock": "^29.7.0", 2455 | "jest-util": "^29.7.0" 2456 | }, 2457 | "engines": { 2458 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2459 | } 2460 | }, 2461 | "node_modules/jest-get-type": { 2462 | "version": "29.6.3", 2463 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.6.3.tgz", 2464 | "integrity": "sha512-zrteXnqYxfQh7l5FHyL38jL39di8H8rHoecLH3JNxH3BwOrBsNeabdap5e0I23lD4HHI8W5VFBZqG4Eaq5LNcw==", 2465 | "dev": true, 2466 | "engines": { 2467 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2468 | } 2469 | }, 2470 | "node_modules/jest-haste-map": { 2471 | "version": "29.7.0", 2472 | "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.7.0.tgz", 2473 | "integrity": "sha512-fP8u2pyfqx0K1rGn1R9pyE0/KTn+G7PxktWidOBTqFPLYX0b9ksaMFkhK5vrS3DVun09pckLdlx90QthlW7AmA==", 2474 | "dev": true, 2475 | "dependencies": { 2476 | "@jest/types": "^29.6.3", 2477 | "@types/graceful-fs": "^4.1.3", 2478 | "@types/node": "*", 2479 | "anymatch": "^3.0.3", 2480 | "fb-watchman": "^2.0.0", 2481 | "graceful-fs": "^4.2.9", 2482 | "jest-regex-util": "^29.6.3", 2483 | "jest-util": "^29.7.0", 2484 | "jest-worker": "^29.7.0", 2485 | "micromatch": "^4.0.4", 2486 | "walker": "^1.0.8" 2487 | }, 2488 | "engines": { 2489 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2490 | }, 2491 | "optionalDependencies": { 2492 | "fsevents": "^2.3.2" 2493 | } 2494 | }, 2495 | "node_modules/jest-leak-detector": { 2496 | "version": "29.7.0", 2497 | "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.7.0.tgz", 2498 | "integrity": "sha512-kYA8IJcSYtST2BY9I+SMC32nDpBT3J2NvWJx8+JCuCdl/CR1I4EKUJROiP8XtCcxqgTTBGJNdbB1A8XRKbTetw==", 2499 | "dev": true, 2500 | "dependencies": { 2501 | "jest-get-type": "^29.6.3", 2502 | "pretty-format": "^29.7.0" 2503 | }, 2504 | "engines": { 2505 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2506 | } 2507 | }, 2508 | "node_modules/jest-matcher-utils": { 2509 | "version": "29.7.0", 2510 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.7.0.tgz", 2511 | "integrity": "sha512-sBkD+Xi9DtcChsI3L3u0+N0opgPYnCRPtGcQYrgXmR+hmt/fYfWAL0xRXYU8eWOdfuLgBe0YCW3AFtnRLagq/g==", 2512 | "dev": true, 2513 | "dependencies": { 2514 | "chalk": "^4.0.0", 2515 | "jest-diff": "^29.7.0", 2516 | "jest-get-type": "^29.6.3", 2517 | "pretty-format": "^29.7.0" 2518 | }, 2519 | "engines": { 2520 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2521 | } 2522 | }, 2523 | "node_modules/jest-message-util": { 2524 | "version": "29.7.0", 2525 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.7.0.tgz", 2526 | "integrity": "sha512-GBEV4GRADeP+qtB2+6u61stea8mGcOT4mCtrYISZwfu9/ISHFJ/5zOMXYbpBE9RsS5+Gb63DW4FgmnKJ79Kf6w==", 2527 | "dev": true, 2528 | "dependencies": { 2529 | "@babel/code-frame": "^7.12.13", 2530 | "@jest/types": "^29.6.3", 2531 | "@types/stack-utils": "^2.0.0", 2532 | "chalk": "^4.0.0", 2533 | "graceful-fs": "^4.2.9", 2534 | "micromatch": "^4.0.4", 2535 | "pretty-format": "^29.7.0", 2536 | "slash": "^3.0.0", 2537 | "stack-utils": "^2.0.3" 2538 | }, 2539 | "engines": { 2540 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2541 | } 2542 | }, 2543 | "node_modules/jest-mock": { 2544 | "version": "29.7.0", 2545 | "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.7.0.tgz", 2546 | "integrity": "sha512-ITOMZn+UkYS4ZFh83xYAOzWStloNzJFO2s8DWrE4lhtGD+AorgnbkiKERe4wQVBydIGPx059g6riW5Btp6Llnw==", 2547 | "dev": true, 2548 | "dependencies": { 2549 | "@jest/types": "^29.6.3", 2550 | "@types/node": "*", 2551 | "jest-util": "^29.7.0" 2552 | }, 2553 | "engines": { 2554 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2555 | } 2556 | }, 2557 | "node_modules/jest-pnp-resolver": { 2558 | "version": "1.2.3", 2559 | "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", 2560 | "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", 2561 | "dev": true, 2562 | "engines": { 2563 | "node": ">=6" 2564 | }, 2565 | "peerDependencies": { 2566 | "jest-resolve": "*" 2567 | }, 2568 | "peerDependenciesMeta": { 2569 | "jest-resolve": { 2570 | "optional": true 2571 | } 2572 | } 2573 | }, 2574 | "node_modules/jest-regex-util": { 2575 | "version": "29.6.3", 2576 | "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.6.3.tgz", 2577 | "integrity": "sha512-KJJBsRCyyLNWCNBOvZyRDnAIfUiRJ8v+hOBQYGn8gDyF3UegwiP4gwRR3/SDa42g1YbVycTidUF3rKjyLFDWbg==", 2578 | "dev": true, 2579 | "engines": { 2580 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2581 | } 2582 | }, 2583 | "node_modules/jest-resolve": { 2584 | "version": "29.7.0", 2585 | "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.7.0.tgz", 2586 | "integrity": "sha512-IOVhZSrg+UvVAshDSDtHyFCCBUl/Q3AAJv8iZ6ZjnZ74xzvwuzLXid9IIIPgTnY62SJjfuupMKZsZQRsCvxEgA==", 2587 | "dev": true, 2588 | "dependencies": { 2589 | "chalk": "^4.0.0", 2590 | "graceful-fs": "^4.2.9", 2591 | "jest-haste-map": "^29.7.0", 2592 | "jest-pnp-resolver": "^1.2.2", 2593 | "jest-util": "^29.7.0", 2594 | "jest-validate": "^29.7.0", 2595 | "resolve": "^1.20.0", 2596 | "resolve.exports": "^2.0.0", 2597 | "slash": "^3.0.0" 2598 | }, 2599 | "engines": { 2600 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2601 | } 2602 | }, 2603 | "node_modules/jest-resolve-dependencies": { 2604 | "version": "29.7.0", 2605 | "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.7.0.tgz", 2606 | "integrity": "sha512-un0zD/6qxJ+S0et7WxeI3H5XSe9lTBBR7bOHCHXkKR6luG5mwDDlIzVQ0V5cZCuoTgEdcdwzTghYkTWfubi+nA==", 2607 | "dev": true, 2608 | "dependencies": { 2609 | "jest-regex-util": "^29.6.3", 2610 | "jest-snapshot": "^29.7.0" 2611 | }, 2612 | "engines": { 2613 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2614 | } 2615 | }, 2616 | "node_modules/jest-runner": { 2617 | "version": "29.7.0", 2618 | "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.7.0.tgz", 2619 | "integrity": "sha512-fsc4N6cPCAahybGBfTRcq5wFR6fpLznMg47sY5aDpsoejOcVYFb07AHuSnR0liMcPTgBsA3ZJL6kFOjPdoNipQ==", 2620 | "dev": true, 2621 | "dependencies": { 2622 | "@jest/console": "^29.7.0", 2623 | "@jest/environment": "^29.7.0", 2624 | "@jest/test-result": "^29.7.0", 2625 | "@jest/transform": "^29.7.0", 2626 | "@jest/types": "^29.6.3", 2627 | "@types/node": "*", 2628 | "chalk": "^4.0.0", 2629 | "emittery": "^0.13.1", 2630 | "graceful-fs": "^4.2.9", 2631 | "jest-docblock": "^29.7.0", 2632 | "jest-environment-node": "^29.7.0", 2633 | "jest-haste-map": "^29.7.0", 2634 | "jest-leak-detector": "^29.7.0", 2635 | "jest-message-util": "^29.7.0", 2636 | "jest-resolve": "^29.7.0", 2637 | "jest-runtime": "^29.7.0", 2638 | "jest-util": "^29.7.0", 2639 | "jest-watcher": "^29.7.0", 2640 | "jest-worker": "^29.7.0", 2641 | "p-limit": "^3.1.0", 2642 | "source-map-support": "0.5.13" 2643 | }, 2644 | "engines": { 2645 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2646 | } 2647 | }, 2648 | "node_modules/jest-runtime": { 2649 | "version": "29.7.0", 2650 | "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.7.0.tgz", 2651 | "integrity": "sha512-gUnLjgwdGqW7B4LvOIkbKs9WGbn+QLqRQQ9juC6HndeDiezIwhDP+mhMwHWCEcfQ5RUXa6OPnFF8BJh5xegwwQ==", 2652 | "dev": true, 2653 | "dependencies": { 2654 | "@jest/environment": "^29.7.0", 2655 | "@jest/fake-timers": "^29.7.0", 2656 | "@jest/globals": "^29.7.0", 2657 | "@jest/source-map": "^29.6.3", 2658 | "@jest/test-result": "^29.7.0", 2659 | "@jest/transform": "^29.7.0", 2660 | "@jest/types": "^29.6.3", 2661 | "@types/node": "*", 2662 | "chalk": "^4.0.0", 2663 | "cjs-module-lexer": "^1.0.0", 2664 | "collect-v8-coverage": "^1.0.0", 2665 | "glob": "^7.1.3", 2666 | "graceful-fs": "^4.2.9", 2667 | "jest-haste-map": "^29.7.0", 2668 | "jest-message-util": "^29.7.0", 2669 | "jest-mock": "^29.7.0", 2670 | "jest-regex-util": "^29.6.3", 2671 | "jest-resolve": "^29.7.0", 2672 | "jest-snapshot": "^29.7.0", 2673 | "jest-util": "^29.7.0", 2674 | "slash": "^3.0.0", 2675 | "strip-bom": "^4.0.0" 2676 | }, 2677 | "engines": { 2678 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2679 | } 2680 | }, 2681 | "node_modules/jest-snapshot": { 2682 | "version": "29.7.0", 2683 | "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.7.0.tgz", 2684 | "integrity": "sha512-Rm0BMWtxBcioHr1/OX5YCP8Uov4riHvKPknOGs804Zg9JGZgmIBkbtlxJC/7Z4msKYVbIJtfU+tKb8xlYNfdkw==", 2685 | "dev": true, 2686 | "dependencies": { 2687 | "@babel/core": "^7.11.6", 2688 | "@babel/generator": "^7.7.2", 2689 | "@babel/plugin-syntax-jsx": "^7.7.2", 2690 | "@babel/plugin-syntax-typescript": "^7.7.2", 2691 | "@babel/types": "^7.3.3", 2692 | "@jest/expect-utils": "^29.7.0", 2693 | "@jest/transform": "^29.7.0", 2694 | "@jest/types": "^29.6.3", 2695 | "babel-preset-current-node-syntax": "^1.0.0", 2696 | "chalk": "^4.0.0", 2697 | "expect": "^29.7.0", 2698 | "graceful-fs": "^4.2.9", 2699 | "jest-diff": "^29.7.0", 2700 | "jest-get-type": "^29.6.3", 2701 | "jest-matcher-utils": "^29.7.0", 2702 | "jest-message-util": "^29.7.0", 2703 | "jest-util": "^29.7.0", 2704 | "natural-compare": "^1.4.0", 2705 | "pretty-format": "^29.7.0", 2706 | "semver": "^7.5.3" 2707 | }, 2708 | "engines": { 2709 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2710 | } 2711 | }, 2712 | "node_modules/jest-snapshot/node_modules/semver": { 2713 | "version": "7.6.3", 2714 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2715 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2716 | "dev": true, 2717 | "bin": { 2718 | "semver": "bin/semver.js" 2719 | }, 2720 | "engines": { 2721 | "node": ">=10" 2722 | } 2723 | }, 2724 | "node_modules/jest-util": { 2725 | "version": "29.7.0", 2726 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.7.0.tgz", 2727 | "integrity": "sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA==", 2728 | "dev": true, 2729 | "dependencies": { 2730 | "@jest/types": "^29.6.3", 2731 | "@types/node": "*", 2732 | "chalk": "^4.0.0", 2733 | "ci-info": "^3.2.0", 2734 | "graceful-fs": "^4.2.9", 2735 | "picomatch": "^2.2.3" 2736 | }, 2737 | "engines": { 2738 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2739 | } 2740 | }, 2741 | "node_modules/jest-validate": { 2742 | "version": "29.7.0", 2743 | "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.7.0.tgz", 2744 | "integrity": "sha512-ZB7wHqaRGVw/9hST/OuFUReG7M8vKeq0/J2egIGLdvjHCmYqGARhzXmtgi+gVeZ5uXFF219aOc3Ls2yLg27tkw==", 2745 | "dev": true, 2746 | "dependencies": { 2747 | "@jest/types": "^29.6.3", 2748 | "camelcase": "^6.2.0", 2749 | "chalk": "^4.0.0", 2750 | "jest-get-type": "^29.6.3", 2751 | "leven": "^3.1.0", 2752 | "pretty-format": "^29.7.0" 2753 | }, 2754 | "engines": { 2755 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2756 | } 2757 | }, 2758 | "node_modules/jest-validate/node_modules/camelcase": { 2759 | "version": "6.3.0", 2760 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2761 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2762 | "dev": true, 2763 | "engines": { 2764 | "node": ">=10" 2765 | }, 2766 | "funding": { 2767 | "url": "https://github.com/sponsors/sindresorhus" 2768 | } 2769 | }, 2770 | "node_modules/jest-watcher": { 2771 | "version": "29.7.0", 2772 | "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.7.0.tgz", 2773 | "integrity": "sha512-49Fg7WXkU3Vl2h6LbLtMQ/HyB6rXSIX7SqvBLQmssRBGN9I0PNvPmAmCWSOY6SOvrjhI/F7/bGAv9RtnsPA03g==", 2774 | "dev": true, 2775 | "dependencies": { 2776 | "@jest/test-result": "^29.7.0", 2777 | "@jest/types": "^29.6.3", 2778 | "@types/node": "*", 2779 | "ansi-escapes": "^4.2.1", 2780 | "chalk": "^4.0.0", 2781 | "emittery": "^0.13.1", 2782 | "jest-util": "^29.7.0", 2783 | "string-length": "^4.0.1" 2784 | }, 2785 | "engines": { 2786 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2787 | } 2788 | }, 2789 | "node_modules/jest-worker": { 2790 | "version": "29.7.0", 2791 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.7.0.tgz", 2792 | "integrity": "sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw==", 2793 | "dev": true, 2794 | "dependencies": { 2795 | "@types/node": "*", 2796 | "jest-util": "^29.7.0", 2797 | "merge-stream": "^2.0.0", 2798 | "supports-color": "^8.0.0" 2799 | }, 2800 | "engines": { 2801 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2802 | } 2803 | }, 2804 | "node_modules/jest-worker/node_modules/supports-color": { 2805 | "version": "8.1.1", 2806 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2807 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2808 | "dev": true, 2809 | "dependencies": { 2810 | "has-flag": "^4.0.0" 2811 | }, 2812 | "engines": { 2813 | "node": ">=10" 2814 | }, 2815 | "funding": { 2816 | "url": "https://github.com/chalk/supports-color?sponsor=1" 2817 | } 2818 | }, 2819 | "node_modules/js-tokens": { 2820 | "version": "4.0.0", 2821 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2822 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2823 | "dev": true 2824 | }, 2825 | "node_modules/js-yaml": { 2826 | "version": "3.14.1", 2827 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2828 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2829 | "dev": true, 2830 | "dependencies": { 2831 | "argparse": "^1.0.7", 2832 | "esprima": "^4.0.0" 2833 | }, 2834 | "bin": { 2835 | "js-yaml": "bin/js-yaml.js" 2836 | } 2837 | }, 2838 | "node_modules/jsesc": { 2839 | "version": "3.1.0", 2840 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", 2841 | "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", 2842 | "dev": true, 2843 | "bin": { 2844 | "jsesc": "bin/jsesc" 2845 | }, 2846 | "engines": { 2847 | "node": ">=6" 2848 | } 2849 | }, 2850 | "node_modules/json-parse-even-better-errors": { 2851 | "version": "2.3.1", 2852 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 2853 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 2854 | "dev": true 2855 | }, 2856 | "node_modules/json5": { 2857 | "version": "2.2.3", 2858 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2859 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2860 | "dev": true, 2861 | "bin": { 2862 | "json5": "lib/cli.js" 2863 | }, 2864 | "engines": { 2865 | "node": ">=6" 2866 | } 2867 | }, 2868 | "node_modules/kleur": { 2869 | "version": "3.0.3", 2870 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", 2871 | "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", 2872 | "dev": true, 2873 | "engines": { 2874 | "node": ">=6" 2875 | } 2876 | }, 2877 | "node_modules/leven": { 2878 | "version": "3.1.0", 2879 | "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", 2880 | "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", 2881 | "dev": true, 2882 | "engines": { 2883 | "node": ">=6" 2884 | } 2885 | }, 2886 | "node_modules/lines-and-columns": { 2887 | "version": "1.2.4", 2888 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 2889 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 2890 | "dev": true 2891 | }, 2892 | "node_modules/locate-path": { 2893 | "version": "5.0.0", 2894 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2895 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2896 | "dev": true, 2897 | "dependencies": { 2898 | "p-locate": "^4.1.0" 2899 | }, 2900 | "engines": { 2901 | "node": ">=8" 2902 | } 2903 | }, 2904 | "node_modules/lodash.memoize": { 2905 | "version": "4.1.2", 2906 | "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", 2907 | "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==", 2908 | "dev": true 2909 | }, 2910 | "node_modules/lru-cache": { 2911 | "version": "5.1.1", 2912 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2913 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2914 | "dev": true, 2915 | "dependencies": { 2916 | "yallist": "^3.0.2" 2917 | } 2918 | }, 2919 | "node_modules/make-dir": { 2920 | "version": "4.0.0", 2921 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", 2922 | "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", 2923 | "dev": true, 2924 | "dependencies": { 2925 | "semver": "^7.5.3" 2926 | }, 2927 | "engines": { 2928 | "node": ">=10" 2929 | }, 2930 | "funding": { 2931 | "url": "https://github.com/sponsors/sindresorhus" 2932 | } 2933 | }, 2934 | "node_modules/make-dir/node_modules/semver": { 2935 | "version": "7.6.3", 2936 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2937 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2938 | "dev": true, 2939 | "bin": { 2940 | "semver": "bin/semver.js" 2941 | }, 2942 | "engines": { 2943 | "node": ">=10" 2944 | } 2945 | }, 2946 | "node_modules/make-error": { 2947 | "version": "1.3.6", 2948 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 2949 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 2950 | "dev": true 2951 | }, 2952 | "node_modules/makeerror": { 2953 | "version": "1.0.12", 2954 | "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", 2955 | "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", 2956 | "dev": true, 2957 | "dependencies": { 2958 | "tmpl": "1.0.5" 2959 | } 2960 | }, 2961 | "node_modules/merge-stream": { 2962 | "version": "2.0.0", 2963 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2964 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2965 | "dev": true 2966 | }, 2967 | "node_modules/micromatch": { 2968 | "version": "4.0.8", 2969 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", 2970 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", 2971 | "dev": true, 2972 | "dependencies": { 2973 | "braces": "^3.0.3", 2974 | "picomatch": "^2.3.1" 2975 | }, 2976 | "engines": { 2977 | "node": ">=8.6" 2978 | } 2979 | }, 2980 | "node_modules/mime-db": { 2981 | "version": "1.52.0", 2982 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2983 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 2984 | "engines": { 2985 | "node": ">= 0.6" 2986 | } 2987 | }, 2988 | "node_modules/mime-types": { 2989 | "version": "2.1.35", 2990 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2991 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2992 | "dependencies": { 2993 | "mime-db": "1.52.0" 2994 | }, 2995 | "engines": { 2996 | "node": ">= 0.6" 2997 | } 2998 | }, 2999 | "node_modules/mimic-fn": { 3000 | "version": "2.1.0", 3001 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 3002 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 3003 | "dev": true, 3004 | "engines": { 3005 | "node": ">=6" 3006 | } 3007 | }, 3008 | "node_modules/minimatch": { 3009 | "version": "3.1.2", 3010 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3011 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3012 | "dev": true, 3013 | "dependencies": { 3014 | "brace-expansion": "^1.1.7" 3015 | }, 3016 | "engines": { 3017 | "node": "*" 3018 | } 3019 | }, 3020 | "node_modules/ms": { 3021 | "version": "2.1.3", 3022 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 3023 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 3024 | "dev": true 3025 | }, 3026 | "node_modules/natural-compare": { 3027 | "version": "1.4.0", 3028 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3029 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 3030 | "dev": true 3031 | }, 3032 | "node_modules/node-int64": { 3033 | "version": "0.4.0", 3034 | "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", 3035 | "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", 3036 | "dev": true 3037 | }, 3038 | "node_modules/node-releases": { 3039 | "version": "2.0.19", 3040 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.19.tgz", 3041 | "integrity": "sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==", 3042 | "dev": true 3043 | }, 3044 | "node_modules/normalize-path": { 3045 | "version": "3.0.0", 3046 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3047 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 3048 | "dev": true, 3049 | "engines": { 3050 | "node": ">=0.10.0" 3051 | } 3052 | }, 3053 | "node_modules/npm-run-path": { 3054 | "version": "4.0.1", 3055 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 3056 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 3057 | "dev": true, 3058 | "dependencies": { 3059 | "path-key": "^3.0.0" 3060 | }, 3061 | "engines": { 3062 | "node": ">=8" 3063 | } 3064 | }, 3065 | "node_modules/once": { 3066 | "version": "1.4.0", 3067 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3068 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3069 | "dev": true, 3070 | "dependencies": { 3071 | "wrappy": "1" 3072 | } 3073 | }, 3074 | "node_modules/onetime": { 3075 | "version": "5.1.2", 3076 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 3077 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 3078 | "dev": true, 3079 | "dependencies": { 3080 | "mimic-fn": "^2.1.0" 3081 | }, 3082 | "engines": { 3083 | "node": ">=6" 3084 | }, 3085 | "funding": { 3086 | "url": "https://github.com/sponsors/sindresorhus" 3087 | } 3088 | }, 3089 | "node_modules/p-limit": { 3090 | "version": "3.1.0", 3091 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3092 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3093 | "dev": true, 3094 | "dependencies": { 3095 | "yocto-queue": "^0.1.0" 3096 | }, 3097 | "engines": { 3098 | "node": ">=10" 3099 | }, 3100 | "funding": { 3101 | "url": "https://github.com/sponsors/sindresorhus" 3102 | } 3103 | }, 3104 | "node_modules/p-locate": { 3105 | "version": "4.1.0", 3106 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 3107 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 3108 | "dev": true, 3109 | "dependencies": { 3110 | "p-limit": "^2.2.0" 3111 | }, 3112 | "engines": { 3113 | "node": ">=8" 3114 | } 3115 | }, 3116 | "node_modules/p-locate/node_modules/p-limit": { 3117 | "version": "2.3.0", 3118 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 3119 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 3120 | "dev": true, 3121 | "dependencies": { 3122 | "p-try": "^2.0.0" 3123 | }, 3124 | "engines": { 3125 | "node": ">=6" 3126 | }, 3127 | "funding": { 3128 | "url": "https://github.com/sponsors/sindresorhus" 3129 | } 3130 | }, 3131 | "node_modules/p-try": { 3132 | "version": "2.2.0", 3133 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 3134 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 3135 | "dev": true, 3136 | "engines": { 3137 | "node": ">=6" 3138 | } 3139 | }, 3140 | "node_modules/parse-json": { 3141 | "version": "5.2.0", 3142 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 3143 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 3144 | "dev": true, 3145 | "dependencies": { 3146 | "@babel/code-frame": "^7.0.0", 3147 | "error-ex": "^1.3.1", 3148 | "json-parse-even-better-errors": "^2.3.0", 3149 | "lines-and-columns": "^1.1.6" 3150 | }, 3151 | "engines": { 3152 | "node": ">=8" 3153 | }, 3154 | "funding": { 3155 | "url": "https://github.com/sponsors/sindresorhus" 3156 | } 3157 | }, 3158 | "node_modules/path-exists": { 3159 | "version": "4.0.0", 3160 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3161 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3162 | "dev": true, 3163 | "engines": { 3164 | "node": ">=8" 3165 | } 3166 | }, 3167 | "node_modules/path-is-absolute": { 3168 | "version": "1.0.1", 3169 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3170 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3171 | "dev": true, 3172 | "engines": { 3173 | "node": ">=0.10.0" 3174 | } 3175 | }, 3176 | "node_modules/path-key": { 3177 | "version": "3.1.1", 3178 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3179 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3180 | "dev": true, 3181 | "engines": { 3182 | "node": ">=8" 3183 | } 3184 | }, 3185 | "node_modules/path-parse": { 3186 | "version": "1.0.7", 3187 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3188 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3189 | "dev": true 3190 | }, 3191 | "node_modules/picocolors": { 3192 | "version": "1.1.1", 3193 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", 3194 | "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==", 3195 | "dev": true 3196 | }, 3197 | "node_modules/picomatch": { 3198 | "version": "2.3.1", 3199 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3200 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3201 | "dev": true, 3202 | "engines": { 3203 | "node": ">=8.6" 3204 | }, 3205 | "funding": { 3206 | "url": "https://github.com/sponsors/jonschlinkert" 3207 | } 3208 | }, 3209 | "node_modules/pirates": { 3210 | "version": "4.0.6", 3211 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", 3212 | "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", 3213 | "dev": true, 3214 | "engines": { 3215 | "node": ">= 6" 3216 | } 3217 | }, 3218 | "node_modules/pkg-dir": { 3219 | "version": "4.2.0", 3220 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 3221 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 3222 | "dev": true, 3223 | "dependencies": { 3224 | "find-up": "^4.0.0" 3225 | }, 3226 | "engines": { 3227 | "node": ">=8" 3228 | } 3229 | }, 3230 | "node_modules/pretty-format": { 3231 | "version": "29.7.0", 3232 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", 3233 | "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", 3234 | "dev": true, 3235 | "dependencies": { 3236 | "@jest/schemas": "^29.6.3", 3237 | "ansi-styles": "^5.0.0", 3238 | "react-is": "^18.0.0" 3239 | }, 3240 | "engines": { 3241 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 3242 | } 3243 | }, 3244 | "node_modules/pretty-format/node_modules/ansi-styles": { 3245 | "version": "5.2.0", 3246 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 3247 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 3248 | "dev": true, 3249 | "engines": { 3250 | "node": ">=10" 3251 | }, 3252 | "funding": { 3253 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 3254 | } 3255 | }, 3256 | "node_modules/prompts": { 3257 | "version": "2.4.2", 3258 | "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", 3259 | "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", 3260 | "dev": true, 3261 | "dependencies": { 3262 | "kleur": "^3.0.3", 3263 | "sisteransi": "^1.0.5" 3264 | }, 3265 | "engines": { 3266 | "node": ">= 6" 3267 | } 3268 | }, 3269 | "node_modules/proxy-from-env": { 3270 | "version": "1.1.0", 3271 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 3272 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 3273 | }, 3274 | "node_modules/pure-rand": { 3275 | "version": "6.1.0", 3276 | "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.1.0.tgz", 3277 | "integrity": "sha512-bVWawvoZoBYpp6yIoQtQXHZjmz35RSVHnUOTefl8Vcjr8snTPY1wnpSPMWekcFwbxI6gtmT7rSYPFvz71ldiOA==", 3278 | "dev": true, 3279 | "funding": [ 3280 | { 3281 | "type": "individual", 3282 | "url": "https://github.com/sponsors/dubzzz" 3283 | }, 3284 | { 3285 | "type": "opencollective", 3286 | "url": "https://opencollective.com/fast-check" 3287 | } 3288 | ] 3289 | }, 3290 | "node_modules/raw-body": { 3291 | "version": "3.0.0", 3292 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.0.tgz", 3293 | "integrity": "sha512-RmkhL8CAyCRPXCE28MMH0z2PNWQBNk2Q09ZdxM9IOOXwxwZbN+qbWaatPkdkWIKL2ZVDImrN/pK5HTRz2PcS4g==", 3294 | "dev": true, 3295 | "dependencies": { 3296 | "bytes": "3.1.2", 3297 | "http-errors": "2.0.0", 3298 | "iconv-lite": "0.6.3", 3299 | "unpipe": "1.0.0" 3300 | }, 3301 | "engines": { 3302 | "node": ">= 0.8" 3303 | } 3304 | }, 3305 | "node_modules/react-is": { 3306 | "version": "18.3.1", 3307 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", 3308 | "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", 3309 | "dev": true 3310 | }, 3311 | "node_modules/require-directory": { 3312 | "version": "2.1.1", 3313 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3314 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 3315 | "dev": true, 3316 | "engines": { 3317 | "node": ">=0.10.0" 3318 | } 3319 | }, 3320 | "node_modules/resolve": { 3321 | "version": "1.22.10", 3322 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.10.tgz", 3323 | "integrity": "sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w==", 3324 | "dev": true, 3325 | "dependencies": { 3326 | "is-core-module": "^2.16.0", 3327 | "path-parse": "^1.0.7", 3328 | "supports-preserve-symlinks-flag": "^1.0.0" 3329 | }, 3330 | "bin": { 3331 | "resolve": "bin/resolve" 3332 | }, 3333 | "engines": { 3334 | "node": ">= 0.4" 3335 | }, 3336 | "funding": { 3337 | "url": "https://github.com/sponsors/ljharb" 3338 | } 3339 | }, 3340 | "node_modules/resolve-cwd": { 3341 | "version": "3.0.0", 3342 | "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", 3343 | "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", 3344 | "dev": true, 3345 | "dependencies": { 3346 | "resolve-from": "^5.0.0" 3347 | }, 3348 | "engines": { 3349 | "node": ">=8" 3350 | } 3351 | }, 3352 | "node_modules/resolve-from": { 3353 | "version": "5.0.0", 3354 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 3355 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 3356 | "dev": true, 3357 | "engines": { 3358 | "node": ">=8" 3359 | } 3360 | }, 3361 | "node_modules/resolve.exports": { 3362 | "version": "2.0.3", 3363 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.3.tgz", 3364 | "integrity": "sha512-OcXjMsGdhL4XnbShKpAcSqPMzQoYkYyhbEaeSko47MjRP9NfEQMhZkXL1DoFlt9LWQn4YttrdnV6X2OiyzBi+A==", 3365 | "dev": true, 3366 | "engines": { 3367 | "node": ">=10" 3368 | } 3369 | }, 3370 | "node_modules/safer-buffer": { 3371 | "version": "2.1.2", 3372 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3373 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 3374 | "dev": true 3375 | }, 3376 | "node_modules/semver": { 3377 | "version": "6.3.1", 3378 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 3379 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 3380 | "dev": true, 3381 | "bin": { 3382 | "semver": "bin/semver.js" 3383 | } 3384 | }, 3385 | "node_modules/setprototypeof": { 3386 | "version": "1.2.0", 3387 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 3388 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", 3389 | "dev": true 3390 | }, 3391 | "node_modules/shebang-command": { 3392 | "version": "2.0.0", 3393 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3394 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3395 | "dev": true, 3396 | "dependencies": { 3397 | "shebang-regex": "^3.0.0" 3398 | }, 3399 | "engines": { 3400 | "node": ">=8" 3401 | } 3402 | }, 3403 | "node_modules/shebang-regex": { 3404 | "version": "3.0.0", 3405 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3406 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3407 | "dev": true, 3408 | "engines": { 3409 | "node": ">=8" 3410 | } 3411 | }, 3412 | "node_modules/signal-exit": { 3413 | "version": "3.0.7", 3414 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 3415 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 3416 | "dev": true 3417 | }, 3418 | "node_modules/sisteransi": { 3419 | "version": "1.0.5", 3420 | "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", 3421 | "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", 3422 | "dev": true 3423 | }, 3424 | "node_modules/slash": { 3425 | "version": "3.0.0", 3426 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3427 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3428 | "dev": true, 3429 | "engines": { 3430 | "node": ">=8" 3431 | } 3432 | }, 3433 | "node_modules/source-map": { 3434 | "version": "0.6.1", 3435 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3436 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3437 | "dev": true, 3438 | "engines": { 3439 | "node": ">=0.10.0" 3440 | } 3441 | }, 3442 | "node_modules/source-map-support": { 3443 | "version": "0.5.13", 3444 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz", 3445 | "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==", 3446 | "dev": true, 3447 | "dependencies": { 3448 | "buffer-from": "^1.0.0", 3449 | "source-map": "^0.6.0" 3450 | } 3451 | }, 3452 | "node_modules/sprintf-js": { 3453 | "version": "1.0.3", 3454 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3455 | "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", 3456 | "dev": true 3457 | }, 3458 | "node_modules/stack-utils": { 3459 | "version": "2.0.6", 3460 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", 3461 | "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", 3462 | "dev": true, 3463 | "dependencies": { 3464 | "escape-string-regexp": "^2.0.0" 3465 | }, 3466 | "engines": { 3467 | "node": ">=10" 3468 | } 3469 | }, 3470 | "node_modules/statuses": { 3471 | "version": "2.0.1", 3472 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 3473 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 3474 | "dev": true, 3475 | "engines": { 3476 | "node": ">= 0.8" 3477 | } 3478 | }, 3479 | "node_modules/string-length": { 3480 | "version": "4.0.2", 3481 | "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", 3482 | "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", 3483 | "dev": true, 3484 | "dependencies": { 3485 | "char-regex": "^1.0.2", 3486 | "strip-ansi": "^6.0.0" 3487 | }, 3488 | "engines": { 3489 | "node": ">=10" 3490 | } 3491 | }, 3492 | "node_modules/string-width": { 3493 | "version": "4.2.3", 3494 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3495 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3496 | "dev": true, 3497 | "dependencies": { 3498 | "emoji-regex": "^8.0.0", 3499 | "is-fullwidth-code-point": "^3.0.0", 3500 | "strip-ansi": "^6.0.1" 3501 | }, 3502 | "engines": { 3503 | "node": ">=8" 3504 | } 3505 | }, 3506 | "node_modules/strip-ansi": { 3507 | "version": "6.0.1", 3508 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3509 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3510 | "dev": true, 3511 | "dependencies": { 3512 | "ansi-regex": "^5.0.1" 3513 | }, 3514 | "engines": { 3515 | "node": ">=8" 3516 | } 3517 | }, 3518 | "node_modules/strip-bom": { 3519 | "version": "4.0.0", 3520 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 3521 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 3522 | "dev": true, 3523 | "engines": { 3524 | "node": ">=8" 3525 | } 3526 | }, 3527 | "node_modules/strip-final-newline": { 3528 | "version": "2.0.0", 3529 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3530 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3531 | "dev": true, 3532 | "engines": { 3533 | "node": ">=6" 3534 | } 3535 | }, 3536 | "node_modules/strip-json-comments": { 3537 | "version": "3.1.1", 3538 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3539 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3540 | "dev": true, 3541 | "engines": { 3542 | "node": ">=8" 3543 | }, 3544 | "funding": { 3545 | "url": "https://github.com/sponsors/sindresorhus" 3546 | } 3547 | }, 3548 | "node_modules/supports-color": { 3549 | "version": "7.2.0", 3550 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3551 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3552 | "dev": true, 3553 | "dependencies": { 3554 | "has-flag": "^4.0.0" 3555 | }, 3556 | "engines": { 3557 | "node": ">=8" 3558 | } 3559 | }, 3560 | "node_modules/supports-preserve-symlinks-flag": { 3561 | "version": "1.0.0", 3562 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3563 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3564 | "dev": true, 3565 | "engines": { 3566 | "node": ">= 0.4" 3567 | }, 3568 | "funding": { 3569 | "url": "https://github.com/sponsors/ljharb" 3570 | } 3571 | }, 3572 | "node_modules/test-exclude": { 3573 | "version": "6.0.0", 3574 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 3575 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 3576 | "dev": true, 3577 | "dependencies": { 3578 | "@istanbuljs/schema": "^0.1.2", 3579 | "glob": "^7.1.4", 3580 | "minimatch": "^3.0.4" 3581 | }, 3582 | "engines": { 3583 | "node": ">=8" 3584 | } 3585 | }, 3586 | "node_modules/tmpl": { 3587 | "version": "1.0.5", 3588 | "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", 3589 | "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", 3590 | "dev": true 3591 | }, 3592 | "node_modules/to-regex-range": { 3593 | "version": "5.0.1", 3594 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3595 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3596 | "dev": true, 3597 | "dependencies": { 3598 | "is-number": "^7.0.0" 3599 | }, 3600 | "engines": { 3601 | "node": ">=8.0" 3602 | } 3603 | }, 3604 | "node_modules/toidentifier": { 3605 | "version": "1.0.1", 3606 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 3607 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 3608 | "dev": true, 3609 | "engines": { 3610 | "node": ">=0.6" 3611 | } 3612 | }, 3613 | "node_modules/ts-jest": { 3614 | "version": "29.2.5", 3615 | "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.2.5.tgz", 3616 | "integrity": "sha512-KD8zB2aAZrcKIdGk4OwpJggeLcH1FgrICqDSROWqlnJXGCXK4Mn6FcdK2B6670Xr73lHMG1kHw8R87A0ecZ+vA==", 3617 | "dev": true, 3618 | "dependencies": { 3619 | "bs-logger": "^0.2.6", 3620 | "ejs": "^3.1.10", 3621 | "fast-json-stable-stringify": "^2.1.0", 3622 | "jest-util": "^29.0.0", 3623 | "json5": "^2.2.3", 3624 | "lodash.memoize": "^4.1.2", 3625 | "make-error": "^1.3.6", 3626 | "semver": "^7.6.3", 3627 | "yargs-parser": "^21.1.1" 3628 | }, 3629 | "bin": { 3630 | "ts-jest": "cli.js" 3631 | }, 3632 | "engines": { 3633 | "node": "^14.15.0 || ^16.10.0 || ^18.0.0 || >=20.0.0" 3634 | }, 3635 | "peerDependencies": { 3636 | "@babel/core": ">=7.0.0-beta.0 <8", 3637 | "@jest/transform": "^29.0.0", 3638 | "@jest/types": "^29.0.0", 3639 | "babel-jest": "^29.0.0", 3640 | "jest": "^29.0.0", 3641 | "typescript": ">=4.3 <6" 3642 | }, 3643 | "peerDependenciesMeta": { 3644 | "@babel/core": { 3645 | "optional": true 3646 | }, 3647 | "@jest/transform": { 3648 | "optional": true 3649 | }, 3650 | "@jest/types": { 3651 | "optional": true 3652 | }, 3653 | "babel-jest": { 3654 | "optional": true 3655 | }, 3656 | "esbuild": { 3657 | "optional": true 3658 | } 3659 | } 3660 | }, 3661 | "node_modules/ts-jest/node_modules/semver": { 3662 | "version": "7.6.3", 3663 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 3664 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 3665 | "dev": true, 3666 | "bin": { 3667 | "semver": "bin/semver.js" 3668 | }, 3669 | "engines": { 3670 | "node": ">=10" 3671 | } 3672 | }, 3673 | "node_modules/ts-node": { 3674 | "version": "10.9.2", 3675 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz", 3676 | "integrity": "sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==", 3677 | "dev": true, 3678 | "dependencies": { 3679 | "@cspotcode/source-map-support": "^0.8.0", 3680 | "@tsconfig/node10": "^1.0.7", 3681 | "@tsconfig/node12": "^1.0.7", 3682 | "@tsconfig/node14": "^1.0.0", 3683 | "@tsconfig/node16": "^1.0.2", 3684 | "acorn": "^8.4.1", 3685 | "acorn-walk": "^8.1.1", 3686 | "arg": "^4.1.0", 3687 | "create-require": "^1.1.0", 3688 | "diff": "^4.0.1", 3689 | "make-error": "^1.1.1", 3690 | "v8-compile-cache-lib": "^3.0.1", 3691 | "yn": "3.1.1" 3692 | }, 3693 | "bin": { 3694 | "ts-node": "dist/bin.js", 3695 | "ts-node-cwd": "dist/bin-cwd.js", 3696 | "ts-node-esm": "dist/bin-esm.js", 3697 | "ts-node-script": "dist/bin-script.js", 3698 | "ts-node-transpile-only": "dist/bin-transpile.js", 3699 | "ts-script": "dist/bin-script-deprecated.js" 3700 | }, 3701 | "peerDependencies": { 3702 | "@swc/core": ">=1.2.50", 3703 | "@swc/wasm": ">=1.2.50", 3704 | "@types/node": "*", 3705 | "typescript": ">=2.7" 3706 | }, 3707 | "peerDependenciesMeta": { 3708 | "@swc/core": { 3709 | "optional": true 3710 | }, 3711 | "@swc/wasm": { 3712 | "optional": true 3713 | } 3714 | } 3715 | }, 3716 | "node_modules/type-detect": { 3717 | "version": "4.0.8", 3718 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3719 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3720 | "dev": true, 3721 | "engines": { 3722 | "node": ">=4" 3723 | } 3724 | }, 3725 | "node_modules/type-fest": { 3726 | "version": "0.21.3", 3727 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3728 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3729 | "dev": true, 3730 | "engines": { 3731 | "node": ">=10" 3732 | }, 3733 | "funding": { 3734 | "url": "https://github.com/sponsors/sindresorhus" 3735 | } 3736 | }, 3737 | "node_modules/typescript": { 3738 | "version": "5.7.2", 3739 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz", 3740 | "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==", 3741 | "dev": true, 3742 | "bin": { 3743 | "tsc": "bin/tsc", 3744 | "tsserver": "bin/tsserver" 3745 | }, 3746 | "engines": { 3747 | "node": ">=14.17" 3748 | } 3749 | }, 3750 | "node_modules/undici-types": { 3751 | "version": "6.19.8", 3752 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", 3753 | "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", 3754 | "dev": true 3755 | }, 3756 | "node_modules/unpipe": { 3757 | "version": "1.0.0", 3758 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3759 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 3760 | "dev": true, 3761 | "engines": { 3762 | "node": ">= 0.8" 3763 | } 3764 | }, 3765 | "node_modules/update-browserslist-db": { 3766 | "version": "1.1.1", 3767 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.1.tgz", 3768 | "integrity": "sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A==", 3769 | "dev": true, 3770 | "funding": [ 3771 | { 3772 | "type": "opencollective", 3773 | "url": "https://opencollective.com/browserslist" 3774 | }, 3775 | { 3776 | "type": "tidelift", 3777 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3778 | }, 3779 | { 3780 | "type": "github", 3781 | "url": "https://github.com/sponsors/ai" 3782 | } 3783 | ], 3784 | "dependencies": { 3785 | "escalade": "^3.2.0", 3786 | "picocolors": "^1.1.0" 3787 | }, 3788 | "bin": { 3789 | "update-browserslist-db": "cli.js" 3790 | }, 3791 | "peerDependencies": { 3792 | "browserslist": ">= 4.21.0" 3793 | } 3794 | }, 3795 | "node_modules/v8-compile-cache-lib": { 3796 | "version": "3.0.1", 3797 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 3798 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 3799 | "dev": true 3800 | }, 3801 | "node_modules/v8-to-istanbul": { 3802 | "version": "9.3.0", 3803 | "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.3.0.tgz", 3804 | "integrity": "sha512-kiGUalWN+rgBJ/1OHZsBtU4rXZOfj/7rKQxULKlIzwzQSvMJUUNgPwJEEh7gU6xEVxC0ahoOBvN2YI8GH6FNgA==", 3805 | "dev": true, 3806 | "dependencies": { 3807 | "@jridgewell/trace-mapping": "^0.3.12", 3808 | "@types/istanbul-lib-coverage": "^2.0.1", 3809 | "convert-source-map": "^2.0.0" 3810 | }, 3811 | "engines": { 3812 | "node": ">=10.12.0" 3813 | } 3814 | }, 3815 | "node_modules/walker": { 3816 | "version": "1.0.8", 3817 | "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", 3818 | "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", 3819 | "dev": true, 3820 | "dependencies": { 3821 | "makeerror": "1.0.12" 3822 | } 3823 | }, 3824 | "node_modules/which": { 3825 | "version": "2.0.2", 3826 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3827 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3828 | "dev": true, 3829 | "dependencies": { 3830 | "isexe": "^2.0.0" 3831 | }, 3832 | "bin": { 3833 | "node-which": "bin/node-which" 3834 | }, 3835 | "engines": { 3836 | "node": ">= 8" 3837 | } 3838 | }, 3839 | "node_modules/wrap-ansi": { 3840 | "version": "7.0.0", 3841 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3842 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3843 | "dev": true, 3844 | "dependencies": { 3845 | "ansi-styles": "^4.0.0", 3846 | "string-width": "^4.1.0", 3847 | "strip-ansi": "^6.0.0" 3848 | }, 3849 | "engines": { 3850 | "node": ">=10" 3851 | }, 3852 | "funding": { 3853 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3854 | } 3855 | }, 3856 | "node_modules/wrappy": { 3857 | "version": "1.0.2", 3858 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3859 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3860 | "dev": true 3861 | }, 3862 | "node_modules/write-file-atomic": { 3863 | "version": "4.0.2", 3864 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", 3865 | "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", 3866 | "dev": true, 3867 | "dependencies": { 3868 | "imurmurhash": "^0.1.4", 3869 | "signal-exit": "^3.0.7" 3870 | }, 3871 | "engines": { 3872 | "node": "^12.13.0 || ^14.15.0 || >=16.0.0" 3873 | } 3874 | }, 3875 | "node_modules/y18n": { 3876 | "version": "5.0.8", 3877 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3878 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3879 | "dev": true, 3880 | "engines": { 3881 | "node": ">=10" 3882 | } 3883 | }, 3884 | "node_modules/yallist": { 3885 | "version": "3.1.1", 3886 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 3887 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 3888 | "dev": true 3889 | }, 3890 | "node_modules/yargs": { 3891 | "version": "17.7.2", 3892 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 3893 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 3894 | "dev": true, 3895 | "dependencies": { 3896 | "cliui": "^8.0.1", 3897 | "escalade": "^3.1.1", 3898 | "get-caller-file": "^2.0.5", 3899 | "require-directory": "^2.1.1", 3900 | "string-width": "^4.2.3", 3901 | "y18n": "^5.0.5", 3902 | "yargs-parser": "^21.1.1" 3903 | }, 3904 | "engines": { 3905 | "node": ">=12" 3906 | } 3907 | }, 3908 | "node_modules/yargs-parser": { 3909 | "version": "21.1.1", 3910 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 3911 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 3912 | "dev": true, 3913 | "engines": { 3914 | "node": ">=12" 3915 | } 3916 | }, 3917 | "node_modules/yn": { 3918 | "version": "3.1.1", 3919 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 3920 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 3921 | "dev": true, 3922 | "engines": { 3923 | "node": ">=6" 3924 | } 3925 | }, 3926 | "node_modules/yocto-queue": { 3927 | "version": "0.1.0", 3928 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3929 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3930 | "dev": true, 3931 | "engines": { 3932 | "node": ">=10" 3933 | }, 3934 | "funding": { 3935 | "url": "https://github.com/sponsors/sindresorhus" 3936 | } 3937 | }, 3938 | "node_modules/zod": { 3939 | "version": "3.24.1", 3940 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.24.1.tgz", 3941 | "integrity": "sha512-muH7gBL9sI1nciMZV67X5fTKKBLtwpZ5VBp1vsOQzj1MhrBZ4wlVCm3gedKZWLp0Oyel8sIGfeiz54Su+OVT+A==", 3942 | "dev": true, 3943 | "funding": { 3944 | "url": "https://github.com/sponsors/colinhacks" 3945 | } 3946 | } 3947 | } 3948 | } 3949 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@hapins/figma-mcp", 3 | "version": "0.1.2", 4 | "description": "A Model Context Protocol server for Figma API integration, enabling seamless interaction with Figma files and components", 5 | "keywords": [ 6 | "figma", 7 | "mcp", 8 | "api", 9 | "typescript", 10 | "claude", 11 | "model-context-protocol" 12 | ], 13 | "repository": { 14 | "type": "git", 15 | "url": "git+https://github.com/hapins/figma-mcp.git" 16 | }, 17 | "author": "hapins", 18 | "license": "MIT", 19 | "bugs": { 20 | "url": "https://github.com/hapins/figma-mcp/issues" 21 | }, 22 | "homepage": "https://github.com/hapins/figma-mcp#readme", 23 | "type": "module", 24 | "bin": { 25 | "figma-mcp": "./build/index.js" 26 | }, 27 | "files": [ 28 | "build/index.js", 29 | "build/index.d.ts", 30 | "build/client/figma.js", 31 | "build/client/figma.d.ts", 32 | "build/types/figma.js", 33 | "build/types/figma.d.ts" 34 | ], 35 | "scripts": { 36 | "build": "tsc && chmod +x build/index.js", 37 | "prepare": "npm run build", 38 | "watch": "tsc --watch", 39 | "inspector": "npx @modelcontextprotocol/inspector build/index.js", 40 | "test": "jest", 41 | "test:watch": "jest --watch", 42 | "test:coverage": "jest --coverage" 43 | }, 44 | "dependencies": { 45 | "axios": "^1.7.9" 46 | }, 47 | "peerDependencies": { 48 | "@modelcontextprotocol/sdk": "0.6.0" 49 | }, 50 | "devDependencies": { 51 | "@modelcontextprotocol/sdk": "0.6.0", 52 | "@types/jest": "^29.5.14", 53 | "@types/node": "^20.11.24", 54 | "jest": "^29.7.0", 55 | "ts-jest": "^29.2.5", 56 | "ts-node": "^10.9.2", 57 | "typescript": "^5.3.3" 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /src/__tests__/index.test.ts: -------------------------------------------------------------------------------- 1 | const mockErrorCode = { 2 | InvalidParams: 'INVALID_PARAMS', 3 | MethodNotFound: 'METHOD_NOT_FOUND', 4 | } as const; 5 | 6 | const mockMcpError = class extends Error { 7 | constructor(public code: string, message: string) { 8 | super(message); 9 | } 10 | }; 11 | 12 | const mockCallToolRequestSchema = Symbol('CallToolRequestSchema'); 13 | const mockListToolsRequestSchema = Symbol('ListToolsRequestSchema'); 14 | 15 | jest.mock('@modelcontextprotocol/sdk/types', () => ({ 16 | ErrorCode: mockErrorCode, 17 | McpError: mockMcpError, 18 | CallToolRequestSchema: mockCallToolRequestSchema, 19 | ListToolsRequestSchema: mockListToolsRequestSchema, 20 | })); 21 | import { FigmaClient } from '../client/figma'; 22 | import { DocumentNode } from '../types/figma'; 23 | 24 | jest.mock('../client/figma'); 25 | 26 | const mockServer = { 27 | setRequestHandler: jest.fn().mockReturnThis(), 28 | connect: jest.fn(), 29 | close: jest.fn(), 30 | onerror: jest.fn(), 31 | }; 32 | 33 | jest.mock('@modelcontextprotocol/sdk/server/index', () => ({ 34 | Server: jest.fn().mockImplementation(() => mockServer), 35 | })); 36 | 37 | jest.mock('@modelcontextprotocol/sdk/server/stdio', () => ({ 38 | StdioServerTransport: jest.fn(), 39 | })); 40 | 41 | describe('FigmaServer', () => { 42 | const mockAccessToken = 'mock-token'; 43 | let originalEnv: NodeJS.ProcessEnv; 44 | 45 | beforeEach(() => { 46 | originalEnv = process.env; 47 | process.env = { ...originalEnv, FIGMA_ACCESS_TOKEN: mockAccessToken }; 48 | }); 49 | 50 | afterEach(() => { 51 | process.env = originalEnv; 52 | jest.clearAllMocks(); 53 | }); 54 | 55 | describe('initialization', () => { 56 | it('should throw error if FIGMA_ACCESS_TOKEN is not provided', () => { 57 | delete process.env.FIGMA_ACCESS_TOKEN; 58 | jest.isolateModules(() => { 59 | expect(() => { 60 | require('../index'); 61 | }).toThrow( 62 | 'FIGMA_ACCESS_TOKEN is required. Provide it via environment variable or config file.' 63 | ); 64 | }); 65 | }); 66 | 67 | it('should initialize server with correct config', () => { 68 | const { Server } = require('@modelcontextprotocol/sdk/server/index'); 69 | jest.isolateModules(() => { 70 | require('../index'); 71 | }); 72 | expect(Server).toHaveBeenCalledWith( 73 | { 74 | name: 'figma-mcp-server', 75 | version: '0.1.0', 76 | }, 77 | { 78 | capabilities: { 79 | tools: {}, 80 | }, 81 | } 82 | ); 83 | }); 84 | 85 | it('should initialize FigmaClient with access token', () => { 86 | jest.isolateModules(() => { 87 | require('../index'); 88 | }); 89 | expect(FigmaClient).toHaveBeenCalledWith(mockAccessToken); 90 | }); 91 | }); 92 | 93 | describe('tool handlers', () => { 94 | let mockFigmaClient: jest.Mocked; 95 | 96 | beforeEach(() => { 97 | mockFigmaClient = { 98 | getFileInfo: jest.fn(), 99 | } as unknown as jest.Mocked; 100 | 101 | (FigmaClient as jest.Mock).mockImplementation(() => mockFigmaClient); 102 | 103 | // Initialize server with mock handlers 104 | jest.isolateModules(() => { 105 | require('../index'); 106 | }); 107 | }); 108 | 109 | it('should handle get_file_info tool', async () => { 110 | const mockFileData = { 111 | document: { 112 | id: 'doc-1', 113 | name: 'Test', 114 | type: 'DOCUMENT', 115 | children: [], 116 | } as DocumentNode, 117 | }; 118 | mockFigmaClient.getFileInfo.mockResolvedValueOnce(mockFileData); 119 | 120 | const request = { 121 | params: { 122 | name: 'get_file_info', 123 | arguments: { 124 | file_key: 'file-1', 125 | depth: 2, 126 | }, 127 | }, 128 | }; 129 | 130 | const handlers = mockServer.setRequestHandler.mock.calls; 131 | const [schema, handler] = 132 | handlers.find(([s]) => s === mockCallToolRequestSchema) || []; 133 | 134 | if (!handler) { 135 | throw new Error('Handler not found'); 136 | } 137 | 138 | const response = await handler(request); 139 | expect(response).toEqual({ 140 | content: [ 141 | { type: 'text', text: JSON.stringify(mockFileData, null, 2) }, 142 | ], 143 | }); 144 | }); 145 | 146 | it('should handle errors', async () => { 147 | mockFigmaClient.getFileInfo.mockRejectedValueOnce(new Error('API Error')); 148 | 149 | const request = { 150 | params: { 151 | name: 'get_file_info', 152 | arguments: { 153 | file_key: 'file-1', 154 | }, 155 | }, 156 | }; 157 | 158 | const handlers = mockServer.setRequestHandler.mock.calls; 159 | const [schema, handler] = 160 | handlers.find(([s]) => s === mockCallToolRequestSchema) || []; 161 | 162 | if (!handler) { 163 | throw new Error('Handler not found'); 164 | } 165 | 166 | const response = await handler(request); 167 | expect(response).toEqual({ 168 | content: [{ type: 'text', text: 'Figma API error: API Error' }], 169 | isError: true, 170 | }); 171 | }); 172 | 173 | it('should validate required parameters', async () => { 174 | const request = { 175 | params: { 176 | name: 'get_file_info', 177 | arguments: {}, 178 | }, 179 | }; 180 | 181 | const handlers = mockServer.setRequestHandler.mock.calls; 182 | const [schema, handler] = 183 | handlers.find(([s]) => s === mockCallToolRequestSchema) || []; 184 | 185 | if (!handler) { 186 | throw new Error('Handler not found'); 187 | } 188 | 189 | await expect(handler(request)).rejects.toThrow( 190 | new mockMcpError(mockErrorCode.InvalidParams, 'file_key is required') 191 | ); 192 | }); 193 | }); 194 | }); 195 | -------------------------------------------------------------------------------- /src/client/__tests__/figma.test.ts: -------------------------------------------------------------------------------- 1 | import axios from 'axios'; 2 | import { FigmaClient } from '../figma'; 3 | 4 | jest.mock('axios'); 5 | const mockedAxios = axios as jest.Mocked; 6 | 7 | describe('FigmaClient', () => { 8 | const mockAccessToken = 'mock-token'; 9 | let client: FigmaClient; 10 | let mockGet: jest.Mock; 11 | 12 | beforeEach(() => { 13 | mockGet = jest.fn(); 14 | mockedAxios.create = jest.fn().mockReturnValue({ 15 | get: mockGet, 16 | } as any); 17 | client = new FigmaClient(mockAccessToken); 18 | }); 19 | 20 | afterEach(() => { 21 | jest.clearAllMocks(); 22 | }); 23 | 24 | describe('listFiles', () => { 25 | it('should list files with project_id', async () => { 26 | const mockResponse = { data: { files: [] } }; 27 | mockGet.mockResolvedValueOnce(mockResponse); 28 | 29 | const result = await client.listFiles({ project_id: 'project-1' }); 30 | expect(result).toEqual(mockResponse.data); 31 | expect(mockGet).toHaveBeenCalledWith('/files', { 32 | params: { project_id: 'project-1' }, 33 | }); 34 | }); 35 | 36 | it('should list files with team_id', async () => { 37 | const mockResponse = { data: { files: [] } }; 38 | mockGet.mockResolvedValueOnce(mockResponse); 39 | 40 | const result = await client.listFiles({ team_id: 'team-1' }); 41 | expect(result).toEqual(mockResponse.data); 42 | expect(mockGet).toHaveBeenCalledWith('/files', { 43 | params: { team_id: 'team-1' }, 44 | }); 45 | }); 46 | }); 47 | 48 | describe('error handling', () => { 49 | it('should propagate API errors', async () => { 50 | const mockError = new Error('API Error'); 51 | mockGet.mockRejectedValueOnce(mockError); 52 | 53 | await expect( 54 | client.listFiles({ project_id: 'project-1' }) 55 | ).rejects.toThrow(mockError); 56 | }); 57 | }); 58 | }); 59 | -------------------------------------------------------------------------------- /src/client/figma.ts: -------------------------------------------------------------------------------- 1 | import axios, { AxiosInstance } from 'axios'; 2 | 3 | export class FigmaClient { 4 | private client: AxiosInstance; 5 | 6 | constructor(accessToken: string) { 7 | this.client = axios.create({ 8 | baseURL: 'https://api.figma.com/v1', 9 | headers: { 10 | 'X-Figma-Token': accessToken, 11 | }, 12 | }); 13 | } 14 | 15 | async listFiles(params: { project_id?: string; team_id?: string }) { 16 | const response = await this.client.get('/files', { params }); 17 | return response.data; 18 | } 19 | 20 | async getFileInfo( 21 | fileKey: string, 22 | options?: { depth?: number; node_id?: string } 23 | ) { 24 | const response = await this.client.get(`/files/${fileKey}`, { 25 | params: options, 26 | }); 27 | return response.data; 28 | } 29 | 30 | async getComponents(fileKey: string) { 31 | const response = await this.client.get(`/files/${fileKey}/components`); 32 | return response.data; 33 | } 34 | 35 | async getStyles(fileKey: string) { 36 | const response = await this.client.get(`/files/${fileKey}/styles`); 37 | return response.data; 38 | } 39 | 40 | async getFileVersions(fileKey: string) { 41 | const response = await this.client.get(`/files/${fileKey}/versions`); 42 | return response.data; 43 | } 44 | 45 | async getFileComments(fileKey: string) { 46 | const response = await this.client.get(`/files/${fileKey}/comments`); 47 | return response.data; 48 | } 49 | 50 | async getFileNodes(fileKey: string, ids: string[]) { 51 | const response = await this.client.get(`/files/${fileKey}/nodes`, { 52 | params: { ids: ids.join(',') }, 53 | }); 54 | return response.data; 55 | } 56 | } 57 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | import fs from 'fs'; 3 | import { Server } from '@modelcontextprotocol/sdk/server/index.js'; 4 | import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js'; 5 | import { 6 | CallToolRequestSchema, 7 | ErrorCode, 8 | ListToolsRequestSchema, 9 | McpError, 10 | Request, 11 | } from '@modelcontextprotocol/sdk/types.js'; 12 | import { FigmaClient } from './client/figma.js'; 13 | 14 | function loadConfig(): { figmaAccessToken: string } { 15 | const configArg = process.argv.find((arg) => arg.startsWith('--config=')); 16 | if (configArg) { 17 | const configPath = configArg.split('=')[1]; 18 | try { 19 | console.debug('[MCP Debug] Loading config from', configPath); 20 | const config = JSON.parse(fs.readFileSync(configPath, 'utf-8')); 21 | const token = config.mcpServers?.figma?.env?.FIGMA_ACCESS_TOKEN; 22 | if (token) { 23 | console.debug('[MCP Debug] Config loaded successfully'); 24 | return { figmaAccessToken: token }; 25 | } 26 | } catch (error) { 27 | console.error('[MCP Error] Failed to load config', error); 28 | } 29 | } 30 | 31 | const token = process.env.FIGMA_ACCESS_TOKEN; 32 | if (!token) { 33 | console.error('[MCP Error] FIGMA_ACCESS_TOKEN not found'); 34 | throw new Error( 35 | 'FIGMA_ACCESS_TOKEN is required. Provide it via environment variable or config file.' 36 | ); 37 | } 38 | 39 | console.debug('[MCP Debug] Using FIGMA_ACCESS_TOKEN from environment'); 40 | return { figmaAccessToken: token }; 41 | } 42 | 43 | function getFigmaAccessToken(): string { 44 | const { figmaAccessToken } = loadConfig(); 45 | console.debug( 46 | '[MCP Debug] Access token found', 47 | figmaAccessToken.substring(0, 8) + '...' 48 | ); 49 | return figmaAccessToken; 50 | } 51 | 52 | class FigmaServer { 53 | private server: Server; 54 | private figmaClient: FigmaClient; 55 | 56 | constructor() { 57 | console.debug('[MCP Debug] Initializing Figma MCP server'); 58 | this.server = new Server( 59 | { 60 | name: 'figma-mcp-server', 61 | version: '0.1.0', 62 | }, 63 | { 64 | capabilities: { 65 | tools: {}, 66 | }, 67 | } 68 | ); 69 | 70 | this.figmaClient = new FigmaClient(getFigmaAccessToken()); 71 | this.setupToolHandlers(); 72 | 73 | this.server.onerror = (error: Error) => { 74 | console.error('[MCP Error]', { 75 | name: error.name, 76 | message: error.message, 77 | stack: error.stack, 78 | }); 79 | }; 80 | 81 | process.on('SIGINT', async () => { 82 | console.debug('[MCP Debug] Shutting down server'); 83 | await this.server.close(); 84 | process.exit(0); 85 | }); 86 | } 87 | 88 | private setupToolHandlers() { 89 | console.debug('[MCP Debug] Setting up tool handlers'); 90 | this.server.setRequestHandler(ListToolsRequestSchema, async () => ({ 91 | tools: [ 92 | { 93 | name: 'list_files', 94 | description: 'List files in a project or team', 95 | inputSchema: { 96 | type: 'object', 97 | properties: { 98 | project_id: { 99 | type: 'string', 100 | description: 'Project ID to list files from', 101 | }, 102 | team_id: { 103 | type: 'string', 104 | description: 'Team ID to list files from', 105 | }, 106 | }, 107 | }, 108 | }, 109 | { 110 | name: 'get_file_versions', 111 | description: 'Get version history of a Figma file', 112 | inputSchema: { 113 | type: 'object', 114 | properties: { 115 | file_key: { 116 | type: 'string', 117 | description: 'Figma file key', 118 | }, 119 | }, 120 | required: ['file_key'], 121 | }, 122 | }, 123 | { 124 | name: 'get_file_comments', 125 | description: 'Get comments on a Figma file', 126 | inputSchema: { 127 | type: 'object', 128 | properties: { 129 | file_key: { 130 | type: 'string', 131 | description: 'Figma file key', 132 | }, 133 | }, 134 | required: ['file_key'], 135 | }, 136 | }, 137 | { 138 | name: 'get_file_info', 139 | description: 'Get Figma file information', 140 | inputSchema: { 141 | type: 'object', 142 | properties: { 143 | file_key: { 144 | type: 'string', 145 | description: 'Figma file key', 146 | }, 147 | depth: { 148 | type: 'number', 149 | description: 150 | 'Maximum depth to traverse the node tree (1-4 recommended)', 151 | minimum: 1, 152 | }, 153 | node_id: { 154 | type: 'string', 155 | description: 'ID of a specific node to fetch', 156 | }, 157 | }, 158 | required: ['file_key'], 159 | }, 160 | }, 161 | { 162 | name: 'get_components', 163 | description: 'Get components from a Figma file', 164 | inputSchema: { 165 | type: 'object', 166 | properties: { 167 | file_key: { 168 | type: 'string', 169 | description: 'Figma file key', 170 | }, 171 | }, 172 | required: ['file_key'], 173 | }, 174 | }, 175 | { 176 | name: 'get_styles', 177 | description: 'Get styles from a Figma file', 178 | inputSchema: { 179 | type: 'object', 180 | properties: { 181 | file_key: { 182 | type: 'string', 183 | description: 'Figma file key', 184 | }, 185 | }, 186 | required: ['file_key'], 187 | }, 188 | }, 189 | { 190 | name: 'get_file_nodes', 191 | description: 'Get specific nodes from a Figma file', 192 | inputSchema: { 193 | type: 'object', 194 | properties: { 195 | file_key: { 196 | type: 'string', 197 | description: 'Figma file key', 198 | }, 199 | ids: { 200 | type: 'array', 201 | items: { 202 | type: 'string', 203 | }, 204 | description: 'Array of node IDs to retrieve', 205 | }, 206 | }, 207 | required: ['file_key', 'ids'], 208 | }, 209 | }, 210 | ], 211 | })); 212 | 213 | this.server.setRequestHandler(CallToolRequestSchema, async (request) => { 214 | console.debug('[MCP Debug] Request', { 215 | tool: request.params.name, 216 | arguments: request.params.arguments, 217 | }); 218 | 219 | try { 220 | switch (request.params.name) { 221 | case 'get_file_info': { 222 | const args = request.params.arguments as { 223 | file_key: string; 224 | depth?: number; 225 | node_id?: string; 226 | }; 227 | if (!args.file_key) { 228 | throw new McpError( 229 | ErrorCode.InvalidParams, 230 | 'file_key is required' 231 | ); 232 | } 233 | console.debug('[MCP Debug] Fetching file info', { 234 | fileKey: args.file_key, 235 | depth: args.depth, 236 | nodeId: args.node_id, 237 | }); 238 | const data = await this.figmaClient.getFileInfo(args.file_key, { 239 | depth: args.depth, 240 | node_id: args.node_id, 241 | }); 242 | console.debug('[MCP Debug] File info fetched successfully'); 243 | 244 | try { 245 | const jsonString = JSON.stringify(data, null, 2); 246 | const sizeInMB = jsonString.length / (1024 * 1024); 247 | console.debug( 248 | '[MCP Debug] Response size', 249 | sizeInMB.toFixed(2), 250 | 'MB' 251 | ); 252 | 253 | return { 254 | content: [{ type: 'text', text: jsonString }], 255 | }; 256 | } catch (error) { 257 | console.error('[MCP Error] JSON stringify error', error); 258 | const suggestion = args.node_id 259 | ? 'Try requesting a child node instead.' 260 | : 'Try using a smaller depth value or specifying a node_id.'; 261 | throw new McpError( 262 | ErrorCode.InternalError, 263 | `Response size too large. ${suggestion}` 264 | ); 265 | } 266 | } 267 | 268 | case 'get_components': { 269 | const args = request.params.arguments as { file_key: string }; 270 | if (!args.file_key) { 271 | throw new McpError( 272 | ErrorCode.InvalidParams, 273 | 'file_key is required' 274 | ); 275 | } 276 | console.debug('[MCP Debug] Fetching components', { 277 | fileKey: args.file_key, 278 | }); 279 | const data = await this.figmaClient.getComponents(args.file_key); 280 | console.debug('[MCP Debug] Components fetched successfully'); 281 | return { 282 | content: [{ type: 'text', text: JSON.stringify(data, null, 2) }], 283 | }; 284 | } 285 | 286 | case 'get_styles': { 287 | const args = request.params.arguments as { file_key: string }; 288 | if (!args.file_key) { 289 | throw new McpError( 290 | ErrorCode.InvalidParams, 291 | 'file_key is required' 292 | ); 293 | } 294 | console.debug('[MCP Debug] Fetching styles', { 295 | fileKey: args.file_key, 296 | }); 297 | const data = await this.figmaClient.getStyles(args.file_key); 298 | console.debug('[MCP Debug] Styles fetched successfully'); 299 | return { 300 | content: [{ type: 'text', text: JSON.stringify(data, null, 2) }], 301 | }; 302 | } 303 | 304 | case 'list_files': { 305 | const args = request.params.arguments as { 306 | project_id?: string; 307 | team_id?: string; 308 | }; 309 | console.debug('[MCP Debug] Listing files', args); 310 | const data = await this.figmaClient.listFiles(args); 311 | console.debug('[MCP Debug] Files listed successfully'); 312 | return { 313 | content: [{ type: 'text', text: JSON.stringify(data, null, 2) }], 314 | }; 315 | } 316 | 317 | case 'get_file_versions': { 318 | const args = request.params.arguments as { file_key: string }; 319 | if (!args.file_key) { 320 | throw new McpError( 321 | ErrorCode.InvalidParams, 322 | 'file_key is required' 323 | ); 324 | } 325 | console.debug('[MCP Debug] Fetching file versions', { 326 | fileKey: args.file_key, 327 | }); 328 | const data = await this.figmaClient.getFileVersions(args.file_key); 329 | console.debug('[MCP Debug] File versions fetched successfully'); 330 | return { 331 | content: [{ type: 'text', text: JSON.stringify(data, null, 2) }], 332 | }; 333 | } 334 | 335 | case 'get_file_comments': { 336 | const args = request.params.arguments as { file_key: string }; 337 | if (!args.file_key) { 338 | throw new McpError( 339 | ErrorCode.InvalidParams, 340 | 'file_key is required' 341 | ); 342 | } 343 | console.debug('[MCP Debug] Fetching file comments', { 344 | fileKey: args.file_key, 345 | }); 346 | const data = await this.figmaClient.getFileComments(args.file_key); 347 | console.debug('[MCP Debug] File comments fetched successfully'); 348 | return { 349 | content: [{ type: 'text', text: JSON.stringify(data, null, 2) }], 350 | }; 351 | } 352 | 353 | case 'get_file_nodes': { 354 | const args = request.params.arguments as { 355 | file_key: string; 356 | ids: string[]; 357 | }; 358 | if (!args.file_key) { 359 | throw new McpError( 360 | ErrorCode.InvalidParams, 361 | 'file_key is required' 362 | ); 363 | } 364 | if ( 365 | !args.ids || 366 | !Array.isArray(args.ids) || 367 | args.ids.length === 0 368 | ) { 369 | throw new McpError( 370 | ErrorCode.InvalidParams, 371 | 'ids array is required and must not be empty' 372 | ); 373 | } 374 | console.debug('[MCP Debug] Fetching file nodes', { 375 | fileKey: args.file_key, 376 | ids: args.ids, 377 | }); 378 | const data = await this.figmaClient.getFileNodes( 379 | args.file_key, 380 | args.ids 381 | ); 382 | console.debug('[MCP Debug] File nodes fetched successfully'); 383 | return { 384 | content: [{ type: 'text', text: JSON.stringify(data, null, 2) }], 385 | }; 386 | } 387 | 388 | default: 389 | throw new McpError( 390 | ErrorCode.MethodNotFound, 391 | `Unknown tool: ${request.params.name}` 392 | ); 393 | } 394 | } catch (error: any) { 395 | console.error('[MCP Error]', { 396 | tool: request.params.name, 397 | arguments: request.params.arguments, 398 | error: { 399 | name: error.name, 400 | message: error.message, 401 | stack: error.stack, 402 | }, 403 | }); 404 | 405 | if (error instanceof McpError) { 406 | throw error; 407 | } 408 | return { 409 | content: [ 410 | { 411 | type: 'text', 412 | text: `Figma API error: ${error.message}`, 413 | }, 414 | ], 415 | isError: true, 416 | }; 417 | } 418 | }); 419 | } 420 | 421 | async run() { 422 | const transport = new StdioServerTransport(); 423 | await this.server.connect(transport); 424 | console.debug('Figma MCP server running on stdio'); 425 | } 426 | } 427 | 428 | const server = new FigmaServer(); 429 | server.run().catch((error) => { 430 | console.error('[MCP Fatal Error]', { 431 | name: error.name, 432 | message: error.message, 433 | stack: error.stack, 434 | }); 435 | process.exit(1); 436 | }); 437 | -------------------------------------------------------------------------------- /src/types/figma.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Represents a color in RGBA format. 3 | */ 4 | export interface Color { 5 | r: number; 6 | g: number; 7 | b: number; 8 | a: number; 9 | } 10 | 11 | /** 12 | * Represents a 2D vector with x and y coordinates. 13 | */ 14 | export interface Vector { 15 | x: number; 16 | y: number; 17 | } 18 | 19 | /** 20 | * Represents a rectangle with position and dimensions. 21 | */ 22 | export interface Rectangle { 23 | x: number; 24 | y: number; 25 | width: number; 26 | height: number; 27 | } 28 | 29 | /** 30 | * Represents a 2D transformation matrix. 31 | */ 32 | export interface Transform { 33 | matrix: [[number, number, number], [number, number, number]]; 34 | } 35 | 36 | /** 37 | * Represents layout constraints for auto-layout frames. 38 | */ 39 | export interface LayoutConstraint { 40 | vertical: 'TOP' | 'BOTTOM' | 'CENTER' | 'TOP_BOTTOM' | 'SCALE'; 41 | horizontal: 'LEFT' | 'RIGHT' | 'CENTER' | 'LEFT_RIGHT' | 'SCALE'; 42 | } 43 | 44 | /** 45 | * Represents the blending mode for layers. 46 | */ 47 | export interface BlendMode { 48 | type: 49 | | 'PASS_THROUGH' 50 | | 'NORMAL' 51 | | 'DARKEN' 52 | | 'MULTIPLY' 53 | | 'LINEAR_BURN' 54 | | 'COLOR_BURN' 55 | | 'LIGHTEN' 56 | | 'SCREEN' 57 | | 'LINEAR_DODGE' 58 | | 'COLOR_DODGE' 59 | | 'OVERLAY' 60 | | 'SOFT_LIGHT' 61 | | 'HARD_LIGHT' 62 | | 'DIFFERENCE' 63 | | 'EXCLUSION' 64 | | 'HUE' 65 | | 'SATURATION' 66 | | 'COLOR' 67 | | 'LUMINOSITY'; 68 | } 69 | 70 | /** 71 | * Represents a paint style that can be solid color, gradient, or image. 72 | */ 73 | export interface Paint { 74 | type: 75 | | 'SOLID' 76 | | 'GRADIENT_LINEAR' 77 | | 'GRADIENT_RADIAL' 78 | | 'GRADIENT_ANGULAR' 79 | | 'GRADIENT_DIAMOND' 80 | | 'IMAGE' 81 | | 'EMOJI'; 82 | visible?: boolean; 83 | opacity?: number; 84 | color?: Color; 85 | gradientHandlePositions?: Vector[]; 86 | gradientStops?: { position: number; color: Color }[]; 87 | imageRef?: string; 88 | scaleMode?: 'FILL' | 'FIT' | 'TILE' | 'STRETCH'; 89 | } 90 | 91 | /** 92 | * Represents a visual effect like shadows or blurs. 93 | */ 94 | export interface Effect { 95 | type: 'INNER_SHADOW' | 'DROP_SHADOW' | 'LAYER_BLUR' | 'BACKGROUND_BLUR'; 96 | visible?: boolean; 97 | radius?: number; 98 | color?: Color; 99 | offset?: Vector; 100 | spread?: number; 101 | } 102 | 103 | /** 104 | * Base interface for all Figma nodes. 105 | */ 106 | export interface BaseNode { 107 | id: string; 108 | name: string; 109 | visible?: boolean; 110 | type: string; 111 | pluginData?: { [key: string]: any }; 112 | sharedPluginData?: { [namespace: string]: { [key: string]: any } }; 113 | } 114 | 115 | /** 116 | * Represents the root node of a Figma document. 117 | */ 118 | export interface DocumentNode extends BaseNode { 119 | type: 'DOCUMENT'; 120 | children: SceneNode[]; 121 | } 122 | 123 | /** 124 | * Represents a canvas/artboard in a Figma document. 125 | */ 126 | export interface CanvasNode extends BaseNode { 127 | type: 'CANVAS'; 128 | children: SceneNode[]; 129 | backgroundColor: Color; 130 | exportSettings?: ExportSetting[]; 131 | } 132 | 133 | /** 134 | * Represents a frame in Figma, which can contain other nodes. 135 | */ 136 | export interface FrameNode extends BaseNode { 137 | type: 'FRAME'; 138 | children: SceneNode[]; 139 | locked?: boolean; 140 | background: Paint[]; 141 | backgroundColor?: Color; 142 | exportSettings?: ExportSetting[]; 143 | blendMode?: BlendMode; 144 | preserveRatio?: boolean; 145 | constraints?: LayoutConstraint; 146 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 147 | layoutGrow?: number; 148 | clipsContent?: boolean; 149 | layoutMode?: 'NONE' | 'HORIZONTAL' | 'VERTICAL'; 150 | primaryAxisSizingMode?: 'FIXED' | 'AUTO'; 151 | counterAxisSizingMode?: 'FIXED' | 'AUTO'; 152 | primaryAxisAlignItems?: 'MIN' | 'CENTER' | 'MAX' | 'SPACE_BETWEEN'; 153 | counterAxisAlignItems?: 'MIN' | 'CENTER' | 'MAX'; 154 | paddingLeft?: number; 155 | paddingRight?: number; 156 | paddingTop?: number; 157 | paddingBottom?: number; 158 | itemSpacing?: number; 159 | } 160 | 161 | /** 162 | * Represents a group of nodes in Figma. 163 | */ 164 | export interface GroupNode extends BaseNode { 165 | type: 'GROUP'; 166 | children: SceneNode[]; 167 | locked?: boolean; 168 | exportSettings?: ExportSetting[]; 169 | blendMode?: BlendMode; 170 | preserveRatio?: boolean; 171 | constraints?: LayoutConstraint; 172 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 173 | layoutGrow?: number; 174 | } 175 | 176 | /** 177 | * Represents a vector node in Figma. 178 | */ 179 | export interface VectorNode extends BaseNode { 180 | type: 'VECTOR'; 181 | locked?: boolean; 182 | exportSettings?: ExportSetting[]; 183 | blendMode?: BlendMode; 184 | preserveRatio?: boolean; 185 | constraints?: LayoutConstraint; 186 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 187 | layoutGrow?: number; 188 | strokeWeight?: number; 189 | strokeAlign?: 'INSIDE' | 'OUTSIDE' | 'CENTER'; 190 | strokeCap?: 'NONE' | 'ROUND' | 'SQUARE' | 'LINE_ARROW' | 'TRIANGLE_ARROW'; 191 | strokeJoin?: 'MITER' | 'BEVEL' | 'ROUND'; 192 | strokeMiterLimit?: number; 193 | strokeGeometry?: Path[]; 194 | fillGeometry?: Path[]; 195 | fills?: Paint[]; 196 | strokes?: Paint[]; 197 | effects?: Effect[]; 198 | } 199 | 200 | /** 201 | * Represents a boolean operation (union, intersection, etc.) between shapes. 202 | */ 203 | export interface BooleanOperationNode extends BaseNode { 204 | type: 'BOOLEAN_OPERATION'; 205 | children: SceneNode[]; 206 | locked?: boolean; 207 | exportSettings?: ExportSetting[]; 208 | blendMode?: BlendMode; 209 | preserveRatio?: boolean; 210 | constraints?: LayoutConstraint; 211 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 212 | layoutGrow?: number; 213 | booleanOperation: 'UNION' | 'INTERSECT' | 'SUBTRACT' | 'EXCLUDE'; 214 | } 215 | 216 | /** 217 | * Represents a star shape in Figma. 218 | */ 219 | export interface StarNode extends BaseNode { 220 | type: 'STAR'; 221 | locked?: boolean; 222 | exportSettings?: ExportSetting[]; 223 | blendMode?: BlendMode; 224 | preserveRatio?: boolean; 225 | constraints?: LayoutConstraint; 226 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 227 | layoutGrow?: number; 228 | fills?: Paint[]; 229 | strokes?: Paint[]; 230 | strokeWeight?: number; 231 | strokeAlign?: 'INSIDE' | 'OUTSIDE' | 'CENTER'; 232 | effects?: Effect[]; 233 | pointCount: number; 234 | innerRadius: number; 235 | } 236 | 237 | /** 238 | * Represents a line in Figma. 239 | */ 240 | export interface LineNode extends BaseNode { 241 | type: 'LINE'; 242 | locked?: boolean; 243 | exportSettings?: ExportSetting[]; 244 | blendMode?: BlendMode; 245 | preserveRatio?: boolean; 246 | constraints?: LayoutConstraint; 247 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 248 | layoutGrow?: number; 249 | strokes?: Paint[]; 250 | strokeWeight?: number; 251 | strokeAlign?: 'INSIDE' | 'OUTSIDE' | 'CENTER'; 252 | strokeCap?: 'NONE' | 'ROUND' | 'SQUARE' | 'LINE_ARROW' | 'TRIANGLE_ARROW'; 253 | effects?: Effect[]; 254 | } 255 | 256 | /** 257 | * Represents a text node in Figma. 258 | */ 259 | export interface TextNode extends BaseNode { 260 | type: 'TEXT'; 261 | locked?: boolean; 262 | exportSettings?: ExportSetting[]; 263 | blendMode?: BlendMode; 264 | preserveRatio?: boolean; 265 | constraints?: LayoutConstraint; 266 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 267 | layoutGrow?: number; 268 | characters: string; 269 | style: TypeStyle; 270 | characterStyleOverrides?: number[]; 271 | styleOverrideTable?: { [index: number]: TypeStyle }; 272 | } 273 | 274 | /** 275 | * Represents a component definition in Figma. 276 | */ 277 | export interface ComponentNode extends BaseNode { 278 | type: 'COMPONENT'; 279 | children: SceneNode[]; 280 | locked?: boolean; 281 | exportSettings?: ExportSetting[]; 282 | blendMode?: BlendMode; 283 | preserveRatio?: boolean; 284 | constraints?: LayoutConstraint; 285 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 286 | layoutGrow?: number; 287 | componentId: string; 288 | } 289 | 290 | /** 291 | * Represents an instance of a component in Figma. 292 | */ 293 | export interface InstanceNode extends BaseNode { 294 | type: 'INSTANCE'; 295 | children: SceneNode[]; 296 | locked?: boolean; 297 | exportSettings?: ExportSetting[]; 298 | blendMode?: BlendMode; 299 | preserveRatio?: boolean; 300 | constraints?: LayoutConstraint; 301 | layoutAlign?: 'MIN' | 'CENTER' | 'MAX' | 'STRETCH'; 302 | layoutGrow?: number; 303 | componentId: string; 304 | } 305 | 306 | /** 307 | * Represents a path used in vector nodes. 308 | */ 309 | export interface Path { 310 | path: string; 311 | windingRule: 'NONZERO' | 'EVENODD'; 312 | } 313 | 314 | /** 315 | * Represents text styling properties. 316 | */ 317 | export interface TypeStyle { 318 | fontFamily: string; 319 | fontPostScriptName?: string; 320 | paragraphSpacing?: number; 321 | paragraphIndent?: number; 322 | italic?: boolean; 323 | fontWeight: number; 324 | fontSize: number; 325 | textCase?: 'ORIGINAL' | 'UPPER' | 'LOWER' | 'TITLE'; 326 | textDecoration?: 'NONE' | 'STRIKETHROUGH' | 'UNDERLINE'; 327 | textAlignHorizontal: 'LEFT' | 'RIGHT' | 'CENTER' | 'JUSTIFIED'; 328 | textAlignVertical?: 'TOP' | 'CENTER' | 'BOTTOM'; 329 | letterSpacing: number; 330 | fills?: Paint[]; 331 | lineHeightPx?: number; 332 | lineHeightPercent?: number; 333 | lineHeightUnit: 'PIXELS' | 'PERCENT'; 334 | } 335 | 336 | /** 337 | * Represents export settings for a node. 338 | */ 339 | export interface ExportSetting { 340 | suffix: string; 341 | format: 'JPG' | 'PNG' | 'SVG' | 'PDF'; 342 | constraint: { 343 | type: 'SCALE' | 'WIDTH' | 'HEIGHT'; 344 | value: number; 345 | }; 346 | } 347 | 348 | /** 349 | * Union type of all possible node types in a Figma scene. 350 | */ 351 | export type SceneNode = 352 | | FrameNode 353 | | GroupNode 354 | | VectorNode 355 | | BooleanOperationNode 356 | | StarNode 357 | | LineNode 358 | | TextNode 359 | | ComponentNode 360 | | InstanceNode; 361 | 362 | /** 363 | * Represents a Figma file metadata. 364 | */ 365 | export interface FigmaFile { 366 | key: string; 367 | name: string; 368 | lastModified: string; 369 | thumbnailUrl: string; 370 | version: string; 371 | } 372 | 373 | /** 374 | * Represents a version of a Figma file. 375 | */ 376 | export interface FigmaFileVersion { 377 | id: string; 378 | created_at: string; 379 | label: string; 380 | description: string; 381 | user: { 382 | id: string; 383 | handle: string; 384 | img_url: string; 385 | }; 386 | } 387 | 388 | /** 389 | * Represents a comment on a Figma file. 390 | */ 391 | export interface FigmaComment { 392 | id: string; 393 | file_key: string; 394 | parent_id: string; 395 | user: { 396 | id: string; 397 | handle: string; 398 | img_url: string; 399 | }; 400 | created_at: string; 401 | resolved_at: string | null; 402 | message: string; 403 | client_meta: { 404 | x: number; 405 | y: number; 406 | node_id: string; 407 | node_offset: { 408 | x: number; 409 | y: number; 410 | }; 411 | } | null; 412 | order_id: string; 413 | } 414 | 415 | /** 416 | * Represents a component in Figma's component library. 417 | */ 418 | export interface FigmaComponent { 419 | key: string; 420 | name: string; 421 | description?: string; 422 | componentSetId?: string; 423 | documentationLinks?: string[]; 424 | } 425 | 426 | /** 427 | * Represents a style in Figma's style library. 428 | */ 429 | export interface FigmaStyle { 430 | key: string; 431 | name: string; 432 | description?: string; 433 | styleType: string; 434 | } 435 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ESNext", 4 | "module": "ES2020", 5 | "moduleResolution": "node", 6 | "declaration": true, 7 | "sourceMap": true, 8 | "outDir": "./build", 9 | "rootDir": "./src", 10 | "strict": true, 11 | "esModuleInterop": true, 12 | "skipLibCheck": true, 13 | "forceConsistentCasingInFileNames": true 14 | }, 15 | "include": ["src/**/*"], 16 | "exclude": ["node_modules"] 17 | } 18 | --------------------------------------------------------------------------------