├── .gitignore ├── README.md ├── dist └── esm │ ├── .gitkeep │ └── package.json ├── index.ts ├── package-lock.json ├── package.json ├── src ├── bridge.ts ├── config.ts └── module.ts ├── tests └── test1 │ ├── script.py │ └── test.spec.ts ├── tsconfig.esm.json └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | dist 2 | !dist/esm/package.json 3 | !dist/esm/.gitkeep 4 | node_modules 5 | .git 6 | .idea 7 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # PyBridge 2 | 3 | A TypeScript library to access your python functions in NodeJS, type-safe and easy to use. 4 | 5 | This is especially useful if you want to use machine learning models in NodeJS. 6 | 7 | ## Features 8 | 9 | - Supports all TypeScript types (including generics) 10 | - Supports generator functions in Python (streaming with RxJS) 11 | - Python modules and scripts 12 | - Automatically serializes and deserializes data between NodeJS and Python 13 | 14 | ## Use-cases 15 | 16 | - Call arbitrary Python functions from NodeJS 17 | - Use machine learning models in NodeJS 18 | - Fine-Tune machine learning models from data coming from NodeJS (like Typescript ORMs) 19 | - Text-Embedding from and to your database managed by NodeJS/TypeScript 20 | 21 | ## Usage 22 | 23 | ### Python 24 | 25 | ```python 26 | # File: script.py 27 | from typing import List 28 | 29 | 30 | def word_sizes(words: List[str]) -> List[int]: 31 | return [len(word) for word in words] 32 | ``` 33 | 34 | ### TypeScript 35 | 36 | ```typescript 37 | // File: app.ts 38 | import {PyBridge} from 'pybridge'; 39 | 40 | const bridge = new PyBridge({python: 'python3', cwd: __dirname}); 41 | 42 | interface API { 43 | word_sizes(words: string[]): number[]; 44 | } 45 | 46 | const api = bridge.controller('script.py'); 47 | const sizes = await api.word_sizes(['hello', 'world']); 48 | 49 | expect(sizes).toEqual([5, 5]); 50 | 51 | bridge.close(); 52 | ``` 53 | 54 | If you use Deepkit Framework, you can PyBridgeModule: 55 | 56 | ```typescript 57 | const app = new App({ 58 | imports: [new PyBridgeModule({ 59 | python: 'python3', 60 | cwd: __dirname, 61 | })] 62 | }).command('test', async (python: PyBridge) => { 63 | interface API { 64 | word_sizes(words: string[]): number[]; 65 | } 66 | 67 | const controller = python.controller('script.py'); 68 | const sizes = await controller.word_sizes(['hello', 'world']); 69 | expect(sizes).toEqual([5, 5]); 70 | }); 71 | 72 | app.run(); 73 | ``` 74 | 75 | In order to not pass the controller type to the controller function all the time, you can prepare your own controller 76 | clas like that 77 | 78 | ```typescript 79 | // file: python-controller.ts 80 | 81 | interface API { 82 | word_sizes(words: string[]): number[]; 83 | } 84 | 85 | interface NLP { 86 | embed(text: string): number[]; 87 | } 88 | 89 | class PythonController { 90 | script = this.python.controller('script.py'); 91 | nlp = this.python.controller('nlp.py'); 92 | 93 | constructor(protected python: PyBridge) { 94 | } 95 | } 96 | ``` 97 | 98 | And then use `PythonController` everywhere. 99 | 100 | ## Example Huggingface Sentence Embedding 101 | 102 | ```python 103 | from sentence_transformers import SentenceTransformer 104 | 105 | embedder = SentenceTransformer('paraphrase-MiniLM-L6-v2') # 90MB model 106 | 107 | 108 | def embed(sentence): 109 | # important to convert to list so json.dumps works 110 | return embedder.encode(sentence).tolist() 111 | 112 | 113 | def batch_embed(sentences): 114 | for sentence in sentences: 115 | yield embed(sentence).tolist() 116 | ``` 117 | 118 | ```typescript 119 | interface ML { 120 | // Return type will be Promise 121 | embed(text: string): number[]; 122 | 123 | // Return type stays Subject, so values of `yield` will be streamed until the function is finished 124 | batch_embed(text: string[]): Subject; 125 | } 126 | 127 | class PythonController { 128 | ml = this.python.controller('nlp.py'); 129 | 130 | constructor(protected python: PyBridge) { 131 | } 132 | } 133 | 134 | const controller = new PythonController(bridge); 135 | 136 | const embedding = await controller.ml.embed('hello world'); 137 | const stream = await controller.ml.batch_embed(['lots', 'of', 'sentences']); 138 | stream.subscribe((embedding) => { 139 | console.log('Got embedding', embedding); 140 | }); 141 | await stream.toPromise(); // wait until stream is finished 142 | ``` 143 | 144 | ## Python code 145 | 146 | Alternatively instead of providing a module name script path, you can also provide a Python code 147 | directly: 148 | 149 | ```typescript 150 | const code = ` 151 | def embed(text): 152 | return [len(text)] 153 | `; 154 | 155 | const controller = python.controller(code); 156 | ``` 157 | 158 | ## Install 159 | 160 | First install pybridge using npm: 161 | 162 | ```shell 163 | npm install pybridge 164 | ``` 165 | 166 | Then install Deepkit (needed for type-safe data serialization between NodeJS and Python): 167 | 168 | ```shell 169 | npm install --save-dev @deepkit/type-compiler 170 | ``` 171 | 172 | Enable Deepkit runtime type reflection: 173 | 174 | File: tsconfig.json 175 | 176 | ```json 177 | { 178 | "compilerOptions": { 179 | // ... 180 | }, 181 | "reflection": true 182 | } 183 | ``` 184 | 185 | ## How it works 186 | 187 | PyBridge starts a Python process and communicates with it via stdin/stdout. 188 | It uses [Deepkit](https://deepkit.io) to serialize data between the two processes. 189 | 190 | It's important to type the API controller in TypeScript correctly, so Deepkit can serialize and deserialize the data 191 | correctly. Make sure it matches the Python function signature. 192 | -------------------------------------------------------------------------------- /dist/esm/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/marcj/pybridge/93549d53c0880383d17740b0ee20aa632a2346d2/dist/esm/.gitkeep -------------------------------------------------------------------------------- /dist/esm/package.json: -------------------------------------------------------------------------------- 1 | {"type": "module"} 2 | -------------------------------------------------------------------------------- /index.ts: -------------------------------------------------------------------------------- 1 | export * from './src/bridge.js'; 2 | export * from './src/config.js'; 3 | export * from './src/module.js'; -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pybridge", 3 | "version": "1.4.3", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "pybridge", 9 | "version": "1.4.3", 10 | "license": "MIT", 11 | "dependencies": { 12 | "@deepkit/app": "^1.0.11", 13 | "@deepkit/logger": "^1.0.11", 14 | "@deepkit/type": "^1.0.11" 15 | }, 16 | "devDependencies": { 17 | "@deepkit/type-compiler": "^1.0.8", 18 | "@types/jest": "^29.5.1", 19 | "@types/node": "^20.17.57", 20 | "jest": "^29.5.0", 21 | "rxjs": "*", 22 | "ts-jest": "^29.3.4", 23 | "typescript": "^5.8.3" 24 | }, 25 | "peerDependencies": { 26 | "rxjs": "*" 27 | } 28 | }, 29 | "node_modules/@ampproject/remapping": { 30 | "version": "2.2.1", 31 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 32 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 33 | "dev": true, 34 | "dependencies": { 35 | "@jridgewell/gen-mapping": "^0.3.0", 36 | "@jridgewell/trace-mapping": "^0.3.9" 37 | }, 38 | "engines": { 39 | "node": ">=6.0.0" 40 | } 41 | }, 42 | "node_modules/@babel/code-frame": { 43 | "version": "7.21.4", 44 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.21.4.tgz", 45 | "integrity": "sha512-LYvhNKfwWSPpocw8GI7gpK2nq3HSDuEPC/uSYaALSJu9xjsalaaYFOq0Pwt5KmVqwEbZlDu81aLXwBOmD/Fv9g==", 46 | "dev": true, 47 | "dependencies": { 48 | "@babel/highlight": "^7.18.6" 49 | }, 50 | "engines": { 51 | "node": ">=6.9.0" 52 | } 53 | }, 54 | "node_modules/@babel/compat-data": { 55 | "version": "7.21.7", 56 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.21.7.tgz", 57 | "integrity": "sha512-KYMqFYTaenzMK4yUtf4EW9wc4N9ef80FsbMtkwool5zpwl4YrT1SdWYSTRcT94KO4hannogdS+LxY7L+arP3gA==", 58 | "dev": true, 59 | "engines": { 60 | "node": ">=6.9.0" 61 | } 62 | }, 63 | "node_modules/@babel/core": { 64 | "version": "7.21.8", 65 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.21.8.tgz", 66 | "integrity": "sha512-YeM22Sondbo523Sz0+CirSPnbj9bG3P0CdHcBZdqUuaeOaYEFbOLoGU7lebvGP6P5J/WE9wOn7u7C4J9HvS1xQ==", 67 | "dev": true, 68 | "dependencies": { 69 | "@ampproject/remapping": "^2.2.0", 70 | "@babel/code-frame": "^7.21.4", 71 | "@babel/generator": "^7.21.5", 72 | "@babel/helper-compilation-targets": "^7.21.5", 73 | "@babel/helper-module-transforms": "^7.21.5", 74 | "@babel/helpers": "^7.21.5", 75 | "@babel/parser": "^7.21.8", 76 | "@babel/template": "^7.20.7", 77 | "@babel/traverse": "^7.21.5", 78 | "@babel/types": "^7.21.5", 79 | "convert-source-map": "^1.7.0", 80 | "debug": "^4.1.0", 81 | "gensync": "^1.0.0-beta.2", 82 | "json5": "^2.2.2", 83 | "semver": "^6.3.0" 84 | }, 85 | "engines": { 86 | "node": ">=6.9.0" 87 | }, 88 | "funding": { 89 | "type": "opencollective", 90 | "url": "https://opencollective.com/babel" 91 | } 92 | }, 93 | "node_modules/@babel/core/node_modules/convert-source-map": { 94 | "version": "1.9.0", 95 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 96 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 97 | "dev": true 98 | }, 99 | "node_modules/@babel/core/node_modules/semver": { 100 | "version": "6.3.0", 101 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 102 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 103 | "dev": true, 104 | "bin": { 105 | "semver": "bin/semver.js" 106 | } 107 | }, 108 | "node_modules/@babel/generator": { 109 | "version": "7.21.5", 110 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.21.5.tgz", 111 | "integrity": "sha512-SrKK/sRv8GesIW1bDagf9cCG38IOMYZusoe1dfg0D8aiUe3Amvoj1QtjTPAWcfrZFvIwlleLb0gxzQidL9w14w==", 112 | "dev": true, 113 | "dependencies": { 114 | "@babel/types": "^7.21.5", 115 | "@jridgewell/gen-mapping": "^0.3.2", 116 | "@jridgewell/trace-mapping": "^0.3.17", 117 | "jsesc": "^2.5.1" 118 | }, 119 | "engines": { 120 | "node": ">=6.9.0" 121 | } 122 | }, 123 | "node_modules/@babel/helper-compilation-targets": { 124 | "version": "7.21.5", 125 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.21.5.tgz", 126 | "integrity": "sha512-1RkbFGUKex4lvsB9yhIfWltJM5cZKUftB2eNajaDv3dCMEp49iBG0K14uH8NnX9IPux2+mK7JGEOB0jn48/J6w==", 127 | "dev": true, 128 | "dependencies": { 129 | "@babel/compat-data": "^7.21.5", 130 | "@babel/helper-validator-option": "^7.21.0", 131 | "browserslist": "^4.21.3", 132 | "lru-cache": "^5.1.1", 133 | "semver": "^6.3.0" 134 | }, 135 | "engines": { 136 | "node": ">=6.9.0" 137 | }, 138 | "peerDependencies": { 139 | "@babel/core": "^7.0.0" 140 | } 141 | }, 142 | "node_modules/@babel/helper-compilation-targets/node_modules/lru-cache": { 143 | "version": "5.1.1", 144 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 145 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 146 | "dev": true, 147 | "dependencies": { 148 | "yallist": "^3.0.2" 149 | } 150 | }, 151 | "node_modules/@babel/helper-compilation-targets/node_modules/semver": { 152 | "version": "6.3.0", 153 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 154 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 155 | "dev": true, 156 | "bin": { 157 | "semver": "bin/semver.js" 158 | } 159 | }, 160 | "node_modules/@babel/helper-compilation-targets/node_modules/yallist": { 161 | "version": "3.1.1", 162 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 163 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 164 | "dev": true 165 | }, 166 | "node_modules/@babel/helper-environment-visitor": { 167 | "version": "7.21.5", 168 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.21.5.tgz", 169 | "integrity": "sha512-IYl4gZ3ETsWocUWgsFZLM5i1BYx9SoemminVEXadgLBa9TdeorzgLKm8wWLA6J1N/kT3Kch8XIk1laNzYoHKvQ==", 170 | "dev": true, 171 | "engines": { 172 | "node": ">=6.9.0" 173 | } 174 | }, 175 | "node_modules/@babel/helper-function-name": { 176 | "version": "7.21.0", 177 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.21.0.tgz", 178 | "integrity": "sha512-HfK1aMRanKHpxemaY2gqBmL04iAPOPRj7DxtNbiDOrJK+gdwkiNRVpCpUJYbUT+aZyemKN8brqTOxzCaG6ExRg==", 179 | "dev": true, 180 | "dependencies": { 181 | "@babel/template": "^7.20.7", 182 | "@babel/types": "^7.21.0" 183 | }, 184 | "engines": { 185 | "node": ">=6.9.0" 186 | } 187 | }, 188 | "node_modules/@babel/helper-hoist-variables": { 189 | "version": "7.18.6", 190 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", 191 | "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", 192 | "dev": true, 193 | "dependencies": { 194 | "@babel/types": "^7.18.6" 195 | }, 196 | "engines": { 197 | "node": ">=6.9.0" 198 | } 199 | }, 200 | "node_modules/@babel/helper-module-imports": { 201 | "version": "7.21.4", 202 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.21.4.tgz", 203 | "integrity": "sha512-orajc5T2PsRYUN3ZryCEFeMDYwyw09c/pZeaQEZPH0MpKzSvn3e0uXsDBu3k03VI+9DBiRo+l22BfKTpKwa/Wg==", 204 | "dev": true, 205 | "dependencies": { 206 | "@babel/types": "^7.21.4" 207 | }, 208 | "engines": { 209 | "node": ">=6.9.0" 210 | } 211 | }, 212 | "node_modules/@babel/helper-module-transforms": { 213 | "version": "7.21.5", 214 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.21.5.tgz", 215 | "integrity": "sha512-bI2Z9zBGY2q5yMHoBvJ2a9iX3ZOAzJPm7Q8Yz6YeoUjU/Cvhmi2G4QyTNyPBqqXSgTjUxRg3L0xV45HvkNWWBw==", 216 | "dev": true, 217 | "dependencies": { 218 | "@babel/helper-environment-visitor": "^7.21.5", 219 | "@babel/helper-module-imports": "^7.21.4", 220 | "@babel/helper-simple-access": "^7.21.5", 221 | "@babel/helper-split-export-declaration": "^7.18.6", 222 | "@babel/helper-validator-identifier": "^7.19.1", 223 | "@babel/template": "^7.20.7", 224 | "@babel/traverse": "^7.21.5", 225 | "@babel/types": "^7.21.5" 226 | }, 227 | "engines": { 228 | "node": ">=6.9.0" 229 | } 230 | }, 231 | "node_modules/@babel/helper-plugin-utils": { 232 | "version": "7.21.5", 233 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.21.5.tgz", 234 | "integrity": "sha512-0WDaIlXKOX/3KfBK/dwP1oQGiPh6rjMkT7HIRv7i5RR2VUMwrx5ZL0dwBkKx7+SW1zwNdgjHd34IMk5ZjTeHVg==", 235 | "dev": true, 236 | "engines": { 237 | "node": ">=6.9.0" 238 | } 239 | }, 240 | "node_modules/@babel/helper-simple-access": { 241 | "version": "7.21.5", 242 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.21.5.tgz", 243 | "integrity": "sha512-ENPDAMC1wAjR0uaCUwliBdiSl1KBJAVnMTzXqi64c2MG8MPR6ii4qf7bSXDqSFbr4W6W028/rf5ivoHop5/mkg==", 244 | "dev": true, 245 | "dependencies": { 246 | "@babel/types": "^7.21.5" 247 | }, 248 | "engines": { 249 | "node": ">=6.9.0" 250 | } 251 | }, 252 | "node_modules/@babel/helper-split-export-declaration": { 253 | "version": "7.18.6", 254 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", 255 | "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", 256 | "dev": true, 257 | "dependencies": { 258 | "@babel/types": "^7.18.6" 259 | }, 260 | "engines": { 261 | "node": ">=6.9.0" 262 | } 263 | }, 264 | "node_modules/@babel/helper-string-parser": { 265 | "version": "7.21.5", 266 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz", 267 | "integrity": "sha512-5pTUx3hAJaZIdW99sJ6ZUUgWq/Y+Hja7TowEnLNMm1VivRgZQL3vpBY3qUACVsvw+yQU6+YgfBVmcbLaZtrA1w==", 268 | "dev": true, 269 | "engines": { 270 | "node": ">=6.9.0" 271 | } 272 | }, 273 | "node_modules/@babel/helper-validator-identifier": { 274 | "version": "7.19.1", 275 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 276 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 277 | "dev": true, 278 | "engines": { 279 | "node": ">=6.9.0" 280 | } 281 | }, 282 | "node_modules/@babel/helper-validator-option": { 283 | "version": "7.21.0", 284 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.21.0.tgz", 285 | "integrity": "sha512-rmL/B8/f0mKS2baE9ZpyTcTavvEuWhTTW8amjzXNvYG4AwBsqTLikfXsEofsJEfKHf+HQVQbFOHy6o+4cnC/fQ==", 286 | "dev": true, 287 | "engines": { 288 | "node": ">=6.9.0" 289 | } 290 | }, 291 | "node_modules/@babel/helpers": { 292 | "version": "7.21.5", 293 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.21.5.tgz", 294 | "integrity": "sha512-BSY+JSlHxOmGsPTydUkPf1MdMQ3M81x5xGCOVgWM3G8XH77sJ292Y2oqcp0CbbgxhqBuI46iUz1tT7hqP7EfgA==", 295 | "dev": true, 296 | "dependencies": { 297 | "@babel/template": "^7.20.7", 298 | "@babel/traverse": "^7.21.5", 299 | "@babel/types": "^7.21.5" 300 | }, 301 | "engines": { 302 | "node": ">=6.9.0" 303 | } 304 | }, 305 | "node_modules/@babel/highlight": { 306 | "version": "7.18.6", 307 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 308 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 309 | "dev": true, 310 | "dependencies": { 311 | "@babel/helper-validator-identifier": "^7.18.6", 312 | "chalk": "^2.0.0", 313 | "js-tokens": "^4.0.0" 314 | }, 315 | "engines": { 316 | "node": ">=6.9.0" 317 | } 318 | }, 319 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 320 | "version": "3.2.1", 321 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 322 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 323 | "dev": true, 324 | "dependencies": { 325 | "color-convert": "^1.9.0" 326 | }, 327 | "engines": { 328 | "node": ">=4" 329 | } 330 | }, 331 | "node_modules/@babel/highlight/node_modules/chalk": { 332 | "version": "2.4.2", 333 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 334 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 335 | "dev": true, 336 | "dependencies": { 337 | "ansi-styles": "^3.2.1", 338 | "escape-string-regexp": "^1.0.5", 339 | "supports-color": "^5.3.0" 340 | }, 341 | "engines": { 342 | "node": ">=4" 343 | } 344 | }, 345 | "node_modules/@babel/highlight/node_modules/color-convert": { 346 | "version": "1.9.3", 347 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 348 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 349 | "dev": true, 350 | "dependencies": { 351 | "color-name": "1.1.3" 352 | } 353 | }, 354 | "node_modules/@babel/highlight/node_modules/color-name": { 355 | "version": "1.1.3", 356 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 357 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 358 | "dev": true 359 | }, 360 | "node_modules/@babel/highlight/node_modules/escape-string-regexp": { 361 | "version": "1.0.5", 362 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 363 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 364 | "dev": true, 365 | "engines": { 366 | "node": ">=0.8.0" 367 | } 368 | }, 369 | "node_modules/@babel/highlight/node_modules/has-flag": { 370 | "version": "3.0.0", 371 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 372 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 373 | "dev": true, 374 | "engines": { 375 | "node": ">=4" 376 | } 377 | }, 378 | "node_modules/@babel/highlight/node_modules/supports-color": { 379 | "version": "5.5.0", 380 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 381 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 382 | "dev": true, 383 | "dependencies": { 384 | "has-flag": "^3.0.0" 385 | }, 386 | "engines": { 387 | "node": ">=4" 388 | } 389 | }, 390 | "node_modules/@babel/parser": { 391 | "version": "7.21.8", 392 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.21.8.tgz", 393 | "integrity": "sha512-6zavDGdzG3gUqAdWvlLFfk+36RilI+Pwyuuh7HItyeScCWP3k6i8vKclAQ0bM/0y/Kz/xiwvxhMv9MgTJP5gmA==", 394 | "dev": true, 395 | "bin": { 396 | "parser": "bin/babel-parser.js" 397 | }, 398 | "engines": { 399 | "node": ">=6.0.0" 400 | } 401 | }, 402 | "node_modules/@babel/plugin-syntax-async-generators": { 403 | "version": "7.8.4", 404 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", 405 | "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", 406 | "dev": true, 407 | "dependencies": { 408 | "@babel/helper-plugin-utils": "^7.8.0" 409 | }, 410 | "peerDependencies": { 411 | "@babel/core": "^7.0.0-0" 412 | } 413 | }, 414 | "node_modules/@babel/plugin-syntax-bigint": { 415 | "version": "7.8.3", 416 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", 417 | "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", 418 | "dev": true, 419 | "dependencies": { 420 | "@babel/helper-plugin-utils": "^7.8.0" 421 | }, 422 | "peerDependencies": { 423 | "@babel/core": "^7.0.0-0" 424 | } 425 | }, 426 | "node_modules/@babel/plugin-syntax-class-properties": { 427 | "version": "7.12.13", 428 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", 429 | "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", 430 | "dev": true, 431 | "dependencies": { 432 | "@babel/helper-plugin-utils": "^7.12.13" 433 | }, 434 | "peerDependencies": { 435 | "@babel/core": "^7.0.0-0" 436 | } 437 | }, 438 | "node_modules/@babel/plugin-syntax-import-meta": { 439 | "version": "7.10.4", 440 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", 441 | "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", 442 | "dev": true, 443 | "dependencies": { 444 | "@babel/helper-plugin-utils": "^7.10.4" 445 | }, 446 | "peerDependencies": { 447 | "@babel/core": "^7.0.0-0" 448 | } 449 | }, 450 | "node_modules/@babel/plugin-syntax-json-strings": { 451 | "version": "7.8.3", 452 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", 453 | "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", 454 | "dev": true, 455 | "dependencies": { 456 | "@babel/helper-plugin-utils": "^7.8.0" 457 | }, 458 | "peerDependencies": { 459 | "@babel/core": "^7.0.0-0" 460 | } 461 | }, 462 | "node_modules/@babel/plugin-syntax-jsx": { 463 | "version": "7.21.4", 464 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.21.4.tgz", 465 | "integrity": "sha512-5hewiLct5OKyh6PLKEYaFclcqtIgCb6bmELouxjF6up5q3Sov7rOayW4RwhbaBL0dit8rA80GNfY+UuDp2mBbQ==", 466 | "dev": true, 467 | "dependencies": { 468 | "@babel/helper-plugin-utils": "^7.20.2" 469 | }, 470 | "engines": { 471 | "node": ">=6.9.0" 472 | }, 473 | "peerDependencies": { 474 | "@babel/core": "^7.0.0-0" 475 | } 476 | }, 477 | "node_modules/@babel/plugin-syntax-logical-assignment-operators": { 478 | "version": "7.10.4", 479 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", 480 | "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", 481 | "dev": true, 482 | "dependencies": { 483 | "@babel/helper-plugin-utils": "^7.10.4" 484 | }, 485 | "peerDependencies": { 486 | "@babel/core": "^7.0.0-0" 487 | } 488 | }, 489 | "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { 490 | "version": "7.8.3", 491 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", 492 | "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", 493 | "dev": true, 494 | "dependencies": { 495 | "@babel/helper-plugin-utils": "^7.8.0" 496 | }, 497 | "peerDependencies": { 498 | "@babel/core": "^7.0.0-0" 499 | } 500 | }, 501 | "node_modules/@babel/plugin-syntax-numeric-separator": { 502 | "version": "7.10.4", 503 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", 504 | "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", 505 | "dev": true, 506 | "dependencies": { 507 | "@babel/helper-plugin-utils": "^7.10.4" 508 | }, 509 | "peerDependencies": { 510 | "@babel/core": "^7.0.0-0" 511 | } 512 | }, 513 | "node_modules/@babel/plugin-syntax-object-rest-spread": { 514 | "version": "7.8.3", 515 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", 516 | "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", 517 | "dev": true, 518 | "dependencies": { 519 | "@babel/helper-plugin-utils": "^7.8.0" 520 | }, 521 | "peerDependencies": { 522 | "@babel/core": "^7.0.0-0" 523 | } 524 | }, 525 | "node_modules/@babel/plugin-syntax-optional-catch-binding": { 526 | "version": "7.8.3", 527 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", 528 | "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", 529 | "dev": true, 530 | "dependencies": { 531 | "@babel/helper-plugin-utils": "^7.8.0" 532 | }, 533 | "peerDependencies": { 534 | "@babel/core": "^7.0.0-0" 535 | } 536 | }, 537 | "node_modules/@babel/plugin-syntax-optional-chaining": { 538 | "version": "7.8.3", 539 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", 540 | "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", 541 | "dev": true, 542 | "dependencies": { 543 | "@babel/helper-plugin-utils": "^7.8.0" 544 | }, 545 | "peerDependencies": { 546 | "@babel/core": "^7.0.0-0" 547 | } 548 | }, 549 | "node_modules/@babel/plugin-syntax-top-level-await": { 550 | "version": "7.14.5", 551 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", 552 | "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", 553 | "dev": true, 554 | "dependencies": { 555 | "@babel/helper-plugin-utils": "^7.14.5" 556 | }, 557 | "engines": { 558 | "node": ">=6.9.0" 559 | }, 560 | "peerDependencies": { 561 | "@babel/core": "^7.0.0-0" 562 | } 563 | }, 564 | "node_modules/@babel/plugin-syntax-typescript": { 565 | "version": "7.21.4", 566 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.21.4.tgz", 567 | "integrity": "sha512-xz0D39NvhQn4t4RNsHmDnnsaQizIlUkdtYvLs8La1BlfjQ6JEwxkJGeqJMW2tAXx+q6H+WFuUTXNdYVpEya0YA==", 568 | "dev": true, 569 | "dependencies": { 570 | "@babel/helper-plugin-utils": "^7.20.2" 571 | }, 572 | "engines": { 573 | "node": ">=6.9.0" 574 | }, 575 | "peerDependencies": { 576 | "@babel/core": "^7.0.0-0" 577 | } 578 | }, 579 | "node_modules/@babel/template": { 580 | "version": "7.20.7", 581 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz", 582 | "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==", 583 | "dev": true, 584 | "dependencies": { 585 | "@babel/code-frame": "^7.18.6", 586 | "@babel/parser": "^7.20.7", 587 | "@babel/types": "^7.20.7" 588 | }, 589 | "engines": { 590 | "node": ">=6.9.0" 591 | } 592 | }, 593 | "node_modules/@babel/traverse": { 594 | "version": "7.21.5", 595 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.21.5.tgz", 596 | "integrity": "sha512-AhQoI3YjWi6u/y/ntv7k48mcrCXmus0t79J9qPNlk/lAsFlCiJ047RmbfMOawySTHtywXhbXgpx/8nXMYd+oFw==", 597 | "dev": true, 598 | "dependencies": { 599 | "@babel/code-frame": "^7.21.4", 600 | "@babel/generator": "^7.21.5", 601 | "@babel/helper-environment-visitor": "^7.21.5", 602 | "@babel/helper-function-name": "^7.21.0", 603 | "@babel/helper-hoist-variables": "^7.18.6", 604 | "@babel/helper-split-export-declaration": "^7.18.6", 605 | "@babel/parser": "^7.21.5", 606 | "@babel/types": "^7.21.5", 607 | "debug": "^4.1.0", 608 | "globals": "^11.1.0" 609 | }, 610 | "engines": { 611 | "node": ">=6.9.0" 612 | } 613 | }, 614 | "node_modules/@babel/types": { 615 | "version": "7.21.5", 616 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.21.5.tgz", 617 | "integrity": "sha512-m4AfNvVF2mVC/F7fDEdH2El3HzUg9It/XsCxZiOTTA3m3qYfcSVSbTfM6Q9xG+hYDniZssYhlXKKUMD5m8tF4Q==", 618 | "dev": true, 619 | "dependencies": { 620 | "@babel/helper-string-parser": "^7.21.5", 621 | "@babel/helper-validator-identifier": "^7.19.1", 622 | "to-fast-properties": "^2.0.0" 623 | }, 624 | "engines": { 625 | "node": ">=6.9.0" 626 | } 627 | }, 628 | "node_modules/@babel/types/node_modules/to-fast-properties": { 629 | "version": "2.0.0", 630 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 631 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 632 | "dev": true, 633 | "engines": { 634 | "node": ">=4" 635 | } 636 | }, 637 | "node_modules/@bcoe/v8-coverage": { 638 | "version": "0.2.3", 639 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 640 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 641 | "dev": true 642 | }, 643 | "node_modules/@deepkit/app": { 644 | "version": "1.0.11", 645 | "resolved": "https://registry.npmjs.org/@deepkit/app/-/app-1.0.11.tgz", 646 | "integrity": "sha512-ohOEOyVOEG7xC7WkI0S0kkxKWFZtbWLrU7PBct/JfttkSnSeH+O10ZzGBcOddPcwRdktAjgmXSz+kg/TV6vhEA==", 647 | "license": "MIT", 648 | "peerDependencies": { 649 | "@deepkit/core": "^1.0.1", 650 | "@deepkit/event": "^1.0.1", 651 | "@deepkit/injector": "^1.0.1", 652 | "@deepkit/logger": "^1.0.1", 653 | "@deepkit/stopwatch": "^1.0.1", 654 | "@deepkit/type": "^1.0.1", 655 | "@deepkit/workflow": "^1.0.1" 656 | } 657 | }, 658 | "node_modules/@deepkit/core": { 659 | "version": "1.0.5", 660 | "resolved": "https://registry.npmjs.org/@deepkit/core/-/core-1.0.5.tgz", 661 | "integrity": "sha512-1N+HuDEV7BOiF1KFg5JwMtgPCtxR1KPLIut645o98sUcnQzJP0ywvgyqpfqV+D9IK7TGBGxQDhbUSQlBG34pTg==", 662 | "license": "MIT", 663 | "peer": true, 664 | "dependencies": { 665 | "dot-prop": "^5.1.1", 666 | "to-fast-properties": "^3.0.1" 667 | } 668 | }, 669 | "node_modules/@deepkit/event": { 670 | "version": "1.0.11", 671 | "resolved": "https://registry.npmjs.org/@deepkit/event/-/event-1.0.11.tgz", 672 | "integrity": "sha512-0A9k1A3PJSJjBTsQn8JoZNqkMgmIebZiItDcmYOl7uZxsuA0V78UDZVtU5N326ZeBNdD28p3QzW0311H3ubBFQ==", 673 | "license": "MIT", 674 | "peer": true, 675 | "peerDependencies": { 676 | "@deepkit/core": "^1.0.1", 677 | "@deepkit/injector": "^1.0.1", 678 | "@deepkit/type": "^1.0.1" 679 | } 680 | }, 681 | "node_modules/@deepkit/injector": { 682 | "version": "1.0.11", 683 | "resolved": "https://registry.npmjs.org/@deepkit/injector/-/injector-1.0.11.tgz", 684 | "integrity": "sha512-glsXX8RfVA4mdw7qkIXsgn/9WCjL3FJH1aBJF6FtUuXfQbktc48Rve0IsMJ5W27RdcQk93/B6jRm9lfxZHbawQ==", 685 | "license": "MIT", 686 | "peer": true, 687 | "peerDependencies": { 688 | "@deepkit/core": "^1.0.1", 689 | "@deepkit/type": "^1.0.1" 690 | } 691 | }, 692 | "node_modules/@deepkit/logger": { 693 | "version": "1.0.11", 694 | "resolved": "https://registry.npmjs.org/@deepkit/logger/-/logger-1.0.11.tgz", 695 | "integrity": "sha512-+AVMd7ufSfp438CoUV3/iV/XGbu4oBYccjCYhFh+Jyv03PEcG9MDK9tpYMSQ0te5gbEMsapFHNEtF1JbyES0tQ==", 696 | "license": "MIT", 697 | "dependencies": { 698 | "@types/format-util": "^1.0.1", 699 | "ansi-styles": "^4.3.0", 700 | "format-util": "^1.0.5" 701 | }, 702 | "peerDependencies": { 703 | "@deepkit/core": "^1.0.1", 704 | "@deepkit/injector": "^1.0.1" 705 | } 706 | }, 707 | "node_modules/@deepkit/stopwatch": { 708 | "version": "1.0.11", 709 | "resolved": "https://registry.npmjs.org/@deepkit/stopwatch/-/stopwatch-1.0.11.tgz", 710 | "integrity": "sha512-o4RCZrzFoSdxaz3QwU0e02rWSnsSiOIM29XB25Y9UCRz2pewMRS9i6PBn3lPcdwyA67nGQhGm2uZ0tsSLXJEjA==", 711 | "license": "MIT", 712 | "peer": true, 713 | "peerDependencies": { 714 | "@deepkit/core": "^1.0.1", 715 | "@deepkit/type": "^1.0.1" 716 | } 717 | }, 718 | "node_modules/@deepkit/type": { 719 | "version": "1.0.11", 720 | "resolved": "https://registry.npmjs.org/@deepkit/type/-/type-1.0.11.tgz", 721 | "integrity": "sha512-yYab5JOuzuW1czzdwJBaqlFci2o90zwEsJsrZqE/IyYaHhVU/HfZ47HpEnqOzmC0JKXdLBGLUaQwI+op0b9cLA==", 722 | "license": "MIT", 723 | "dependencies": { 724 | "@deepkit/type-spec": "^1.0.1", 725 | "@types/uuid": "^8.3.0", 726 | "buffer": "^5.2.1", 727 | "uuid": "^8.3.2" 728 | }, 729 | "peerDependencies": { 730 | "@deepkit/core": "^1.0.1" 731 | } 732 | }, 733 | "node_modules/@deepkit/type-compiler": { 734 | "version": "1.0.8", 735 | "resolved": "https://registry.npmjs.org/@deepkit/type-compiler/-/type-compiler-1.0.8.tgz", 736 | "integrity": "sha512-3AmyfMYJ+bej+v9T46pIViIEaN0wp7v5grO8huvC1x1H1T4cogM68Hyw2VibkfUkS9H68ACC9VimP3i7TT+PTg==", 737 | "dev": true, 738 | "hasInstallScript": true, 739 | "license": "MIT", 740 | "dependencies": { 741 | "@deepkit/type-spec": "^1.0.1", 742 | "@marcj/ts-clone-node": "^2.0.0", 743 | "@rollup/pluginutils": "^5.1.0", 744 | "@typescript/vfs": "1.5.0", 745 | "get-tsconfig": "^4.5.0", 746 | "lz-string": "^1.4.4", 747 | "micromatch": "^4.0.5", 748 | "strip-json-comments": "^3.1.1" 749 | }, 750 | "bin": { 751 | "deepkit-compiler-debug": "deepkit-compiler-debug.js", 752 | "deepkit-type-install": "deepkit-type-install.js" 753 | }, 754 | "peerDependencies": { 755 | "typescript": "*" 756 | } 757 | }, 758 | "node_modules/@deepkit/type-spec": { 759 | "version": "1.0.1", 760 | "resolved": "https://registry.npmjs.org/@deepkit/type-spec/-/type-spec-1.0.1.tgz", 761 | "integrity": "sha512-14iJbtfGdjewxhzSWTU+nxQOD+sopFg8MP0W0kizJQMRADxhreDID8lDUk6zWoAJ6aLsQ1QbKZAl1UokzRI69A==", 762 | "license": "MIT" 763 | }, 764 | "node_modules/@deepkit/workflow": { 765 | "version": "1.0.11", 766 | "resolved": "https://registry.npmjs.org/@deepkit/workflow/-/workflow-1.0.11.tgz", 767 | "integrity": "sha512-2WvhG4TOye9edSdnUXK7IjTyK/T6rhL1sWB0lBCJbHdNotREzBxa0i1QYCMyLeKsO8kWC6/wcwJSQVV1IFtcRg==", 768 | "license": "MIT", 769 | "peer": true, 770 | "peerDependencies": { 771 | "@deepkit/core": "^1.0.1", 772 | "@deepkit/event": "^1.0.1", 773 | "@deepkit/injector": "^1.0.1", 774 | "@deepkit/stopwatch": "^1.0.1", 775 | "@deepkit/type": "^1.0.1" 776 | } 777 | }, 778 | "node_modules/@istanbuljs/load-nyc-config": { 779 | "version": "1.1.0", 780 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 781 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 782 | "dev": true, 783 | "dependencies": { 784 | "camelcase": "^5.3.1", 785 | "find-up": "^4.1.0", 786 | "get-package-type": "^0.1.0", 787 | "js-yaml": "^3.13.1", 788 | "resolve-from": "^5.0.0" 789 | }, 790 | "engines": { 791 | "node": ">=8" 792 | } 793 | }, 794 | "node_modules/@istanbuljs/schema": { 795 | "version": "0.1.3", 796 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 797 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 798 | "dev": true, 799 | "engines": { 800 | "node": ">=8" 801 | } 802 | }, 803 | "node_modules/@jest/console": { 804 | "version": "29.5.0", 805 | "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.5.0.tgz", 806 | "integrity": "sha512-NEpkObxPwyw/XxZVLPmAGKE89IQRp4puc6IQRPru6JKd1M3fW9v1xM1AnzIJE65hbCkzQAdnL8P47e9hzhiYLQ==", 807 | "dev": true, 808 | "dependencies": { 809 | "@jest/types": "^29.5.0", 810 | "@types/node": "*", 811 | "chalk": "^4.0.0", 812 | "jest-message-util": "^29.5.0", 813 | "jest-util": "^29.5.0", 814 | "slash": "^3.0.0" 815 | }, 816 | "engines": { 817 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 818 | } 819 | }, 820 | "node_modules/@jest/core": { 821 | "version": "29.5.0", 822 | "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.5.0.tgz", 823 | "integrity": "sha512-28UzQc7ulUrOQw1IsN/kv1QES3q2kkbl/wGslyhAclqZ/8cMdB5M68BffkIdSJgKBUt50d3hbwJ92XESlE7LiQ==", 824 | "dev": true, 825 | "dependencies": { 826 | "@jest/console": "^29.5.0", 827 | "@jest/reporters": "^29.5.0", 828 | "@jest/test-result": "^29.5.0", 829 | "@jest/transform": "^29.5.0", 830 | "@jest/types": "^29.5.0", 831 | "@types/node": "*", 832 | "ansi-escapes": "^4.2.1", 833 | "chalk": "^4.0.0", 834 | "ci-info": "^3.2.0", 835 | "exit": "^0.1.2", 836 | "graceful-fs": "^4.2.9", 837 | "jest-changed-files": "^29.5.0", 838 | "jest-config": "^29.5.0", 839 | "jest-haste-map": "^29.5.0", 840 | "jest-message-util": "^29.5.0", 841 | "jest-regex-util": "^29.4.3", 842 | "jest-resolve": "^29.5.0", 843 | "jest-resolve-dependencies": "^29.5.0", 844 | "jest-runner": "^29.5.0", 845 | "jest-runtime": "^29.5.0", 846 | "jest-snapshot": "^29.5.0", 847 | "jest-util": "^29.5.0", 848 | "jest-validate": "^29.5.0", 849 | "jest-watcher": "^29.5.0", 850 | "micromatch": "^4.0.4", 851 | "pretty-format": "^29.5.0", 852 | "slash": "^3.0.0", 853 | "strip-ansi": "^6.0.0" 854 | }, 855 | "engines": { 856 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 857 | }, 858 | "peerDependencies": { 859 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 860 | }, 861 | "peerDependenciesMeta": { 862 | "node-notifier": { 863 | "optional": true 864 | } 865 | } 866 | }, 867 | "node_modules/@jest/environment": { 868 | "version": "29.5.0", 869 | "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.5.0.tgz", 870 | "integrity": "sha512-5FXw2+wD29YU1d4I2htpRX7jYnAyTRjP2CsXQdo9SAM8g3ifxWPSV0HnClSn71xwctr0U3oZIIH+dtbfmnbXVQ==", 871 | "dev": true, 872 | "dependencies": { 873 | "@jest/fake-timers": "^29.5.0", 874 | "@jest/types": "^29.5.0", 875 | "@types/node": "*", 876 | "jest-mock": "^29.5.0" 877 | }, 878 | "engines": { 879 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 880 | } 881 | }, 882 | "node_modules/@jest/expect": { 883 | "version": "29.5.0", 884 | "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.5.0.tgz", 885 | "integrity": "sha512-PueDR2HGihN3ciUNGr4uelropW7rqUfTiOn+8u0leg/42UhblPxHkfoh0Ruu3I9Y1962P3u2DY4+h7GVTSVU6g==", 886 | "dev": true, 887 | "dependencies": { 888 | "expect": "^29.5.0", 889 | "jest-snapshot": "^29.5.0" 890 | }, 891 | "engines": { 892 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 893 | } 894 | }, 895 | "node_modules/@jest/expect-utils": { 896 | "version": "29.5.0", 897 | "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.5.0.tgz", 898 | "integrity": "sha512-fmKzsidoXQT2KwnrwE0SQq3uj8Z763vzR8LnLBwC2qYWEFpjX8daRsk6rHUM1QvNlEW/UJXNXm59ztmJJWs2Mg==", 899 | "dev": true, 900 | "dependencies": { 901 | "jest-get-type": "^29.4.3" 902 | }, 903 | "engines": { 904 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 905 | } 906 | }, 907 | "node_modules/@jest/fake-timers": { 908 | "version": "29.5.0", 909 | "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.5.0.tgz", 910 | "integrity": "sha512-9ARvuAAQcBwDAqOnglWq2zwNIRUDtk/SCkp/ToGEhFv5r86K21l+VEs0qNTaXtyiY0lEePl3kylijSYJQqdbDg==", 911 | "dev": true, 912 | "dependencies": { 913 | "@jest/types": "^29.5.0", 914 | "@sinonjs/fake-timers": "^10.0.2", 915 | "@types/node": "*", 916 | "jest-message-util": "^29.5.0", 917 | "jest-mock": "^29.5.0", 918 | "jest-util": "^29.5.0" 919 | }, 920 | "engines": { 921 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 922 | } 923 | }, 924 | "node_modules/@jest/globals": { 925 | "version": "29.5.0", 926 | "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.5.0.tgz", 927 | "integrity": "sha512-S02y0qMWGihdzNbUiqSAiKSpSozSuHX5UYc7QbnHP+D9Lyw8DgGGCinrN9uSuHPeKgSSzvPom2q1nAtBvUsvPQ==", 928 | "dev": true, 929 | "dependencies": { 930 | "@jest/environment": "^29.5.0", 931 | "@jest/expect": "^29.5.0", 932 | "@jest/types": "^29.5.0", 933 | "jest-mock": "^29.5.0" 934 | }, 935 | "engines": { 936 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 937 | } 938 | }, 939 | "node_modules/@jest/reporters": { 940 | "version": "29.5.0", 941 | "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.5.0.tgz", 942 | "integrity": "sha512-D05STXqj/M8bP9hQNSICtPqz97u7ffGzZu+9XLucXhkOFBqKcXe04JLZOgIekOxdb73MAoBUFnqvf7MCpKk5OA==", 943 | "dev": true, 944 | "dependencies": { 945 | "@bcoe/v8-coverage": "^0.2.3", 946 | "@jest/console": "^29.5.0", 947 | "@jest/test-result": "^29.5.0", 948 | "@jest/transform": "^29.5.0", 949 | "@jest/types": "^29.5.0", 950 | "@jridgewell/trace-mapping": "^0.3.15", 951 | "@types/node": "*", 952 | "chalk": "^4.0.0", 953 | "collect-v8-coverage": "^1.0.0", 954 | "exit": "^0.1.2", 955 | "glob": "^7.1.3", 956 | "graceful-fs": "^4.2.9", 957 | "istanbul-lib-coverage": "^3.0.0", 958 | "istanbul-lib-instrument": "^5.1.0", 959 | "istanbul-lib-report": "^3.0.0", 960 | "istanbul-lib-source-maps": "^4.0.0", 961 | "istanbul-reports": "^3.1.3", 962 | "jest-message-util": "^29.5.0", 963 | "jest-util": "^29.5.0", 964 | "jest-worker": "^29.5.0", 965 | "slash": "^3.0.0", 966 | "string-length": "^4.0.1", 967 | "strip-ansi": "^6.0.0", 968 | "v8-to-istanbul": "^9.0.1" 969 | }, 970 | "engines": { 971 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 972 | }, 973 | "peerDependencies": { 974 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 975 | }, 976 | "peerDependenciesMeta": { 977 | "node-notifier": { 978 | "optional": true 979 | } 980 | } 981 | }, 982 | "node_modules/@jest/schemas": { 983 | "version": "29.4.3", 984 | "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.4.3.tgz", 985 | "integrity": "sha512-VLYKXQmtmuEz6IxJsrZwzG9NvtkQsWNnWMsKxqWNu3+CnfzJQhp0WDDKWLVV9hLKr0l3SLLFRqcYHjhtyuDVxg==", 986 | "dev": true, 987 | "dependencies": { 988 | "@sinclair/typebox": "^0.25.16" 989 | }, 990 | "engines": { 991 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 992 | } 993 | }, 994 | "node_modules/@jest/source-map": { 995 | "version": "29.4.3", 996 | "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.4.3.tgz", 997 | "integrity": "sha512-qyt/mb6rLyd9j1jUts4EQncvS6Yy3PM9HghnNv86QBlV+zdL2inCdK1tuVlL+J+lpiw2BI67qXOrX3UurBqQ1w==", 998 | "dev": true, 999 | "dependencies": { 1000 | "@jridgewell/trace-mapping": "^0.3.15", 1001 | "callsites": "^3.0.0", 1002 | "graceful-fs": "^4.2.9" 1003 | }, 1004 | "engines": { 1005 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1006 | } 1007 | }, 1008 | "node_modules/@jest/test-result": { 1009 | "version": "29.5.0", 1010 | "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.5.0.tgz", 1011 | "integrity": "sha512-fGl4rfitnbfLsrfx1uUpDEESS7zM8JdgZgOCQuxQvL1Sn/I6ijeAVQWGfXI9zb1i9Mzo495cIpVZhA0yr60PkQ==", 1012 | "dev": true, 1013 | "dependencies": { 1014 | "@jest/console": "^29.5.0", 1015 | "@jest/types": "^29.5.0", 1016 | "@types/istanbul-lib-coverage": "^2.0.0", 1017 | "collect-v8-coverage": "^1.0.0" 1018 | }, 1019 | "engines": { 1020 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1021 | } 1022 | }, 1023 | "node_modules/@jest/test-sequencer": { 1024 | "version": "29.5.0", 1025 | "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.5.0.tgz", 1026 | "integrity": "sha512-yPafQEcKjkSfDXyvtgiV4pevSeyuA6MQr6ZIdVkWJly9vkqjnFfcfhRQqpD5whjoU8EORki752xQmjaqoFjzMQ==", 1027 | "dev": true, 1028 | "dependencies": { 1029 | "@jest/test-result": "^29.5.0", 1030 | "graceful-fs": "^4.2.9", 1031 | "jest-haste-map": "^29.5.0", 1032 | "slash": "^3.0.0" 1033 | }, 1034 | "engines": { 1035 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1036 | } 1037 | }, 1038 | "node_modules/@jest/transform": { 1039 | "version": "29.5.0", 1040 | "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.5.0.tgz", 1041 | "integrity": "sha512-8vbeZWqLJOvHaDfeMuoHITGKSz5qWc9u04lnWrQE3VyuSw604PzQM824ZeX9XSjUCeDiE3GuxZe5UKa8J61NQw==", 1042 | "dev": true, 1043 | "dependencies": { 1044 | "@babel/core": "^7.11.6", 1045 | "@jest/types": "^29.5.0", 1046 | "@jridgewell/trace-mapping": "^0.3.15", 1047 | "babel-plugin-istanbul": "^6.1.1", 1048 | "chalk": "^4.0.0", 1049 | "convert-source-map": "^2.0.0", 1050 | "fast-json-stable-stringify": "^2.1.0", 1051 | "graceful-fs": "^4.2.9", 1052 | "jest-haste-map": "^29.5.0", 1053 | "jest-regex-util": "^29.4.3", 1054 | "jest-util": "^29.5.0", 1055 | "micromatch": "^4.0.4", 1056 | "pirates": "^4.0.4", 1057 | "slash": "^3.0.0", 1058 | "write-file-atomic": "^4.0.2" 1059 | }, 1060 | "engines": { 1061 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1062 | } 1063 | }, 1064 | "node_modules/@jest/types": { 1065 | "version": "29.5.0", 1066 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.5.0.tgz", 1067 | "integrity": "sha512-qbu7kN6czmVRc3xWFQcAN03RAUamgppVUdXrvl1Wr3jlNF93o9mJbGcDWrwGB6ht44u7efB1qCFgVQmca24Uog==", 1068 | "dev": true, 1069 | "dependencies": { 1070 | "@jest/schemas": "^29.4.3", 1071 | "@types/istanbul-lib-coverage": "^2.0.0", 1072 | "@types/istanbul-reports": "^3.0.0", 1073 | "@types/node": "*", 1074 | "@types/yargs": "^17.0.8", 1075 | "chalk": "^4.0.0" 1076 | }, 1077 | "engines": { 1078 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1079 | } 1080 | }, 1081 | "node_modules/@jridgewell/gen-mapping": { 1082 | "version": "0.3.3", 1083 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 1084 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 1085 | "dev": true, 1086 | "dependencies": { 1087 | "@jridgewell/set-array": "^1.0.1", 1088 | "@jridgewell/sourcemap-codec": "^1.4.10", 1089 | "@jridgewell/trace-mapping": "^0.3.9" 1090 | }, 1091 | "engines": { 1092 | "node": ">=6.0.0" 1093 | } 1094 | }, 1095 | "node_modules/@jridgewell/resolve-uri": { 1096 | "version": "3.1.0", 1097 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 1098 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 1099 | "dev": true, 1100 | "engines": { 1101 | "node": ">=6.0.0" 1102 | } 1103 | }, 1104 | "node_modules/@jridgewell/set-array": { 1105 | "version": "1.1.2", 1106 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 1107 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 1108 | "dev": true, 1109 | "engines": { 1110 | "node": ">=6.0.0" 1111 | } 1112 | }, 1113 | "node_modules/@jridgewell/sourcemap-codec": { 1114 | "version": "1.4.15", 1115 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 1116 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 1117 | "dev": true 1118 | }, 1119 | "node_modules/@jridgewell/trace-mapping": { 1120 | "version": "0.3.18", 1121 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", 1122 | "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", 1123 | "dev": true, 1124 | "dependencies": { 1125 | "@jridgewell/resolve-uri": "3.1.0", 1126 | "@jridgewell/sourcemap-codec": "1.4.14" 1127 | } 1128 | }, 1129 | "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { 1130 | "version": "1.4.14", 1131 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 1132 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 1133 | "dev": true 1134 | }, 1135 | "node_modules/@marcj/ts-clone-node": { 1136 | "version": "2.2.0", 1137 | "resolved": "https://registry.npmjs.org/@marcj/ts-clone-node/-/ts-clone-node-2.2.0.tgz", 1138 | "integrity": "sha512-72i531GZWaiHDvNZr0Fz+uiZMMyWzQqJxbhxD5g2dpU3eqEBk6p6mcDNBcOdiNhngAJ5Ebqv2krrs7MwuFg9rw==", 1139 | "dev": true, 1140 | "dependencies": { 1141 | "compatfactory": "^2.0.9" 1142 | }, 1143 | "engines": { 1144 | "node": ">=14.9.0" 1145 | }, 1146 | "funding": { 1147 | "type": "github", 1148 | "url": "https://github.com/wessberg/ts-clone-node?sponsor=1" 1149 | } 1150 | }, 1151 | "node_modules/@rollup/pluginutils": { 1152 | "version": "5.1.0", 1153 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.0.tgz", 1154 | "integrity": "sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g==", 1155 | "dev": true, 1156 | "dependencies": { 1157 | "@types/estree": "^1.0.0", 1158 | "estree-walker": "^2.0.2", 1159 | "picomatch": "^2.3.1" 1160 | }, 1161 | "engines": { 1162 | "node": ">=14.0.0" 1163 | }, 1164 | "peerDependencies": { 1165 | "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" 1166 | }, 1167 | "peerDependenciesMeta": { 1168 | "rollup": { 1169 | "optional": true 1170 | } 1171 | } 1172 | }, 1173 | "node_modules/@sinclair/typebox": { 1174 | "version": "0.25.24", 1175 | "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.25.24.tgz", 1176 | "integrity": "sha512-XJfwUVUKDHF5ugKwIcxEgc9k8b7HbznCp6eUfWgu710hMPNIO4aw4/zB5RogDQz8nd6gyCDpU9O/m6qYEWY6yQ==", 1177 | "dev": true 1178 | }, 1179 | "node_modules/@sinonjs/commons": { 1180 | "version": "2.0.0", 1181 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-2.0.0.tgz", 1182 | "integrity": "sha512-uLa0j859mMrg2slwQYdO/AkrOfmH+X6LTVmNTS9CqexuE2IvVORIkSpJLqePAbEnKJ77aMmCwr1NUZ57120Xcg==", 1183 | "dev": true, 1184 | "dependencies": { 1185 | "type-detect": "4.0.8" 1186 | } 1187 | }, 1188 | "node_modules/@sinonjs/fake-timers": { 1189 | "version": "10.0.2", 1190 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.0.2.tgz", 1191 | "integrity": "sha512-SwUDyjWnah1AaNl7kxsa7cfLhlTYoiyhDAIgyh+El30YvXs/o7OLXpYH88Zdhyx9JExKrmHDJ+10bwIcY80Jmw==", 1192 | "dev": true, 1193 | "dependencies": { 1194 | "@sinonjs/commons": "^2.0.0" 1195 | } 1196 | }, 1197 | "node_modules/@types/babel__core": { 1198 | "version": "7.20.0", 1199 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.0.tgz", 1200 | "integrity": "sha512-+n8dL/9GWblDO0iU6eZAwEIJVr5DWigtle+Q6HLOrh/pdbXOhOtqzq8VPPE2zvNJzSKY4vH/z3iT3tn0A3ypiQ==", 1201 | "dev": true, 1202 | "dependencies": { 1203 | "@babel/parser": "^7.20.7", 1204 | "@babel/types": "^7.20.7", 1205 | "@types/babel__generator": "*", 1206 | "@types/babel__template": "*", 1207 | "@types/babel__traverse": "*" 1208 | } 1209 | }, 1210 | "node_modules/@types/babel__generator": { 1211 | "version": "7.6.4", 1212 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", 1213 | "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", 1214 | "dev": true, 1215 | "dependencies": { 1216 | "@babel/types": "^7.0.0" 1217 | } 1218 | }, 1219 | "node_modules/@types/babel__template": { 1220 | "version": "7.4.1", 1221 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", 1222 | "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", 1223 | "dev": true, 1224 | "dependencies": { 1225 | "@babel/parser": "^7.1.0", 1226 | "@babel/types": "^7.0.0" 1227 | } 1228 | }, 1229 | "node_modules/@types/babel__traverse": { 1230 | "version": "7.18.5", 1231 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.18.5.tgz", 1232 | "integrity": "sha512-enCvTL8m/EHS/zIvJno9nE+ndYPh1/oNFzRYRmtUqJICG2VnCSBzMLW5VN2KCQU91f23tsNKR8v7VJJQMatl7Q==", 1233 | "dev": true, 1234 | "dependencies": { 1235 | "@babel/types": "^7.3.0" 1236 | } 1237 | }, 1238 | "node_modules/@types/estree": { 1239 | "version": "1.0.5", 1240 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 1241 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 1242 | "dev": true 1243 | }, 1244 | "node_modules/@types/format-util": { 1245 | "version": "1.0.4", 1246 | "resolved": "https://registry.npmjs.org/@types/format-util/-/format-util-1.0.4.tgz", 1247 | "integrity": "sha512-xrCYOdHh5zA3LUrn6CvspYwlzSWxPso11Lx32WnAG6KvLCRecKZ/Rh21PLXUkzUFsQmrGcx/traJAFjR6dVS5Q==", 1248 | "license": "MIT" 1249 | }, 1250 | "node_modules/@types/graceful-fs": { 1251 | "version": "4.1.6", 1252 | "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", 1253 | "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", 1254 | "dev": true, 1255 | "dependencies": { 1256 | "@types/node": "*" 1257 | } 1258 | }, 1259 | "node_modules/@types/istanbul-lib-coverage": { 1260 | "version": "2.0.4", 1261 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", 1262 | "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", 1263 | "dev": true 1264 | }, 1265 | "node_modules/@types/istanbul-lib-report": { 1266 | "version": "3.0.0", 1267 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1268 | "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", 1269 | "dev": true, 1270 | "dependencies": { 1271 | "@types/istanbul-lib-coverage": "*" 1272 | } 1273 | }, 1274 | "node_modules/@types/istanbul-reports": { 1275 | "version": "3.0.1", 1276 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", 1277 | "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", 1278 | "dev": true, 1279 | "dependencies": { 1280 | "@types/istanbul-lib-report": "*" 1281 | } 1282 | }, 1283 | "node_modules/@types/jest": { 1284 | "version": "29.5.1", 1285 | "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.1.tgz", 1286 | "integrity": "sha512-tEuVcHrpaixS36w7hpsfLBLpjtMRJUE09/MHXn923LOVojDwyC14cWcfc0rDs0VEfUyYmt/+iX1kxxp+gZMcaQ==", 1287 | "dev": true, 1288 | "dependencies": { 1289 | "expect": "^29.0.0", 1290 | "pretty-format": "^29.0.0" 1291 | } 1292 | }, 1293 | "node_modules/@types/node": { 1294 | "version": "20.17.57", 1295 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.57.tgz", 1296 | "integrity": "sha512-f3T4y6VU4fVQDKVqJV4Uppy8c1p/sVvS3peyqxyWnzkqXFJLRU7Y1Bl7rMS1Qe9z0v4M6McY0Fp9yBsgHJUsWQ==", 1297 | "dev": true, 1298 | "license": "MIT", 1299 | "dependencies": { 1300 | "undici-types": "~6.19.2" 1301 | } 1302 | }, 1303 | "node_modules/@types/prettier": { 1304 | "version": "2.7.2", 1305 | "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.2.tgz", 1306 | "integrity": "sha512-KufADq8uQqo1pYKVIYzfKbJfBAc0sOeXqGbFaSpv8MRmC/zXgowNZmFcbngndGk922QDmOASEXUZCaY48gs4cg==", 1307 | "dev": true 1308 | }, 1309 | "node_modules/@types/stack-utils": { 1310 | "version": "2.0.1", 1311 | "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", 1312 | "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", 1313 | "dev": true 1314 | }, 1315 | "node_modules/@types/uuid": { 1316 | "version": "8.3.4", 1317 | "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-8.3.4.tgz", 1318 | "integrity": "sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw==", 1319 | "license": "MIT" 1320 | }, 1321 | "node_modules/@types/yargs": { 1322 | "version": "17.0.24", 1323 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.24.tgz", 1324 | "integrity": "sha512-6i0aC7jV6QzQB8ne1joVZ0eSFIstHsCrobmOtghM11yGlH0j43FKL2UhWdELkyps0zuf7qVTUVCCR+tgSlyLLw==", 1325 | "dev": true, 1326 | "dependencies": { 1327 | "@types/yargs-parser": "*" 1328 | } 1329 | }, 1330 | "node_modules/@types/yargs-parser": { 1331 | "version": "21.0.0", 1332 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", 1333 | "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", 1334 | "dev": true 1335 | }, 1336 | "node_modules/@typescript/vfs": { 1337 | "version": "1.5.0", 1338 | "resolved": "https://registry.npmjs.org/@typescript/vfs/-/vfs-1.5.0.tgz", 1339 | "integrity": "sha512-AJS307bPgbsZZ9ggCT3wwpg3VbTKMFNHfaY/uF0ahSkYYrPF2dSSKDNIDIQAHm9qJqbLvCsSJH7yN4Vs/CsMMg==", 1340 | "dev": true, 1341 | "dependencies": { 1342 | "debug": "^4.1.1" 1343 | } 1344 | }, 1345 | "node_modules/ansi-escapes": { 1346 | "version": "4.3.2", 1347 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 1348 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 1349 | "dev": true, 1350 | "dependencies": { 1351 | "type-fest": "^0.21.3" 1352 | }, 1353 | "engines": { 1354 | "node": ">=8" 1355 | }, 1356 | "funding": { 1357 | "url": "https://github.com/sponsors/sindresorhus" 1358 | } 1359 | }, 1360 | "node_modules/ansi-regex": { 1361 | "version": "5.0.1", 1362 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1363 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1364 | "dev": true, 1365 | "engines": { 1366 | "node": ">=8" 1367 | } 1368 | }, 1369 | "node_modules/ansi-styles": { 1370 | "version": "4.3.0", 1371 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1372 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1373 | "dependencies": { 1374 | "color-convert": "^2.0.1" 1375 | }, 1376 | "engines": { 1377 | "node": ">=8" 1378 | }, 1379 | "funding": { 1380 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1381 | } 1382 | }, 1383 | "node_modules/anymatch": { 1384 | "version": "3.1.3", 1385 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1386 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1387 | "dev": true, 1388 | "dependencies": { 1389 | "normalize-path": "^3.0.0", 1390 | "picomatch": "^2.0.4" 1391 | }, 1392 | "engines": { 1393 | "node": ">= 8" 1394 | } 1395 | }, 1396 | "node_modules/argparse": { 1397 | "version": "1.0.10", 1398 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1399 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1400 | "dev": true, 1401 | "dependencies": { 1402 | "sprintf-js": "~1.0.2" 1403 | } 1404 | }, 1405 | "node_modules/async": { 1406 | "version": "3.2.6", 1407 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.6.tgz", 1408 | "integrity": "sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==", 1409 | "dev": true, 1410 | "license": "MIT" 1411 | }, 1412 | "node_modules/babel-jest": { 1413 | "version": "29.5.0", 1414 | "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.5.0.tgz", 1415 | "integrity": "sha512-mA4eCDh5mSo2EcA9xQjVTpmbbNk32Zb3Q3QFQsNhaK56Q+yoXowzFodLux30HRgyOho5rsQ6B0P9QpMkvvnJ0Q==", 1416 | "dev": true, 1417 | "dependencies": { 1418 | "@jest/transform": "^29.5.0", 1419 | "@types/babel__core": "^7.1.14", 1420 | "babel-plugin-istanbul": "^6.1.1", 1421 | "babel-preset-jest": "^29.5.0", 1422 | "chalk": "^4.0.0", 1423 | "graceful-fs": "^4.2.9", 1424 | "slash": "^3.0.0" 1425 | }, 1426 | "engines": { 1427 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1428 | }, 1429 | "peerDependencies": { 1430 | "@babel/core": "^7.8.0" 1431 | } 1432 | }, 1433 | "node_modules/babel-plugin-istanbul": { 1434 | "version": "6.1.1", 1435 | "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", 1436 | "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", 1437 | "dev": true, 1438 | "dependencies": { 1439 | "@babel/helper-plugin-utils": "^7.0.0", 1440 | "@istanbuljs/load-nyc-config": "^1.0.0", 1441 | "@istanbuljs/schema": "^0.1.2", 1442 | "istanbul-lib-instrument": "^5.0.4", 1443 | "test-exclude": "^6.0.0" 1444 | }, 1445 | "engines": { 1446 | "node": ">=8" 1447 | } 1448 | }, 1449 | "node_modules/babel-plugin-jest-hoist": { 1450 | "version": "29.5.0", 1451 | "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.5.0.tgz", 1452 | "integrity": "sha512-zSuuuAlTMT4mzLj2nPnUm6fsE6270vdOfnpbJ+RmruU75UhLFvL0N2NgI7xpeS7NaB6hGqmd5pVpGTDYvi4Q3w==", 1453 | "dev": true, 1454 | "dependencies": { 1455 | "@babel/template": "^7.3.3", 1456 | "@babel/types": "^7.3.3", 1457 | "@types/babel__core": "^7.1.14", 1458 | "@types/babel__traverse": "^7.0.6" 1459 | }, 1460 | "engines": { 1461 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1462 | } 1463 | }, 1464 | "node_modules/babel-preset-current-node-syntax": { 1465 | "version": "1.0.1", 1466 | "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", 1467 | "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", 1468 | "dev": true, 1469 | "dependencies": { 1470 | "@babel/plugin-syntax-async-generators": "^7.8.4", 1471 | "@babel/plugin-syntax-bigint": "^7.8.3", 1472 | "@babel/plugin-syntax-class-properties": "^7.8.3", 1473 | "@babel/plugin-syntax-import-meta": "^7.8.3", 1474 | "@babel/plugin-syntax-json-strings": "^7.8.3", 1475 | "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", 1476 | "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", 1477 | "@babel/plugin-syntax-numeric-separator": "^7.8.3", 1478 | "@babel/plugin-syntax-object-rest-spread": "^7.8.3", 1479 | "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", 1480 | "@babel/plugin-syntax-optional-chaining": "^7.8.3", 1481 | "@babel/plugin-syntax-top-level-await": "^7.8.3" 1482 | }, 1483 | "peerDependencies": { 1484 | "@babel/core": "^7.0.0" 1485 | } 1486 | }, 1487 | "node_modules/babel-preset-jest": { 1488 | "version": "29.5.0", 1489 | "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.5.0.tgz", 1490 | "integrity": "sha512-JOMloxOqdiBSxMAzjRaH023/vvcaSaec49zvg+2LmNsktC7ei39LTJGw02J+9uUtTZUq6xbLyJ4dxe9sSmIuAg==", 1491 | "dev": true, 1492 | "dependencies": { 1493 | "babel-plugin-jest-hoist": "^29.5.0", 1494 | "babel-preset-current-node-syntax": "^1.0.0" 1495 | }, 1496 | "engines": { 1497 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1498 | }, 1499 | "peerDependencies": { 1500 | "@babel/core": "^7.0.0" 1501 | } 1502 | }, 1503 | "node_modules/balanced-match": { 1504 | "version": "1.0.2", 1505 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1506 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1507 | "dev": true 1508 | }, 1509 | "node_modules/base64-js": { 1510 | "version": "1.5.1", 1511 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 1512 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 1513 | "funding": [ 1514 | { 1515 | "type": "github", 1516 | "url": "https://github.com/sponsors/feross" 1517 | }, 1518 | { 1519 | "type": "patreon", 1520 | "url": "https://www.patreon.com/feross" 1521 | }, 1522 | { 1523 | "type": "consulting", 1524 | "url": "https://feross.org/support" 1525 | } 1526 | ], 1527 | "license": "MIT" 1528 | }, 1529 | "node_modules/brace-expansion": { 1530 | "version": "1.1.11", 1531 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1532 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1533 | "dev": true, 1534 | "dependencies": { 1535 | "balanced-match": "^1.0.0", 1536 | "concat-map": "0.0.1" 1537 | } 1538 | }, 1539 | "node_modules/braces": { 1540 | "version": "3.0.2", 1541 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1542 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1543 | "dev": true, 1544 | "dependencies": { 1545 | "fill-range": "^7.0.1" 1546 | }, 1547 | "engines": { 1548 | "node": ">=8" 1549 | } 1550 | }, 1551 | "node_modules/browserslist": { 1552 | "version": "4.21.5", 1553 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz", 1554 | "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==", 1555 | "dev": true, 1556 | "funding": [ 1557 | { 1558 | "type": "opencollective", 1559 | "url": "https://opencollective.com/browserslist" 1560 | }, 1561 | { 1562 | "type": "tidelift", 1563 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1564 | } 1565 | ], 1566 | "dependencies": { 1567 | "caniuse-lite": "^1.0.30001449", 1568 | "electron-to-chromium": "^1.4.284", 1569 | "node-releases": "^2.0.8", 1570 | "update-browserslist-db": "^1.0.10" 1571 | }, 1572 | "bin": { 1573 | "browserslist": "cli.js" 1574 | }, 1575 | "engines": { 1576 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1577 | } 1578 | }, 1579 | "node_modules/bs-logger": { 1580 | "version": "0.2.6", 1581 | "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz", 1582 | "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==", 1583 | "dev": true, 1584 | "dependencies": { 1585 | "fast-json-stable-stringify": "2.x" 1586 | }, 1587 | "engines": { 1588 | "node": ">= 6" 1589 | } 1590 | }, 1591 | "node_modules/bser": { 1592 | "version": "2.1.1", 1593 | "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", 1594 | "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", 1595 | "dev": true, 1596 | "dependencies": { 1597 | "node-int64": "^0.4.0" 1598 | } 1599 | }, 1600 | "node_modules/buffer": { 1601 | "version": "5.7.1", 1602 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 1603 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 1604 | "funding": [ 1605 | { 1606 | "type": "github", 1607 | "url": "https://github.com/sponsors/feross" 1608 | }, 1609 | { 1610 | "type": "patreon", 1611 | "url": "https://www.patreon.com/feross" 1612 | }, 1613 | { 1614 | "type": "consulting", 1615 | "url": "https://feross.org/support" 1616 | } 1617 | ], 1618 | "license": "MIT", 1619 | "dependencies": { 1620 | "base64-js": "^1.3.1", 1621 | "ieee754": "^1.1.13" 1622 | } 1623 | }, 1624 | "node_modules/buffer-from": { 1625 | "version": "1.1.2", 1626 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1627 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1628 | "dev": true 1629 | }, 1630 | "node_modules/callsites": { 1631 | "version": "3.1.0", 1632 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1633 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1634 | "dev": true, 1635 | "engines": { 1636 | "node": ">=6" 1637 | } 1638 | }, 1639 | "node_modules/camelcase": { 1640 | "version": "5.3.1", 1641 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 1642 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 1643 | "dev": true, 1644 | "engines": { 1645 | "node": ">=6" 1646 | } 1647 | }, 1648 | "node_modules/caniuse-lite": { 1649 | "version": "1.0.30001486", 1650 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001486.tgz", 1651 | "integrity": "sha512-uv7/gXuHi10Whlj0pp5q/tsK/32J2QSqVRKQhs2j8VsDCjgyruAh/eEXHF822VqO9yT6iZKw3nRwZRSPBE9OQg==", 1652 | "dev": true, 1653 | "funding": [ 1654 | { 1655 | "type": "opencollective", 1656 | "url": "https://opencollective.com/browserslist" 1657 | }, 1658 | { 1659 | "type": "tidelift", 1660 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1661 | }, 1662 | { 1663 | "type": "github", 1664 | "url": "https://github.com/sponsors/ai" 1665 | } 1666 | ] 1667 | }, 1668 | "node_modules/chalk": { 1669 | "version": "4.1.2", 1670 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1671 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1672 | "dev": true, 1673 | "dependencies": { 1674 | "ansi-styles": "^4.1.0", 1675 | "supports-color": "^7.1.0" 1676 | }, 1677 | "engines": { 1678 | "node": ">=10" 1679 | }, 1680 | "funding": { 1681 | "url": "https://github.com/chalk/chalk?sponsor=1" 1682 | } 1683 | }, 1684 | "node_modules/char-regex": { 1685 | "version": "1.0.2", 1686 | "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", 1687 | "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", 1688 | "dev": true, 1689 | "engines": { 1690 | "node": ">=10" 1691 | } 1692 | }, 1693 | "node_modules/ci-info": { 1694 | "version": "3.8.0", 1695 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", 1696 | "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", 1697 | "dev": true, 1698 | "funding": [ 1699 | { 1700 | "type": "github", 1701 | "url": "https://github.com/sponsors/sibiraj-s" 1702 | } 1703 | ], 1704 | "engines": { 1705 | "node": ">=8" 1706 | } 1707 | }, 1708 | "node_modules/cjs-module-lexer": { 1709 | "version": "1.2.2", 1710 | "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", 1711 | "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", 1712 | "dev": true 1713 | }, 1714 | "node_modules/cliui": { 1715 | "version": "8.0.1", 1716 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 1717 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 1718 | "dev": true, 1719 | "dependencies": { 1720 | "string-width": "^4.2.0", 1721 | "strip-ansi": "^6.0.1", 1722 | "wrap-ansi": "^7.0.0" 1723 | }, 1724 | "engines": { 1725 | "node": ">=12" 1726 | } 1727 | }, 1728 | "node_modules/co": { 1729 | "version": "4.6.0", 1730 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 1731 | "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", 1732 | "dev": true, 1733 | "engines": { 1734 | "iojs": ">= 1.0.0", 1735 | "node": ">= 0.12.0" 1736 | } 1737 | }, 1738 | "node_modules/collect-v8-coverage": { 1739 | "version": "1.0.1", 1740 | "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", 1741 | "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", 1742 | "dev": true 1743 | }, 1744 | "node_modules/color-convert": { 1745 | "version": "2.0.1", 1746 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1747 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1748 | "dependencies": { 1749 | "color-name": "~1.1.4" 1750 | }, 1751 | "engines": { 1752 | "node": ">=7.0.0" 1753 | } 1754 | }, 1755 | "node_modules/color-name": { 1756 | "version": "1.1.4", 1757 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1758 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 1759 | }, 1760 | "node_modules/compatfactory": { 1761 | "version": "2.0.9", 1762 | "resolved": "https://registry.npmjs.org/compatfactory/-/compatfactory-2.0.9.tgz", 1763 | "integrity": "sha512-fvO+AWcmbO7P1S+A3mwm3IGr74eHMeq5ZLhNhyNQc9mVDNHT4oe0Gg0ksdIFFNXLK7k7Z/TYcLAUSQdRgh1bsA==", 1764 | "dev": true, 1765 | "dependencies": { 1766 | "helpertypes": "^0.0.19" 1767 | }, 1768 | "engines": { 1769 | "node": ">=14.9.0" 1770 | }, 1771 | "peerDependencies": { 1772 | "typescript": ">=3.x || >= 4.x" 1773 | } 1774 | }, 1775 | "node_modules/concat-map": { 1776 | "version": "0.0.1", 1777 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1778 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1779 | "dev": true 1780 | }, 1781 | "node_modules/convert-source-map": { 1782 | "version": "2.0.0", 1783 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1784 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1785 | "dev": true 1786 | }, 1787 | "node_modules/cross-spawn": { 1788 | "version": "7.0.3", 1789 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1790 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1791 | "dev": true, 1792 | "dependencies": { 1793 | "path-key": "^3.1.0", 1794 | "shebang-command": "^2.0.0", 1795 | "which": "^2.0.1" 1796 | }, 1797 | "engines": { 1798 | "node": ">= 8" 1799 | } 1800 | }, 1801 | "node_modules/debug": { 1802 | "version": "4.3.4", 1803 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1804 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1805 | "dev": true, 1806 | "dependencies": { 1807 | "ms": "2.1.2" 1808 | }, 1809 | "engines": { 1810 | "node": ">=6.0" 1811 | }, 1812 | "peerDependenciesMeta": { 1813 | "supports-color": { 1814 | "optional": true 1815 | } 1816 | } 1817 | }, 1818 | "node_modules/dedent": { 1819 | "version": "0.7.0", 1820 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 1821 | "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", 1822 | "dev": true 1823 | }, 1824 | "node_modules/deepmerge": { 1825 | "version": "4.3.1", 1826 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", 1827 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", 1828 | "dev": true, 1829 | "engines": { 1830 | "node": ">=0.10.0" 1831 | } 1832 | }, 1833 | "node_modules/detect-newline": { 1834 | "version": "3.1.0", 1835 | "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", 1836 | "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", 1837 | "dev": true, 1838 | "engines": { 1839 | "node": ">=8" 1840 | } 1841 | }, 1842 | "node_modules/diff-sequences": { 1843 | "version": "29.4.3", 1844 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.4.3.tgz", 1845 | "integrity": "sha512-ofrBgwpPhCD85kMKtE9RYFFq6OC1A89oW2vvgWZNCwxrUpRUILopY7lsYyMDSjc8g6U6aiO0Qubg6r4Wgt5ZnA==", 1846 | "dev": true, 1847 | "engines": { 1848 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1849 | } 1850 | }, 1851 | "node_modules/dot-prop": { 1852 | "version": "5.3.0", 1853 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 1854 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 1855 | "license": "MIT", 1856 | "peer": true, 1857 | "dependencies": { 1858 | "is-obj": "^2.0.0" 1859 | }, 1860 | "engines": { 1861 | "node": ">=8" 1862 | } 1863 | }, 1864 | "node_modules/ejs": { 1865 | "version": "3.1.10", 1866 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz", 1867 | "integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==", 1868 | "dev": true, 1869 | "license": "Apache-2.0", 1870 | "dependencies": { 1871 | "jake": "^10.8.5" 1872 | }, 1873 | "bin": { 1874 | "ejs": "bin/cli.js" 1875 | }, 1876 | "engines": { 1877 | "node": ">=0.10.0" 1878 | } 1879 | }, 1880 | "node_modules/electron-to-chromium": { 1881 | "version": "1.4.385", 1882 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.385.tgz", 1883 | "integrity": "sha512-L9zlje9bIw0h+CwPQumiuVlfMcV4boxRjFIWDcLfFqTZNbkwOExBzfmswytHawObQX4OUhtNv8gIiB21kOurIg==", 1884 | "dev": true 1885 | }, 1886 | "node_modules/emittery": { 1887 | "version": "0.13.1", 1888 | "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", 1889 | "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", 1890 | "dev": true, 1891 | "engines": { 1892 | "node": ">=12" 1893 | }, 1894 | "funding": { 1895 | "url": "https://github.com/sindresorhus/emittery?sponsor=1" 1896 | } 1897 | }, 1898 | "node_modules/emoji-regex": { 1899 | "version": "8.0.0", 1900 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1901 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1902 | "dev": true 1903 | }, 1904 | "node_modules/error-ex": { 1905 | "version": "1.3.2", 1906 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 1907 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 1908 | "dev": true, 1909 | "dependencies": { 1910 | "is-arrayish": "^0.2.1" 1911 | } 1912 | }, 1913 | "node_modules/escalade": { 1914 | "version": "3.1.1", 1915 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1916 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1917 | "dev": true, 1918 | "engines": { 1919 | "node": ">=6" 1920 | } 1921 | }, 1922 | "node_modules/esprima": { 1923 | "version": "4.0.1", 1924 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1925 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1926 | "dev": true, 1927 | "bin": { 1928 | "esparse": "bin/esparse.js", 1929 | "esvalidate": "bin/esvalidate.js" 1930 | }, 1931 | "engines": { 1932 | "node": ">=4" 1933 | } 1934 | }, 1935 | "node_modules/estree-walker": { 1936 | "version": "2.0.2", 1937 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 1938 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 1939 | "dev": true 1940 | }, 1941 | "node_modules/execa": { 1942 | "version": "5.1.1", 1943 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 1944 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 1945 | "dev": true, 1946 | "dependencies": { 1947 | "cross-spawn": "^7.0.3", 1948 | "get-stream": "^6.0.0", 1949 | "human-signals": "^2.1.0", 1950 | "is-stream": "^2.0.0", 1951 | "merge-stream": "^2.0.0", 1952 | "npm-run-path": "^4.0.1", 1953 | "onetime": "^5.1.2", 1954 | "signal-exit": "^3.0.3", 1955 | "strip-final-newline": "^2.0.0" 1956 | }, 1957 | "engines": { 1958 | "node": ">=10" 1959 | }, 1960 | "funding": { 1961 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 1962 | } 1963 | }, 1964 | "node_modules/exit": { 1965 | "version": "0.1.2", 1966 | "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", 1967 | "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", 1968 | "dev": true, 1969 | "engines": { 1970 | "node": ">= 0.8.0" 1971 | } 1972 | }, 1973 | "node_modules/expect": { 1974 | "version": "29.5.0", 1975 | "resolved": "https://registry.npmjs.org/expect/-/expect-29.5.0.tgz", 1976 | "integrity": "sha512-yM7xqUrCO2JdpFo4XpM82t+PJBFybdqoQuJLDGeDX2ij8NZzqRHyu3Hp188/JX7SWqud+7t4MUdvcgGBICMHZg==", 1977 | "dev": true, 1978 | "dependencies": { 1979 | "@jest/expect-utils": "^29.5.0", 1980 | "jest-get-type": "^29.4.3", 1981 | "jest-matcher-utils": "^29.5.0", 1982 | "jest-message-util": "^29.5.0", 1983 | "jest-util": "^29.5.0" 1984 | }, 1985 | "engines": { 1986 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1987 | } 1988 | }, 1989 | "node_modules/fast-json-stable-stringify": { 1990 | "version": "2.1.0", 1991 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1992 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1993 | "dev": true 1994 | }, 1995 | "node_modules/fb-watchman": { 1996 | "version": "2.0.2", 1997 | "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", 1998 | "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", 1999 | "dev": true, 2000 | "dependencies": { 2001 | "bser": "2.1.1" 2002 | } 2003 | }, 2004 | "node_modules/filelist": { 2005 | "version": "1.0.4", 2006 | "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz", 2007 | "integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==", 2008 | "dev": true, 2009 | "license": "Apache-2.0", 2010 | "dependencies": { 2011 | "minimatch": "^5.0.1" 2012 | } 2013 | }, 2014 | "node_modules/filelist/node_modules/brace-expansion": { 2015 | "version": "2.0.1", 2016 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2017 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2018 | "dev": true, 2019 | "license": "MIT", 2020 | "dependencies": { 2021 | "balanced-match": "^1.0.0" 2022 | } 2023 | }, 2024 | "node_modules/filelist/node_modules/minimatch": { 2025 | "version": "5.1.6", 2026 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 2027 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 2028 | "dev": true, 2029 | "license": "ISC", 2030 | "dependencies": { 2031 | "brace-expansion": "^2.0.1" 2032 | }, 2033 | "engines": { 2034 | "node": ">=10" 2035 | } 2036 | }, 2037 | "node_modules/fill-range": { 2038 | "version": "7.0.1", 2039 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2040 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2041 | "dev": true, 2042 | "dependencies": { 2043 | "to-regex-range": "^5.0.1" 2044 | }, 2045 | "engines": { 2046 | "node": ">=8" 2047 | } 2048 | }, 2049 | "node_modules/find-up": { 2050 | "version": "4.1.0", 2051 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2052 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2053 | "dev": true, 2054 | "dependencies": { 2055 | "locate-path": "^5.0.0", 2056 | "path-exists": "^4.0.0" 2057 | }, 2058 | "engines": { 2059 | "node": ">=8" 2060 | } 2061 | }, 2062 | "node_modules/format-util": { 2063 | "version": "1.0.5", 2064 | "resolved": "https://registry.npmjs.org/format-util/-/format-util-1.0.5.tgz", 2065 | "integrity": "sha512-varLbTj0e0yVyRpqQhuWV+8hlePAgaoFRhNFj50BNjEIrw1/DphHSObtqwskVCPWNgzwPoQrZAbfa/SBiicNeg==", 2066 | "license": "MIT" 2067 | }, 2068 | "node_modules/fs.realpath": { 2069 | "version": "1.0.0", 2070 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2071 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2072 | "dev": true 2073 | }, 2074 | "node_modules/fsevents": { 2075 | "version": "2.3.2", 2076 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2077 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2078 | "dev": true, 2079 | "hasInstallScript": true, 2080 | "optional": true, 2081 | "os": [ 2082 | "darwin" 2083 | ], 2084 | "engines": { 2085 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2086 | } 2087 | }, 2088 | "node_modules/function-bind": { 2089 | "version": "1.1.1", 2090 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2091 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 2092 | "dev": true 2093 | }, 2094 | "node_modules/gensync": { 2095 | "version": "1.0.0-beta.2", 2096 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2097 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2098 | "dev": true, 2099 | "engines": { 2100 | "node": ">=6.9.0" 2101 | } 2102 | }, 2103 | "node_modules/get-caller-file": { 2104 | "version": "2.0.5", 2105 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2106 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2107 | "dev": true, 2108 | "engines": { 2109 | "node": "6.* || 8.* || >= 10.*" 2110 | } 2111 | }, 2112 | "node_modules/get-package-type": { 2113 | "version": "0.1.0", 2114 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 2115 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 2116 | "dev": true, 2117 | "engines": { 2118 | "node": ">=8.0.0" 2119 | } 2120 | }, 2121 | "node_modules/get-stream": { 2122 | "version": "6.0.1", 2123 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 2124 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 2125 | "dev": true, 2126 | "engines": { 2127 | "node": ">=10" 2128 | }, 2129 | "funding": { 2130 | "url": "https://github.com/sponsors/sindresorhus" 2131 | } 2132 | }, 2133 | "node_modules/get-tsconfig": { 2134 | "version": "4.5.0", 2135 | "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.5.0.tgz", 2136 | "integrity": "sha512-MjhiaIWCJ1sAU4pIQ5i5OfOuHHxVo1oYeNsWTON7jxYkod8pHocXeh+SSbmu5OZZZK73B6cbJ2XADzXehLyovQ==", 2137 | "dev": true, 2138 | "funding": { 2139 | "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" 2140 | } 2141 | }, 2142 | "node_modules/glob": { 2143 | "version": "7.2.3", 2144 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2145 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2146 | "dev": true, 2147 | "dependencies": { 2148 | "fs.realpath": "^1.0.0", 2149 | "inflight": "^1.0.4", 2150 | "inherits": "2", 2151 | "minimatch": "^3.1.1", 2152 | "once": "^1.3.0", 2153 | "path-is-absolute": "^1.0.0" 2154 | }, 2155 | "engines": { 2156 | "node": "*" 2157 | }, 2158 | "funding": { 2159 | "url": "https://github.com/sponsors/isaacs" 2160 | } 2161 | }, 2162 | "node_modules/globals": { 2163 | "version": "11.12.0", 2164 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2165 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2166 | "dev": true, 2167 | "engines": { 2168 | "node": ">=4" 2169 | } 2170 | }, 2171 | "node_modules/graceful-fs": { 2172 | "version": "4.2.11", 2173 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 2174 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 2175 | "dev": true 2176 | }, 2177 | "node_modules/has": { 2178 | "version": "1.0.3", 2179 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2180 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2181 | "dev": true, 2182 | "dependencies": { 2183 | "function-bind": "^1.1.1" 2184 | }, 2185 | "engines": { 2186 | "node": ">= 0.4.0" 2187 | } 2188 | }, 2189 | "node_modules/has-flag": { 2190 | "version": "4.0.0", 2191 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2192 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2193 | "dev": true, 2194 | "engines": { 2195 | "node": ">=8" 2196 | } 2197 | }, 2198 | "node_modules/helpertypes": { 2199 | "version": "0.0.19", 2200 | "resolved": "https://registry.npmjs.org/helpertypes/-/helpertypes-0.0.19.tgz", 2201 | "integrity": "sha512-J00e55zffgi3yVnUp0UdbMztNkr2PnizEkOe9URNohnrNhW5X0QpegkuLpOmFQInpi93Nb8MCjQRHAiCDF42NQ==", 2202 | "dev": true, 2203 | "engines": { 2204 | "node": ">=10.0.0" 2205 | } 2206 | }, 2207 | "node_modules/html-escaper": { 2208 | "version": "2.0.2", 2209 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 2210 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 2211 | "dev": true 2212 | }, 2213 | "node_modules/human-signals": { 2214 | "version": "2.1.0", 2215 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 2216 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 2217 | "dev": true, 2218 | "engines": { 2219 | "node": ">=10.17.0" 2220 | } 2221 | }, 2222 | "node_modules/ieee754": { 2223 | "version": "1.2.1", 2224 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 2225 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 2226 | "funding": [ 2227 | { 2228 | "type": "github", 2229 | "url": "https://github.com/sponsors/feross" 2230 | }, 2231 | { 2232 | "type": "patreon", 2233 | "url": "https://www.patreon.com/feross" 2234 | }, 2235 | { 2236 | "type": "consulting", 2237 | "url": "https://feross.org/support" 2238 | } 2239 | ], 2240 | "license": "BSD-3-Clause" 2241 | }, 2242 | "node_modules/import-local": { 2243 | "version": "3.1.0", 2244 | "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", 2245 | "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", 2246 | "dev": true, 2247 | "dependencies": { 2248 | "pkg-dir": "^4.2.0", 2249 | "resolve-cwd": "^3.0.0" 2250 | }, 2251 | "bin": { 2252 | "import-local-fixture": "fixtures/cli.js" 2253 | }, 2254 | "engines": { 2255 | "node": ">=8" 2256 | }, 2257 | "funding": { 2258 | "url": "https://github.com/sponsors/sindresorhus" 2259 | } 2260 | }, 2261 | "node_modules/imurmurhash": { 2262 | "version": "0.1.4", 2263 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2264 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2265 | "dev": true, 2266 | "engines": { 2267 | "node": ">=0.8.19" 2268 | } 2269 | }, 2270 | "node_modules/inflight": { 2271 | "version": "1.0.6", 2272 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2273 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2274 | "dev": true, 2275 | "dependencies": { 2276 | "once": "^1.3.0", 2277 | "wrappy": "1" 2278 | } 2279 | }, 2280 | "node_modules/inherits": { 2281 | "version": "2.0.4", 2282 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2283 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2284 | "dev": true 2285 | }, 2286 | "node_modules/is-arrayish": { 2287 | "version": "0.2.1", 2288 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2289 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", 2290 | "dev": true 2291 | }, 2292 | "node_modules/is-core-module": { 2293 | "version": "2.12.0", 2294 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.0.tgz", 2295 | "integrity": "sha512-RECHCBCd/viahWmwj6enj19sKbHfJrddi/6cBDsNTKbNq0f7VeaUkBo60BqzvPqo/W54ChS62Z5qyun7cfOMqQ==", 2296 | "dev": true, 2297 | "dependencies": { 2298 | "has": "^1.0.3" 2299 | }, 2300 | "funding": { 2301 | "url": "https://github.com/sponsors/ljharb" 2302 | } 2303 | }, 2304 | "node_modules/is-fullwidth-code-point": { 2305 | "version": "3.0.0", 2306 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2307 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2308 | "dev": true, 2309 | "engines": { 2310 | "node": ">=8" 2311 | } 2312 | }, 2313 | "node_modules/is-generator-fn": { 2314 | "version": "2.1.0", 2315 | "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", 2316 | "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", 2317 | "dev": true, 2318 | "engines": { 2319 | "node": ">=6" 2320 | } 2321 | }, 2322 | "node_modules/is-number": { 2323 | "version": "7.0.0", 2324 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2325 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2326 | "dev": true, 2327 | "engines": { 2328 | "node": ">=0.12.0" 2329 | } 2330 | }, 2331 | "node_modules/is-obj": { 2332 | "version": "2.0.0", 2333 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 2334 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 2335 | "license": "MIT", 2336 | "peer": true, 2337 | "engines": { 2338 | "node": ">=8" 2339 | } 2340 | }, 2341 | "node_modules/is-stream": { 2342 | "version": "2.0.1", 2343 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 2344 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 2345 | "dev": true, 2346 | "engines": { 2347 | "node": ">=8" 2348 | }, 2349 | "funding": { 2350 | "url": "https://github.com/sponsors/sindresorhus" 2351 | } 2352 | }, 2353 | "node_modules/isexe": { 2354 | "version": "2.0.0", 2355 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2356 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2357 | "dev": true 2358 | }, 2359 | "node_modules/istanbul-lib-coverage": { 2360 | "version": "3.2.0", 2361 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", 2362 | "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", 2363 | "dev": true, 2364 | "engines": { 2365 | "node": ">=8" 2366 | } 2367 | }, 2368 | "node_modules/istanbul-lib-instrument": { 2369 | "version": "5.2.1", 2370 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", 2371 | "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", 2372 | "dev": true, 2373 | "dependencies": { 2374 | "@babel/core": "^7.12.3", 2375 | "@babel/parser": "^7.14.7", 2376 | "@istanbuljs/schema": "^0.1.2", 2377 | "istanbul-lib-coverage": "^3.2.0", 2378 | "semver": "^6.3.0" 2379 | }, 2380 | "engines": { 2381 | "node": ">=8" 2382 | } 2383 | }, 2384 | "node_modules/istanbul-lib-instrument/node_modules/semver": { 2385 | "version": "6.3.0", 2386 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2387 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2388 | "dev": true, 2389 | "bin": { 2390 | "semver": "bin/semver.js" 2391 | } 2392 | }, 2393 | "node_modules/istanbul-lib-report": { 2394 | "version": "3.0.0", 2395 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 2396 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 2397 | "dev": true, 2398 | "dependencies": { 2399 | "istanbul-lib-coverage": "^3.0.0", 2400 | "make-dir": "^3.0.0", 2401 | "supports-color": "^7.1.0" 2402 | }, 2403 | "engines": { 2404 | "node": ">=8" 2405 | } 2406 | }, 2407 | "node_modules/istanbul-lib-source-maps": { 2408 | "version": "4.0.1", 2409 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", 2410 | "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", 2411 | "dev": true, 2412 | "dependencies": { 2413 | "debug": "^4.1.1", 2414 | "istanbul-lib-coverage": "^3.0.0", 2415 | "source-map": "^0.6.1" 2416 | }, 2417 | "engines": { 2418 | "node": ">=10" 2419 | } 2420 | }, 2421 | "node_modules/istanbul-reports": { 2422 | "version": "3.1.5", 2423 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", 2424 | "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", 2425 | "dev": true, 2426 | "dependencies": { 2427 | "html-escaper": "^2.0.0", 2428 | "istanbul-lib-report": "^3.0.0" 2429 | }, 2430 | "engines": { 2431 | "node": ">=8" 2432 | } 2433 | }, 2434 | "node_modules/jake": { 2435 | "version": "10.9.2", 2436 | "resolved": "https://registry.npmjs.org/jake/-/jake-10.9.2.tgz", 2437 | "integrity": "sha512-2P4SQ0HrLQ+fw6llpLnOaGAvN2Zu6778SJMrCUwns4fOoG9ayrTiZk3VV8sCPkVZF8ab0zksVpS8FDY5pRCNBA==", 2438 | "dev": true, 2439 | "license": "Apache-2.0", 2440 | "dependencies": { 2441 | "async": "^3.2.3", 2442 | "chalk": "^4.0.2", 2443 | "filelist": "^1.0.4", 2444 | "minimatch": "^3.1.2" 2445 | }, 2446 | "bin": { 2447 | "jake": "bin/cli.js" 2448 | }, 2449 | "engines": { 2450 | "node": ">=10" 2451 | } 2452 | }, 2453 | "node_modules/jest": { 2454 | "version": "29.5.0", 2455 | "resolved": "https://registry.npmjs.org/jest/-/jest-29.5.0.tgz", 2456 | "integrity": "sha512-juMg3he2uru1QoXX078zTa7pO85QyB9xajZc6bU+d9yEGwrKX6+vGmJQ3UdVZsvTEUARIdObzH68QItim6OSSQ==", 2457 | "dev": true, 2458 | "dependencies": { 2459 | "@jest/core": "^29.5.0", 2460 | "@jest/types": "^29.5.0", 2461 | "import-local": "^3.0.2", 2462 | "jest-cli": "^29.5.0" 2463 | }, 2464 | "bin": { 2465 | "jest": "bin/jest.js" 2466 | }, 2467 | "engines": { 2468 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2469 | }, 2470 | "peerDependencies": { 2471 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 2472 | }, 2473 | "peerDependenciesMeta": { 2474 | "node-notifier": { 2475 | "optional": true 2476 | } 2477 | } 2478 | }, 2479 | "node_modules/jest-changed-files": { 2480 | "version": "29.5.0", 2481 | "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.5.0.tgz", 2482 | "integrity": "sha512-IFG34IUMUaNBIxjQXF/iu7g6EcdMrGRRxaUSw92I/2g2YC6vCdTltl4nHvt7Ci5nSJwXIkCu8Ka1DKF+X7Z1Ag==", 2483 | "dev": true, 2484 | "dependencies": { 2485 | "execa": "^5.0.0", 2486 | "p-limit": "^3.1.0" 2487 | }, 2488 | "engines": { 2489 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2490 | } 2491 | }, 2492 | "node_modules/jest-circus": { 2493 | "version": "29.5.0", 2494 | "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.5.0.tgz", 2495 | "integrity": "sha512-gq/ongqeQKAplVxqJmbeUOJJKkW3dDNPY8PjhJ5G0lBRvu0e3EWGxGy5cI4LAGA7gV2UHCtWBI4EMXK8c9nQKA==", 2496 | "dev": true, 2497 | "dependencies": { 2498 | "@jest/environment": "^29.5.0", 2499 | "@jest/expect": "^29.5.0", 2500 | "@jest/test-result": "^29.5.0", 2501 | "@jest/types": "^29.5.0", 2502 | "@types/node": "*", 2503 | "chalk": "^4.0.0", 2504 | "co": "^4.6.0", 2505 | "dedent": "^0.7.0", 2506 | "is-generator-fn": "^2.0.0", 2507 | "jest-each": "^29.5.0", 2508 | "jest-matcher-utils": "^29.5.0", 2509 | "jest-message-util": "^29.5.0", 2510 | "jest-runtime": "^29.5.0", 2511 | "jest-snapshot": "^29.5.0", 2512 | "jest-util": "^29.5.0", 2513 | "p-limit": "^3.1.0", 2514 | "pretty-format": "^29.5.0", 2515 | "pure-rand": "^6.0.0", 2516 | "slash": "^3.0.0", 2517 | "stack-utils": "^2.0.3" 2518 | }, 2519 | "engines": { 2520 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2521 | } 2522 | }, 2523 | "node_modules/jest-cli": { 2524 | "version": "29.5.0", 2525 | "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.5.0.tgz", 2526 | "integrity": "sha512-L1KcP1l4HtfwdxXNFCL5bmUbLQiKrakMUriBEcc1Vfz6gx31ORKdreuWvmQVBit+1ss9NNR3yxjwfwzZNdQXJw==", 2527 | "dev": true, 2528 | "dependencies": { 2529 | "@jest/core": "^29.5.0", 2530 | "@jest/test-result": "^29.5.0", 2531 | "@jest/types": "^29.5.0", 2532 | "chalk": "^4.0.0", 2533 | "exit": "^0.1.2", 2534 | "graceful-fs": "^4.2.9", 2535 | "import-local": "^3.0.2", 2536 | "jest-config": "^29.5.0", 2537 | "jest-util": "^29.5.0", 2538 | "jest-validate": "^29.5.0", 2539 | "prompts": "^2.0.1", 2540 | "yargs": "^17.3.1" 2541 | }, 2542 | "bin": { 2543 | "jest": "bin/jest.js" 2544 | }, 2545 | "engines": { 2546 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2547 | }, 2548 | "peerDependencies": { 2549 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 2550 | }, 2551 | "peerDependenciesMeta": { 2552 | "node-notifier": { 2553 | "optional": true 2554 | } 2555 | } 2556 | }, 2557 | "node_modules/jest-config": { 2558 | "version": "29.5.0", 2559 | "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.5.0.tgz", 2560 | "integrity": "sha512-kvDUKBnNJPNBmFFOhDbm59iu1Fii1Q6SxyhXfvylq3UTHbg6o7j/g8k2dZyXWLvfdKB1vAPxNZnMgtKJcmu3kA==", 2561 | "dev": true, 2562 | "dependencies": { 2563 | "@babel/core": "^7.11.6", 2564 | "@jest/test-sequencer": "^29.5.0", 2565 | "@jest/types": "^29.5.0", 2566 | "babel-jest": "^29.5.0", 2567 | "chalk": "^4.0.0", 2568 | "ci-info": "^3.2.0", 2569 | "deepmerge": "^4.2.2", 2570 | "glob": "^7.1.3", 2571 | "graceful-fs": "^4.2.9", 2572 | "jest-circus": "^29.5.0", 2573 | "jest-environment-node": "^29.5.0", 2574 | "jest-get-type": "^29.4.3", 2575 | "jest-regex-util": "^29.4.3", 2576 | "jest-resolve": "^29.5.0", 2577 | "jest-runner": "^29.5.0", 2578 | "jest-util": "^29.5.0", 2579 | "jest-validate": "^29.5.0", 2580 | "micromatch": "^4.0.4", 2581 | "parse-json": "^5.2.0", 2582 | "pretty-format": "^29.5.0", 2583 | "slash": "^3.0.0", 2584 | "strip-json-comments": "^3.1.1" 2585 | }, 2586 | "engines": { 2587 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2588 | }, 2589 | "peerDependencies": { 2590 | "@types/node": "*", 2591 | "ts-node": ">=9.0.0" 2592 | }, 2593 | "peerDependenciesMeta": { 2594 | "@types/node": { 2595 | "optional": true 2596 | }, 2597 | "ts-node": { 2598 | "optional": true 2599 | } 2600 | } 2601 | }, 2602 | "node_modules/jest-diff": { 2603 | "version": "29.5.0", 2604 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.5.0.tgz", 2605 | "integrity": "sha512-LtxijLLZBduXnHSniy0WMdaHjmQnt3g5sa16W4p0HqukYTTsyTW3GD1q41TyGl5YFXj/5B2U6dlh5FM1LIMgxw==", 2606 | "dev": true, 2607 | "dependencies": { 2608 | "chalk": "^4.0.0", 2609 | "diff-sequences": "^29.4.3", 2610 | "jest-get-type": "^29.4.3", 2611 | "pretty-format": "^29.5.0" 2612 | }, 2613 | "engines": { 2614 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2615 | } 2616 | }, 2617 | "node_modules/jest-docblock": { 2618 | "version": "29.4.3", 2619 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz", 2620 | "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==", 2621 | "dev": true, 2622 | "dependencies": { 2623 | "detect-newline": "^3.0.0" 2624 | }, 2625 | "engines": { 2626 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2627 | } 2628 | }, 2629 | "node_modules/jest-each": { 2630 | "version": "29.5.0", 2631 | "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.5.0.tgz", 2632 | "integrity": "sha512-HM5kIJ1BTnVt+DQZ2ALp3rzXEl+g726csObrW/jpEGl+CDSSQpOJJX2KE/vEg8cxcMXdyEPu6U4QX5eruQv5hA==", 2633 | "dev": true, 2634 | "dependencies": { 2635 | "@jest/types": "^29.5.0", 2636 | "chalk": "^4.0.0", 2637 | "jest-get-type": "^29.4.3", 2638 | "jest-util": "^29.5.0", 2639 | "pretty-format": "^29.5.0" 2640 | }, 2641 | "engines": { 2642 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2643 | } 2644 | }, 2645 | "node_modules/jest-environment-node": { 2646 | "version": "29.5.0", 2647 | "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.5.0.tgz", 2648 | "integrity": "sha512-ExxuIK/+yQ+6PRGaHkKewYtg6hto2uGCgvKdb2nfJfKXgZ17DfXjvbZ+jA1Qt9A8EQSfPnt5FKIfnOO3u1h9qw==", 2649 | "dev": true, 2650 | "dependencies": { 2651 | "@jest/environment": "^29.5.0", 2652 | "@jest/fake-timers": "^29.5.0", 2653 | "@jest/types": "^29.5.0", 2654 | "@types/node": "*", 2655 | "jest-mock": "^29.5.0", 2656 | "jest-util": "^29.5.0" 2657 | }, 2658 | "engines": { 2659 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2660 | } 2661 | }, 2662 | "node_modules/jest-get-type": { 2663 | "version": "29.4.3", 2664 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.4.3.tgz", 2665 | "integrity": "sha512-J5Xez4nRRMjk8emnTpWrlkyb9pfRQQanDrvWHhsR1+VUfbwxi30eVcZFlcdGInRibU4G5LwHXpI7IRHU0CY+gg==", 2666 | "dev": true, 2667 | "engines": { 2668 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2669 | } 2670 | }, 2671 | "node_modules/jest-haste-map": { 2672 | "version": "29.5.0", 2673 | "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.5.0.tgz", 2674 | "integrity": "sha512-IspOPnnBro8YfVYSw6yDRKh/TiCdRngjxeacCps1cQ9cgVN6+10JUcuJ1EabrgYLOATsIAigxA0rLR9x/YlrSA==", 2675 | "dev": true, 2676 | "dependencies": { 2677 | "@jest/types": "^29.5.0", 2678 | "@types/graceful-fs": "^4.1.3", 2679 | "@types/node": "*", 2680 | "anymatch": "^3.0.3", 2681 | "fb-watchman": "^2.0.0", 2682 | "graceful-fs": "^4.2.9", 2683 | "jest-regex-util": "^29.4.3", 2684 | "jest-util": "^29.5.0", 2685 | "jest-worker": "^29.5.0", 2686 | "micromatch": "^4.0.4", 2687 | "walker": "^1.0.8" 2688 | }, 2689 | "engines": { 2690 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2691 | }, 2692 | "optionalDependencies": { 2693 | "fsevents": "^2.3.2" 2694 | } 2695 | }, 2696 | "node_modules/jest-leak-detector": { 2697 | "version": "29.5.0", 2698 | "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.5.0.tgz", 2699 | "integrity": "sha512-u9YdeeVnghBUtpN5mVxjID7KbkKE1QU4f6uUwuxiY0vYRi9BUCLKlPEZfDGR67ofdFmDz9oPAy2G92Ujrntmow==", 2700 | "dev": true, 2701 | "dependencies": { 2702 | "jest-get-type": "^29.4.3", 2703 | "pretty-format": "^29.5.0" 2704 | }, 2705 | "engines": { 2706 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2707 | } 2708 | }, 2709 | "node_modules/jest-matcher-utils": { 2710 | "version": "29.5.0", 2711 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.5.0.tgz", 2712 | "integrity": "sha512-lecRtgm/rjIK0CQ7LPQwzCs2VwW6WAahA55YBuI+xqmhm7LAaxokSB8C97yJeYyT+HvQkH741StzpU41wohhWw==", 2713 | "dev": true, 2714 | "dependencies": { 2715 | "chalk": "^4.0.0", 2716 | "jest-diff": "^29.5.0", 2717 | "jest-get-type": "^29.4.3", 2718 | "pretty-format": "^29.5.0" 2719 | }, 2720 | "engines": { 2721 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2722 | } 2723 | }, 2724 | "node_modules/jest-message-util": { 2725 | "version": "29.5.0", 2726 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.5.0.tgz", 2727 | "integrity": "sha512-Kijeg9Dag6CKtIDA7O21zNTACqD5MD/8HfIV8pdD94vFyFuer52SigdC3IQMhab3vACxXMiFk+yMHNdbqtyTGA==", 2728 | "dev": true, 2729 | "dependencies": { 2730 | "@babel/code-frame": "^7.12.13", 2731 | "@jest/types": "^29.5.0", 2732 | "@types/stack-utils": "^2.0.0", 2733 | "chalk": "^4.0.0", 2734 | "graceful-fs": "^4.2.9", 2735 | "micromatch": "^4.0.4", 2736 | "pretty-format": "^29.5.0", 2737 | "slash": "^3.0.0", 2738 | "stack-utils": "^2.0.3" 2739 | }, 2740 | "engines": { 2741 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2742 | } 2743 | }, 2744 | "node_modules/jest-mock": { 2745 | "version": "29.5.0", 2746 | "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.5.0.tgz", 2747 | "integrity": "sha512-GqOzvdWDE4fAV2bWQLQCkujxYWL7RxjCnj71b5VhDAGOevB3qj3Ovg26A5NI84ZpODxyzaozXLOh2NCgkbvyaw==", 2748 | "dev": true, 2749 | "dependencies": { 2750 | "@jest/types": "^29.5.0", 2751 | "@types/node": "*", 2752 | "jest-util": "^29.5.0" 2753 | }, 2754 | "engines": { 2755 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2756 | } 2757 | }, 2758 | "node_modules/jest-pnp-resolver": { 2759 | "version": "1.2.3", 2760 | "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", 2761 | "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", 2762 | "dev": true, 2763 | "engines": { 2764 | "node": ">=6" 2765 | }, 2766 | "peerDependencies": { 2767 | "jest-resolve": "*" 2768 | }, 2769 | "peerDependenciesMeta": { 2770 | "jest-resolve": { 2771 | "optional": true 2772 | } 2773 | } 2774 | }, 2775 | "node_modules/jest-regex-util": { 2776 | "version": "29.4.3", 2777 | "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.4.3.tgz", 2778 | "integrity": "sha512-O4FglZaMmWXbGHSQInfXewIsd1LMn9p3ZXB/6r4FOkyhX2/iP/soMG98jGvk/A3HAN78+5VWcBGO0BJAPRh4kg==", 2779 | "dev": true, 2780 | "engines": { 2781 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2782 | } 2783 | }, 2784 | "node_modules/jest-resolve": { 2785 | "version": "29.5.0", 2786 | "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.5.0.tgz", 2787 | "integrity": "sha512-1TzxJ37FQq7J10jPtQjcc+MkCkE3GBpBecsSUWJ0qZNJpmg6m0D9/7II03yJulm3H/fvVjgqLh/k2eYg+ui52w==", 2788 | "dev": true, 2789 | "dependencies": { 2790 | "chalk": "^4.0.0", 2791 | "graceful-fs": "^4.2.9", 2792 | "jest-haste-map": "^29.5.0", 2793 | "jest-pnp-resolver": "^1.2.2", 2794 | "jest-util": "^29.5.0", 2795 | "jest-validate": "^29.5.0", 2796 | "resolve": "^1.20.0", 2797 | "resolve.exports": "^2.0.0", 2798 | "slash": "^3.0.0" 2799 | }, 2800 | "engines": { 2801 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2802 | } 2803 | }, 2804 | "node_modules/jest-resolve-dependencies": { 2805 | "version": "29.5.0", 2806 | "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.5.0.tgz", 2807 | "integrity": "sha512-sjV3GFr0hDJMBpYeUuGduP+YeCRbd7S/ck6IvL3kQ9cpySYKqcqhdLLC2rFwrcL7tz5vYibomBrsFYWkIGGjOg==", 2808 | "dev": true, 2809 | "dependencies": { 2810 | "jest-regex-util": "^29.4.3", 2811 | "jest-snapshot": "^29.5.0" 2812 | }, 2813 | "engines": { 2814 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2815 | } 2816 | }, 2817 | "node_modules/jest-runner": { 2818 | "version": "29.5.0", 2819 | "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.5.0.tgz", 2820 | "integrity": "sha512-m7b6ypERhFghJsslMLhydaXBiLf7+jXy8FwGRHO3BGV1mcQpPbwiqiKUR2zU2NJuNeMenJmlFZCsIqzJCTeGLQ==", 2821 | "dev": true, 2822 | "dependencies": { 2823 | "@jest/console": "^29.5.0", 2824 | "@jest/environment": "^29.5.0", 2825 | "@jest/test-result": "^29.5.0", 2826 | "@jest/transform": "^29.5.0", 2827 | "@jest/types": "^29.5.0", 2828 | "@types/node": "*", 2829 | "chalk": "^4.0.0", 2830 | "emittery": "^0.13.1", 2831 | "graceful-fs": "^4.2.9", 2832 | "jest-docblock": "^29.4.3", 2833 | "jest-environment-node": "^29.5.0", 2834 | "jest-haste-map": "^29.5.0", 2835 | "jest-leak-detector": "^29.5.0", 2836 | "jest-message-util": "^29.5.0", 2837 | "jest-resolve": "^29.5.0", 2838 | "jest-runtime": "^29.5.0", 2839 | "jest-util": "^29.5.0", 2840 | "jest-watcher": "^29.5.0", 2841 | "jest-worker": "^29.5.0", 2842 | "p-limit": "^3.1.0", 2843 | "source-map-support": "0.5.13" 2844 | }, 2845 | "engines": { 2846 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2847 | } 2848 | }, 2849 | "node_modules/jest-runtime": { 2850 | "version": "29.5.0", 2851 | "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.5.0.tgz", 2852 | "integrity": "sha512-1Hr6Hh7bAgXQP+pln3homOiEZtCDZFqwmle7Ew2j8OlbkIu6uE3Y/etJQG8MLQs3Zy90xrp2C0BRrtPHG4zryw==", 2853 | "dev": true, 2854 | "dependencies": { 2855 | "@jest/environment": "^29.5.0", 2856 | "@jest/fake-timers": "^29.5.0", 2857 | "@jest/globals": "^29.5.0", 2858 | "@jest/source-map": "^29.4.3", 2859 | "@jest/test-result": "^29.5.0", 2860 | "@jest/transform": "^29.5.0", 2861 | "@jest/types": "^29.5.0", 2862 | "@types/node": "*", 2863 | "chalk": "^4.0.0", 2864 | "cjs-module-lexer": "^1.0.0", 2865 | "collect-v8-coverage": "^1.0.0", 2866 | "glob": "^7.1.3", 2867 | "graceful-fs": "^4.2.9", 2868 | "jest-haste-map": "^29.5.0", 2869 | "jest-message-util": "^29.5.0", 2870 | "jest-mock": "^29.5.0", 2871 | "jest-regex-util": "^29.4.3", 2872 | "jest-resolve": "^29.5.0", 2873 | "jest-snapshot": "^29.5.0", 2874 | "jest-util": "^29.5.0", 2875 | "slash": "^3.0.0", 2876 | "strip-bom": "^4.0.0" 2877 | }, 2878 | "engines": { 2879 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2880 | } 2881 | }, 2882 | "node_modules/jest-snapshot": { 2883 | "version": "29.5.0", 2884 | "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.5.0.tgz", 2885 | "integrity": "sha512-x7Wolra5V0tt3wRs3/ts3S6ciSQVypgGQlJpz2rsdQYoUKxMxPNaoHMGJN6qAuPJqS+2iQ1ZUn5kl7HCyls84g==", 2886 | "dev": true, 2887 | "dependencies": { 2888 | "@babel/core": "^7.11.6", 2889 | "@babel/generator": "^7.7.2", 2890 | "@babel/plugin-syntax-jsx": "^7.7.2", 2891 | "@babel/plugin-syntax-typescript": "^7.7.2", 2892 | "@babel/traverse": "^7.7.2", 2893 | "@babel/types": "^7.3.3", 2894 | "@jest/expect-utils": "^29.5.0", 2895 | "@jest/transform": "^29.5.0", 2896 | "@jest/types": "^29.5.0", 2897 | "@types/babel__traverse": "^7.0.6", 2898 | "@types/prettier": "^2.1.5", 2899 | "babel-preset-current-node-syntax": "^1.0.0", 2900 | "chalk": "^4.0.0", 2901 | "expect": "^29.5.0", 2902 | "graceful-fs": "^4.2.9", 2903 | "jest-diff": "^29.5.0", 2904 | "jest-get-type": "^29.4.3", 2905 | "jest-matcher-utils": "^29.5.0", 2906 | "jest-message-util": "^29.5.0", 2907 | "jest-util": "^29.5.0", 2908 | "natural-compare": "^1.4.0", 2909 | "pretty-format": "^29.5.0", 2910 | "semver": "^7.3.5" 2911 | }, 2912 | "engines": { 2913 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2914 | } 2915 | }, 2916 | "node_modules/jest-util": { 2917 | "version": "29.5.0", 2918 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.5.0.tgz", 2919 | "integrity": "sha512-RYMgG/MTadOr5t8KdhejfvUU82MxsCu5MF6KuDUHl+NuwzUt+Sm6jJWxTJVrDR1j5M/gJVCPKQEpWXY+yIQ6lQ==", 2920 | "dev": true, 2921 | "dependencies": { 2922 | "@jest/types": "^29.5.0", 2923 | "@types/node": "*", 2924 | "chalk": "^4.0.0", 2925 | "ci-info": "^3.2.0", 2926 | "graceful-fs": "^4.2.9", 2927 | "picomatch": "^2.2.3" 2928 | }, 2929 | "engines": { 2930 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2931 | } 2932 | }, 2933 | "node_modules/jest-validate": { 2934 | "version": "29.5.0", 2935 | "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.5.0.tgz", 2936 | "integrity": "sha512-pC26etNIi+y3HV8A+tUGr/lph9B18GnzSRAkPaaZJIE1eFdiYm6/CewuiJQ8/RlfHd1u/8Ioi8/sJ+CmbA+zAQ==", 2937 | "dev": true, 2938 | "dependencies": { 2939 | "@jest/types": "^29.5.0", 2940 | "camelcase": "^6.2.0", 2941 | "chalk": "^4.0.0", 2942 | "jest-get-type": "^29.4.3", 2943 | "leven": "^3.1.0", 2944 | "pretty-format": "^29.5.0" 2945 | }, 2946 | "engines": { 2947 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2948 | } 2949 | }, 2950 | "node_modules/jest-validate/node_modules/camelcase": { 2951 | "version": "6.3.0", 2952 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2953 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2954 | "dev": true, 2955 | "engines": { 2956 | "node": ">=10" 2957 | }, 2958 | "funding": { 2959 | "url": "https://github.com/sponsors/sindresorhus" 2960 | } 2961 | }, 2962 | "node_modules/jest-watcher": { 2963 | "version": "29.5.0", 2964 | "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.5.0.tgz", 2965 | "integrity": "sha512-KmTojKcapuqYrKDpRwfqcQ3zjMlwu27SYext9pt4GlF5FUgB+7XE1mcCnSm6a4uUpFyQIkb6ZhzZvHl+jiBCiA==", 2966 | "dev": true, 2967 | "dependencies": { 2968 | "@jest/test-result": "^29.5.0", 2969 | "@jest/types": "^29.5.0", 2970 | "@types/node": "*", 2971 | "ansi-escapes": "^4.2.1", 2972 | "chalk": "^4.0.0", 2973 | "emittery": "^0.13.1", 2974 | "jest-util": "^29.5.0", 2975 | "string-length": "^4.0.1" 2976 | }, 2977 | "engines": { 2978 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2979 | } 2980 | }, 2981 | "node_modules/jest-worker": { 2982 | "version": "29.5.0", 2983 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.5.0.tgz", 2984 | "integrity": "sha512-NcrQnevGoSp4b5kg+akIpthoAFHxPBcb5P6mYPY0fUNT+sSvmtu6jlkEle3anczUKIKEbMxFimk9oTP/tpIPgA==", 2985 | "dev": true, 2986 | "dependencies": { 2987 | "@types/node": "*", 2988 | "jest-util": "^29.5.0", 2989 | "merge-stream": "^2.0.0", 2990 | "supports-color": "^8.0.0" 2991 | }, 2992 | "engines": { 2993 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2994 | } 2995 | }, 2996 | "node_modules/jest-worker/node_modules/supports-color": { 2997 | "version": "8.1.1", 2998 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2999 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 3000 | "dev": true, 3001 | "dependencies": { 3002 | "has-flag": "^4.0.0" 3003 | }, 3004 | "engines": { 3005 | "node": ">=10" 3006 | }, 3007 | "funding": { 3008 | "url": "https://github.com/chalk/supports-color?sponsor=1" 3009 | } 3010 | }, 3011 | "node_modules/js-tokens": { 3012 | "version": "4.0.0", 3013 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 3014 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 3015 | "dev": true 3016 | }, 3017 | "node_modules/js-yaml": { 3018 | "version": "3.14.1", 3019 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 3020 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 3021 | "dev": true, 3022 | "dependencies": { 3023 | "argparse": "^1.0.7", 3024 | "esprima": "^4.0.0" 3025 | }, 3026 | "bin": { 3027 | "js-yaml": "bin/js-yaml.js" 3028 | } 3029 | }, 3030 | "node_modules/jsesc": { 3031 | "version": "2.5.2", 3032 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 3033 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 3034 | "dev": true, 3035 | "bin": { 3036 | "jsesc": "bin/jsesc" 3037 | }, 3038 | "engines": { 3039 | "node": ">=4" 3040 | } 3041 | }, 3042 | "node_modules/json-parse-even-better-errors": { 3043 | "version": "2.3.1", 3044 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 3045 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 3046 | "dev": true 3047 | }, 3048 | "node_modules/json5": { 3049 | "version": "2.2.3", 3050 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 3051 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 3052 | "dev": true, 3053 | "bin": { 3054 | "json5": "lib/cli.js" 3055 | }, 3056 | "engines": { 3057 | "node": ">=6" 3058 | } 3059 | }, 3060 | "node_modules/kleur": { 3061 | "version": "3.0.3", 3062 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", 3063 | "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", 3064 | "dev": true, 3065 | "engines": { 3066 | "node": ">=6" 3067 | } 3068 | }, 3069 | "node_modules/leven": { 3070 | "version": "3.1.0", 3071 | "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", 3072 | "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", 3073 | "dev": true, 3074 | "engines": { 3075 | "node": ">=6" 3076 | } 3077 | }, 3078 | "node_modules/lines-and-columns": { 3079 | "version": "1.2.4", 3080 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 3081 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 3082 | "dev": true 3083 | }, 3084 | "node_modules/locate-path": { 3085 | "version": "5.0.0", 3086 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 3087 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 3088 | "dev": true, 3089 | "dependencies": { 3090 | "p-locate": "^4.1.0" 3091 | }, 3092 | "engines": { 3093 | "node": ">=8" 3094 | } 3095 | }, 3096 | "node_modules/lodash.memoize": { 3097 | "version": "4.1.2", 3098 | "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", 3099 | "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==", 3100 | "dev": true 3101 | }, 3102 | "node_modules/lz-string": { 3103 | "version": "1.5.0", 3104 | "resolved": "https://registry.npmjs.org/lz-string/-/lz-string-1.5.0.tgz", 3105 | "integrity": "sha512-h5bgJWpxJNswbU7qCrV0tIKQCaS3blPDrqKWx+QxzuzL1zGUzij9XCWLrSLsJPu5t+eWA/ycetzYAO5IOMcWAQ==", 3106 | "dev": true, 3107 | "bin": { 3108 | "lz-string": "bin/bin.js" 3109 | } 3110 | }, 3111 | "node_modules/make-dir": { 3112 | "version": "3.1.0", 3113 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 3114 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 3115 | "dev": true, 3116 | "dependencies": { 3117 | "semver": "^6.0.0" 3118 | }, 3119 | "engines": { 3120 | "node": ">=8" 3121 | }, 3122 | "funding": { 3123 | "url": "https://github.com/sponsors/sindresorhus" 3124 | } 3125 | }, 3126 | "node_modules/make-dir/node_modules/semver": { 3127 | "version": "6.3.0", 3128 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 3129 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 3130 | "dev": true, 3131 | "bin": { 3132 | "semver": "bin/semver.js" 3133 | } 3134 | }, 3135 | "node_modules/make-error": { 3136 | "version": "1.3.6", 3137 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 3138 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 3139 | "dev": true 3140 | }, 3141 | "node_modules/makeerror": { 3142 | "version": "1.0.12", 3143 | "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", 3144 | "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", 3145 | "dev": true, 3146 | "dependencies": { 3147 | "tmpl": "1.0.5" 3148 | } 3149 | }, 3150 | "node_modules/merge-stream": { 3151 | "version": "2.0.0", 3152 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 3153 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 3154 | "dev": true 3155 | }, 3156 | "node_modules/micromatch": { 3157 | "version": "4.0.5", 3158 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 3159 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 3160 | "dev": true, 3161 | "dependencies": { 3162 | "braces": "^3.0.2", 3163 | "picomatch": "^2.3.1" 3164 | }, 3165 | "engines": { 3166 | "node": ">=8.6" 3167 | } 3168 | }, 3169 | "node_modules/mimic-fn": { 3170 | "version": "2.1.0", 3171 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 3172 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 3173 | "dev": true, 3174 | "engines": { 3175 | "node": ">=6" 3176 | } 3177 | }, 3178 | "node_modules/minimatch": { 3179 | "version": "3.1.2", 3180 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3181 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3182 | "dev": true, 3183 | "dependencies": { 3184 | "brace-expansion": "^1.1.7" 3185 | }, 3186 | "engines": { 3187 | "node": "*" 3188 | } 3189 | }, 3190 | "node_modules/ms": { 3191 | "version": "2.1.2", 3192 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3193 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3194 | "dev": true 3195 | }, 3196 | "node_modules/natural-compare": { 3197 | "version": "1.4.0", 3198 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3199 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 3200 | "dev": true 3201 | }, 3202 | "node_modules/node-int64": { 3203 | "version": "0.4.0", 3204 | "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", 3205 | "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", 3206 | "dev": true 3207 | }, 3208 | "node_modules/node-releases": { 3209 | "version": "2.0.10", 3210 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.10.tgz", 3211 | "integrity": "sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==", 3212 | "dev": true 3213 | }, 3214 | "node_modules/normalize-path": { 3215 | "version": "3.0.0", 3216 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3217 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 3218 | "dev": true, 3219 | "engines": { 3220 | "node": ">=0.10.0" 3221 | } 3222 | }, 3223 | "node_modules/npm-run-path": { 3224 | "version": "4.0.1", 3225 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 3226 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 3227 | "dev": true, 3228 | "dependencies": { 3229 | "path-key": "^3.0.0" 3230 | }, 3231 | "engines": { 3232 | "node": ">=8" 3233 | } 3234 | }, 3235 | "node_modules/once": { 3236 | "version": "1.4.0", 3237 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3238 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3239 | "dev": true, 3240 | "dependencies": { 3241 | "wrappy": "1" 3242 | } 3243 | }, 3244 | "node_modules/onetime": { 3245 | "version": "5.1.2", 3246 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 3247 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 3248 | "dev": true, 3249 | "dependencies": { 3250 | "mimic-fn": "^2.1.0" 3251 | }, 3252 | "engines": { 3253 | "node": ">=6" 3254 | }, 3255 | "funding": { 3256 | "url": "https://github.com/sponsors/sindresorhus" 3257 | } 3258 | }, 3259 | "node_modules/p-limit": { 3260 | "version": "3.1.0", 3261 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3262 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3263 | "dev": true, 3264 | "dependencies": { 3265 | "yocto-queue": "^0.1.0" 3266 | }, 3267 | "engines": { 3268 | "node": ">=10" 3269 | }, 3270 | "funding": { 3271 | "url": "https://github.com/sponsors/sindresorhus" 3272 | } 3273 | }, 3274 | "node_modules/p-locate": { 3275 | "version": "4.1.0", 3276 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 3277 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 3278 | "dev": true, 3279 | "dependencies": { 3280 | "p-limit": "^2.2.0" 3281 | }, 3282 | "engines": { 3283 | "node": ">=8" 3284 | } 3285 | }, 3286 | "node_modules/p-locate/node_modules/p-limit": { 3287 | "version": "2.3.0", 3288 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 3289 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 3290 | "dev": true, 3291 | "dependencies": { 3292 | "p-try": "^2.0.0" 3293 | }, 3294 | "engines": { 3295 | "node": ">=6" 3296 | }, 3297 | "funding": { 3298 | "url": "https://github.com/sponsors/sindresorhus" 3299 | } 3300 | }, 3301 | "node_modules/p-try": { 3302 | "version": "2.2.0", 3303 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 3304 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 3305 | "dev": true, 3306 | "engines": { 3307 | "node": ">=6" 3308 | } 3309 | }, 3310 | "node_modules/parse-json": { 3311 | "version": "5.2.0", 3312 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 3313 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 3314 | "dev": true, 3315 | "dependencies": { 3316 | "@babel/code-frame": "^7.0.0", 3317 | "error-ex": "^1.3.1", 3318 | "json-parse-even-better-errors": "^2.3.0", 3319 | "lines-and-columns": "^1.1.6" 3320 | }, 3321 | "engines": { 3322 | "node": ">=8" 3323 | }, 3324 | "funding": { 3325 | "url": "https://github.com/sponsors/sindresorhus" 3326 | } 3327 | }, 3328 | "node_modules/path-exists": { 3329 | "version": "4.0.0", 3330 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3331 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3332 | "dev": true, 3333 | "engines": { 3334 | "node": ">=8" 3335 | } 3336 | }, 3337 | "node_modules/path-is-absolute": { 3338 | "version": "1.0.1", 3339 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3340 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3341 | "dev": true, 3342 | "engines": { 3343 | "node": ">=0.10.0" 3344 | } 3345 | }, 3346 | "node_modules/path-key": { 3347 | "version": "3.1.1", 3348 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3349 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3350 | "dev": true, 3351 | "engines": { 3352 | "node": ">=8" 3353 | } 3354 | }, 3355 | "node_modules/path-parse": { 3356 | "version": "1.0.7", 3357 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3358 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3359 | "dev": true 3360 | }, 3361 | "node_modules/picocolors": { 3362 | "version": "1.0.0", 3363 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 3364 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 3365 | "dev": true 3366 | }, 3367 | "node_modules/picomatch": { 3368 | "version": "2.3.1", 3369 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3370 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3371 | "dev": true, 3372 | "engines": { 3373 | "node": ">=8.6" 3374 | }, 3375 | "funding": { 3376 | "url": "https://github.com/sponsors/jonschlinkert" 3377 | } 3378 | }, 3379 | "node_modules/pirates": { 3380 | "version": "4.0.5", 3381 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", 3382 | "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", 3383 | "dev": true, 3384 | "engines": { 3385 | "node": ">= 6" 3386 | } 3387 | }, 3388 | "node_modules/pkg-dir": { 3389 | "version": "4.2.0", 3390 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 3391 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 3392 | "dev": true, 3393 | "dependencies": { 3394 | "find-up": "^4.0.0" 3395 | }, 3396 | "engines": { 3397 | "node": ">=8" 3398 | } 3399 | }, 3400 | "node_modules/pretty-format": { 3401 | "version": "29.5.0", 3402 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.5.0.tgz", 3403 | "integrity": "sha512-V2mGkI31qdttvTFX7Mt4efOqHXqJWMu4/r66Xh3Z3BwZaPfPJgp6/gbwoujRpPUtfEF6AUUWx3Jim3GCw5g/Qw==", 3404 | "dev": true, 3405 | "dependencies": { 3406 | "@jest/schemas": "^29.4.3", 3407 | "ansi-styles": "^5.0.0", 3408 | "react-is": "^18.0.0" 3409 | }, 3410 | "engines": { 3411 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 3412 | } 3413 | }, 3414 | "node_modules/pretty-format/node_modules/ansi-styles": { 3415 | "version": "5.2.0", 3416 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 3417 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 3418 | "dev": true, 3419 | "engines": { 3420 | "node": ">=10" 3421 | }, 3422 | "funding": { 3423 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 3424 | } 3425 | }, 3426 | "node_modules/prompts": { 3427 | "version": "2.4.2", 3428 | "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", 3429 | "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", 3430 | "dev": true, 3431 | "dependencies": { 3432 | "kleur": "^3.0.3", 3433 | "sisteransi": "^1.0.5" 3434 | }, 3435 | "engines": { 3436 | "node": ">= 6" 3437 | } 3438 | }, 3439 | "node_modules/pure-rand": { 3440 | "version": "6.0.2", 3441 | "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.2.tgz", 3442 | "integrity": "sha512-6Yg0ekpKICSjPswYOuC5sku/TSWaRYlA0qsXqJgM/d/4pLPHPuTxK7Nbf7jFKzAeedUhR8C7K9Uv63FBsSo8xQ==", 3443 | "dev": true, 3444 | "funding": [ 3445 | { 3446 | "type": "individual", 3447 | "url": "https://github.com/sponsors/dubzzz" 3448 | }, 3449 | { 3450 | "type": "opencollective", 3451 | "url": "https://opencollective.com/fast-check" 3452 | } 3453 | ] 3454 | }, 3455 | "node_modules/react-is": { 3456 | "version": "18.2.0", 3457 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", 3458 | "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", 3459 | "dev": true 3460 | }, 3461 | "node_modules/require-directory": { 3462 | "version": "2.1.1", 3463 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3464 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 3465 | "dev": true, 3466 | "engines": { 3467 | "node": ">=0.10.0" 3468 | } 3469 | }, 3470 | "node_modules/resolve": { 3471 | "version": "1.22.2", 3472 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", 3473 | "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", 3474 | "dev": true, 3475 | "dependencies": { 3476 | "is-core-module": "^2.11.0", 3477 | "path-parse": "^1.0.7", 3478 | "supports-preserve-symlinks-flag": "^1.0.0" 3479 | }, 3480 | "bin": { 3481 | "resolve": "bin/resolve" 3482 | }, 3483 | "funding": { 3484 | "url": "https://github.com/sponsors/ljharb" 3485 | } 3486 | }, 3487 | "node_modules/resolve-cwd": { 3488 | "version": "3.0.0", 3489 | "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", 3490 | "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", 3491 | "dev": true, 3492 | "dependencies": { 3493 | "resolve-from": "^5.0.0" 3494 | }, 3495 | "engines": { 3496 | "node": ">=8" 3497 | } 3498 | }, 3499 | "node_modules/resolve-from": { 3500 | "version": "5.0.0", 3501 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 3502 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 3503 | "dev": true, 3504 | "engines": { 3505 | "node": ">=8" 3506 | } 3507 | }, 3508 | "node_modules/resolve.exports": { 3509 | "version": "2.0.2", 3510 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", 3511 | "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", 3512 | "dev": true, 3513 | "engines": { 3514 | "node": ">=10" 3515 | } 3516 | }, 3517 | "node_modules/rxjs": { 3518 | "version": "7.8.1", 3519 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz", 3520 | "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==", 3521 | "dev": true, 3522 | "dependencies": { 3523 | "tslib": "^2.1.0" 3524 | } 3525 | }, 3526 | "node_modules/semver": { 3527 | "version": "7.7.2", 3528 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", 3529 | "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", 3530 | "dev": true, 3531 | "license": "ISC", 3532 | "bin": { 3533 | "semver": "bin/semver.js" 3534 | }, 3535 | "engines": { 3536 | "node": ">=10" 3537 | } 3538 | }, 3539 | "node_modules/shebang-command": { 3540 | "version": "2.0.0", 3541 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3542 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3543 | "dev": true, 3544 | "dependencies": { 3545 | "shebang-regex": "^3.0.0" 3546 | }, 3547 | "engines": { 3548 | "node": ">=8" 3549 | } 3550 | }, 3551 | "node_modules/shebang-regex": { 3552 | "version": "3.0.0", 3553 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3554 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3555 | "dev": true, 3556 | "engines": { 3557 | "node": ">=8" 3558 | } 3559 | }, 3560 | "node_modules/signal-exit": { 3561 | "version": "3.0.7", 3562 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 3563 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 3564 | "dev": true 3565 | }, 3566 | "node_modules/sisteransi": { 3567 | "version": "1.0.5", 3568 | "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", 3569 | "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", 3570 | "dev": true 3571 | }, 3572 | "node_modules/slash": { 3573 | "version": "3.0.0", 3574 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3575 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3576 | "dev": true, 3577 | "engines": { 3578 | "node": ">=8" 3579 | } 3580 | }, 3581 | "node_modules/source-map": { 3582 | "version": "0.6.1", 3583 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3584 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3585 | "dev": true, 3586 | "engines": { 3587 | "node": ">=0.10.0" 3588 | } 3589 | }, 3590 | "node_modules/source-map-support": { 3591 | "version": "0.5.13", 3592 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz", 3593 | "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==", 3594 | "dev": true, 3595 | "dependencies": { 3596 | "buffer-from": "^1.0.0", 3597 | "source-map": "^0.6.0" 3598 | } 3599 | }, 3600 | "node_modules/sprintf-js": { 3601 | "version": "1.0.3", 3602 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3603 | "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", 3604 | "dev": true 3605 | }, 3606 | "node_modules/stack-utils": { 3607 | "version": "2.0.6", 3608 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", 3609 | "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", 3610 | "dev": true, 3611 | "dependencies": { 3612 | "escape-string-regexp": "^2.0.0" 3613 | }, 3614 | "engines": { 3615 | "node": ">=10" 3616 | } 3617 | }, 3618 | "node_modules/stack-utils/node_modules/escape-string-regexp": { 3619 | "version": "2.0.0", 3620 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 3621 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 3622 | "dev": true, 3623 | "engines": { 3624 | "node": ">=8" 3625 | } 3626 | }, 3627 | "node_modules/string-length": { 3628 | "version": "4.0.2", 3629 | "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", 3630 | "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", 3631 | "dev": true, 3632 | "dependencies": { 3633 | "char-regex": "^1.0.2", 3634 | "strip-ansi": "^6.0.0" 3635 | }, 3636 | "engines": { 3637 | "node": ">=10" 3638 | } 3639 | }, 3640 | "node_modules/string-width": { 3641 | "version": "4.2.3", 3642 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3643 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3644 | "dev": true, 3645 | "dependencies": { 3646 | "emoji-regex": "^8.0.0", 3647 | "is-fullwidth-code-point": "^3.0.0", 3648 | "strip-ansi": "^6.0.1" 3649 | }, 3650 | "engines": { 3651 | "node": ">=8" 3652 | } 3653 | }, 3654 | "node_modules/strip-ansi": { 3655 | "version": "6.0.1", 3656 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3657 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3658 | "dev": true, 3659 | "dependencies": { 3660 | "ansi-regex": "^5.0.1" 3661 | }, 3662 | "engines": { 3663 | "node": ">=8" 3664 | } 3665 | }, 3666 | "node_modules/strip-bom": { 3667 | "version": "4.0.0", 3668 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 3669 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 3670 | "dev": true, 3671 | "engines": { 3672 | "node": ">=8" 3673 | } 3674 | }, 3675 | "node_modules/strip-final-newline": { 3676 | "version": "2.0.0", 3677 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3678 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3679 | "dev": true, 3680 | "engines": { 3681 | "node": ">=6" 3682 | } 3683 | }, 3684 | "node_modules/strip-json-comments": { 3685 | "version": "3.1.1", 3686 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3687 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3688 | "dev": true, 3689 | "engines": { 3690 | "node": ">=8" 3691 | }, 3692 | "funding": { 3693 | "url": "https://github.com/sponsors/sindresorhus" 3694 | } 3695 | }, 3696 | "node_modules/supports-color": { 3697 | "version": "7.2.0", 3698 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3699 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3700 | "dev": true, 3701 | "dependencies": { 3702 | "has-flag": "^4.0.0" 3703 | }, 3704 | "engines": { 3705 | "node": ">=8" 3706 | } 3707 | }, 3708 | "node_modules/supports-preserve-symlinks-flag": { 3709 | "version": "1.0.0", 3710 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3711 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3712 | "dev": true, 3713 | "engines": { 3714 | "node": ">= 0.4" 3715 | }, 3716 | "funding": { 3717 | "url": "https://github.com/sponsors/ljharb" 3718 | } 3719 | }, 3720 | "node_modules/test-exclude": { 3721 | "version": "6.0.0", 3722 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 3723 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 3724 | "dev": true, 3725 | "dependencies": { 3726 | "@istanbuljs/schema": "^0.1.2", 3727 | "glob": "^7.1.4", 3728 | "minimatch": "^3.0.4" 3729 | }, 3730 | "engines": { 3731 | "node": ">=8" 3732 | } 3733 | }, 3734 | "node_modules/tmpl": { 3735 | "version": "1.0.5", 3736 | "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", 3737 | "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", 3738 | "dev": true 3739 | }, 3740 | "node_modules/to-fast-properties": { 3741 | "version": "3.0.1", 3742 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-3.0.1.tgz", 3743 | "integrity": "sha512-/wtNi1tW1F3nf0OL6AqVxGw9Tr1ET70InMhJuVxPwFdGqparF0nQ4UWGLf2DsoI2bFDtthlBnALncZpUzOnsUw==", 3744 | "license": "MIT", 3745 | "peer": true, 3746 | "engines": { 3747 | "node": ">=8" 3748 | }, 3749 | "funding": { 3750 | "url": "https://github.com/sponsors/sindresorhus" 3751 | } 3752 | }, 3753 | "node_modules/to-regex-range": { 3754 | "version": "5.0.1", 3755 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3756 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3757 | "dev": true, 3758 | "dependencies": { 3759 | "is-number": "^7.0.0" 3760 | }, 3761 | "engines": { 3762 | "node": ">=8.0" 3763 | } 3764 | }, 3765 | "node_modules/ts-jest": { 3766 | "version": "29.3.4", 3767 | "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.3.4.tgz", 3768 | "integrity": "sha512-Iqbrm8IXOmV+ggWHOTEbjwyCf2xZlUMv5npExksXohL+tk8va4Fjhb+X2+Rt9NBmgO7bJ8WpnMLOwih/DnMlFA==", 3769 | "dev": true, 3770 | "license": "MIT", 3771 | "dependencies": { 3772 | "bs-logger": "^0.2.6", 3773 | "ejs": "^3.1.10", 3774 | "fast-json-stable-stringify": "^2.1.0", 3775 | "jest-util": "^29.0.0", 3776 | "json5": "^2.2.3", 3777 | "lodash.memoize": "^4.1.2", 3778 | "make-error": "^1.3.6", 3779 | "semver": "^7.7.2", 3780 | "type-fest": "^4.41.0", 3781 | "yargs-parser": "^21.1.1" 3782 | }, 3783 | "bin": { 3784 | "ts-jest": "cli.js" 3785 | }, 3786 | "engines": { 3787 | "node": "^14.15.0 || ^16.10.0 || ^18.0.0 || >=20.0.0" 3788 | }, 3789 | "peerDependencies": { 3790 | "@babel/core": ">=7.0.0-beta.0 <8", 3791 | "@jest/transform": "^29.0.0", 3792 | "@jest/types": "^29.0.0", 3793 | "babel-jest": "^29.0.0", 3794 | "jest": "^29.0.0", 3795 | "typescript": ">=4.3 <6" 3796 | }, 3797 | "peerDependenciesMeta": { 3798 | "@babel/core": { 3799 | "optional": true 3800 | }, 3801 | "@jest/transform": { 3802 | "optional": true 3803 | }, 3804 | "@jest/types": { 3805 | "optional": true 3806 | }, 3807 | "babel-jest": { 3808 | "optional": true 3809 | }, 3810 | "esbuild": { 3811 | "optional": true 3812 | } 3813 | } 3814 | }, 3815 | "node_modules/ts-jest/node_modules/type-fest": { 3816 | "version": "4.41.0", 3817 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.41.0.tgz", 3818 | "integrity": "sha512-TeTSQ6H5YHvpqVwBRcnLDCBnDOHWYu7IvGbHT6N8AOymcr9PJGjc1GTtiWZTYg0NCgYwvnYWEkVChQAr9bjfwA==", 3819 | "dev": true, 3820 | "license": "(MIT OR CC0-1.0)", 3821 | "engines": { 3822 | "node": ">=16" 3823 | }, 3824 | "funding": { 3825 | "url": "https://github.com/sponsors/sindresorhus" 3826 | } 3827 | }, 3828 | "node_modules/tslib": { 3829 | "version": "2.5.0", 3830 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz", 3831 | "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==", 3832 | "dev": true 3833 | }, 3834 | "node_modules/type-detect": { 3835 | "version": "4.0.8", 3836 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3837 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3838 | "dev": true, 3839 | "engines": { 3840 | "node": ">=4" 3841 | } 3842 | }, 3843 | "node_modules/type-fest": { 3844 | "version": "0.21.3", 3845 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3846 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3847 | "dev": true, 3848 | "engines": { 3849 | "node": ">=10" 3850 | }, 3851 | "funding": { 3852 | "url": "https://github.com/sponsors/sindresorhus" 3853 | } 3854 | }, 3855 | "node_modules/typescript": { 3856 | "version": "5.8.3", 3857 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.8.3.tgz", 3858 | "integrity": "sha512-p1diW6TqL9L07nNxvRMM7hMMw4c5XOo/1ibL4aAIGmSAt9slTE1Xgw5KWuof2uTOvCg9BY7ZRi+GaF+7sfgPeQ==", 3859 | "dev": true, 3860 | "license": "Apache-2.0", 3861 | "bin": { 3862 | "tsc": "bin/tsc", 3863 | "tsserver": "bin/tsserver" 3864 | }, 3865 | "engines": { 3866 | "node": ">=14.17" 3867 | } 3868 | }, 3869 | "node_modules/undici-types": { 3870 | "version": "6.19.8", 3871 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", 3872 | "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", 3873 | "dev": true, 3874 | "license": "MIT" 3875 | }, 3876 | "node_modules/update-browserslist-db": { 3877 | "version": "1.0.11", 3878 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", 3879 | "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", 3880 | "dev": true, 3881 | "funding": [ 3882 | { 3883 | "type": "opencollective", 3884 | "url": "https://opencollective.com/browserslist" 3885 | }, 3886 | { 3887 | "type": "tidelift", 3888 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3889 | }, 3890 | { 3891 | "type": "github", 3892 | "url": "https://github.com/sponsors/ai" 3893 | } 3894 | ], 3895 | "dependencies": { 3896 | "escalade": "^3.1.1", 3897 | "picocolors": "^1.0.0" 3898 | }, 3899 | "bin": { 3900 | "update-browserslist-db": "cli.js" 3901 | }, 3902 | "peerDependencies": { 3903 | "browserslist": ">= 4.21.0" 3904 | } 3905 | }, 3906 | "node_modules/uuid": { 3907 | "version": "8.3.2", 3908 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 3909 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", 3910 | "license": "MIT", 3911 | "bin": { 3912 | "uuid": "dist/bin/uuid" 3913 | } 3914 | }, 3915 | "node_modules/v8-to-istanbul": { 3916 | "version": "9.1.0", 3917 | "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", 3918 | "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", 3919 | "dev": true, 3920 | "dependencies": { 3921 | "@jridgewell/trace-mapping": "^0.3.12", 3922 | "@types/istanbul-lib-coverage": "^2.0.1", 3923 | "convert-source-map": "^1.6.0" 3924 | }, 3925 | "engines": { 3926 | "node": ">=10.12.0" 3927 | } 3928 | }, 3929 | "node_modules/v8-to-istanbul/node_modules/convert-source-map": { 3930 | "version": "1.9.0", 3931 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 3932 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 3933 | "dev": true 3934 | }, 3935 | "node_modules/walker": { 3936 | "version": "1.0.8", 3937 | "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", 3938 | "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", 3939 | "dev": true, 3940 | "dependencies": { 3941 | "makeerror": "1.0.12" 3942 | } 3943 | }, 3944 | "node_modules/which": { 3945 | "version": "2.0.2", 3946 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3947 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3948 | "dev": true, 3949 | "dependencies": { 3950 | "isexe": "^2.0.0" 3951 | }, 3952 | "bin": { 3953 | "node-which": "bin/node-which" 3954 | }, 3955 | "engines": { 3956 | "node": ">= 8" 3957 | } 3958 | }, 3959 | "node_modules/wrap-ansi": { 3960 | "version": "7.0.0", 3961 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3962 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3963 | "dev": true, 3964 | "dependencies": { 3965 | "ansi-styles": "^4.0.0", 3966 | "string-width": "^4.1.0", 3967 | "strip-ansi": "^6.0.0" 3968 | }, 3969 | "engines": { 3970 | "node": ">=10" 3971 | }, 3972 | "funding": { 3973 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3974 | } 3975 | }, 3976 | "node_modules/wrappy": { 3977 | "version": "1.0.2", 3978 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3979 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3980 | "dev": true 3981 | }, 3982 | "node_modules/write-file-atomic": { 3983 | "version": "4.0.2", 3984 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", 3985 | "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", 3986 | "dev": true, 3987 | "dependencies": { 3988 | "imurmurhash": "^0.1.4", 3989 | "signal-exit": "^3.0.7" 3990 | }, 3991 | "engines": { 3992 | "node": "^12.13.0 || ^14.15.0 || >=16.0.0" 3993 | } 3994 | }, 3995 | "node_modules/y18n": { 3996 | "version": "5.0.8", 3997 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3998 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3999 | "dev": true, 4000 | "engines": { 4001 | "node": ">=10" 4002 | } 4003 | }, 4004 | "node_modules/yargs": { 4005 | "version": "17.7.2", 4006 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 4007 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 4008 | "dev": true, 4009 | "dependencies": { 4010 | "cliui": "^8.0.1", 4011 | "escalade": "^3.1.1", 4012 | "get-caller-file": "^2.0.5", 4013 | "require-directory": "^2.1.1", 4014 | "string-width": "^4.2.3", 4015 | "y18n": "^5.0.5", 4016 | "yargs-parser": "^21.1.1" 4017 | }, 4018 | "engines": { 4019 | "node": ">=12" 4020 | } 4021 | }, 4022 | "node_modules/yargs-parser": { 4023 | "version": "21.1.1", 4024 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 4025 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 4026 | "dev": true, 4027 | "engines": { 4028 | "node": ">=12" 4029 | } 4030 | }, 4031 | "node_modules/yocto-queue": { 4032 | "version": "0.1.0", 4033 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4034 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4035 | "dev": true, 4036 | "engines": { 4037 | "node": ">=10" 4038 | }, 4039 | "funding": { 4040 | "url": "https://github.com/sponsors/sindresorhus" 4041 | } 4042 | } 4043 | } 4044 | } 4045 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pybridge", 3 | "version": "1.4.4", 4 | "description": "TypeScript library for Python interop", 5 | "type": "commonjs", 6 | "main": "./dist/cjs/index.js", 7 | "module": "./dist/esm/index.js", 8 | "types": "./dist/cjs/index.d.ts", 9 | "files": [ 10 | "src", 11 | "index.ts", 12 | "package.json", 13 | "dist", 14 | "README.md" 15 | ], 16 | "exports": { 17 | ".": { 18 | "types": "./dist/cjs/index.d.ts", 19 | "require": "./dist/cjs/index.js", 20 | "default": "./dist/esm/index.js" 21 | } 22 | }, 23 | "scripts": { 24 | "test": "jest", 25 | "postinstall": "deepkit-type-install", 26 | "build": "echo '{\"type\": \"module\"}' > ./dist/esm/package.json && tsc && tsc --project tsconfig.esm.json" 27 | }, 28 | "sideEffects": false, 29 | "publishConfig": { 30 | "access": "public" 31 | }, 32 | "repository": "https://github.com/marcj/pybridge", 33 | "author": "Marc J. Schmidt ", 34 | "license": "MIT", 35 | "devDependencies": { 36 | "@deepkit/type-compiler": "^1.0.8", 37 | "@types/jest": "^29.5.1", 38 | "@types/node": "^20.17.57", 39 | "jest": "^29.5.0", 40 | "rxjs": "*", 41 | "ts-jest": "^29.3.4", 42 | "typescript": "^5.8.3" 43 | }, 44 | "dependencies": { 45 | "@deepkit/app": "^1.0.11", 46 | "@deepkit/logger": "^1.0.11", 47 | "@deepkit/type": "^1.0.11" 48 | }, 49 | "peerDependencies": { 50 | "rxjs": "*" 51 | }, 52 | "jest": { 53 | "transform": { 54 | "^.+\\.(ts|tsx)$": "ts-jest" 55 | }, 56 | "moduleNameMapper": { 57 | "(.+)\\.js": "$1" 58 | }, 59 | "testEnvironment": "node", 60 | "testMatch": [ 61 | "**/*.spec.ts" 62 | ] 63 | } 64 | } 65 | -------------------------------------------------------------------------------- /src/bridge.ts: -------------------------------------------------------------------------------- 1 | import { ChildProcess, spawn } from "child_process"; 2 | import { isAbsolute, join } from "path"; 3 | import { findParentPath } from "@deepkit/app"; 4 | import { ConsoleTransport, Logger } from "@deepkit/logger"; 5 | import { deserializeFunction, ReceiveType, ReflectionClass, ReflectionKind, resolveReceiveType, Type, TypeClass } from "@deepkit/type"; 6 | import { Subject } from "rxjs"; 7 | import { PyBridgeConfig } from "./config"; 8 | 9 | interface RpcMessage { 10 | id: number; 11 | ready?: true; 12 | result?: any; 13 | yield?: any; 14 | error?: string; 15 | } 16 | 17 | function fromCode(code: string): string { 18 | return ` 19 | import sys 20 | import types 21 | 22 | module = types.ModuleType('my_module') 23 | my_code = ${JSON.stringify(code)} 24 | exec(my_code, module.__dict__) 25 | `; 26 | } 27 | 28 | const hook: string = ` 29 | import sys 30 | import traceback 31 | import json 32 | from typing import Generator 33 | 34 | def debug(*args): 35 | print(*args, file=sys.stderr, flush=True) 36 | 37 | # redirect all output to stderr 38 | orig_stdout = sys.stdout 39 | sys.stdout = sys.stderr 40 | 41 | {{__load__}} 42 | 43 | try: 44 | for line in sys.stdin: 45 | p = None 46 | try: 47 | # debug("got: ", line) 48 | p = json.loads(line) 49 | result = getattr(module, p['method'])(*p['args']) 50 | # if result is a generator, iterate over it 51 | if isinstance(result, Generator): 52 | for r in result: 53 | message = {'id': p['id'], 'yield': r} 54 | print(json.dumps(message) + '\\n', file=orig_stdout, flush=True) 55 | print(json.dumps({'id': p['id']}) + '\\n', file=orig_stdout, flush=True) 56 | else: 57 | print(json.dumps({'id': p['id'], 'yield': result}) + '\\n', file=orig_stdout, flush=True) 58 | print(json.dumps({'id': p['id']}) + '\\n', file=orig_stdout, flush=True) 59 | except Exception as e: 60 | if p is not None: 61 | message = {'id': p['id'], 'error': traceback.format_exception(*sys.exc_info())} 62 | print(json.dumps(message) + '\\n', file=orig_stdout, flush=True) 63 | print("Failed nlp method\\n", file=sys.stderr, flush=True) 64 | traceback.print_exception(*sys.exc_info(), file=sys.stderr) 65 | except KeyboardInterrupt: 66 | sys.exit(0) 67 | `; 68 | 69 | function isSubjectType(type: Type): type is TypeClass & { typeArguments: [Type] } { 70 | return Boolean(type.kind === ReflectionKind.class && type.classType === Subject && type.typeArguments); 71 | } 72 | 73 | export class Controller { 74 | process?: ChildProcess; 75 | messageId: number = 0; 76 | subscribers: { [messageId: number]: (data: RpcMessage) => void } = {}; 77 | 78 | constructor(private moduleNameOrCode: string, private config: PyBridgeConfig, private logger: Logger) { 79 | } 80 | 81 | ensureProcess(): ChildProcess { 82 | if (this.process) return this.process; 83 | 84 | let python = this.config.python; 85 | 86 | if (!isAbsolute(python)) { 87 | const venvBin = findParentPath('venv/bin'); 88 | if (venvBin) { 89 | python = join(venvBin, python); 90 | } 91 | } 92 | 93 | let cwd = this.config.cwd; 94 | 95 | this.logger.log(`Start python via ${python} in ${cwd} for ${this.moduleNameOrCode.replace(/\n/g, '\\n').substring(0, 50)}`); 96 | 97 | let load = this.moduleNameOrCode.includes(' ') ? fromCode(this.moduleNameOrCode) : `import ${this.moduleNameOrCode} as module;`; 98 | if (this.moduleNameOrCode.endsWith('.py')) { 99 | load = `import sys; sys.path.append('${cwd}'); import ${this.moduleNameOrCode.replace('.py', '')} as module;`; 100 | } 101 | 102 | const code = hook.replace('{{__load__}}', load); 103 | // console.log(code); 104 | this.process = spawn(python, ['-c', code], { 105 | stdio: ['pipe', 'pipe', process.stderr], 106 | cwd: cwd, 107 | }); 108 | 109 | const onExit = () => { 110 | this.process?.kill(); 111 | } 112 | 113 | process.on('exit', onExit); 114 | this.process.on('close', () => { 115 | this.process = undefined; 116 | process.off('exit', onExit); 117 | }); 118 | 119 | const buffer: Buffer[] = []; 120 | const read = (data: Buffer) => { 121 | buffer.push(data); 122 | // console.log('read', data.includes('\n'), Buffer.concat(buffer).toString('utf8')); 123 | if (data.includes('\n'.charCodeAt(0))) { 124 | const messages = Buffer.concat(buffer).toString('utf8').trim().split('\n'); 125 | for (const message of messages) { 126 | if (!message.startsWith('{"')) continue; 127 | try { 128 | const res = JSON.parse(message); 129 | const messageId = res.id; 130 | if (this.subscribers[messageId]) { 131 | this.subscribers[messageId](res); 132 | } 133 | } catch (error) { 134 | console.warn('Could not parse: ' + message); 135 | } 136 | } 137 | buffer.length = 0; 138 | } 139 | } 140 | 141 | this.process.stdout!.on('data', read); 142 | return this.process; 143 | } 144 | 145 | send(method: string, args: any[], type?: ReceiveType): Subject { 146 | const pythonProcess = this.ensureProcess(); 147 | const messageId = this.messageId++; 148 | 149 | type = resolveReceiveType(type); 150 | if (isSubjectType(type)) { 151 | type = type.typeArguments[0]; 152 | } 153 | const subject = new Subject(); 154 | const deserializer = deserializeFunction(undefined, undefined, type); 155 | 156 | this.subscribers[messageId] = (data) => { 157 | try { 158 | if (data.ready) { 159 | 160 | } else if (data.yield) { 161 | const v = deserializer(data.yield); 162 | subject.next(v); 163 | } else if (data.error) { 164 | delete this.subscribers[messageId]; 165 | subject.error(new Error(data.error)); 166 | } else { 167 | delete this.subscribers[messageId]; 168 | subject.complete(); 169 | } 170 | } catch { 171 | } 172 | }; 173 | pythonProcess.stdin!.write(JSON.stringify({ id: messageId, method, args }) + '\n'); 174 | 175 | return subject; 176 | } 177 | } 178 | 179 | type PromisifyFn any)> = (...args: Parameters) => ReturnType extends Subject ? ReturnType : ReturnType extends Promise ? ReturnType : Promise>; 180 | export type RemoteController = { 181 | [P in keyof T]: T[P] extends (...args: any[]) => any ? PromisifyFn : never 182 | } & Controller; 183 | 184 | export class PyBridge { 185 | protected controllers: { [name: string]: RemoteController } = {}; 186 | 187 | constructor(protected config: PyBridgeConfig, protected logger: Logger = new Logger([new ConsoleTransport()])) { 188 | } 189 | 190 | close() { 191 | for (const controller of Object.values(this.controllers)) { 192 | controller.process?.kill(); 193 | } 194 | } 195 | 196 | controller(moduleName: string, type?: ReceiveType): RemoteController { 197 | if (this.controllers[moduleName]) return this.controllers[moduleName] as RemoteController; 198 | const controller = new Controller(moduleName, this.config, this.logger); 199 | if (!type) throw new Error('No controller type T given'); 200 | 201 | const reflectionClass = ReflectionClass.from(resolveReceiveType(type)); 202 | 203 | return this.controllers[moduleName] = new Proxy({}, { 204 | get: (target, name: string) => { 205 | if (name === 'process') return controller.process; 206 | 207 | return (...args: any[]) => { 208 | const returnType = reflectionClass.getMethod(name).getReturnType(); 209 | const subject = controller.send(name, args, returnType); 210 | return isSubjectType(returnType) ? subject : subject.toPromise(); 211 | } 212 | } 213 | }) as any; 214 | } 215 | } 216 | -------------------------------------------------------------------------------- /src/config.ts: -------------------------------------------------------------------------------- 1 | export class PyBridgeConfig { 2 | /** 3 | * The path to the python executable. 4 | */ 5 | python: string = 'python3'; 6 | 7 | cwd: string = ''; 8 | } -------------------------------------------------------------------------------- /src/module.ts: -------------------------------------------------------------------------------- 1 | import { createModuleClass, onAppShutdown } from '@deepkit/app'; 2 | import { PyBridgeConfig } from "./config.js"; 3 | import { PyBridge } from "./bridge.js"; 4 | 5 | export class PyBridgeModule extends createModuleClass({ 6 | config: PyBridgeConfig, 7 | providers: [ 8 | PyBridge, 9 | ], 10 | listeners: [ 11 | onAppShutdown.listen((event, python: PyBridge) => { 12 | // disconnect all open python processes when app shuts down 13 | python.close(); 14 | }) 15 | ], 16 | exports: [ 17 | PyBridge 18 | ] 19 | }) { 20 | } 21 | -------------------------------------------------------------------------------- /tests/test1/script.py: -------------------------------------------------------------------------------- 1 | from typing import List 2 | 3 | 4 | def word_sizes(words: List[str]) -> List[int]: 5 | return [len(word) for word in words] 6 | 7 | 8 | def stream() -> str: 9 | yield {'type': 'loading'} 10 | yield {'type': 'loaded'} 11 | -------------------------------------------------------------------------------- /tests/test1/test.spec.ts: -------------------------------------------------------------------------------- 1 | import { App } from "@deepkit/app"; 2 | import { PyBridge } from "../../src/bridge"; 3 | import { PyBridgeModule } from "../../src/module"; 4 | import { Subject } from "rxjs"; 5 | 6 | test('script', async () => { 7 | const bridge = new PyBridge({ python: 'python3', cwd: __dirname }); 8 | 9 | interface API { 10 | word_sizes(words: string[]): number[]; 11 | 12 | stream(): Subject<{ type: 'loading' } | { type: 'loaded' }>; 13 | } 14 | 15 | const api = bridge.controller('script.py'); 16 | const sizes = await api.word_sizes(['hello', 'world']); 17 | expect(sizes).toEqual([5, 5]); 18 | 19 | const stream = api.stream(); 20 | const values: any[] = []; 21 | stream.subscribe(v => values.push(v)); 22 | await stream.toPromise(); 23 | expect(values).toEqual([{ type: 'loading' }, { type: 'loaded' }]); 24 | 25 | bridge.close(); 26 | }); 27 | 28 | test('app', async () => { 29 | const app = new App({ 30 | imports: [new PyBridgeModule({ 31 | python: 'python3', 32 | cwd: __dirname, 33 | })] 34 | }).command('test', async (python: PyBridge) => { 35 | interface API { 36 | word_sizes(words: string[]): number[]; 37 | } 38 | 39 | const controller = python.controller('script.py'); 40 | const sizes = await controller.word_sizes(['hello', 'world']); 41 | expect(sizes).toEqual([5, 5]); 42 | }); 43 | 44 | await app.run(['test']); 45 | }); 46 | 47 | test('script code', async () => { 48 | const bridge = new PyBridge({ python: 'python3', cwd: __dirname }); 49 | 50 | interface API { 51 | embed(text: string): number[]; 52 | } 53 | 54 | const code = ` 55 | def embed(text): 56 | return [len(text)] 57 | `; 58 | 59 | const api = bridge.controller(code); 60 | 61 | const result = await api.embed('hello'); 62 | expect(result).toEqual([5]); 63 | }); 64 | -------------------------------------------------------------------------------- /tsconfig.esm.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "compilerOptions": { 4 | "outDir": "./dist/esm", 5 | "module": "ES2020" 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "baseUrl": "./", 4 | "outDir": "./dist/cjs", 5 | "strict": true, 6 | "sourceMap": true, 7 | "declaration": true, 8 | "experimentalDecorators": true, 9 | "moduleResolution": "node", 10 | "target": "es2018", 11 | "module": "CommonJS", 12 | "preserveSymlinks": true, 13 | "esModuleInterop": true 14 | }, 15 | "reflection": true, 16 | "include": [ 17 | "index.ts", 18 | "src" 19 | ] 20 | } 21 | --------------------------------------------------------------------------------