├── .gitignore ├── .gitpod.yml ├── .husky ├── .gitignore └── pre-commit ├── .npmignore ├── .prettierignore ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── prettier.config.js ├── src ├── index.ts ├── lib │ └── crypto.ts └── types │ ├── generated-types.ts │ └── types.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | dist/ 3 | .env -------------------------------------------------------------------------------- /.gitpod.yml: -------------------------------------------------------------------------------- 1 | tasks: 2 | - init: npm install 3 | command: npm run dev 4 | -------------------------------------------------------------------------------- /.husky/.gitignore: -------------------------------------------------------------------------------- 1 | _ 2 | -------------------------------------------------------------------------------- /.husky/pre-commit: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | . "$(dirname "$0")/_/husky.sh" 3 | 4 | npx lint-staged 5 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .env -------------------------------------------------------------------------------- /.prettierignore: -------------------------------------------------------------------------------- 1 | *.json 2 | 3 | dist/ -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 Kiros Choi 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # 3Commas API Client for TypeScript 2 | 3 | ![npm](https://img.shields.io/npm/v/3commas-typescript) 4 | ![npm bundle size](https://img.shields.io/bundlephobia/min/3commas-typescript) 5 | 6 | [![Open in Gitpod](https://gitpod.io/button/open-in-gitpod.svg)](https://gitpod.io/#https://github.com/kirosc/3commas-typescript) 7 | 8 | An unofficial 3Commas API wrapper in TypeScript. Check out the offical documentation [here](https://github.com/3commas-io/3commas-official-api-docs). 9 | 10 | ## Install 11 | 12 | ``` 13 | npm install 3commas-typescript 14 | ``` 15 | 16 | ## Usage 17 | 18 | ```ts 19 | import { API } from '3commas-typescript'; 20 | 21 | const api = new API({ 22 | key: 'YOUR_KEY', // Optional if only query endpoints with no security requirement 23 | secrets: 'YOUR_SECRETS', // Optional 24 | timeout: 60000, // Optional, in ms, default to 30000 25 | forcedMode: 'real' | 'paper', 26 | errorHandler: (response, reject) => { 27 | // Optional, Custom handler for 3Commas error 28 | const { error, error_description } = response; 29 | reject(new Error(error_description ?? error)); 30 | }, 31 | }); 32 | ``` 33 | 34 | ## Supported Request 35 | 36 | ### Account 37 | 38 | ```ts 39 | ping() 40 | 41 | time() 42 | 43 | transfer(params: TransferParams) 44 | 45 | getTransferHistory(params: TransferHistoryParams) 46 | 47 | getTransferData() 48 | 49 | addExchangeAccount(params: any) 50 | 51 | editExchangeAccount(params: any) 52 | 53 | getExchange() 54 | 55 | getMarketList() 56 | 57 | getMarketPairs(params?: any) 58 | 59 | getCurrencyRate(params: CurrencyParams) 60 | 61 | getCurrencyRateWithLeverageData(params: MarketCurrencyParams) 62 | 63 | getActiveTradeEntities(account_id: number) 64 | 65 | sellAllToUSD(account_id: number) 66 | 67 | sellAllToBTC(account_id: number) 68 | 69 | getBalanceChartData(account_id: number, params: any) 70 | 71 | loadBalances(account_id: number) 72 | 73 | renameExchangeAccount(account_id: number, name: string) 74 | 75 | removeExchangeAccount(account_id: number) 76 | 77 | getPieChartData(account_id: number) 78 | 79 | getAccountTableData(account_id: number) 80 | 81 | getAccountInfo(account_id?: number) 82 | ``` 83 | 84 | ### User 85 | 86 | ```ts 87 | changeUserMode(mode: 'paper' | 'real') 88 | ``` 89 | 90 | ### Smart Trade 91 | 92 | ```ts 93 | getSmartTradeHistory(params?: SmartTradeHistoryParams) 94 | 95 | smartTrade(params: SmartTradeParams) 96 | 97 | getSmartTrade(id: number) 98 | 99 | cancelSmartTrade(id: number) 100 | 101 | updateSmartTrade(id: number) 102 | 103 | averageSmartTrade(id: number, params: FundParams) 104 | 105 | reduceFund(id: number, params: FundParams) 106 | 107 | closeSmartTrade(id: number) 108 | 109 | forceStartSmartTrade(id: number) 110 | 111 | forceProcessSmartTrade(id: number) 112 | 113 | setNoteSmartTrade(id: number, note: string) 114 | 115 | getSubTrade(id: number) 116 | 117 | closeSubTrade(smartTradeId: number, subTradeId: number) 118 | 119 | cancelSubTrade(smartTradeId: number, subTradeId: number) 120 | 121 | ``` 122 | 123 | ### Bots 124 | 125 | ```ts 126 | getBots(params?: BotsParams) 127 | 128 | getBot(id: number) 129 | 130 | getBotsStats(params?: BotsStatsParams) 131 | 132 | getDeals(params?: DealsParams) 133 | 134 | getDeal(id: number) 135 | 136 | getDealSafetyOrders(id: number) 137 | ``` 138 | 139 | ### Custom Request 140 | 141 | ```ts 142 | customRequest(method: string, version: number, path: string, payload?: any) 143 | ``` 144 | 145 | ### Websocket 146 | 147 | ```ts 148 | subscribeSmartTrade(callback?: (data: WebSocket.Data) => void) 149 | 150 | subscribeDeal(callback?: (data: WebSocket.Data) => void) 151 | 152 | unsubscribe() 153 | ``` 154 | 155 | ## Response Type 156 | 157 | The Order type returned by smart trade endpoint is generated using [quicktype](https://github.com/quicktype/quicktype). 158 | 159 | The type correctness isn't guaranteed. You can perform a type check before access. 160 | 161 | ```ts 162 | try { 163 | const order = await api.getSmartTrade(1234567) 164 | const validatedOrder = api.validateOrderType(order) 165 | ... 166 | } catch (error) { 167 | console.error(error) 168 | } 169 | ``` 170 | 171 | ## Support 172 | 173 | Buy me a coffee 174 | 175 | ETH: 0xB6fc1dFABf1244138b048C3F80ba5678d8f6f0CE 176 | 177 | BAT: 0x336bFB8247640C0848F8aFFB80464f3fF489B888 178 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "3commas-typescript", 3 | "version": "1.3.6", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "3commas-typescript", 9 | "version": "1.3.6", 10 | "license": "MIT", 11 | "dependencies": { 12 | "axios": "^0.27.2", 13 | "crypto-js": "^4.1.1", 14 | "qs": "^6.11.0", 15 | "ws": "^8.8.1" 16 | }, 17 | "devDependencies": { 18 | "@types/crypto-js": "^4.1.1", 19 | "@types/node": "^18.0.6", 20 | "@types/qs": "^6.9.7", 21 | "@types/ws": "^8.5.3", 22 | "dotenv": "^16.0.1", 23 | "husky": "^8.0.1", 24 | "lint-staged": "^13.0.3", 25 | "prettier": "^2.7.1", 26 | "ts-node-dev": "^2.0.0", 27 | "typescript": "^4.7.4" 28 | } 29 | }, 30 | "node_modules/@cspotcode/source-map-support": { 31 | "version": "0.8.1", 32 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 33 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 34 | "dev": true, 35 | "dependencies": { 36 | "@jridgewell/trace-mapping": "0.3.9" 37 | }, 38 | "engines": { 39 | "node": ">=12" 40 | } 41 | }, 42 | "node_modules/@jridgewell/resolve-uri": { 43 | "version": "3.1.0", 44 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 45 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 46 | "dev": true, 47 | "engines": { 48 | "node": ">=6.0.0" 49 | } 50 | }, 51 | "node_modules/@jridgewell/sourcemap-codec": { 52 | "version": "1.4.14", 53 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 54 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 55 | "dev": true 56 | }, 57 | "node_modules/@jridgewell/trace-mapping": { 58 | "version": "0.3.9", 59 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 60 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 61 | "dev": true, 62 | "dependencies": { 63 | "@jridgewell/resolve-uri": "^3.0.3", 64 | "@jridgewell/sourcemap-codec": "^1.4.10" 65 | } 66 | }, 67 | "node_modules/@tsconfig/node10": { 68 | "version": "1.0.9", 69 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", 70 | "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==", 71 | "dev": true 72 | }, 73 | "node_modules/@tsconfig/node12": { 74 | "version": "1.0.11", 75 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 76 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 77 | "dev": true 78 | }, 79 | "node_modules/@tsconfig/node14": { 80 | "version": "1.0.3", 81 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 82 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 83 | "dev": true 84 | }, 85 | "node_modules/@tsconfig/node16": { 86 | "version": "1.0.3", 87 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.3.tgz", 88 | "integrity": "sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ==", 89 | "dev": true 90 | }, 91 | "node_modules/@types/crypto-js": { 92 | "version": "4.1.1", 93 | "resolved": "https://registry.npmjs.org/@types/crypto-js/-/crypto-js-4.1.1.tgz", 94 | "integrity": "sha512-BG7fQKZ689HIoc5h+6D2Dgq1fABRa0RbBWKBd9SP/MVRVXROflpm5fhwyATX5duFmbStzyzyycPB8qUYKDH3NA==", 95 | "dev": true 96 | }, 97 | "node_modules/@types/node": { 98 | "version": "18.0.6", 99 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.0.6.tgz", 100 | "integrity": "sha512-/xUq6H2aQm261exT6iZTMifUySEt4GR5KX8eYyY+C4MSNPqSh9oNIP7tz2GLKTlFaiBbgZNxffoR3CVRG+cljw==", 101 | "dev": true 102 | }, 103 | "node_modules/@types/qs": { 104 | "version": "6.9.7", 105 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 106 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 107 | "dev": true 108 | }, 109 | "node_modules/@types/strip-bom": { 110 | "version": "3.0.0", 111 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 112 | "integrity": "sha1-FKjsOVbC6B7bdSB5CuzyHCkK69I=", 113 | "dev": true 114 | }, 115 | "node_modules/@types/strip-json-comments": { 116 | "version": "0.0.30", 117 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 118 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 119 | "dev": true 120 | }, 121 | "node_modules/@types/ws": { 122 | "version": "8.5.3", 123 | "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz", 124 | "integrity": "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==", 125 | "dev": true, 126 | "dependencies": { 127 | "@types/node": "*" 128 | } 129 | }, 130 | "node_modules/acorn": { 131 | "version": "8.8.0", 132 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.0.tgz", 133 | "integrity": "sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w==", 134 | "dev": true, 135 | "bin": { 136 | "acorn": "bin/acorn" 137 | }, 138 | "engines": { 139 | "node": ">=0.4.0" 140 | } 141 | }, 142 | "node_modules/acorn-walk": { 143 | "version": "8.2.0", 144 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 145 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 146 | "dev": true, 147 | "engines": { 148 | "node": ">=0.4.0" 149 | } 150 | }, 151 | "node_modules/aggregate-error": { 152 | "version": "3.1.0", 153 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 154 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 155 | "dev": true, 156 | "dependencies": { 157 | "clean-stack": "^2.0.0", 158 | "indent-string": "^4.0.0" 159 | }, 160 | "engines": { 161 | "node": ">=8" 162 | } 163 | }, 164 | "node_modules/ansi-escapes": { 165 | "version": "4.3.2", 166 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 167 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 168 | "dev": true, 169 | "dependencies": { 170 | "type-fest": "^0.21.3" 171 | }, 172 | "engines": { 173 | "node": ">=8" 174 | }, 175 | "funding": { 176 | "url": "https://github.com/sponsors/sindresorhus" 177 | } 178 | }, 179 | "node_modules/ansi-regex": { 180 | "version": "6.0.1", 181 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 182 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 183 | "dev": true, 184 | "engines": { 185 | "node": ">=12" 186 | }, 187 | "funding": { 188 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 189 | } 190 | }, 191 | "node_modules/ansi-styles": { 192 | "version": "6.1.0", 193 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.1.0.tgz", 194 | "integrity": "sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ==", 195 | "dev": true, 196 | "engines": { 197 | "node": ">=12" 198 | }, 199 | "funding": { 200 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 201 | } 202 | }, 203 | "node_modules/anymatch": { 204 | "version": "3.1.2", 205 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 206 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 207 | "dev": true, 208 | "dependencies": { 209 | "normalize-path": "^3.0.0", 210 | "picomatch": "^2.0.4" 211 | }, 212 | "engines": { 213 | "node": ">= 8" 214 | } 215 | }, 216 | "node_modules/arg": { 217 | "version": "4.1.3", 218 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 219 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 220 | "dev": true 221 | }, 222 | "node_modules/astral-regex": { 223 | "version": "2.0.0", 224 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 225 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 226 | "dev": true, 227 | "engines": { 228 | "node": ">=8" 229 | } 230 | }, 231 | "node_modules/asynckit": { 232 | "version": "0.4.0", 233 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 234 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 235 | }, 236 | "node_modules/axios": { 237 | "version": "0.27.2", 238 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.27.2.tgz", 239 | "integrity": "sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ==", 240 | "dependencies": { 241 | "follow-redirects": "^1.14.9", 242 | "form-data": "^4.0.0" 243 | } 244 | }, 245 | "node_modules/balanced-match": { 246 | "version": "1.0.2", 247 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 248 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 249 | "dev": true 250 | }, 251 | "node_modules/binary-extensions": { 252 | "version": "2.2.0", 253 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 254 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 255 | "dev": true, 256 | "engines": { 257 | "node": ">=8" 258 | } 259 | }, 260 | "node_modules/brace-expansion": { 261 | "version": "1.1.11", 262 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 263 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 264 | "dev": true, 265 | "dependencies": { 266 | "balanced-match": "^1.0.0", 267 | "concat-map": "0.0.1" 268 | } 269 | }, 270 | "node_modules/braces": { 271 | "version": "3.0.2", 272 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 273 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 274 | "dev": true, 275 | "dependencies": { 276 | "fill-range": "^7.0.1" 277 | }, 278 | "engines": { 279 | "node": ">=8" 280 | } 281 | }, 282 | "node_modules/buffer-from": { 283 | "version": "1.1.2", 284 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 285 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 286 | "dev": true 287 | }, 288 | "node_modules/call-bind": { 289 | "version": "1.0.2", 290 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 291 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 292 | "dependencies": { 293 | "function-bind": "^1.1.1", 294 | "get-intrinsic": "^1.0.2" 295 | }, 296 | "funding": { 297 | "url": "https://github.com/sponsors/ljharb" 298 | } 299 | }, 300 | "node_modules/chokidar": { 301 | "version": "3.5.3", 302 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 303 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 304 | "dev": true, 305 | "funding": [ 306 | { 307 | "type": "individual", 308 | "url": "https://paulmillr.com/funding/" 309 | } 310 | ], 311 | "dependencies": { 312 | "anymatch": "~3.1.2", 313 | "braces": "~3.0.2", 314 | "glob-parent": "~5.1.2", 315 | "is-binary-path": "~2.1.0", 316 | "is-glob": "~4.0.1", 317 | "normalize-path": "~3.0.0", 318 | "readdirp": "~3.6.0" 319 | }, 320 | "engines": { 321 | "node": ">= 8.10.0" 322 | }, 323 | "optionalDependencies": { 324 | "fsevents": "~2.3.2" 325 | } 326 | }, 327 | "node_modules/clean-stack": { 328 | "version": "2.2.0", 329 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 330 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 331 | "dev": true, 332 | "engines": { 333 | "node": ">=6" 334 | } 335 | }, 336 | "node_modules/cli-cursor": { 337 | "version": "3.1.0", 338 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 339 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 340 | "dev": true, 341 | "dependencies": { 342 | "restore-cursor": "^3.1.0" 343 | }, 344 | "engines": { 345 | "node": ">=8" 346 | } 347 | }, 348 | "node_modules/cli-truncate": { 349 | "version": "3.1.0", 350 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-3.1.0.tgz", 351 | "integrity": "sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==", 352 | "dev": true, 353 | "dependencies": { 354 | "slice-ansi": "^5.0.0", 355 | "string-width": "^5.0.0" 356 | }, 357 | "engines": { 358 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 359 | }, 360 | "funding": { 361 | "url": "https://github.com/sponsors/sindresorhus" 362 | } 363 | }, 364 | "node_modules/color-convert": { 365 | "version": "2.0.1", 366 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 367 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 368 | "dev": true, 369 | "dependencies": { 370 | "color-name": "~1.1.4" 371 | }, 372 | "engines": { 373 | "node": ">=7.0.0" 374 | } 375 | }, 376 | "node_modules/color-name": { 377 | "version": "1.1.4", 378 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 379 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 380 | "dev": true 381 | }, 382 | "node_modules/colorette": { 383 | "version": "2.0.19", 384 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.19.tgz", 385 | "integrity": "sha512-3tlv/dIP7FWvj3BsbHrGLJ6l/oKh1O3TcgBqMn+yyCagOxc23fyzDS6HypQbgxWbkpDnf52p1LuR4eWDQ/K9WQ==", 386 | "dev": true 387 | }, 388 | "node_modules/combined-stream": { 389 | "version": "1.0.8", 390 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 391 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 392 | "dependencies": { 393 | "delayed-stream": "~1.0.0" 394 | }, 395 | "engines": { 396 | "node": ">= 0.8" 397 | } 398 | }, 399 | "node_modules/commander": { 400 | "version": "9.4.0", 401 | "resolved": "https://registry.npmjs.org/commander/-/commander-9.4.0.tgz", 402 | "integrity": "sha512-sRPT+umqkz90UA8M1yqYfnHlZA7fF6nSphDtxeywPZ49ysjxDQybzk13CL+mXekDRG92skbcqCLVovuCusNmFw==", 403 | "dev": true, 404 | "engines": { 405 | "node": "^12.20.0 || >=14" 406 | } 407 | }, 408 | "node_modules/concat-map": { 409 | "version": "0.0.1", 410 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 411 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 412 | "dev": true 413 | }, 414 | "node_modules/create-require": { 415 | "version": "1.1.1", 416 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 417 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 418 | "dev": true 419 | }, 420 | "node_modules/cross-spawn": { 421 | "version": "7.0.3", 422 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 423 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 424 | "dev": true, 425 | "dependencies": { 426 | "path-key": "^3.1.0", 427 | "shebang-command": "^2.0.0", 428 | "which": "^2.0.1" 429 | }, 430 | "engines": { 431 | "node": ">= 8" 432 | } 433 | }, 434 | "node_modules/crypto-js": { 435 | "version": "4.1.1", 436 | "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-4.1.1.tgz", 437 | "integrity": "sha512-o2JlM7ydqd3Qk9CA0L4NL6mTzU2sdx96a+oOfPu8Mkl/PK51vSyoi8/rQ8NknZtk44vq15lmhAj9CIAGwgeWKw==" 438 | }, 439 | "node_modules/debug": { 440 | "version": "4.3.4", 441 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 442 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 443 | "dev": true, 444 | "dependencies": { 445 | "ms": "2.1.2" 446 | }, 447 | "engines": { 448 | "node": ">=6.0" 449 | }, 450 | "peerDependenciesMeta": { 451 | "supports-color": { 452 | "optional": true 453 | } 454 | } 455 | }, 456 | "node_modules/delayed-stream": { 457 | "version": "1.0.0", 458 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 459 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 460 | "engines": { 461 | "node": ">=0.4.0" 462 | } 463 | }, 464 | "node_modules/diff": { 465 | "version": "4.0.2", 466 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 467 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 468 | "dev": true, 469 | "engines": { 470 | "node": ">=0.3.1" 471 | } 472 | }, 473 | "node_modules/dotenv": { 474 | "version": "16.0.1", 475 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz", 476 | "integrity": "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ==", 477 | "dev": true, 478 | "engines": { 479 | "node": ">=12" 480 | } 481 | }, 482 | "node_modules/dynamic-dedupe": { 483 | "version": "0.3.0", 484 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 485 | "integrity": "sha1-BuRMIj9eTpTXjvnbI6ZRXOL5YqE=", 486 | "dev": true, 487 | "dependencies": { 488 | "xtend": "^4.0.0" 489 | } 490 | }, 491 | "node_modules/eastasianwidth": { 492 | "version": "0.2.0", 493 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 494 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 495 | "dev": true 496 | }, 497 | "node_modules/emoji-regex": { 498 | "version": "9.2.2", 499 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 500 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 501 | "dev": true 502 | }, 503 | "node_modules/execa": { 504 | "version": "6.1.0", 505 | "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", 506 | "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", 507 | "dev": true, 508 | "dependencies": { 509 | "cross-spawn": "^7.0.3", 510 | "get-stream": "^6.0.1", 511 | "human-signals": "^3.0.1", 512 | "is-stream": "^3.0.0", 513 | "merge-stream": "^2.0.0", 514 | "npm-run-path": "^5.1.0", 515 | "onetime": "^6.0.0", 516 | "signal-exit": "^3.0.7", 517 | "strip-final-newline": "^3.0.0" 518 | }, 519 | "engines": { 520 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 521 | }, 522 | "funding": { 523 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 524 | } 525 | }, 526 | "node_modules/fill-range": { 527 | "version": "7.0.1", 528 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 529 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 530 | "dev": true, 531 | "dependencies": { 532 | "to-regex-range": "^5.0.1" 533 | }, 534 | "engines": { 535 | "node": ">=8" 536 | } 537 | }, 538 | "node_modules/follow-redirects": { 539 | "version": "1.15.1", 540 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.1.tgz", 541 | "integrity": "sha512-yLAMQs+k0b2m7cVxpS1VKJVvoz7SS9Td1zss3XRwXj+ZDH00RJgnuLx7E44wx02kQLrdM3aOOy+FpzS7+8OizA==", 542 | "funding": [ 543 | { 544 | "type": "individual", 545 | "url": "https://github.com/sponsors/RubenVerborgh" 546 | } 547 | ], 548 | "engines": { 549 | "node": ">=4.0" 550 | }, 551 | "peerDependenciesMeta": { 552 | "debug": { 553 | "optional": true 554 | } 555 | } 556 | }, 557 | "node_modules/form-data": { 558 | "version": "4.0.0", 559 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 560 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 561 | "dependencies": { 562 | "asynckit": "^0.4.0", 563 | "combined-stream": "^1.0.8", 564 | "mime-types": "^2.1.12" 565 | }, 566 | "engines": { 567 | "node": ">= 6" 568 | } 569 | }, 570 | "node_modules/fs.realpath": { 571 | "version": "1.0.0", 572 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 573 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 574 | "dev": true 575 | }, 576 | "node_modules/fsevents": { 577 | "version": "2.3.2", 578 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 579 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 580 | "dev": true, 581 | "hasInstallScript": true, 582 | "optional": true, 583 | "os": [ 584 | "darwin" 585 | ], 586 | "engines": { 587 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 588 | } 589 | }, 590 | "node_modules/function-bind": { 591 | "version": "1.1.1", 592 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 593 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 594 | }, 595 | "node_modules/get-intrinsic": { 596 | "version": "1.1.1", 597 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 598 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 599 | "dependencies": { 600 | "function-bind": "^1.1.1", 601 | "has": "^1.0.3", 602 | "has-symbols": "^1.0.1" 603 | }, 604 | "funding": { 605 | "url": "https://github.com/sponsors/ljharb" 606 | } 607 | }, 608 | "node_modules/get-stream": { 609 | "version": "6.0.1", 610 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 611 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 612 | "dev": true, 613 | "engines": { 614 | "node": ">=10" 615 | }, 616 | "funding": { 617 | "url": "https://github.com/sponsors/sindresorhus" 618 | } 619 | }, 620 | "node_modules/glob": { 621 | "version": "7.2.0", 622 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 623 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 624 | "dev": true, 625 | "dependencies": { 626 | "fs.realpath": "^1.0.0", 627 | "inflight": "^1.0.4", 628 | "inherits": "2", 629 | "minimatch": "^3.0.4", 630 | "once": "^1.3.0", 631 | "path-is-absolute": "^1.0.0" 632 | }, 633 | "engines": { 634 | "node": "*" 635 | }, 636 | "funding": { 637 | "url": "https://github.com/sponsors/isaacs" 638 | } 639 | }, 640 | "node_modules/glob-parent": { 641 | "version": "5.1.2", 642 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 643 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 644 | "dev": true, 645 | "dependencies": { 646 | "is-glob": "^4.0.1" 647 | }, 648 | "engines": { 649 | "node": ">= 6" 650 | } 651 | }, 652 | "node_modules/has": { 653 | "version": "1.0.3", 654 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 655 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 656 | "dependencies": { 657 | "function-bind": "^1.1.1" 658 | }, 659 | "engines": { 660 | "node": ">= 0.4.0" 661 | } 662 | }, 663 | "node_modules/has-symbols": { 664 | "version": "1.0.2", 665 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 666 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 667 | "engines": { 668 | "node": ">= 0.4" 669 | }, 670 | "funding": { 671 | "url": "https://github.com/sponsors/ljharb" 672 | } 673 | }, 674 | "node_modules/human-signals": { 675 | "version": "3.0.1", 676 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", 677 | "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", 678 | "dev": true, 679 | "engines": { 680 | "node": ">=12.20.0" 681 | } 682 | }, 683 | "node_modules/husky": { 684 | "version": "8.0.1", 685 | "resolved": "https://registry.npmjs.org/husky/-/husky-8.0.1.tgz", 686 | "integrity": "sha512-xs7/chUH/CKdOCs7Zy0Aev9e/dKOMZf3K1Az1nar3tzlv0jfqnYtu235bstsWTmXOR0EfINrPa97yy4Lz6RiKw==", 687 | "dev": true, 688 | "bin": { 689 | "husky": "lib/bin.js" 690 | }, 691 | "engines": { 692 | "node": ">=14" 693 | }, 694 | "funding": { 695 | "url": "https://github.com/sponsors/typicode" 696 | } 697 | }, 698 | "node_modules/indent-string": { 699 | "version": "4.0.0", 700 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 701 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 702 | "dev": true, 703 | "engines": { 704 | "node": ">=8" 705 | } 706 | }, 707 | "node_modules/inflight": { 708 | "version": "1.0.6", 709 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 710 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 711 | "dev": true, 712 | "dependencies": { 713 | "once": "^1.3.0", 714 | "wrappy": "1" 715 | } 716 | }, 717 | "node_modules/inherits": { 718 | "version": "2.0.4", 719 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 720 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 721 | "dev": true 722 | }, 723 | "node_modules/is-binary-path": { 724 | "version": "2.1.0", 725 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 726 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 727 | "dev": true, 728 | "dependencies": { 729 | "binary-extensions": "^2.0.0" 730 | }, 731 | "engines": { 732 | "node": ">=8" 733 | } 734 | }, 735 | "node_modules/is-core-module": { 736 | "version": "2.8.1", 737 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 738 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 739 | "dev": true, 740 | "dependencies": { 741 | "has": "^1.0.3" 742 | }, 743 | "funding": { 744 | "url": "https://github.com/sponsors/ljharb" 745 | } 746 | }, 747 | "node_modules/is-extglob": { 748 | "version": "2.1.1", 749 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 750 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 751 | "dev": true, 752 | "engines": { 753 | "node": ">=0.10.0" 754 | } 755 | }, 756 | "node_modules/is-fullwidth-code-point": { 757 | "version": "4.0.0", 758 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", 759 | "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", 760 | "dev": true, 761 | "engines": { 762 | "node": ">=12" 763 | }, 764 | "funding": { 765 | "url": "https://github.com/sponsors/sindresorhus" 766 | } 767 | }, 768 | "node_modules/is-glob": { 769 | "version": "4.0.3", 770 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 771 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 772 | "dev": true, 773 | "dependencies": { 774 | "is-extglob": "^2.1.1" 775 | }, 776 | "engines": { 777 | "node": ">=0.10.0" 778 | } 779 | }, 780 | "node_modules/is-number": { 781 | "version": "7.0.0", 782 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 783 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 784 | "dev": true, 785 | "engines": { 786 | "node": ">=0.12.0" 787 | } 788 | }, 789 | "node_modules/is-stream": { 790 | "version": "3.0.0", 791 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 792 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 793 | "dev": true, 794 | "engines": { 795 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 796 | }, 797 | "funding": { 798 | "url": "https://github.com/sponsors/sindresorhus" 799 | } 800 | }, 801 | "node_modules/isexe": { 802 | "version": "2.0.0", 803 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 804 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 805 | "dev": true 806 | }, 807 | "node_modules/lilconfig": { 808 | "version": "2.0.5", 809 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.5.tgz", 810 | "integrity": "sha512-xaYmXZtTHPAw5m+xLN8ab9C+3a8YmV3asNSPOATITbtwrfbwaLJj8h66H1WMIpALCkqsIzK3h7oQ+PdX+LQ9Eg==", 811 | "dev": true, 812 | "engines": { 813 | "node": ">=10" 814 | } 815 | }, 816 | "node_modules/lint-staged": { 817 | "version": "13.0.3", 818 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-13.0.3.tgz", 819 | "integrity": "sha512-9hmrwSCFroTSYLjflGI8Uk+GWAwMB4OlpU4bMJEAT5d/llQwtYKoim4bLOyLCuWFAhWEupE0vkIFqtw/WIsPug==", 820 | "dev": true, 821 | "dependencies": { 822 | "cli-truncate": "^3.1.0", 823 | "colorette": "^2.0.17", 824 | "commander": "^9.3.0", 825 | "debug": "^4.3.4", 826 | "execa": "^6.1.0", 827 | "lilconfig": "2.0.5", 828 | "listr2": "^4.0.5", 829 | "micromatch": "^4.0.5", 830 | "normalize-path": "^3.0.0", 831 | "object-inspect": "^1.12.2", 832 | "pidtree": "^0.6.0", 833 | "string-argv": "^0.3.1", 834 | "yaml": "^2.1.1" 835 | }, 836 | "bin": { 837 | "lint-staged": "bin/lint-staged.js" 838 | }, 839 | "engines": { 840 | "node": "^14.13.1 || >=16.0.0" 841 | }, 842 | "funding": { 843 | "url": "https://opencollective.com/lint-staged" 844 | } 845 | }, 846 | "node_modules/listr2": { 847 | "version": "4.0.5", 848 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-4.0.5.tgz", 849 | "integrity": "sha512-juGHV1doQdpNT3GSTs9IUN43QJb7KHdF9uqg7Vufs/tG9VTzpFphqF4pm/ICdAABGQxsyNn9CiYA3StkI6jpwA==", 850 | "dev": true, 851 | "dependencies": { 852 | "cli-truncate": "^2.1.0", 853 | "colorette": "^2.0.16", 854 | "log-update": "^4.0.0", 855 | "p-map": "^4.0.0", 856 | "rfdc": "^1.3.0", 857 | "rxjs": "^7.5.5", 858 | "through": "^2.3.8", 859 | "wrap-ansi": "^7.0.0" 860 | }, 861 | "engines": { 862 | "node": ">=12" 863 | }, 864 | "peerDependencies": { 865 | "enquirer": ">= 2.3.0 < 3" 866 | }, 867 | "peerDependenciesMeta": { 868 | "enquirer": { 869 | "optional": true 870 | } 871 | } 872 | }, 873 | "node_modules/listr2/node_modules/ansi-regex": { 874 | "version": "5.0.1", 875 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 876 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 877 | "dev": true, 878 | "engines": { 879 | "node": ">=8" 880 | } 881 | }, 882 | "node_modules/listr2/node_modules/ansi-styles": { 883 | "version": "4.3.0", 884 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 885 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 886 | "dev": true, 887 | "dependencies": { 888 | "color-convert": "^2.0.1" 889 | }, 890 | "engines": { 891 | "node": ">=8" 892 | }, 893 | "funding": { 894 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 895 | } 896 | }, 897 | "node_modules/listr2/node_modules/cli-truncate": { 898 | "version": "2.1.0", 899 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 900 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 901 | "dev": true, 902 | "dependencies": { 903 | "slice-ansi": "^3.0.0", 904 | "string-width": "^4.2.0" 905 | }, 906 | "engines": { 907 | "node": ">=8" 908 | }, 909 | "funding": { 910 | "url": "https://github.com/sponsors/sindresorhus" 911 | } 912 | }, 913 | "node_modules/listr2/node_modules/emoji-regex": { 914 | "version": "8.0.0", 915 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 916 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 917 | "dev": true 918 | }, 919 | "node_modules/listr2/node_modules/is-fullwidth-code-point": { 920 | "version": "3.0.0", 921 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 922 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 923 | "dev": true, 924 | "engines": { 925 | "node": ">=8" 926 | } 927 | }, 928 | "node_modules/listr2/node_modules/slice-ansi": { 929 | "version": "3.0.0", 930 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 931 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 932 | "dev": true, 933 | "dependencies": { 934 | "ansi-styles": "^4.0.0", 935 | "astral-regex": "^2.0.0", 936 | "is-fullwidth-code-point": "^3.0.0" 937 | }, 938 | "engines": { 939 | "node": ">=8" 940 | } 941 | }, 942 | "node_modules/listr2/node_modules/string-width": { 943 | "version": "4.2.3", 944 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 945 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 946 | "dev": true, 947 | "dependencies": { 948 | "emoji-regex": "^8.0.0", 949 | "is-fullwidth-code-point": "^3.0.0", 950 | "strip-ansi": "^6.0.1" 951 | }, 952 | "engines": { 953 | "node": ">=8" 954 | } 955 | }, 956 | "node_modules/listr2/node_modules/strip-ansi": { 957 | "version": "6.0.1", 958 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 959 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 960 | "dev": true, 961 | "dependencies": { 962 | "ansi-regex": "^5.0.1" 963 | }, 964 | "engines": { 965 | "node": ">=8" 966 | } 967 | }, 968 | "node_modules/log-update": { 969 | "version": "4.0.0", 970 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 971 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 972 | "dev": true, 973 | "dependencies": { 974 | "ansi-escapes": "^4.3.0", 975 | "cli-cursor": "^3.1.0", 976 | "slice-ansi": "^4.0.0", 977 | "wrap-ansi": "^6.2.0" 978 | }, 979 | "engines": { 980 | "node": ">=10" 981 | }, 982 | "funding": { 983 | "url": "https://github.com/sponsors/sindresorhus" 984 | } 985 | }, 986 | "node_modules/log-update/node_modules/ansi-regex": { 987 | "version": "5.0.1", 988 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 989 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 990 | "dev": true, 991 | "engines": { 992 | "node": ">=8" 993 | } 994 | }, 995 | "node_modules/log-update/node_modules/ansi-styles": { 996 | "version": "4.3.0", 997 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 998 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 999 | "dev": true, 1000 | "dependencies": { 1001 | "color-convert": "^2.0.1" 1002 | }, 1003 | "engines": { 1004 | "node": ">=8" 1005 | }, 1006 | "funding": { 1007 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1008 | } 1009 | }, 1010 | "node_modules/log-update/node_modules/emoji-regex": { 1011 | "version": "8.0.0", 1012 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1013 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1014 | "dev": true 1015 | }, 1016 | "node_modules/log-update/node_modules/is-fullwidth-code-point": { 1017 | "version": "3.0.0", 1018 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1019 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1020 | "dev": true, 1021 | "engines": { 1022 | "node": ">=8" 1023 | } 1024 | }, 1025 | "node_modules/log-update/node_modules/slice-ansi": { 1026 | "version": "4.0.0", 1027 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1028 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1029 | "dev": true, 1030 | "dependencies": { 1031 | "ansi-styles": "^4.0.0", 1032 | "astral-regex": "^2.0.0", 1033 | "is-fullwidth-code-point": "^3.0.0" 1034 | }, 1035 | "engines": { 1036 | "node": ">=10" 1037 | }, 1038 | "funding": { 1039 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1040 | } 1041 | }, 1042 | "node_modules/log-update/node_modules/string-width": { 1043 | "version": "4.2.3", 1044 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1045 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1046 | "dev": true, 1047 | "dependencies": { 1048 | "emoji-regex": "^8.0.0", 1049 | "is-fullwidth-code-point": "^3.0.0", 1050 | "strip-ansi": "^6.0.1" 1051 | }, 1052 | "engines": { 1053 | "node": ">=8" 1054 | } 1055 | }, 1056 | "node_modules/log-update/node_modules/strip-ansi": { 1057 | "version": "6.0.1", 1058 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1059 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1060 | "dev": true, 1061 | "dependencies": { 1062 | "ansi-regex": "^5.0.1" 1063 | }, 1064 | "engines": { 1065 | "node": ">=8" 1066 | } 1067 | }, 1068 | "node_modules/log-update/node_modules/wrap-ansi": { 1069 | "version": "6.2.0", 1070 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 1071 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 1072 | "dev": true, 1073 | "dependencies": { 1074 | "ansi-styles": "^4.0.0", 1075 | "string-width": "^4.1.0", 1076 | "strip-ansi": "^6.0.0" 1077 | }, 1078 | "engines": { 1079 | "node": ">=8" 1080 | } 1081 | }, 1082 | "node_modules/make-error": { 1083 | "version": "1.3.6", 1084 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1085 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1086 | "dev": true 1087 | }, 1088 | "node_modules/merge-stream": { 1089 | "version": "2.0.0", 1090 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1091 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1092 | "dev": true 1093 | }, 1094 | "node_modules/micromatch": { 1095 | "version": "4.0.5", 1096 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1097 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1098 | "dev": true, 1099 | "dependencies": { 1100 | "braces": "^3.0.2", 1101 | "picomatch": "^2.3.1" 1102 | }, 1103 | "engines": { 1104 | "node": ">=8.6" 1105 | } 1106 | }, 1107 | "node_modules/mime-db": { 1108 | "version": "1.52.0", 1109 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1110 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1111 | "engines": { 1112 | "node": ">= 0.6" 1113 | } 1114 | }, 1115 | "node_modules/mime-types": { 1116 | "version": "2.1.35", 1117 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1118 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1119 | "dependencies": { 1120 | "mime-db": "1.52.0" 1121 | }, 1122 | "engines": { 1123 | "node": ">= 0.6" 1124 | } 1125 | }, 1126 | "node_modules/mimic-fn": { 1127 | "version": "4.0.0", 1128 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 1129 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 1130 | "dev": true, 1131 | "engines": { 1132 | "node": ">=12" 1133 | }, 1134 | "funding": { 1135 | "url": "https://github.com/sponsors/sindresorhus" 1136 | } 1137 | }, 1138 | "node_modules/minimatch": { 1139 | "version": "3.0.4", 1140 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1141 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1142 | "dev": true, 1143 | "dependencies": { 1144 | "brace-expansion": "^1.1.7" 1145 | }, 1146 | "engines": { 1147 | "node": "*" 1148 | } 1149 | }, 1150 | "node_modules/minimist": { 1151 | "version": "1.2.6", 1152 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1153 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1154 | "dev": true 1155 | }, 1156 | "node_modules/mkdirp": { 1157 | "version": "1.0.4", 1158 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1159 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1160 | "dev": true, 1161 | "bin": { 1162 | "mkdirp": "bin/cmd.js" 1163 | }, 1164 | "engines": { 1165 | "node": ">=10" 1166 | } 1167 | }, 1168 | "node_modules/ms": { 1169 | "version": "2.1.2", 1170 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1171 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1172 | "dev": true 1173 | }, 1174 | "node_modules/normalize-path": { 1175 | "version": "3.0.0", 1176 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1177 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1178 | "dev": true, 1179 | "engines": { 1180 | "node": ">=0.10.0" 1181 | } 1182 | }, 1183 | "node_modules/npm-run-path": { 1184 | "version": "5.1.0", 1185 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", 1186 | "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", 1187 | "dev": true, 1188 | "dependencies": { 1189 | "path-key": "^4.0.0" 1190 | }, 1191 | "engines": { 1192 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1193 | }, 1194 | "funding": { 1195 | "url": "https://github.com/sponsors/sindresorhus" 1196 | } 1197 | }, 1198 | "node_modules/npm-run-path/node_modules/path-key": { 1199 | "version": "4.0.0", 1200 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 1201 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 1202 | "dev": true, 1203 | "engines": { 1204 | "node": ">=12" 1205 | }, 1206 | "funding": { 1207 | "url": "https://github.com/sponsors/sindresorhus" 1208 | } 1209 | }, 1210 | "node_modules/object-inspect": { 1211 | "version": "1.12.2", 1212 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 1213 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", 1214 | "funding": { 1215 | "url": "https://github.com/sponsors/ljharb" 1216 | } 1217 | }, 1218 | "node_modules/once": { 1219 | "version": "1.4.0", 1220 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1221 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1222 | "dev": true, 1223 | "dependencies": { 1224 | "wrappy": "1" 1225 | } 1226 | }, 1227 | "node_modules/onetime": { 1228 | "version": "6.0.0", 1229 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 1230 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 1231 | "dev": true, 1232 | "dependencies": { 1233 | "mimic-fn": "^4.0.0" 1234 | }, 1235 | "engines": { 1236 | "node": ">=12" 1237 | }, 1238 | "funding": { 1239 | "url": "https://github.com/sponsors/sindresorhus" 1240 | } 1241 | }, 1242 | "node_modules/p-map": { 1243 | "version": "4.0.0", 1244 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 1245 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 1246 | "dev": true, 1247 | "dependencies": { 1248 | "aggregate-error": "^3.0.0" 1249 | }, 1250 | "engines": { 1251 | "node": ">=10" 1252 | }, 1253 | "funding": { 1254 | "url": "https://github.com/sponsors/sindresorhus" 1255 | } 1256 | }, 1257 | "node_modules/path-is-absolute": { 1258 | "version": "1.0.1", 1259 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1260 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1261 | "dev": true, 1262 | "engines": { 1263 | "node": ">=0.10.0" 1264 | } 1265 | }, 1266 | "node_modules/path-key": { 1267 | "version": "3.1.1", 1268 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1269 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1270 | "dev": true, 1271 | "engines": { 1272 | "node": ">=8" 1273 | } 1274 | }, 1275 | "node_modules/path-parse": { 1276 | "version": "1.0.7", 1277 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1278 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1279 | "dev": true 1280 | }, 1281 | "node_modules/picomatch": { 1282 | "version": "2.3.1", 1283 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1284 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1285 | "dev": true, 1286 | "engines": { 1287 | "node": ">=8.6" 1288 | }, 1289 | "funding": { 1290 | "url": "https://github.com/sponsors/jonschlinkert" 1291 | } 1292 | }, 1293 | "node_modules/pidtree": { 1294 | "version": "0.6.0", 1295 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.6.0.tgz", 1296 | "integrity": "sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g==", 1297 | "dev": true, 1298 | "bin": { 1299 | "pidtree": "bin/pidtree.js" 1300 | }, 1301 | "engines": { 1302 | "node": ">=0.10" 1303 | } 1304 | }, 1305 | "node_modules/prettier": { 1306 | "version": "2.7.1", 1307 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.7.1.tgz", 1308 | "integrity": "sha512-ujppO+MkdPqoVINuDFDRLClm7D78qbDt0/NR+wp5FqEZOoTNAjPHWj17QRhu7geIHJfcNhRk1XVQmF8Bp3ye+g==", 1309 | "dev": true, 1310 | "bin": { 1311 | "prettier": "bin-prettier.js" 1312 | }, 1313 | "engines": { 1314 | "node": ">=10.13.0" 1315 | }, 1316 | "funding": { 1317 | "url": "https://github.com/prettier/prettier?sponsor=1" 1318 | } 1319 | }, 1320 | "node_modules/qs": { 1321 | "version": "6.11.0", 1322 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1323 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1324 | "dependencies": { 1325 | "side-channel": "^1.0.4" 1326 | }, 1327 | "engines": { 1328 | "node": ">=0.6" 1329 | }, 1330 | "funding": { 1331 | "url": "https://github.com/sponsors/ljharb" 1332 | } 1333 | }, 1334 | "node_modules/readdirp": { 1335 | "version": "3.6.0", 1336 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1337 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1338 | "dev": true, 1339 | "dependencies": { 1340 | "picomatch": "^2.2.1" 1341 | }, 1342 | "engines": { 1343 | "node": ">=8.10.0" 1344 | } 1345 | }, 1346 | "node_modules/resolve": { 1347 | "version": "1.22.0", 1348 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 1349 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 1350 | "dev": true, 1351 | "dependencies": { 1352 | "is-core-module": "^2.8.1", 1353 | "path-parse": "^1.0.7", 1354 | "supports-preserve-symlinks-flag": "^1.0.0" 1355 | }, 1356 | "bin": { 1357 | "resolve": "bin/resolve" 1358 | }, 1359 | "funding": { 1360 | "url": "https://github.com/sponsors/ljharb" 1361 | } 1362 | }, 1363 | "node_modules/restore-cursor": { 1364 | "version": "3.1.0", 1365 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1366 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1367 | "dev": true, 1368 | "dependencies": { 1369 | "onetime": "^5.1.0", 1370 | "signal-exit": "^3.0.2" 1371 | }, 1372 | "engines": { 1373 | "node": ">=8" 1374 | } 1375 | }, 1376 | "node_modules/restore-cursor/node_modules/mimic-fn": { 1377 | "version": "2.1.0", 1378 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1379 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1380 | "dev": true, 1381 | "engines": { 1382 | "node": ">=6" 1383 | } 1384 | }, 1385 | "node_modules/restore-cursor/node_modules/onetime": { 1386 | "version": "5.1.2", 1387 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 1388 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 1389 | "dev": true, 1390 | "dependencies": { 1391 | "mimic-fn": "^2.1.0" 1392 | }, 1393 | "engines": { 1394 | "node": ">=6" 1395 | }, 1396 | "funding": { 1397 | "url": "https://github.com/sponsors/sindresorhus" 1398 | } 1399 | }, 1400 | "node_modules/rfdc": { 1401 | "version": "1.3.0", 1402 | "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", 1403 | "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", 1404 | "dev": true 1405 | }, 1406 | "node_modules/rimraf": { 1407 | "version": "2.7.1", 1408 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1409 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1410 | "dev": true, 1411 | "dependencies": { 1412 | "glob": "^7.1.3" 1413 | }, 1414 | "bin": { 1415 | "rimraf": "bin.js" 1416 | } 1417 | }, 1418 | "node_modules/rxjs": { 1419 | "version": "7.5.6", 1420 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.6.tgz", 1421 | "integrity": "sha512-dnyv2/YsXhnm461G+R/Pe5bWP41Nm6LBXEYWI6eiFP4fiwx6WRI/CD0zbdVAudd9xwLEF2IDcKXLHit0FYjUzw==", 1422 | "dev": true, 1423 | "dependencies": { 1424 | "tslib": "^2.1.0" 1425 | } 1426 | }, 1427 | "node_modules/shebang-command": { 1428 | "version": "2.0.0", 1429 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1430 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1431 | "dev": true, 1432 | "dependencies": { 1433 | "shebang-regex": "^3.0.0" 1434 | }, 1435 | "engines": { 1436 | "node": ">=8" 1437 | } 1438 | }, 1439 | "node_modules/shebang-regex": { 1440 | "version": "3.0.0", 1441 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1442 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1443 | "dev": true, 1444 | "engines": { 1445 | "node": ">=8" 1446 | } 1447 | }, 1448 | "node_modules/side-channel": { 1449 | "version": "1.0.4", 1450 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1451 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1452 | "dependencies": { 1453 | "call-bind": "^1.0.0", 1454 | "get-intrinsic": "^1.0.2", 1455 | "object-inspect": "^1.9.0" 1456 | }, 1457 | "funding": { 1458 | "url": "https://github.com/sponsors/ljharb" 1459 | } 1460 | }, 1461 | "node_modules/signal-exit": { 1462 | "version": "3.0.7", 1463 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1464 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 1465 | "dev": true 1466 | }, 1467 | "node_modules/slice-ansi": { 1468 | "version": "5.0.0", 1469 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", 1470 | "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", 1471 | "dev": true, 1472 | "dependencies": { 1473 | "ansi-styles": "^6.0.0", 1474 | "is-fullwidth-code-point": "^4.0.0" 1475 | }, 1476 | "engines": { 1477 | "node": ">=12" 1478 | }, 1479 | "funding": { 1480 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1481 | } 1482 | }, 1483 | "node_modules/source-map": { 1484 | "version": "0.6.1", 1485 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1486 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1487 | "dev": true, 1488 | "engines": { 1489 | "node": ">=0.10.0" 1490 | } 1491 | }, 1492 | "node_modules/source-map-support": { 1493 | "version": "0.5.21", 1494 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1495 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1496 | "dev": true, 1497 | "dependencies": { 1498 | "buffer-from": "^1.0.0", 1499 | "source-map": "^0.6.0" 1500 | } 1501 | }, 1502 | "node_modules/string-argv": { 1503 | "version": "0.3.1", 1504 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 1505 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 1506 | "dev": true, 1507 | "engines": { 1508 | "node": ">=0.6.19" 1509 | } 1510 | }, 1511 | "node_modules/string-width": { 1512 | "version": "5.1.0", 1513 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.0.tgz", 1514 | "integrity": "sha512-7x54QnN21P+XL/v8SuNKvfgsUre6PXpN7mc77N3HlZv+f1SBRGmjxtOud2Z6FZ8DmdkD/IdjCaf9XXbnqmTZGQ==", 1515 | "dev": true, 1516 | "dependencies": { 1517 | "eastasianwidth": "^0.2.0", 1518 | "emoji-regex": "^9.2.2", 1519 | "strip-ansi": "^7.0.1" 1520 | }, 1521 | "engines": { 1522 | "node": ">=12" 1523 | }, 1524 | "funding": { 1525 | "url": "https://github.com/sponsors/sindresorhus" 1526 | } 1527 | }, 1528 | "node_modules/strip-ansi": { 1529 | "version": "7.0.1", 1530 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", 1531 | "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", 1532 | "dev": true, 1533 | "dependencies": { 1534 | "ansi-regex": "^6.0.1" 1535 | }, 1536 | "engines": { 1537 | "node": ">=12" 1538 | }, 1539 | "funding": { 1540 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 1541 | } 1542 | }, 1543 | "node_modules/strip-bom": { 1544 | "version": "3.0.0", 1545 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1546 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1547 | "dev": true, 1548 | "engines": { 1549 | "node": ">=4" 1550 | } 1551 | }, 1552 | "node_modules/strip-final-newline": { 1553 | "version": "3.0.0", 1554 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 1555 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 1556 | "dev": true, 1557 | "engines": { 1558 | "node": ">=12" 1559 | }, 1560 | "funding": { 1561 | "url": "https://github.com/sponsors/sindresorhus" 1562 | } 1563 | }, 1564 | "node_modules/strip-json-comments": { 1565 | "version": "2.0.1", 1566 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1567 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1568 | "dev": true, 1569 | "engines": { 1570 | "node": ">=0.10.0" 1571 | } 1572 | }, 1573 | "node_modules/supports-preserve-symlinks-flag": { 1574 | "version": "1.0.0", 1575 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1576 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1577 | "dev": true, 1578 | "engines": { 1579 | "node": ">= 0.4" 1580 | }, 1581 | "funding": { 1582 | "url": "https://github.com/sponsors/ljharb" 1583 | } 1584 | }, 1585 | "node_modules/through": { 1586 | "version": "2.3.8", 1587 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1588 | "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", 1589 | "dev": true 1590 | }, 1591 | "node_modules/to-regex-range": { 1592 | "version": "5.0.1", 1593 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1594 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1595 | "dev": true, 1596 | "dependencies": { 1597 | "is-number": "^7.0.0" 1598 | }, 1599 | "engines": { 1600 | "node": ">=8.0" 1601 | } 1602 | }, 1603 | "node_modules/tree-kill": { 1604 | "version": "1.2.2", 1605 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 1606 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 1607 | "dev": true, 1608 | "bin": { 1609 | "tree-kill": "cli.js" 1610 | } 1611 | }, 1612 | "node_modules/ts-node": { 1613 | "version": "10.9.1", 1614 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz", 1615 | "integrity": "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==", 1616 | "dev": true, 1617 | "dependencies": { 1618 | "@cspotcode/source-map-support": "^0.8.0", 1619 | "@tsconfig/node10": "^1.0.7", 1620 | "@tsconfig/node12": "^1.0.7", 1621 | "@tsconfig/node14": "^1.0.0", 1622 | "@tsconfig/node16": "^1.0.2", 1623 | "acorn": "^8.4.1", 1624 | "acorn-walk": "^8.1.1", 1625 | "arg": "^4.1.0", 1626 | "create-require": "^1.1.0", 1627 | "diff": "^4.0.1", 1628 | "make-error": "^1.1.1", 1629 | "v8-compile-cache-lib": "^3.0.1", 1630 | "yn": "3.1.1" 1631 | }, 1632 | "bin": { 1633 | "ts-node": "dist/bin.js", 1634 | "ts-node-cwd": "dist/bin-cwd.js", 1635 | "ts-node-esm": "dist/bin-esm.js", 1636 | "ts-node-script": "dist/bin-script.js", 1637 | "ts-node-transpile-only": "dist/bin-transpile.js", 1638 | "ts-script": "dist/bin-script-deprecated.js" 1639 | }, 1640 | "peerDependencies": { 1641 | "@swc/core": ">=1.2.50", 1642 | "@swc/wasm": ">=1.2.50", 1643 | "@types/node": "*", 1644 | "typescript": ">=2.7" 1645 | }, 1646 | "peerDependenciesMeta": { 1647 | "@swc/core": { 1648 | "optional": true 1649 | }, 1650 | "@swc/wasm": { 1651 | "optional": true 1652 | } 1653 | } 1654 | }, 1655 | "node_modules/ts-node-dev": { 1656 | "version": "2.0.0", 1657 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz", 1658 | "integrity": "sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w==", 1659 | "dev": true, 1660 | "dependencies": { 1661 | "chokidar": "^3.5.1", 1662 | "dynamic-dedupe": "^0.3.0", 1663 | "minimist": "^1.2.6", 1664 | "mkdirp": "^1.0.4", 1665 | "resolve": "^1.0.0", 1666 | "rimraf": "^2.6.1", 1667 | "source-map-support": "^0.5.12", 1668 | "tree-kill": "^1.2.2", 1669 | "ts-node": "^10.4.0", 1670 | "tsconfig": "^7.0.0" 1671 | }, 1672 | "bin": { 1673 | "ts-node-dev": "lib/bin.js", 1674 | "tsnd": "lib/bin.js" 1675 | }, 1676 | "engines": { 1677 | "node": ">=0.8.0" 1678 | }, 1679 | "peerDependencies": { 1680 | "node-notifier": "*", 1681 | "typescript": "*" 1682 | }, 1683 | "peerDependenciesMeta": { 1684 | "node-notifier": { 1685 | "optional": true 1686 | } 1687 | } 1688 | }, 1689 | "node_modules/tsconfig": { 1690 | "version": "7.0.0", 1691 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 1692 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 1693 | "dev": true, 1694 | "dependencies": { 1695 | "@types/strip-bom": "^3.0.0", 1696 | "@types/strip-json-comments": "0.0.30", 1697 | "strip-bom": "^3.0.0", 1698 | "strip-json-comments": "^2.0.0" 1699 | } 1700 | }, 1701 | "node_modules/tslib": { 1702 | "version": "2.4.0", 1703 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 1704 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==", 1705 | "dev": true 1706 | }, 1707 | "node_modules/type-fest": { 1708 | "version": "0.21.3", 1709 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 1710 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 1711 | "dev": true, 1712 | "engines": { 1713 | "node": ">=10" 1714 | }, 1715 | "funding": { 1716 | "url": "https://github.com/sponsors/sindresorhus" 1717 | } 1718 | }, 1719 | "node_modules/typescript": { 1720 | "version": "4.7.4", 1721 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz", 1722 | "integrity": "sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ==", 1723 | "dev": true, 1724 | "bin": { 1725 | "tsc": "bin/tsc", 1726 | "tsserver": "bin/tsserver" 1727 | }, 1728 | "engines": { 1729 | "node": ">=4.2.0" 1730 | } 1731 | }, 1732 | "node_modules/v8-compile-cache-lib": { 1733 | "version": "3.0.1", 1734 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 1735 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 1736 | "dev": true 1737 | }, 1738 | "node_modules/which": { 1739 | "version": "2.0.2", 1740 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1741 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1742 | "dev": true, 1743 | "dependencies": { 1744 | "isexe": "^2.0.0" 1745 | }, 1746 | "bin": { 1747 | "node-which": "bin/node-which" 1748 | }, 1749 | "engines": { 1750 | "node": ">= 8" 1751 | } 1752 | }, 1753 | "node_modules/wrap-ansi": { 1754 | "version": "7.0.0", 1755 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1756 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1757 | "dev": true, 1758 | "dependencies": { 1759 | "ansi-styles": "^4.0.0", 1760 | "string-width": "^4.1.0", 1761 | "strip-ansi": "^6.0.0" 1762 | }, 1763 | "engines": { 1764 | "node": ">=10" 1765 | }, 1766 | "funding": { 1767 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1768 | } 1769 | }, 1770 | "node_modules/wrap-ansi/node_modules/ansi-regex": { 1771 | "version": "5.0.1", 1772 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1773 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1774 | "dev": true, 1775 | "engines": { 1776 | "node": ">=8" 1777 | } 1778 | }, 1779 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 1780 | "version": "4.3.0", 1781 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1782 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1783 | "dev": true, 1784 | "dependencies": { 1785 | "color-convert": "^2.0.1" 1786 | }, 1787 | "engines": { 1788 | "node": ">=8" 1789 | }, 1790 | "funding": { 1791 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1792 | } 1793 | }, 1794 | "node_modules/wrap-ansi/node_modules/emoji-regex": { 1795 | "version": "8.0.0", 1796 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1797 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1798 | "dev": true 1799 | }, 1800 | "node_modules/wrap-ansi/node_modules/is-fullwidth-code-point": { 1801 | "version": "3.0.0", 1802 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1803 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1804 | "dev": true, 1805 | "engines": { 1806 | "node": ">=8" 1807 | } 1808 | }, 1809 | "node_modules/wrap-ansi/node_modules/string-width": { 1810 | "version": "4.2.3", 1811 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1812 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1813 | "dev": true, 1814 | "dependencies": { 1815 | "emoji-regex": "^8.0.0", 1816 | "is-fullwidth-code-point": "^3.0.0", 1817 | "strip-ansi": "^6.0.1" 1818 | }, 1819 | "engines": { 1820 | "node": ">=8" 1821 | } 1822 | }, 1823 | "node_modules/wrap-ansi/node_modules/strip-ansi": { 1824 | "version": "6.0.1", 1825 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1826 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1827 | "dev": true, 1828 | "dependencies": { 1829 | "ansi-regex": "^5.0.1" 1830 | }, 1831 | "engines": { 1832 | "node": ">=8" 1833 | } 1834 | }, 1835 | "node_modules/wrappy": { 1836 | "version": "1.0.2", 1837 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1838 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1839 | "dev": true 1840 | }, 1841 | "node_modules/ws": { 1842 | "version": "8.8.1", 1843 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz", 1844 | "integrity": "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==", 1845 | "engines": { 1846 | "node": ">=10.0.0" 1847 | }, 1848 | "peerDependencies": { 1849 | "bufferutil": "^4.0.1", 1850 | "utf-8-validate": "^5.0.2" 1851 | }, 1852 | "peerDependenciesMeta": { 1853 | "bufferutil": { 1854 | "optional": true 1855 | }, 1856 | "utf-8-validate": { 1857 | "optional": true 1858 | } 1859 | } 1860 | }, 1861 | "node_modules/xtend": { 1862 | "version": "4.0.2", 1863 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 1864 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 1865 | "dev": true, 1866 | "engines": { 1867 | "node": ">=0.4" 1868 | } 1869 | }, 1870 | "node_modules/yaml": { 1871 | "version": "2.1.1", 1872 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.1.1.tgz", 1873 | "integrity": "sha512-o96x3OPo8GjWeSLF+wOAbrPfhFOGY0W00GNaxCDv+9hkcDJEnev1yh8S7pgHF0ik6zc8sQLuL8hjHjJULZp8bw==", 1874 | "dev": true, 1875 | "engines": { 1876 | "node": ">= 14" 1877 | } 1878 | }, 1879 | "node_modules/yn": { 1880 | "version": "3.1.1", 1881 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1882 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1883 | "dev": true, 1884 | "engines": { 1885 | "node": ">=6" 1886 | } 1887 | } 1888 | }, 1889 | "dependencies": { 1890 | "@cspotcode/source-map-support": { 1891 | "version": "0.8.1", 1892 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 1893 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 1894 | "dev": true, 1895 | "requires": { 1896 | "@jridgewell/trace-mapping": "0.3.9" 1897 | } 1898 | }, 1899 | "@jridgewell/resolve-uri": { 1900 | "version": "3.1.0", 1901 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 1902 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 1903 | "dev": true 1904 | }, 1905 | "@jridgewell/sourcemap-codec": { 1906 | "version": "1.4.14", 1907 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 1908 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 1909 | "dev": true 1910 | }, 1911 | "@jridgewell/trace-mapping": { 1912 | "version": "0.3.9", 1913 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 1914 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 1915 | "dev": true, 1916 | "requires": { 1917 | "@jridgewell/resolve-uri": "^3.0.3", 1918 | "@jridgewell/sourcemap-codec": "^1.4.10" 1919 | } 1920 | }, 1921 | "@tsconfig/node10": { 1922 | "version": "1.0.9", 1923 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", 1924 | "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==", 1925 | "dev": true 1926 | }, 1927 | "@tsconfig/node12": { 1928 | "version": "1.0.11", 1929 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 1930 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 1931 | "dev": true 1932 | }, 1933 | "@tsconfig/node14": { 1934 | "version": "1.0.3", 1935 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 1936 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 1937 | "dev": true 1938 | }, 1939 | "@tsconfig/node16": { 1940 | "version": "1.0.3", 1941 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.3.tgz", 1942 | "integrity": "sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ==", 1943 | "dev": true 1944 | }, 1945 | "@types/crypto-js": { 1946 | "version": "4.1.1", 1947 | "resolved": "https://registry.npmjs.org/@types/crypto-js/-/crypto-js-4.1.1.tgz", 1948 | "integrity": "sha512-BG7fQKZ689HIoc5h+6D2Dgq1fABRa0RbBWKBd9SP/MVRVXROflpm5fhwyATX5duFmbStzyzyycPB8qUYKDH3NA==", 1949 | "dev": true 1950 | }, 1951 | "@types/node": { 1952 | "version": "18.0.6", 1953 | "resolved": "https://registry.npmjs.org/@types/node/-/node-18.0.6.tgz", 1954 | "integrity": "sha512-/xUq6H2aQm261exT6iZTMifUySEt4GR5KX8eYyY+C4MSNPqSh9oNIP7tz2GLKTlFaiBbgZNxffoR3CVRG+cljw==", 1955 | "dev": true 1956 | }, 1957 | "@types/qs": { 1958 | "version": "6.9.7", 1959 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", 1960 | "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==", 1961 | "dev": true 1962 | }, 1963 | "@types/strip-bom": { 1964 | "version": "3.0.0", 1965 | "resolved": "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz", 1966 | "integrity": "sha1-FKjsOVbC6B7bdSB5CuzyHCkK69I=", 1967 | "dev": true 1968 | }, 1969 | "@types/strip-json-comments": { 1970 | "version": "0.0.30", 1971 | "resolved": "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz", 1972 | "integrity": "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==", 1973 | "dev": true 1974 | }, 1975 | "@types/ws": { 1976 | "version": "8.5.3", 1977 | "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz", 1978 | "integrity": "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==", 1979 | "dev": true, 1980 | "requires": { 1981 | "@types/node": "*" 1982 | } 1983 | }, 1984 | "acorn": { 1985 | "version": "8.8.0", 1986 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.0.tgz", 1987 | "integrity": "sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w==", 1988 | "dev": true 1989 | }, 1990 | "acorn-walk": { 1991 | "version": "8.2.0", 1992 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", 1993 | "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", 1994 | "dev": true 1995 | }, 1996 | "aggregate-error": { 1997 | "version": "3.1.0", 1998 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 1999 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 2000 | "dev": true, 2001 | "requires": { 2002 | "clean-stack": "^2.0.0", 2003 | "indent-string": "^4.0.0" 2004 | } 2005 | }, 2006 | "ansi-escapes": { 2007 | "version": "4.3.2", 2008 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 2009 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 2010 | "dev": true, 2011 | "requires": { 2012 | "type-fest": "^0.21.3" 2013 | } 2014 | }, 2015 | "ansi-regex": { 2016 | "version": "6.0.1", 2017 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 2018 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 2019 | "dev": true 2020 | }, 2021 | "ansi-styles": { 2022 | "version": "6.1.0", 2023 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.1.0.tgz", 2024 | "integrity": "sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ==", 2025 | "dev": true 2026 | }, 2027 | "anymatch": { 2028 | "version": "3.1.2", 2029 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 2030 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 2031 | "dev": true, 2032 | "requires": { 2033 | "normalize-path": "^3.0.0", 2034 | "picomatch": "^2.0.4" 2035 | } 2036 | }, 2037 | "arg": { 2038 | "version": "4.1.3", 2039 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 2040 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 2041 | "dev": true 2042 | }, 2043 | "astral-regex": { 2044 | "version": "2.0.0", 2045 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 2046 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 2047 | "dev": true 2048 | }, 2049 | "asynckit": { 2050 | "version": "0.4.0", 2051 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 2052 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 2053 | }, 2054 | "axios": { 2055 | "version": "0.27.2", 2056 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.27.2.tgz", 2057 | "integrity": "sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ==", 2058 | "requires": { 2059 | "follow-redirects": "^1.14.9", 2060 | "form-data": "^4.0.0" 2061 | } 2062 | }, 2063 | "balanced-match": { 2064 | "version": "1.0.2", 2065 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2066 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2067 | "dev": true 2068 | }, 2069 | "binary-extensions": { 2070 | "version": "2.2.0", 2071 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2072 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2073 | "dev": true 2074 | }, 2075 | "brace-expansion": { 2076 | "version": "1.1.11", 2077 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2078 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2079 | "dev": true, 2080 | "requires": { 2081 | "balanced-match": "^1.0.0", 2082 | "concat-map": "0.0.1" 2083 | } 2084 | }, 2085 | "braces": { 2086 | "version": "3.0.2", 2087 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2088 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2089 | "dev": true, 2090 | "requires": { 2091 | "fill-range": "^7.0.1" 2092 | } 2093 | }, 2094 | "buffer-from": { 2095 | "version": "1.1.2", 2096 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 2097 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 2098 | "dev": true 2099 | }, 2100 | "call-bind": { 2101 | "version": "1.0.2", 2102 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2103 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2104 | "requires": { 2105 | "function-bind": "^1.1.1", 2106 | "get-intrinsic": "^1.0.2" 2107 | } 2108 | }, 2109 | "chokidar": { 2110 | "version": "3.5.3", 2111 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 2112 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 2113 | "dev": true, 2114 | "requires": { 2115 | "anymatch": "~3.1.2", 2116 | "braces": "~3.0.2", 2117 | "fsevents": "~2.3.2", 2118 | "glob-parent": "~5.1.2", 2119 | "is-binary-path": "~2.1.0", 2120 | "is-glob": "~4.0.1", 2121 | "normalize-path": "~3.0.0", 2122 | "readdirp": "~3.6.0" 2123 | } 2124 | }, 2125 | "clean-stack": { 2126 | "version": "2.2.0", 2127 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 2128 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 2129 | "dev": true 2130 | }, 2131 | "cli-cursor": { 2132 | "version": "3.1.0", 2133 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 2134 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 2135 | "dev": true, 2136 | "requires": { 2137 | "restore-cursor": "^3.1.0" 2138 | } 2139 | }, 2140 | "cli-truncate": { 2141 | "version": "3.1.0", 2142 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-3.1.0.tgz", 2143 | "integrity": "sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==", 2144 | "dev": true, 2145 | "requires": { 2146 | "slice-ansi": "^5.0.0", 2147 | "string-width": "^5.0.0" 2148 | } 2149 | }, 2150 | "color-convert": { 2151 | "version": "2.0.1", 2152 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2153 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2154 | "dev": true, 2155 | "requires": { 2156 | "color-name": "~1.1.4" 2157 | } 2158 | }, 2159 | "color-name": { 2160 | "version": "1.1.4", 2161 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2162 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2163 | "dev": true 2164 | }, 2165 | "colorette": { 2166 | "version": "2.0.19", 2167 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.19.tgz", 2168 | "integrity": "sha512-3tlv/dIP7FWvj3BsbHrGLJ6l/oKh1O3TcgBqMn+yyCagOxc23fyzDS6HypQbgxWbkpDnf52p1LuR4eWDQ/K9WQ==", 2169 | "dev": true 2170 | }, 2171 | "combined-stream": { 2172 | "version": "1.0.8", 2173 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 2174 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 2175 | "requires": { 2176 | "delayed-stream": "~1.0.0" 2177 | } 2178 | }, 2179 | "commander": { 2180 | "version": "9.4.0", 2181 | "resolved": "https://registry.npmjs.org/commander/-/commander-9.4.0.tgz", 2182 | "integrity": "sha512-sRPT+umqkz90UA8M1yqYfnHlZA7fF6nSphDtxeywPZ49ysjxDQybzk13CL+mXekDRG92skbcqCLVovuCusNmFw==", 2183 | "dev": true 2184 | }, 2185 | "concat-map": { 2186 | "version": "0.0.1", 2187 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2188 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2189 | "dev": true 2190 | }, 2191 | "create-require": { 2192 | "version": "1.1.1", 2193 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 2194 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 2195 | "dev": true 2196 | }, 2197 | "cross-spawn": { 2198 | "version": "7.0.3", 2199 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2200 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2201 | "dev": true, 2202 | "requires": { 2203 | "path-key": "^3.1.0", 2204 | "shebang-command": "^2.0.0", 2205 | "which": "^2.0.1" 2206 | } 2207 | }, 2208 | "crypto-js": { 2209 | "version": "4.1.1", 2210 | "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-4.1.1.tgz", 2211 | "integrity": "sha512-o2JlM7ydqd3Qk9CA0L4NL6mTzU2sdx96a+oOfPu8Mkl/PK51vSyoi8/rQ8NknZtk44vq15lmhAj9CIAGwgeWKw==" 2212 | }, 2213 | "debug": { 2214 | "version": "4.3.4", 2215 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2216 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2217 | "dev": true, 2218 | "requires": { 2219 | "ms": "2.1.2" 2220 | } 2221 | }, 2222 | "delayed-stream": { 2223 | "version": "1.0.0", 2224 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 2225 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" 2226 | }, 2227 | "diff": { 2228 | "version": "4.0.2", 2229 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2230 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2231 | "dev": true 2232 | }, 2233 | "dotenv": { 2234 | "version": "16.0.1", 2235 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz", 2236 | "integrity": "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ==", 2237 | "dev": true 2238 | }, 2239 | "dynamic-dedupe": { 2240 | "version": "0.3.0", 2241 | "resolved": "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz", 2242 | "integrity": "sha1-BuRMIj9eTpTXjvnbI6ZRXOL5YqE=", 2243 | "dev": true, 2244 | "requires": { 2245 | "xtend": "^4.0.0" 2246 | } 2247 | }, 2248 | "eastasianwidth": { 2249 | "version": "0.2.0", 2250 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 2251 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 2252 | "dev": true 2253 | }, 2254 | "emoji-regex": { 2255 | "version": "9.2.2", 2256 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 2257 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 2258 | "dev": true 2259 | }, 2260 | "execa": { 2261 | "version": "6.1.0", 2262 | "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", 2263 | "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", 2264 | "dev": true, 2265 | "requires": { 2266 | "cross-spawn": "^7.0.3", 2267 | "get-stream": "^6.0.1", 2268 | "human-signals": "^3.0.1", 2269 | "is-stream": "^3.0.0", 2270 | "merge-stream": "^2.0.0", 2271 | "npm-run-path": "^5.1.0", 2272 | "onetime": "^6.0.0", 2273 | "signal-exit": "^3.0.7", 2274 | "strip-final-newline": "^3.0.0" 2275 | } 2276 | }, 2277 | "fill-range": { 2278 | "version": "7.0.1", 2279 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2280 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2281 | "dev": true, 2282 | "requires": { 2283 | "to-regex-range": "^5.0.1" 2284 | } 2285 | }, 2286 | "follow-redirects": { 2287 | "version": "1.15.1", 2288 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.1.tgz", 2289 | "integrity": "sha512-yLAMQs+k0b2m7cVxpS1VKJVvoz7SS9Td1zss3XRwXj+ZDH00RJgnuLx7E44wx02kQLrdM3aOOy+FpzS7+8OizA==" 2290 | }, 2291 | "form-data": { 2292 | "version": "4.0.0", 2293 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 2294 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 2295 | "requires": { 2296 | "asynckit": "^0.4.0", 2297 | "combined-stream": "^1.0.8", 2298 | "mime-types": "^2.1.12" 2299 | } 2300 | }, 2301 | "fs.realpath": { 2302 | "version": "1.0.0", 2303 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2304 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2305 | "dev": true 2306 | }, 2307 | "fsevents": { 2308 | "version": "2.3.2", 2309 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2310 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2311 | "dev": true, 2312 | "optional": true 2313 | }, 2314 | "function-bind": { 2315 | "version": "1.1.1", 2316 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2317 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2318 | }, 2319 | "get-intrinsic": { 2320 | "version": "1.1.1", 2321 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 2322 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 2323 | "requires": { 2324 | "function-bind": "^1.1.1", 2325 | "has": "^1.0.3", 2326 | "has-symbols": "^1.0.1" 2327 | } 2328 | }, 2329 | "get-stream": { 2330 | "version": "6.0.1", 2331 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 2332 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 2333 | "dev": true 2334 | }, 2335 | "glob": { 2336 | "version": "7.2.0", 2337 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 2338 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 2339 | "dev": true, 2340 | "requires": { 2341 | "fs.realpath": "^1.0.0", 2342 | "inflight": "^1.0.4", 2343 | "inherits": "2", 2344 | "minimatch": "^3.0.4", 2345 | "once": "^1.3.0", 2346 | "path-is-absolute": "^1.0.0" 2347 | } 2348 | }, 2349 | "glob-parent": { 2350 | "version": "5.1.2", 2351 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2352 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2353 | "dev": true, 2354 | "requires": { 2355 | "is-glob": "^4.0.1" 2356 | } 2357 | }, 2358 | "has": { 2359 | "version": "1.0.3", 2360 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2361 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2362 | "requires": { 2363 | "function-bind": "^1.1.1" 2364 | } 2365 | }, 2366 | "has-symbols": { 2367 | "version": "1.0.2", 2368 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 2369 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==" 2370 | }, 2371 | "human-signals": { 2372 | "version": "3.0.1", 2373 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", 2374 | "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", 2375 | "dev": true 2376 | }, 2377 | "husky": { 2378 | "version": "8.0.1", 2379 | "resolved": "https://registry.npmjs.org/husky/-/husky-8.0.1.tgz", 2380 | "integrity": "sha512-xs7/chUH/CKdOCs7Zy0Aev9e/dKOMZf3K1Az1nar3tzlv0jfqnYtu235bstsWTmXOR0EfINrPa97yy4Lz6RiKw==", 2381 | "dev": true 2382 | }, 2383 | "indent-string": { 2384 | "version": "4.0.0", 2385 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 2386 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 2387 | "dev": true 2388 | }, 2389 | "inflight": { 2390 | "version": "1.0.6", 2391 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2392 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2393 | "dev": true, 2394 | "requires": { 2395 | "once": "^1.3.0", 2396 | "wrappy": "1" 2397 | } 2398 | }, 2399 | "inherits": { 2400 | "version": "2.0.4", 2401 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2402 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2403 | "dev": true 2404 | }, 2405 | "is-binary-path": { 2406 | "version": "2.1.0", 2407 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2408 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2409 | "dev": true, 2410 | "requires": { 2411 | "binary-extensions": "^2.0.0" 2412 | } 2413 | }, 2414 | "is-core-module": { 2415 | "version": "2.8.1", 2416 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 2417 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 2418 | "dev": true, 2419 | "requires": { 2420 | "has": "^1.0.3" 2421 | } 2422 | }, 2423 | "is-extglob": { 2424 | "version": "2.1.1", 2425 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2426 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2427 | "dev": true 2428 | }, 2429 | "is-fullwidth-code-point": { 2430 | "version": "4.0.0", 2431 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", 2432 | "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", 2433 | "dev": true 2434 | }, 2435 | "is-glob": { 2436 | "version": "4.0.3", 2437 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2438 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2439 | "dev": true, 2440 | "requires": { 2441 | "is-extglob": "^2.1.1" 2442 | } 2443 | }, 2444 | "is-number": { 2445 | "version": "7.0.0", 2446 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2447 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2448 | "dev": true 2449 | }, 2450 | "is-stream": { 2451 | "version": "3.0.0", 2452 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 2453 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 2454 | "dev": true 2455 | }, 2456 | "isexe": { 2457 | "version": "2.0.0", 2458 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2459 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2460 | "dev": true 2461 | }, 2462 | "lilconfig": { 2463 | "version": "2.0.5", 2464 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.5.tgz", 2465 | "integrity": "sha512-xaYmXZtTHPAw5m+xLN8ab9C+3a8YmV3asNSPOATITbtwrfbwaLJj8h66H1WMIpALCkqsIzK3h7oQ+PdX+LQ9Eg==", 2466 | "dev": true 2467 | }, 2468 | "lint-staged": { 2469 | "version": "13.0.3", 2470 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-13.0.3.tgz", 2471 | "integrity": "sha512-9hmrwSCFroTSYLjflGI8Uk+GWAwMB4OlpU4bMJEAT5d/llQwtYKoim4bLOyLCuWFAhWEupE0vkIFqtw/WIsPug==", 2472 | "dev": true, 2473 | "requires": { 2474 | "cli-truncate": "^3.1.0", 2475 | "colorette": "^2.0.17", 2476 | "commander": "^9.3.0", 2477 | "debug": "^4.3.4", 2478 | "execa": "^6.1.0", 2479 | "lilconfig": "2.0.5", 2480 | "listr2": "^4.0.5", 2481 | "micromatch": "^4.0.5", 2482 | "normalize-path": "^3.0.0", 2483 | "object-inspect": "^1.12.2", 2484 | "pidtree": "^0.6.0", 2485 | "string-argv": "^0.3.1", 2486 | "yaml": "^2.1.1" 2487 | } 2488 | }, 2489 | "listr2": { 2490 | "version": "4.0.5", 2491 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-4.0.5.tgz", 2492 | "integrity": "sha512-juGHV1doQdpNT3GSTs9IUN43QJb7KHdF9uqg7Vufs/tG9VTzpFphqF4pm/ICdAABGQxsyNn9CiYA3StkI6jpwA==", 2493 | "dev": true, 2494 | "requires": { 2495 | "cli-truncate": "^2.1.0", 2496 | "colorette": "^2.0.16", 2497 | "log-update": "^4.0.0", 2498 | "p-map": "^4.0.0", 2499 | "rfdc": "^1.3.0", 2500 | "rxjs": "^7.5.5", 2501 | "through": "^2.3.8", 2502 | "wrap-ansi": "^7.0.0" 2503 | }, 2504 | "dependencies": { 2505 | "ansi-regex": { 2506 | "version": "5.0.1", 2507 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2508 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2509 | "dev": true 2510 | }, 2511 | "ansi-styles": { 2512 | "version": "4.3.0", 2513 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2514 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2515 | "dev": true, 2516 | "requires": { 2517 | "color-convert": "^2.0.1" 2518 | } 2519 | }, 2520 | "cli-truncate": { 2521 | "version": "2.1.0", 2522 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 2523 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 2524 | "dev": true, 2525 | "requires": { 2526 | "slice-ansi": "^3.0.0", 2527 | "string-width": "^4.2.0" 2528 | } 2529 | }, 2530 | "emoji-regex": { 2531 | "version": "8.0.0", 2532 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2533 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2534 | "dev": true 2535 | }, 2536 | "is-fullwidth-code-point": { 2537 | "version": "3.0.0", 2538 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2539 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2540 | "dev": true 2541 | }, 2542 | "slice-ansi": { 2543 | "version": "3.0.0", 2544 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 2545 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 2546 | "dev": true, 2547 | "requires": { 2548 | "ansi-styles": "^4.0.0", 2549 | "astral-regex": "^2.0.0", 2550 | "is-fullwidth-code-point": "^3.0.0" 2551 | } 2552 | }, 2553 | "string-width": { 2554 | "version": "4.2.3", 2555 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2556 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2557 | "dev": true, 2558 | "requires": { 2559 | "emoji-regex": "^8.0.0", 2560 | "is-fullwidth-code-point": "^3.0.0", 2561 | "strip-ansi": "^6.0.1" 2562 | } 2563 | }, 2564 | "strip-ansi": { 2565 | "version": "6.0.1", 2566 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2567 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2568 | "dev": true, 2569 | "requires": { 2570 | "ansi-regex": "^5.0.1" 2571 | } 2572 | } 2573 | } 2574 | }, 2575 | "log-update": { 2576 | "version": "4.0.0", 2577 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 2578 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 2579 | "dev": true, 2580 | "requires": { 2581 | "ansi-escapes": "^4.3.0", 2582 | "cli-cursor": "^3.1.0", 2583 | "slice-ansi": "^4.0.0", 2584 | "wrap-ansi": "^6.2.0" 2585 | }, 2586 | "dependencies": { 2587 | "ansi-regex": { 2588 | "version": "5.0.1", 2589 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2590 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2591 | "dev": true 2592 | }, 2593 | "ansi-styles": { 2594 | "version": "4.3.0", 2595 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2596 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2597 | "dev": true, 2598 | "requires": { 2599 | "color-convert": "^2.0.1" 2600 | } 2601 | }, 2602 | "emoji-regex": { 2603 | "version": "8.0.0", 2604 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2605 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2606 | "dev": true 2607 | }, 2608 | "is-fullwidth-code-point": { 2609 | "version": "3.0.0", 2610 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2611 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2612 | "dev": true 2613 | }, 2614 | "slice-ansi": { 2615 | "version": "4.0.0", 2616 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 2617 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 2618 | "dev": true, 2619 | "requires": { 2620 | "ansi-styles": "^4.0.0", 2621 | "astral-regex": "^2.0.0", 2622 | "is-fullwidth-code-point": "^3.0.0" 2623 | } 2624 | }, 2625 | "string-width": { 2626 | "version": "4.2.3", 2627 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2628 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2629 | "dev": true, 2630 | "requires": { 2631 | "emoji-regex": "^8.0.0", 2632 | "is-fullwidth-code-point": "^3.0.0", 2633 | "strip-ansi": "^6.0.1" 2634 | } 2635 | }, 2636 | "strip-ansi": { 2637 | "version": "6.0.1", 2638 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2639 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2640 | "dev": true, 2641 | "requires": { 2642 | "ansi-regex": "^5.0.1" 2643 | } 2644 | }, 2645 | "wrap-ansi": { 2646 | "version": "6.2.0", 2647 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 2648 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 2649 | "dev": true, 2650 | "requires": { 2651 | "ansi-styles": "^4.0.0", 2652 | "string-width": "^4.1.0", 2653 | "strip-ansi": "^6.0.0" 2654 | } 2655 | } 2656 | } 2657 | }, 2658 | "make-error": { 2659 | "version": "1.3.6", 2660 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 2661 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 2662 | "dev": true 2663 | }, 2664 | "merge-stream": { 2665 | "version": "2.0.0", 2666 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2667 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2668 | "dev": true 2669 | }, 2670 | "micromatch": { 2671 | "version": "4.0.5", 2672 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 2673 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 2674 | "dev": true, 2675 | "requires": { 2676 | "braces": "^3.0.2", 2677 | "picomatch": "^2.3.1" 2678 | } 2679 | }, 2680 | "mime-db": { 2681 | "version": "1.52.0", 2682 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2683 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 2684 | }, 2685 | "mime-types": { 2686 | "version": "2.1.35", 2687 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2688 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2689 | "requires": { 2690 | "mime-db": "1.52.0" 2691 | } 2692 | }, 2693 | "mimic-fn": { 2694 | "version": "4.0.0", 2695 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 2696 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 2697 | "dev": true 2698 | }, 2699 | "minimatch": { 2700 | "version": "3.0.4", 2701 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2702 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2703 | "dev": true, 2704 | "requires": { 2705 | "brace-expansion": "^1.1.7" 2706 | } 2707 | }, 2708 | "minimist": { 2709 | "version": "1.2.6", 2710 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 2711 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 2712 | "dev": true 2713 | }, 2714 | "mkdirp": { 2715 | "version": "1.0.4", 2716 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2717 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 2718 | "dev": true 2719 | }, 2720 | "ms": { 2721 | "version": "2.1.2", 2722 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2723 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2724 | "dev": true 2725 | }, 2726 | "normalize-path": { 2727 | "version": "3.0.0", 2728 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2729 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2730 | "dev": true 2731 | }, 2732 | "npm-run-path": { 2733 | "version": "5.1.0", 2734 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", 2735 | "integrity": "sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==", 2736 | "dev": true, 2737 | "requires": { 2738 | "path-key": "^4.0.0" 2739 | }, 2740 | "dependencies": { 2741 | "path-key": { 2742 | "version": "4.0.0", 2743 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 2744 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 2745 | "dev": true 2746 | } 2747 | } 2748 | }, 2749 | "object-inspect": { 2750 | "version": "1.12.2", 2751 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 2752 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==" 2753 | }, 2754 | "once": { 2755 | "version": "1.4.0", 2756 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2757 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2758 | "dev": true, 2759 | "requires": { 2760 | "wrappy": "1" 2761 | } 2762 | }, 2763 | "onetime": { 2764 | "version": "6.0.0", 2765 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 2766 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 2767 | "dev": true, 2768 | "requires": { 2769 | "mimic-fn": "^4.0.0" 2770 | } 2771 | }, 2772 | "p-map": { 2773 | "version": "4.0.0", 2774 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 2775 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 2776 | "dev": true, 2777 | "requires": { 2778 | "aggregate-error": "^3.0.0" 2779 | } 2780 | }, 2781 | "path-is-absolute": { 2782 | "version": "1.0.1", 2783 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2784 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2785 | "dev": true 2786 | }, 2787 | "path-key": { 2788 | "version": "3.1.1", 2789 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2790 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2791 | "dev": true 2792 | }, 2793 | "path-parse": { 2794 | "version": "1.0.7", 2795 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2796 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2797 | "dev": true 2798 | }, 2799 | "picomatch": { 2800 | "version": "2.3.1", 2801 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2802 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2803 | "dev": true 2804 | }, 2805 | "pidtree": { 2806 | "version": "0.6.0", 2807 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.6.0.tgz", 2808 | "integrity": "sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g==", 2809 | "dev": true 2810 | }, 2811 | "prettier": { 2812 | "version": "2.7.1", 2813 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.7.1.tgz", 2814 | "integrity": "sha512-ujppO+MkdPqoVINuDFDRLClm7D78qbDt0/NR+wp5FqEZOoTNAjPHWj17QRhu7geIHJfcNhRk1XVQmF8Bp3ye+g==", 2815 | "dev": true 2816 | }, 2817 | "qs": { 2818 | "version": "6.11.0", 2819 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 2820 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 2821 | "requires": { 2822 | "side-channel": "^1.0.4" 2823 | } 2824 | }, 2825 | "readdirp": { 2826 | "version": "3.6.0", 2827 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2828 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2829 | "dev": true, 2830 | "requires": { 2831 | "picomatch": "^2.2.1" 2832 | } 2833 | }, 2834 | "resolve": { 2835 | "version": "1.22.0", 2836 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 2837 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 2838 | "dev": true, 2839 | "requires": { 2840 | "is-core-module": "^2.8.1", 2841 | "path-parse": "^1.0.7", 2842 | "supports-preserve-symlinks-flag": "^1.0.0" 2843 | } 2844 | }, 2845 | "restore-cursor": { 2846 | "version": "3.1.0", 2847 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 2848 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 2849 | "dev": true, 2850 | "requires": { 2851 | "onetime": "^5.1.0", 2852 | "signal-exit": "^3.0.2" 2853 | }, 2854 | "dependencies": { 2855 | "mimic-fn": { 2856 | "version": "2.1.0", 2857 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2858 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2859 | "dev": true 2860 | }, 2861 | "onetime": { 2862 | "version": "5.1.2", 2863 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 2864 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 2865 | "dev": true, 2866 | "requires": { 2867 | "mimic-fn": "^2.1.0" 2868 | } 2869 | } 2870 | } 2871 | }, 2872 | "rfdc": { 2873 | "version": "1.3.0", 2874 | "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", 2875 | "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", 2876 | "dev": true 2877 | }, 2878 | "rimraf": { 2879 | "version": "2.7.1", 2880 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2881 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2882 | "dev": true, 2883 | "requires": { 2884 | "glob": "^7.1.3" 2885 | } 2886 | }, 2887 | "rxjs": { 2888 | "version": "7.5.6", 2889 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.6.tgz", 2890 | "integrity": "sha512-dnyv2/YsXhnm461G+R/Pe5bWP41Nm6LBXEYWI6eiFP4fiwx6WRI/CD0zbdVAudd9xwLEF2IDcKXLHit0FYjUzw==", 2891 | "dev": true, 2892 | "requires": { 2893 | "tslib": "^2.1.0" 2894 | } 2895 | }, 2896 | "shebang-command": { 2897 | "version": "2.0.0", 2898 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2899 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2900 | "dev": true, 2901 | "requires": { 2902 | "shebang-regex": "^3.0.0" 2903 | } 2904 | }, 2905 | "shebang-regex": { 2906 | "version": "3.0.0", 2907 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2908 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2909 | "dev": true 2910 | }, 2911 | "side-channel": { 2912 | "version": "1.0.4", 2913 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2914 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2915 | "requires": { 2916 | "call-bind": "^1.0.0", 2917 | "get-intrinsic": "^1.0.2", 2918 | "object-inspect": "^1.9.0" 2919 | } 2920 | }, 2921 | "signal-exit": { 2922 | "version": "3.0.7", 2923 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 2924 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 2925 | "dev": true 2926 | }, 2927 | "slice-ansi": { 2928 | "version": "5.0.0", 2929 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", 2930 | "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", 2931 | "dev": true, 2932 | "requires": { 2933 | "ansi-styles": "^6.0.0", 2934 | "is-fullwidth-code-point": "^4.0.0" 2935 | } 2936 | }, 2937 | "source-map": { 2938 | "version": "0.6.1", 2939 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2940 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2941 | "dev": true 2942 | }, 2943 | "source-map-support": { 2944 | "version": "0.5.21", 2945 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 2946 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 2947 | "dev": true, 2948 | "requires": { 2949 | "buffer-from": "^1.0.0", 2950 | "source-map": "^0.6.0" 2951 | } 2952 | }, 2953 | "string-argv": { 2954 | "version": "0.3.1", 2955 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 2956 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 2957 | "dev": true 2958 | }, 2959 | "string-width": { 2960 | "version": "5.1.0", 2961 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.0.tgz", 2962 | "integrity": "sha512-7x54QnN21P+XL/v8SuNKvfgsUre6PXpN7mc77N3HlZv+f1SBRGmjxtOud2Z6FZ8DmdkD/IdjCaf9XXbnqmTZGQ==", 2963 | "dev": true, 2964 | "requires": { 2965 | "eastasianwidth": "^0.2.0", 2966 | "emoji-regex": "^9.2.2", 2967 | "strip-ansi": "^7.0.1" 2968 | } 2969 | }, 2970 | "strip-ansi": { 2971 | "version": "7.0.1", 2972 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", 2973 | "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", 2974 | "dev": true, 2975 | "requires": { 2976 | "ansi-regex": "^6.0.1" 2977 | } 2978 | }, 2979 | "strip-bom": { 2980 | "version": "3.0.0", 2981 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2982 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2983 | "dev": true 2984 | }, 2985 | "strip-final-newline": { 2986 | "version": "3.0.0", 2987 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 2988 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 2989 | "dev": true 2990 | }, 2991 | "strip-json-comments": { 2992 | "version": "2.0.1", 2993 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2994 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2995 | "dev": true 2996 | }, 2997 | "supports-preserve-symlinks-flag": { 2998 | "version": "1.0.0", 2999 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3000 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3001 | "dev": true 3002 | }, 3003 | "through": { 3004 | "version": "2.3.8", 3005 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3006 | "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", 3007 | "dev": true 3008 | }, 3009 | "to-regex-range": { 3010 | "version": "5.0.1", 3011 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3012 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3013 | "dev": true, 3014 | "requires": { 3015 | "is-number": "^7.0.0" 3016 | } 3017 | }, 3018 | "tree-kill": { 3019 | "version": "1.2.2", 3020 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", 3021 | "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", 3022 | "dev": true 3023 | }, 3024 | "ts-node": { 3025 | "version": "10.9.1", 3026 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz", 3027 | "integrity": "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==", 3028 | "dev": true, 3029 | "requires": { 3030 | "@cspotcode/source-map-support": "^0.8.0", 3031 | "@tsconfig/node10": "^1.0.7", 3032 | "@tsconfig/node12": "^1.0.7", 3033 | "@tsconfig/node14": "^1.0.0", 3034 | "@tsconfig/node16": "^1.0.2", 3035 | "acorn": "^8.4.1", 3036 | "acorn-walk": "^8.1.1", 3037 | "arg": "^4.1.0", 3038 | "create-require": "^1.1.0", 3039 | "diff": "^4.0.1", 3040 | "make-error": "^1.1.1", 3041 | "v8-compile-cache-lib": "^3.0.1", 3042 | "yn": "3.1.1" 3043 | } 3044 | }, 3045 | "ts-node-dev": { 3046 | "version": "2.0.0", 3047 | "resolved": "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz", 3048 | "integrity": "sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w==", 3049 | "dev": true, 3050 | "requires": { 3051 | "chokidar": "^3.5.1", 3052 | "dynamic-dedupe": "^0.3.0", 3053 | "minimist": "^1.2.6", 3054 | "mkdirp": "^1.0.4", 3055 | "resolve": "^1.0.0", 3056 | "rimraf": "^2.6.1", 3057 | "source-map-support": "^0.5.12", 3058 | "tree-kill": "^1.2.2", 3059 | "ts-node": "^10.4.0", 3060 | "tsconfig": "^7.0.0" 3061 | } 3062 | }, 3063 | "tsconfig": { 3064 | "version": "7.0.0", 3065 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz", 3066 | "integrity": "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==", 3067 | "dev": true, 3068 | "requires": { 3069 | "@types/strip-bom": "^3.0.0", 3070 | "@types/strip-json-comments": "0.0.30", 3071 | "strip-bom": "^3.0.0", 3072 | "strip-json-comments": "^2.0.0" 3073 | } 3074 | }, 3075 | "tslib": { 3076 | "version": "2.4.0", 3077 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 3078 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==", 3079 | "dev": true 3080 | }, 3081 | "type-fest": { 3082 | "version": "0.21.3", 3083 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3084 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3085 | "dev": true 3086 | }, 3087 | "typescript": { 3088 | "version": "4.7.4", 3089 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz", 3090 | "integrity": "sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ==", 3091 | "dev": true 3092 | }, 3093 | "v8-compile-cache-lib": { 3094 | "version": "3.0.1", 3095 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 3096 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 3097 | "dev": true 3098 | }, 3099 | "which": { 3100 | "version": "2.0.2", 3101 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3102 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3103 | "dev": true, 3104 | "requires": { 3105 | "isexe": "^2.0.0" 3106 | } 3107 | }, 3108 | "wrap-ansi": { 3109 | "version": "7.0.0", 3110 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3111 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3112 | "dev": true, 3113 | "requires": { 3114 | "ansi-styles": "^4.0.0", 3115 | "string-width": "^4.1.0", 3116 | "strip-ansi": "^6.0.0" 3117 | }, 3118 | "dependencies": { 3119 | "ansi-regex": { 3120 | "version": "5.0.1", 3121 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 3122 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 3123 | "dev": true 3124 | }, 3125 | "ansi-styles": { 3126 | "version": "4.3.0", 3127 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3128 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3129 | "dev": true, 3130 | "requires": { 3131 | "color-convert": "^2.0.1" 3132 | } 3133 | }, 3134 | "emoji-regex": { 3135 | "version": "8.0.0", 3136 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3137 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3138 | "dev": true 3139 | }, 3140 | "is-fullwidth-code-point": { 3141 | "version": "3.0.0", 3142 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3143 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3144 | "dev": true 3145 | }, 3146 | "string-width": { 3147 | "version": "4.2.3", 3148 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3149 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3150 | "dev": true, 3151 | "requires": { 3152 | "emoji-regex": "^8.0.0", 3153 | "is-fullwidth-code-point": "^3.0.0", 3154 | "strip-ansi": "^6.0.1" 3155 | } 3156 | }, 3157 | "strip-ansi": { 3158 | "version": "6.0.1", 3159 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3160 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3161 | "dev": true, 3162 | "requires": { 3163 | "ansi-regex": "^5.0.1" 3164 | } 3165 | } 3166 | } 3167 | }, 3168 | "wrappy": { 3169 | "version": "1.0.2", 3170 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3171 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3172 | "dev": true 3173 | }, 3174 | "ws": { 3175 | "version": "8.8.1", 3176 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz", 3177 | "integrity": "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==", 3178 | "requires": {} 3179 | }, 3180 | "xtend": { 3181 | "version": "4.0.2", 3182 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 3183 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 3184 | "dev": true 3185 | }, 3186 | "yaml": { 3187 | "version": "2.1.1", 3188 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.1.1.tgz", 3189 | "integrity": "sha512-o96x3OPo8GjWeSLF+wOAbrPfhFOGY0W00GNaxCDv+9hkcDJEnev1yh8S7pgHF0ik6zc8sQLuL8hjHjJULZp8bw==", 3190 | "dev": true 3191 | }, 3192 | "yn": { 3193 | "version": "3.1.1", 3194 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 3195 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 3196 | "dev": true 3197 | } 3198 | } 3199 | } 3200 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "3commas-typescript", 3 | "version": "1.3.6", 4 | "description": "TypeScript 3Commas API client", 5 | "repository": { 6 | "type": "git", 7 | "url": "https://github.com/kirosc/3commas-typescript" 8 | }, 9 | "bugs": { 10 | "url": "https://github.com/kirosc/3commas-typescript/issues" 11 | }, 12 | "homepage": "https://github.com/kirosc/3commas-typescript", 13 | "main": "dist/index.js", 14 | "types": "dist/index.d.ts", 15 | "scripts": { 16 | "build": "rm -rf dist && tsc", 17 | "prepare": "husky install", 18 | "dev": "ts-node-dev --respawn src/index.ts", 19 | "prettier": "prettier --write .", 20 | "publish:npm": "npm run build && npm publish" 21 | }, 22 | "keywords": [ 23 | "typescript", 24 | "3commas" 25 | ], 26 | "author": "Kiros Choi", 27 | "license": "MIT", 28 | "devDependencies": { 29 | "@types/crypto-js": "^4.1.1", 30 | "@types/node": "^18.0.6", 31 | "@types/qs": "^6.9.7", 32 | "@types/ws": "^8.5.3", 33 | "dotenv": "^16.0.1", 34 | "husky": "^8.0.1", 35 | "lint-staged": "^13.0.3", 36 | "prettier": "^2.7.1", 37 | "ts-node-dev": "^2.0.0", 38 | "typescript": "^4.7.4" 39 | }, 40 | "dependencies": { 41 | "axios": "^0.27.2", 42 | "crypto-js": "^4.1.1", 43 | "qs": "^6.11.0", 44 | "ws": "^8.8.1" 45 | }, 46 | "lint-staged": { 47 | "*.{ts,json,md}": "prettier --write" 48 | } 49 | } 50 | -------------------------------------------------------------------------------- /prettier.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | trailingComma: 'es5', 3 | tabWidth: 2, 4 | semi: true, 5 | singleQuote: true, 6 | }; 7 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import Axios, { AxiosError, AxiosInstance } from 'axios'; 2 | import qs from 'qs'; 3 | import WebSocket from 'ws'; 4 | import { 5 | APIOptions, 6 | BotOptionalParams, 7 | BotsParams, 8 | BotsStatsParams, 9 | Channel, 10 | CurrencyParams, 11 | DealsParams, 12 | FundParams, 13 | MarketCurrencyParams, 14 | SmartTradeHistoryParams, 15 | SmartTradeParams, 16 | ThreeCommasError, 17 | TransferHistoryParams, 18 | TransferParams, 19 | WebsocketCallback, 20 | } from './types/types'; 21 | import { sign } from './lib/crypto'; 22 | import { Convert, Order } from './types/generated-types'; 23 | 24 | const ENDPOINT = 'https://api.3commas.io'; 25 | const V1 = '/public/api/ver1'; 26 | const V2 = '/public/api/v2'; 27 | const WS = 'wss://ws.3commas.io/websocket'; 28 | 29 | export class API { 30 | private readonly KEY: string; 31 | private readonly SECRETS: string; 32 | private readonly errorHandler?: ( 33 | response: ThreeCommasError, 34 | reject: (reason?: any) => void 35 | ) => void | Promise; 36 | private axios: AxiosInstance; 37 | private ws?: WebSocket; 38 | 39 | constructor(options?: APIOptions) { 40 | this.KEY = options?.key ?? ''; 41 | this.SECRETS = options?.secrets ?? ''; 42 | this.errorHandler = options?.errorHandler; 43 | this.axios = Axios.create({ 44 | baseURL: ENDPOINT, 45 | timeout: options?.timeout ?? 30000, 46 | headers: { 47 | APIKEY: this.KEY, 48 | ...(options?.forcedMode && { 'Forced-Mode': options?.forcedMode }), 49 | }, 50 | }); 51 | this.axios.interceptors.request.use( 52 | (config) => { 53 | let payload = JSON.stringify(config.data); 54 | 55 | if (config.method === 'get') { 56 | payload = qs.stringify(config.params); 57 | config.data = null; 58 | } 59 | 60 | const relativeUrl = config.url!.replace(config.baseURL!, ''); 61 | const signature = this.SECRETS 62 | ? sign(this.SECRETS, relativeUrl, payload) 63 | : ''; 64 | const newConfig = { 65 | ...config, 66 | headers: { 67 | ...config.headers, 68 | signature, 69 | }, 70 | }; 71 | 72 | return newConfig; 73 | }, 74 | (error) => { 75 | return Promise.reject(error); 76 | } 77 | ); 78 | } 79 | 80 | private request( 81 | method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH', 82 | version: 1 | 2, 83 | path: string, 84 | payload?: any 85 | ): Promise { 86 | return new Promise(async (resolve, reject) => { 87 | try { 88 | const { data } = await this.axios({ 89 | method, 90 | url: `${ENDPOINT}${version === 1 ? V1 : V2}${path}`, 91 | params: method === 'GET' ? payload : undefined, 92 | data: method !== 'GET' ? payload : undefined, 93 | }); 94 | resolve(data); 95 | } catch (e) { 96 | const error = e as AxiosError; 97 | if (error.response?.data && this.errorHandler) { 98 | await this.errorHandler(error.response.data, reject); 99 | } 100 | reject(error.response?.data ?? error); 101 | } 102 | }); 103 | } 104 | 105 | async ping() { 106 | return await this.request('GET', 1, '/ping'); 107 | } 108 | 109 | async time() { 110 | return await this.request('GET', 1, '/time'); 111 | } 112 | 113 | async transfer(params: TransferParams) { 114 | return await this.request('POST', 1, '/accounts/transfer', params); 115 | } 116 | 117 | async getTransferHistory(params: TransferHistoryParams) { 118 | return await this.request('GET', 1, '/accounts/transfer_history', params); 119 | } 120 | 121 | async getTransferData() { 122 | return await this.request('GET', 1, '/accounts/transfer_data'); 123 | } 124 | 125 | async addExchangeAccount(params: any) { 126 | return await this.request('POST', 1, '/accounts/new', params); 127 | } 128 | 129 | async editExchangeAccount(params: any) { 130 | return await this.request('POST', 1, '/accounts/update', params); 131 | } 132 | 133 | async getExchange() { 134 | return await this.request('GET', 1, '/accounts'); 135 | } 136 | 137 | async getMarketList() { 138 | return await this.request('GET', 1, '/accounts/market_list'); 139 | } 140 | 141 | async getMarketPairs(params?: any) { 142 | return await this.request('GET', 1, '/accounts/market_pairs', params); 143 | } 144 | 145 | async getCurrencyRate(params: CurrencyParams) { 146 | return await this.request('GET', 1, '/accounts/currency_rates', params); 147 | } 148 | 149 | async getCurrencyRateWithLeverageData(params: MarketCurrencyParams) { 150 | return await this.request( 151 | 'GET', 152 | 1, 153 | '/accounts/currency_rates_with_leverage_data', 154 | params 155 | ); 156 | } 157 | 158 | async getActiveTradeEntities(account_id: number | string) { 159 | return await this.request( 160 | 'GET', 161 | 1, 162 | `/accounts/${account_id}/active_trading_entities` 163 | ); 164 | } 165 | 166 | async sellAllToUSD(account_id: number | string) { 167 | return await this.request( 168 | 'POST', 169 | 1, 170 | `/accounts/${account_id}/sell_all_to_usd` 171 | ); 172 | } 173 | 174 | async sellAllToBTC(account_id: number | string) { 175 | return await this.request( 176 | 'POST', 177 | 1, 178 | `/accounts/${account_id}/sell_all_to_btc` 179 | ); 180 | } 181 | 182 | async getBalanceChartData(account_id: number | string, params: any) { 183 | return await this.request( 184 | 'GET', 185 | 1, 186 | `/accounts/${account_id}/balance_chart_data`, 187 | params 188 | ); 189 | } 190 | 191 | async loadBalances(account_id: number | string) { 192 | return await this.request( 193 | 'POST', 194 | 1, 195 | `/accounts/${account_id}/load_balances` 196 | ); 197 | } 198 | 199 | async renameExchangeAccount(account_id: number | string, name: string) { 200 | return await this.request('POST', 1, `/accounts/${account_id}/rename`, { 201 | name, 202 | }); 203 | } 204 | 205 | async removeExchangeAccount(account_id: number | string) { 206 | return await this.request('POST', 1, `/accounts/${account_id}/remove`); 207 | } 208 | 209 | async getPieChartData(account_id: number | string) { 210 | return await this.request( 211 | 'POST', 212 | 1, 213 | `/accounts/${account_id}/pie_chart_data` 214 | ); 215 | } 216 | 217 | async getAccountTableData(account_id: number | string) { 218 | return await this.request( 219 | 'POST', 220 | 1, 221 | `/accounts/${account_id}/account_table_data` 222 | ); 223 | } 224 | 225 | async getAccountInfo(account_id?: number) { 226 | return await this.request('GET', 1, `/accounts/${account_id ?? 'summary'}`); 227 | } 228 | 229 | async getLeverageData(account_id: number | string, pair: string) { 230 | return await this.request( 231 | 'GET', 232 | 1, 233 | `/accounts/${account_id}/leverage_data`, 234 | { pair } 235 | ); 236 | } 237 | 238 | async changeUserMode(mode: 'paper' | 'real') { 239 | return await this.request('POST', 1, '/users/change_mode', { mode }); 240 | } 241 | 242 | async getSmartTradeHistory( 243 | params?: SmartTradeHistoryParams 244 | ): Promise { 245 | return await this.request('GET', 2, '/smart_trades', params); 246 | } 247 | 248 | async smartTrade(params: SmartTradeParams): Promise { 249 | return await this.request('POST', 2, '/smart_trades', params); 250 | } 251 | 252 | async getSmartTrade(id: number): Promise { 253 | return await this.request('GET', 2, `/smart_trades/${id}`); 254 | } 255 | 256 | async cancelSmartTrade(id: number): Promise { 257 | return await this.request('DELETE', 2, `/smart_trades/${id}`); 258 | } 259 | 260 | async updateSmartTrade(id: number, params: any): Promise { 261 | return await this.request('PATCH', 2, `/smart_trades/${id}`, params); 262 | } 263 | 264 | async averageSmartTrade(id: number, params: FundParams): Promise { 265 | return await this.request( 266 | 'POST', 267 | 2, 268 | `/smart_trades/${id}/add_funds`, 269 | params 270 | ); 271 | } 272 | 273 | async reduceFund(id: number, params: FundParams): Promise { 274 | return await this.request( 275 | 'POST', 276 | 2, 277 | `/smart_trades/${id}/reduce_funds`, 278 | params 279 | ); 280 | } 281 | 282 | async closeSmartTrade(id: number): Promise { 283 | return await this.request('POST', 2, `/smart_trades/${id}/close_by_market`); 284 | } 285 | 286 | async forceStartSmartTrade(id: number): Promise { 287 | return await this.request('POST', 2, `/smart_trades/${id}/force_start`); 288 | } 289 | 290 | async forceProcessSmartTrade(id: number): Promise { 291 | return await this.request('POST', 2, `/smart_trades/${id}/force_process`); 292 | } 293 | 294 | async setNoteSmartTrade(id: number, note: string): Promise { 295 | return await this.request('POST', 2, `/smart_trades/${id}/set_note`, { 296 | note, 297 | }); 298 | } 299 | 300 | /** 301 | * Get the sub trades of a smart trade, including entry and take profit orders. 302 | * 303 | * @param id smart trade id 304 | * @returns SmartTrade Order 305 | */ 306 | async getSubTrade(id: number) { 307 | return await this.request('GET', 2, `/smart_trades/${id}/trades`); 308 | } 309 | 310 | async closeSubTrade(smartTradeId: number, subTradeId: number) { 311 | return await this.request( 312 | 'POST', 313 | 2, 314 | `/smart_trades/${smartTradeId}/trades/${subTradeId}/close_by_market` 315 | ); 316 | } 317 | 318 | async cancelSubTrade(smartTradeId: number, subTradeId: number) { 319 | return await this.request( 320 | 'DELETE', 321 | 2, 322 | `/smart_trades/${smartTradeId}/trades/${subTradeId}` 323 | ); 324 | } 325 | 326 | async getBots( 327 | params: BotsParams = { 328 | limit: 50, 329 | sort_by: 'created_at', 330 | sort_direction: 'desc', 331 | } 332 | ) { 333 | return await this.request('GET', 1, '/bots', params); 334 | } 335 | 336 | async getBotsStats(params?: BotsStatsParams) { 337 | return await this.request('GET', 1, '/bots/stats', params); 338 | } 339 | 340 | async getBot(id: number, options?: BotOptionalParams) { 341 | return await this.request('GET', 1, `/bots/${id}/show`, options); 342 | } 343 | 344 | async getDeals( 345 | params: DealsParams = { 346 | limit: 50, 347 | order: 'created_at', 348 | order_direction: 'desc', 349 | } 350 | ) { 351 | return await this.request('GET', 1, '/deals', params); 352 | } 353 | 354 | async getDeal(id: number) { 355 | return await this.request('GET', 1, `/deals/${id}/show`); 356 | } 357 | 358 | async getDealSafetyOrders(id: number) { 359 | return await this.request('GET', 1, `/deals/${id}/market_orders`); 360 | } 361 | 362 | async customRequest( 363 | method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH', 364 | version: 1 | 2, 365 | path: string, 366 | payload?: any 367 | ) { 368 | return await this.request(method, version, path, payload); 369 | } 370 | 371 | // Websocket 372 | 373 | private buildIdentifier(channel: Channel, url: string): string { 374 | const idetifier = { 375 | channel, 376 | users: [ 377 | { 378 | api_key: this.KEY, 379 | signature: sign(this.SECRETS, url), 380 | }, 381 | ], 382 | }; 383 | 384 | return JSON.stringify(idetifier); 385 | } 386 | 387 | private subscribe( 388 | channel: Channel, 389 | url: string, 390 | callback?: WebsocketCallback 391 | ) { 392 | const payload = JSON.stringify({ 393 | identifier: this.buildIdentifier(channel, url), 394 | command: 'subscribe', 395 | }); 396 | const setUpWebsocketListener = (callback?: WebsocketCallback) => { 397 | if (callback) { 398 | this.ws?.on('message', (data: Buffer, isBinary: boolean) => { 399 | const message = isBinary ? data : data.toString(); 400 | callback(message); 401 | }); 402 | } 403 | this.ws?.on('close', (code) => { 404 | if (code === 1006) { 405 | setUpWebsocket(payload); 406 | } 407 | }); 408 | }; 409 | const setUpWebsocket = (payload: string) => { 410 | this.ws = new WebSocket(WS); 411 | this.ws.onopen = () => this.ws?.send(payload); 412 | setUpWebsocketListener(callback); 413 | }; 414 | 415 | if (!this.ws) { 416 | setUpWebsocket(payload); 417 | } else { 418 | this.ws.send(payload); 419 | } 420 | } 421 | 422 | subscribeSmartTrade(callback?: (data: WebSocket.Data) => void) { 423 | this.subscribe('SmartTradesChannel', '/smart_trades', callback); 424 | } 425 | 426 | subscribeDeal(callback?: (data: WebSocket.Data) => void) { 427 | this.subscribe('DealsChannel', '/deals', callback); 428 | } 429 | 430 | // 3Commas does not support unsubscribe a channel 431 | unsubscribe() { 432 | if (this.ws) { 433 | this.ws.close(); 434 | } 435 | } 436 | 437 | /** 438 | * Validate the response order is consistent with the generated type 439 | * Or, an error is thrown 440 | * 441 | * @param order order 442 | */ 443 | validateOrderType(order: Order) { 444 | return Convert.toOrder(JSON.stringify(order)); 445 | } 446 | } 447 | -------------------------------------------------------------------------------- /src/lib/crypto.ts: -------------------------------------------------------------------------------- 1 | import HmacSHA256 from 'crypto-js/hmac-sha256'; 2 | import Hex from 'crypto-js/enc-hex'; 3 | 4 | export function sign(secret: string, url: string, params?: string): string { 5 | const message = params ? `${url}?${params}` : url; 6 | 7 | return HmacSHA256(message, secret).toString(Hex); 8 | } 9 | -------------------------------------------------------------------------------- /src/types/generated-types.ts: -------------------------------------------------------------------------------- 1 | // To parse this data: 2 | // 3 | // import { Convert, Order } from "./file"; 4 | // 5 | // const order = Convert.toOrder(json); 6 | // 7 | // These functions will throw an error if the JSON doesn't 8 | // match the expected interface, even if the JSON is valid. 9 | 10 | export interface Order { 11 | id: number; 12 | version: number; 13 | account: Account; 14 | pair: string; 15 | instant: boolean; 16 | status: PositionStatus; 17 | leverage: Leverage; 18 | position: Position; 19 | take_profit: TakeProfit; 20 | stop_loss: StopLoss; 21 | note: string; 22 | skip_enter_step: boolean; 23 | data: OrderData; 24 | profit: Profit; 25 | margin?: Margin; 26 | is_position_not_filled?: boolean; 27 | editable?: boolean; 28 | } 29 | 30 | export interface Account { 31 | id: number; 32 | type: string; 33 | name: string; 34 | market: string; 35 | link: string; 36 | class?: string; 37 | } 38 | 39 | export interface OrderData { 40 | editable: boolean; 41 | current_price: CurrentPrice | null; 42 | target_price_type: string; 43 | base_order_finished: boolean; 44 | missing_funds_to_close: number | string; 45 | liquidation_price?: null | string; 46 | average_enter_price: null | string; 47 | average_close_price: null | string; 48 | average_enter_price_without_commission?: null | string; 49 | average_close_price_without_commission?: null | string; 50 | panic_sell_available: boolean; 51 | add_funds_available: boolean; 52 | force_start_available: boolean; 53 | force_process_available: boolean; 54 | cancel_available: boolean; 55 | created_at: string; 56 | updated_at: string; 57 | type: string; 58 | closed_at?: string; 59 | } 60 | 61 | export interface CurrentPrice { 62 | bid: string; 63 | ask: string; 64 | last: string; 65 | day_change_percent?: string; 66 | quote_volume?: string; 67 | } 68 | 69 | export interface Leverage { 70 | enabled: boolean; 71 | type?: string; 72 | value?: string; 73 | } 74 | 75 | export interface Margin { 76 | amount: null | string; 77 | total: null | string; 78 | } 79 | 80 | export interface Position { 81 | type: string; 82 | editable: boolean; 83 | units: Units; 84 | price: PositionPrice; 85 | total: Total; 86 | order_type: string; 87 | status: PositionStatus; 88 | conditional?: PositionConditional; 89 | } 90 | 91 | export interface PositionConditional { 92 | editable: boolean; 93 | price: PurplePrice; 94 | order_type: string; 95 | trailing: Trailing; 96 | } 97 | 98 | export interface PurplePrice { 99 | value: string; 100 | type: string; 101 | } 102 | 103 | export interface Trailing { 104 | enabled: boolean; 105 | percent: null; 106 | } 107 | 108 | export interface PositionPrice { 109 | value: string; 110 | value_without_commission?: null | string; 111 | editable: boolean; 112 | } 113 | 114 | export interface PositionStatus { 115 | type: string; 116 | title: string; 117 | error?: string; 118 | } 119 | 120 | export interface Total { 121 | value: null | string; 122 | } 123 | 124 | export interface Units { 125 | value: string; 126 | editable?: boolean; 127 | } 128 | 129 | export interface Profit { 130 | volume: null | string; 131 | usd: null | string; 132 | percent: number | null | string; 133 | roe?: null | string; 134 | } 135 | 136 | export interface StopLoss { 137 | enabled: boolean; 138 | order_type?: string; 139 | editable?: boolean; 140 | price?: Total; 141 | conditional?: StopLossConditional; 142 | timeout?: Timeout; 143 | status?: StopLossStatus; 144 | } 145 | 146 | export interface StopLossConditional { 147 | price: StepPrice; 148 | trailing: Trailing; 149 | } 150 | 151 | export interface StepPrice { 152 | value: string; 153 | type: string; 154 | percent: null; 155 | } 156 | 157 | export interface StopLossStatus { 158 | type: string; 159 | title: string; 160 | } 161 | 162 | export interface Timeout { 163 | enabled: boolean; 164 | value: number | null; 165 | } 166 | 167 | export interface TakeProfit { 168 | enabled: boolean; 169 | steps: Step[]; 170 | } 171 | 172 | export interface Step { 173 | id: number; 174 | order_type: string; 175 | editable: boolean; 176 | units?: Total; 177 | price: StepPrice; 178 | volume: number | string; 179 | total?: null | string; 180 | trailing: Trailing; 181 | status: PositionStatus; 182 | data: StepData; 183 | position: number; 184 | } 185 | 186 | export interface StepData { 187 | cancelable: boolean; 188 | panic_sell_available: boolean; 189 | } 190 | 191 | // Converts JSON strings to/from your types 192 | // and asserts the results of JSON.parse at runtime 193 | export class Convert { 194 | public static toOrder(json: string): Order { 195 | return cast(JSON.parse(json), r('Order')); 196 | } 197 | 198 | public static orderToJson(value: Order): string { 199 | return JSON.stringify(uncast(value, r('Order')), null, 2); 200 | } 201 | } 202 | 203 | function invalidValue(typ: any, val: any, key: any = ''): never { 204 | if (key) { 205 | throw Error( 206 | `Invalid value for key "${key}". Expected type ${JSON.stringify( 207 | typ 208 | )} but got ${JSON.stringify(val)}` 209 | ); 210 | } 211 | throw Error( 212 | `Invalid value ${JSON.stringify(val)} for type ${JSON.stringify(typ)}` 213 | ); 214 | } 215 | 216 | function jsonToJSProps(typ: any): any { 217 | if (typ.jsonToJS === undefined) { 218 | const map: any = {}; 219 | typ.props.forEach((p: any) => (map[p.json] = { key: p.js, typ: p.typ })); 220 | typ.jsonToJS = map; 221 | } 222 | return typ.jsonToJS; 223 | } 224 | 225 | function jsToJSONProps(typ: any): any { 226 | if (typ.jsToJSON === undefined) { 227 | const map: any = {}; 228 | typ.props.forEach((p: any) => (map[p.js] = { key: p.json, typ: p.typ })); 229 | typ.jsToJSON = map; 230 | } 231 | return typ.jsToJSON; 232 | } 233 | 234 | function transform(val: any, typ: any, getProps: any, key: any = ''): any { 235 | function transformPrimitive(typ: string, val: any): any { 236 | if (typeof typ === typeof val) return val; 237 | return invalidValue(typ, val, key); 238 | } 239 | 240 | function transformUnion(typs: any[], val: any): any { 241 | // val must validate against one typ in typs 242 | const l = typs.length; 243 | for (let i = 0; i < l; i++) { 244 | const typ = typs[i]; 245 | try { 246 | return transform(val, typ, getProps); 247 | } catch (_) {} 248 | } 249 | return invalidValue(typs, val); 250 | } 251 | 252 | function transformEnum(cases: string[], val: any): any { 253 | if (cases.indexOf(val) !== -1) return val; 254 | return invalidValue(cases, val); 255 | } 256 | 257 | function transformArray(typ: any, val: any): any { 258 | // val must be an array with no invalid elements 259 | if (!Array.isArray(val)) return invalidValue('array', val); 260 | return val.map((el) => transform(el, typ, getProps)); 261 | } 262 | 263 | function transformDate(val: any): any { 264 | if (val === null) { 265 | return null; 266 | } 267 | const d = new Date(val); 268 | if (isNaN(d.valueOf())) { 269 | return invalidValue('Date', val); 270 | } 271 | return d; 272 | } 273 | 274 | function transformObject( 275 | props: { [k: string]: any }, 276 | additional: any, 277 | val: any 278 | ): any { 279 | if (val === null || typeof val !== 'object' || Array.isArray(val)) { 280 | return invalidValue('object', val); 281 | } 282 | const result: any = {}; 283 | Object.getOwnPropertyNames(props).forEach((key) => { 284 | const prop = props[key]; 285 | const v = Object.prototype.hasOwnProperty.call(val, key) 286 | ? val[key] 287 | : undefined; 288 | result[prop.key] = transform(v, prop.typ, getProps, prop.key); 289 | }); 290 | Object.getOwnPropertyNames(val).forEach((key) => { 291 | if (!Object.prototype.hasOwnProperty.call(props, key)) { 292 | result[key] = transform(val[key], additional, getProps, key); 293 | } 294 | }); 295 | return result; 296 | } 297 | 298 | if (typ === 'any') return val; 299 | if (typ === null) { 300 | if (val === null) return val; 301 | return invalidValue(typ, val); 302 | } 303 | if (typ === false) return invalidValue(typ, val); 304 | while (typeof typ === 'object' && typ.ref !== undefined) { 305 | typ = typeMap[typ.ref]; 306 | } 307 | if (Array.isArray(typ)) return transformEnum(typ, val); 308 | if (typeof typ === 'object') { 309 | return typ.hasOwnProperty('unionMembers') 310 | ? transformUnion(typ.unionMembers, val) 311 | : typ.hasOwnProperty('arrayItems') 312 | ? transformArray(typ.arrayItems, val) 313 | : typ.hasOwnProperty('props') 314 | ? transformObject(getProps(typ), typ.additional, val) 315 | : invalidValue(typ, val); 316 | } 317 | // Numbers can be parsed by Date but shouldn't be. 318 | if (typ === Date && typeof val !== 'number') return transformDate(val); 319 | return transformPrimitive(typ, val); 320 | } 321 | 322 | function cast(val: any, typ: any): T { 323 | return transform(val, typ, jsonToJSProps); 324 | } 325 | 326 | function uncast(val: T, typ: any): any { 327 | return transform(val, typ, jsToJSONProps); 328 | } 329 | 330 | function a(typ: any) { 331 | return { arrayItems: typ }; 332 | } 333 | 334 | function u(...typs: any[]) { 335 | return { unionMembers: typs }; 336 | } 337 | 338 | function o(props: any[], additional: any) { 339 | return { props, additional }; 340 | } 341 | 342 | function m(additional: any) { 343 | return { props: [], additional }; 344 | } 345 | 346 | function r(name: string) { 347 | return { ref: name }; 348 | } 349 | 350 | const typeMap: any = { 351 | Order: o( 352 | [ 353 | { json: 'id', js: 'id', typ: 0 }, 354 | { json: 'version', js: 'version', typ: 0 }, 355 | { json: 'account', js: 'account', typ: r('Account') }, 356 | { json: 'pair', js: 'pair', typ: '' }, 357 | { json: 'instant', js: 'instant', typ: true }, 358 | { json: 'status', js: 'status', typ: r('PositionStatus') }, 359 | { json: 'leverage', js: 'leverage', typ: r('Leverage') }, 360 | { json: 'position', js: 'position', typ: r('Position') }, 361 | { json: 'take_profit', js: 'take_profit', typ: r('TakeProfit') }, 362 | { json: 'stop_loss', js: 'stop_loss', typ: r('StopLoss') }, 363 | { json: 'note', js: 'note', typ: '' }, 364 | { json: 'skip_enter_step', js: 'skip_enter_step', typ: true }, 365 | { json: 'data', js: 'data', typ: r('OrderData') }, 366 | { json: 'profit', js: 'profit', typ: r('Profit') }, 367 | { json: 'margin', js: 'margin', typ: u(undefined, r('Margin')) }, 368 | { 369 | json: 'is_position_not_filled', 370 | js: 'is_position_not_filled', 371 | typ: u(undefined, true), 372 | }, 373 | { json: 'editable', js: 'editable', typ: u(undefined, true) }, 374 | ], 375 | false 376 | ), 377 | Account: o( 378 | [ 379 | { json: 'id', js: 'id', typ: 0 }, 380 | { json: 'type', js: 'type', typ: '' }, 381 | { json: 'name', js: 'name', typ: '' }, 382 | { json: 'market', js: 'market', typ: '' }, 383 | { json: 'link', js: 'link', typ: '' }, 384 | { json: 'class', js: 'class', typ: u(undefined, '') }, 385 | ], 386 | false 387 | ), 388 | OrderData: o( 389 | [ 390 | { json: 'editable', js: 'editable', typ: true }, 391 | { 392 | json: 'current_price', 393 | js: 'current_price', 394 | typ: u(r('CurrentPrice'), null), 395 | }, 396 | { json: 'target_price_type', js: 'target_price_type', typ: '' }, 397 | { json: 'base_order_finished', js: 'base_order_finished', typ: true }, 398 | { 399 | json: 'missing_funds_to_close', 400 | js: 'missing_funds_to_close', 401 | typ: u(0, ''), 402 | }, 403 | { 404 | json: 'liquidation_price', 405 | js: 'liquidation_price', 406 | typ: u(undefined, u(null, '')), 407 | }, 408 | { 409 | json: 'average_enter_price', 410 | js: 'average_enter_price', 411 | typ: u(null, ''), 412 | }, 413 | { 414 | json: 'average_close_price', 415 | js: 'average_close_price', 416 | typ: u(null, ''), 417 | }, 418 | { 419 | json: 'average_enter_price_without_commission', 420 | js: 'average_enter_price_without_commission', 421 | typ: u(undefined, u(null, '')), 422 | }, 423 | { 424 | json: 'average_close_price_without_commission', 425 | js: 'average_close_price_without_commission', 426 | typ: u(undefined, u(null, '')), 427 | }, 428 | { json: 'panic_sell_available', js: 'panic_sell_available', typ: true }, 429 | { json: 'add_funds_available', js: 'add_funds_available', typ: true }, 430 | { json: 'force_start_available', js: 'force_start_available', typ: true }, 431 | { 432 | json: 'force_process_available', 433 | js: 'force_process_available', 434 | typ: true, 435 | }, 436 | { json: 'cancel_available', js: 'cancel_available', typ: true }, 437 | { json: 'created_at', js: 'created_at', typ: '' }, 438 | { json: 'updated_at', js: 'updated_at', typ: '' }, 439 | { json: 'type', js: 'type', typ: '' }, 440 | { json: 'closed_at', js: 'closed_at', typ: u(undefined, '') }, 441 | ], 442 | false 443 | ), 444 | CurrentPrice: o( 445 | [ 446 | { json: 'bid', js: 'bid', typ: '' }, 447 | { json: 'ask', js: 'ask', typ: '' }, 448 | { json: 'last', js: 'last', typ: '' }, 449 | { 450 | json: 'day_change_percent', 451 | js: 'day_change_percent', 452 | typ: u(undefined, ''), 453 | }, 454 | { json: 'quote_volume', js: 'quote_volume', typ: u(undefined, '') }, 455 | ], 456 | false 457 | ), 458 | Leverage: o( 459 | [ 460 | { json: 'enabled', js: 'enabled', typ: true }, 461 | { json: 'type', js: 'type', typ: u(undefined, '') }, 462 | { json: 'value', js: 'value', typ: u(undefined, '') }, 463 | ], 464 | false 465 | ), 466 | Margin: o( 467 | [ 468 | { json: 'amount', js: 'amount', typ: u(null, '') }, 469 | { json: 'total', js: 'total', typ: u(null, '') }, 470 | ], 471 | false 472 | ), 473 | Position: o( 474 | [ 475 | { json: 'type', js: 'type', typ: '' }, 476 | { json: 'editable', js: 'editable', typ: true }, 477 | { json: 'units', js: 'units', typ: r('Units') }, 478 | { json: 'price', js: 'price', typ: r('PositionPrice') }, 479 | { json: 'total', js: 'total', typ: r('Total') }, 480 | { json: 'order_type', js: 'order_type', typ: '' }, 481 | { json: 'status', js: 'status', typ: r('PositionStatus') }, 482 | { 483 | json: 'conditional', 484 | js: 'conditional', 485 | typ: u(undefined, r('PositionConditional')), 486 | }, 487 | ], 488 | false 489 | ), 490 | PositionConditional: o( 491 | [ 492 | { json: 'editable', js: 'editable', typ: true }, 493 | { json: 'price', js: 'price', typ: r('PurplePrice') }, 494 | { json: 'order_type', js: 'order_type', typ: '' }, 495 | { json: 'trailing', js: 'trailing', typ: r('Trailing') }, 496 | ], 497 | false 498 | ), 499 | PurplePrice: o( 500 | [ 501 | { json: 'value', js: 'value', typ: '' }, 502 | { json: 'type', js: 'type', typ: '' }, 503 | ], 504 | false 505 | ), 506 | Trailing: o( 507 | [ 508 | { json: 'enabled', js: 'enabled', typ: true }, 509 | { json: 'percent', js: 'percent', typ: null }, 510 | ], 511 | false 512 | ), 513 | PositionPrice: o( 514 | [ 515 | { json: 'value', js: 'value', typ: '' }, 516 | { 517 | json: 'value_without_commission', 518 | js: 'value_without_commission', 519 | typ: u(undefined, u(null, '')), 520 | }, 521 | { json: 'editable', js: 'editable', typ: true }, 522 | ], 523 | false 524 | ), 525 | PositionStatus: o( 526 | [ 527 | { json: 'type', js: 'type', typ: '' }, 528 | { json: 'title', js: 'title', typ: '' }, 529 | { json: 'error', js: 'error', typ: u(undefined, '') }, 530 | ], 531 | false 532 | ), 533 | Total: o([{ json: 'value', js: 'value', typ: u(null, '') }], false), 534 | Units: o( 535 | [ 536 | { json: 'value', js: 'value', typ: '' }, 537 | { json: 'editable', js: 'editable', typ: u(undefined, true) }, 538 | ], 539 | false 540 | ), 541 | Profit: o( 542 | [ 543 | { json: 'volume', js: 'volume', typ: u(null, '') }, 544 | { json: 'usd', js: 'usd', typ: u(null, '') }, 545 | { json: 'percent', js: 'percent', typ: u(0, null, '') }, 546 | { json: 'roe', js: 'roe', typ: u(undefined, u(null, '')) }, 547 | ], 548 | false 549 | ), 550 | StopLoss: o( 551 | [ 552 | { json: 'enabled', js: 'enabled', typ: true }, 553 | { json: 'order_type', js: 'order_type', typ: u(undefined, '') }, 554 | { json: 'editable', js: 'editable', typ: u(undefined, true) }, 555 | { json: 'price', js: 'price', typ: u(undefined, r('Total')) }, 556 | { 557 | json: 'conditional', 558 | js: 'conditional', 559 | typ: u(undefined, r('StopLossConditional')), 560 | }, 561 | { json: 'timeout', js: 'timeout', typ: u(undefined, r('Timeout')) }, 562 | { json: 'status', js: 'status', typ: u(undefined, r('StopLossStatus')) }, 563 | ], 564 | false 565 | ), 566 | StopLossConditional: o( 567 | [ 568 | { json: 'price', js: 'price', typ: r('StepPrice') }, 569 | { json: 'trailing', js: 'trailing', typ: r('Trailing') }, 570 | ], 571 | false 572 | ), 573 | StepPrice: o( 574 | [ 575 | { json: 'value', js: 'value', typ: '' }, 576 | { json: 'type', js: 'type', typ: '' }, 577 | { json: 'percent', js: 'percent', typ: null }, 578 | ], 579 | false 580 | ), 581 | StopLossStatus: o( 582 | [ 583 | { json: 'type', js: 'type', typ: '' }, 584 | { json: 'title', js: 'title', typ: '' }, 585 | ], 586 | false 587 | ), 588 | Timeout: o( 589 | [ 590 | { json: 'enabled', js: 'enabled', typ: true }, 591 | { json: 'value', js: 'value', typ: u(0, null) }, 592 | ], 593 | false 594 | ), 595 | TakeProfit: o( 596 | [ 597 | { json: 'enabled', js: 'enabled', typ: true }, 598 | { json: 'steps', js: 'steps', typ: a(r('Step')) }, 599 | ], 600 | false 601 | ), 602 | Step: o( 603 | [ 604 | { json: 'id', js: 'id', typ: 0 }, 605 | { json: 'order_type', js: 'order_type', typ: '' }, 606 | { json: 'editable', js: 'editable', typ: true }, 607 | { json: 'units', js: 'units', typ: u(undefined, r('Total')) }, 608 | { json: 'price', js: 'price', typ: r('StepPrice') }, 609 | { json: 'volume', js: 'volume', typ: u(0, '') }, 610 | { json: 'total', js: 'total', typ: u(undefined, u(null, '')) }, 611 | { json: 'trailing', js: 'trailing', typ: r('Trailing') }, 612 | { json: 'status', js: 'status', typ: r('PositionStatus') }, 613 | { json: 'data', js: 'data', typ: r('StepData') }, 614 | { json: 'position', js: 'position', typ: 0 }, 615 | ], 616 | false 617 | ), 618 | StepData: o( 619 | [ 620 | { json: 'cancelable', js: 'cancelable', typ: true }, 621 | { json: 'panic_sell_available', js: 'panic_sell_available', typ: true }, 622 | ], 623 | false 624 | ), 625 | }; 626 | -------------------------------------------------------------------------------- /src/types/types.ts: -------------------------------------------------------------------------------- 1 | import WebSocket from 'ws'; 2 | 3 | export interface APIOptions { 4 | key?: string; 5 | secrets?: string; 6 | timeout?: number; 7 | forcedMode?: 'real' | 'paper'; 8 | errorHandler?: ( 9 | response: ThreeCommasError, 10 | reject: (reason?: any) => void 11 | ) => void | Promise; 12 | } 13 | 14 | export interface ThreeCommasError { 15 | error: string; 16 | error_description?: string; 17 | error_attributes?: { 18 | [key: string]: string; 19 | }; 20 | } 21 | 22 | export interface BotsParams { 23 | limit?: number; // Max 100 24 | offset?: number; 25 | account_id?: number; 26 | scope?: 'enabled' | 'disabled'; 27 | strategy?: 'long' | 'short'; 28 | sort_by?: 'profit' | 'created_at' | 'updated_at'; 29 | sort_direction?: 'asc' | 'desc'; 30 | quote?: string; 31 | } 32 | 33 | export interface BotsStatsParams { 34 | account_id?: number; 35 | bot_id?: number; 36 | } 37 | 38 | export interface BotOptionalParams { 39 | /** 40 | * Include bot events on the bot object, defaults `false`. 41 | */ 42 | include_events: boolean; 43 | } 44 | 45 | export interface CurrencyParams { 46 | market_code?: string; 47 | pair: string; 48 | } 49 | 50 | export interface DealsParams { 51 | limit?: number; // Max 1000 52 | offset?: number; 53 | account_id?: number; 54 | bot_id?: number; 55 | scope?: 'active' | 'finished' | 'completed' | 'cancelled' | 'failed'; 56 | order?: 57 | | 'created_at' 58 | | 'updated_at' 59 | | 'closed_at' 60 | | 'profit' 61 | | 'profit_percentage'; 62 | order_direction?: 'asc' | 'desc'; 63 | base?: string; 64 | quote?: string; 65 | } 66 | 67 | export interface FundParams { 68 | order_type: 'market' | 'limit'; 69 | units: { 70 | value: number | string; 71 | }; 72 | price?: { 73 | value: number | string; 74 | }; 75 | } 76 | 77 | export interface MarketCurrencyParams { 78 | market_code: string; 79 | pair: string; 80 | } 81 | 82 | export interface TransferParams { 83 | currency: string; 84 | amount: number | string; 85 | from_account_id: number | string; 86 | to_account_id: number | string; 87 | } 88 | 89 | export interface TransferHistoryParams { 90 | account_id: number | string; 91 | currency: string; 92 | page?: number | string; 93 | per_page?: number | string; 94 | } 95 | 96 | export interface SmartTradeHistoryParams { 97 | account_id?: number | string; 98 | pair?: string; 99 | type?: 100 | | 'simple_buy' 101 | | 'simple_sell' 102 | | 'smart_sell' 103 | | 'smart_trade' 104 | | 'smart_cover'; 105 | page?: number | string; 106 | per_page?: number | string; 107 | status?: 'all' | 'active' | 'finished' | 'cancelled' | 'failed'; 108 | order_by?: 'created_at' | 'updated_at' | 'closed_at' | 'status'; 109 | order_direction?: 'asc' | 'desc'; 110 | } 111 | 112 | export interface SmartTradeParams { 113 | account_id: number; 114 | pair: string; 115 | note?: string; 116 | instant?: boolean; 117 | skip_enter_step?: boolean; 118 | leverage?: Leverage; 119 | position: Position; 120 | take_profit?: TakeProfit; 121 | stop_loss?: StopLoss; 122 | } 123 | 124 | export interface Leverage { 125 | enabled: boolean; 126 | type?: 'custom' | 'cross'; 127 | value?: number; 128 | } 129 | 130 | export interface Position { 131 | type: 'buy' | 'sell'; 132 | units: UnitsClass; 133 | price?: UnitsClass; 134 | order_type: 'market' | 'limit' | 'conditional'; 135 | conditional?: PositionConditional; 136 | } 137 | 138 | export interface PositionConditional { 139 | price: PositionConditionalPrice; 140 | order_type: 'market' | 'limit'; 141 | trailing?: Trailing; 142 | } 143 | 144 | export interface PositionConditionalPrice { 145 | value: number; 146 | type: 'bid' | 'ask' | 'last'; 147 | } 148 | 149 | export interface Trailing { 150 | enabled: boolean; 151 | percent?: number; 152 | } 153 | 154 | export interface UnitsClass { 155 | value: number; 156 | } 157 | 158 | export interface StopLoss { 159 | enabled: boolean; 160 | breakeven?: boolean; 161 | order_type?: 'market' | 'limit'; 162 | price?: UnitsClass; 163 | conditional?: StopLossConditional; 164 | timeout?: Timeout; 165 | } 166 | 167 | export interface StopLossConditional { 168 | price: StepPrice; 169 | trailing?: Trailing; 170 | } 171 | 172 | export interface StepPrice { 173 | value?: number; 174 | type: 'bid' | 'ask' | 'last'; 175 | percent?: number; 176 | } 177 | 178 | export interface Timeout { 179 | enabled: boolean; 180 | value: number; 181 | } 182 | 183 | export interface TakeProfit { 184 | enabled: boolean; 185 | steps?: Step[]; 186 | } 187 | 188 | export interface Step { 189 | order_type: 'market' | 'limit'; 190 | price: StepPrice; 191 | volume: number; 192 | trailing?: Trailing; 193 | } 194 | 195 | // Websocket 196 | export type Channel = 'SmartTradesChannel' | 'DealsChannel'; 197 | export type WebsocketCallback = (data: WebSocket.Data) => void; 198 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig.json to read more about this file */ 4 | 5 | /* Basic Options */ 6 | // "incremental": true, /* Enable incremental compilation */ 7 | "target": "es2017", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */ 8 | "module": "commonjs", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */ 9 | // "lib": [], /* Specify library files to be included in the compilation. */ 10 | // "allowJs": true, /* Allow javascript files to be compiled. */ 11 | // "checkJs": true, /* Report errors in .js files. */ 12 | // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ 13 | "declaration": true, /* Generates corresponding '.d.ts' file. */ 14 | // "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */ 15 | // "sourceMap": true, /* Generates corresponding '.map' file. */ 16 | // "outFile": "./", /* Concatenate and emit output to single file. */ 17 | "outDir": "./dist", /* Redirect output structure to the directory. */ 18 | "rootDir": "./src", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */ 19 | // "composite": true, /* Enable project compilation */ 20 | // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ 21 | // "removeComments": true, /* Do not emit comments to output. */ 22 | // "noEmit": true, /* Do not emit outputs. */ 23 | // "importHelpers": true, /* Import emit helpers from 'tslib'. */ 24 | // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ 25 | // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ 26 | 27 | /* Strict Type-Checking Options */ 28 | "strict": true, /* Enable all strict type-checking options. */ 29 | "noImplicitAny": false, /* Raise error on expressions and declarations with an implied 'any' type. */ 30 | // "strictNullChecks": true, /* Enable strict null checks. */ 31 | // "strictFunctionTypes": true, /* Enable strict checking of function types. */ 32 | // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ 33 | // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */ 34 | // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ 35 | // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */ 36 | 37 | /* Additional Checks */ 38 | // "noUnusedLocals": true, /* Report errors on unused locals. */ 39 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 40 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 41 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 42 | 43 | /* Module Resolution Options */ 44 | "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ 45 | // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ 46 | // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ 47 | // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ 48 | // "typeRoots": [], /* List of folders to include type definitions from. */ 49 | // "types": [], /* Type declaration files to be included in compilation. */ 50 | // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ 51 | "esModuleInterop": true, /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */ 52 | // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ 53 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 54 | 55 | /* Source Map Options */ 56 | // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ 57 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 58 | // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ 59 | // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ 60 | 61 | /* Experimental Options */ 62 | // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ 63 | // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ 64 | 65 | /* Advanced Options */ 66 | "skipLibCheck": true, /* Skip type checking of declaration files. */ 67 | "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */ 68 | } 69 | } 70 | --------------------------------------------------------------------------------