├── .editorconfig ├── .github └── workflows │ └── test.yml ├── .gitignore ├── .husky └── pre-commit ├── .prettierrc ├── CHANGELOG.md ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── src ├── index.ts └── ulid.ts ├── test └── ulid.spec.ts └── tsconfig.json /.editorconfig: -------------------------------------------------------------------------------- 1 | # EditorConfig is awesome: https://EditorConfig.org 2 | 3 | # top-most EditorConfig file 4 | root = true 5 | 6 | [*] 7 | indent_style = space 8 | indent_size = 4 9 | end_of_line = lf 10 | charset = utf-8 11 | trim_trailing_whitespace = true 12 | insert_final_newline = true 13 | 14 | [{package.json,package-lock.json,.prettierrc}] 15 | indent_size = 2 16 | -------------------------------------------------------------------------------- /.github/workflows/test.yml: -------------------------------------------------------------------------------- 1 | name: Tests 2 | 3 | on: push 4 | 5 | jobs: 6 | specs: 7 | runs-on: ubuntu-latest 8 | strategy: 9 | matrix: 10 | node-version: [16.x, 17.x] 11 | steps: 12 | - uses: actions/checkout@v2 13 | - name: Specs ${{ matrix.node-version }} 14 | uses: actions/setup-node@v2 15 | with: 16 | node-version: ${{ matrix.node-version }} 17 | - run: npm ci 18 | - run: npm run test:specs 19 | formatting: 20 | runs-on: ubuntu-latest 21 | steps: 22 | - uses: actions/checkout@v2 23 | - name: Formatting 24 | uses: actions/setup-node@v2 25 | with: 26 | node-version: 16.x 27 | - run: npm ci 28 | - run: npm run test:format 29 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | *.logs 2 | node_modules 3 | /dist 4 | .nyc_output 5 | -------------------------------------------------------------------------------- /.husky/pre-commit: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | . "$(dirname "$0")/_/husky.sh" 3 | 4 | npx lint-staged 5 | npm test 6 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "printWidth": 100, 3 | "tabWidth": 4 4 | } 5 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # ulid-workers changelog 2 | 3 | ## v2.1.0 4 | 5 | 2022-12-08 6 | 7 | - Export `encodeTime` to allow encoding of a MAX token when querying a list 8 | 9 | ## v2.0.0 10 | 11 | 2022-02-09 12 | 13 | - Use a factory function that returns a function for both `monotonic` and `non-monotonic` uses. 14 | - Default to using `monotonic` ULID generation 15 | - Fully remove PRNG agility. Always use `crypto.getRandomValues()` 16 | - Allow passing `timestamp` argument to both `monotonic` and `non-monotonic` `ulid()` functions 17 | - Stop public export of private functions, provide them only to test suite 18 | - Modernize all dev dependencies 19 | - Convert Mocha test suite and runner to Typescript 20 | - No longer require build from Typescript to JS to test 21 | - Expand test coverage 22 | - Update README for clarity and to reflect Cloudflare use case 23 | - Modernize Husky git pre-commit toolchain 24 | 25 | ## v1.0.0 26 | 27 | 2021-11-10 28 | 29 | - Initial release 30 | - Fork from ulidx 31 | - Remove dependencies 32 | - Remove PRNG detection 33 | - Web Crypto API only 34 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 Ryan Marsh 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. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # ulid-workers 2 | 3 | A zero-dependency `ULID` generator for [Cloudflare Workers](https://developers.cloudflare.com/workers/) that is written entirely in Typescript and generates `ULID`s monotonically by default. It is **not** compatible with Node.js. 4 | 5 | This library was forked [ulidx](https://github.com/perry-mitchell/ulidx), which in turn was based on the original [ulid](https://github.com/ulid/javascript) library that targeted Node.js and the browser. 6 | 7 | ## About 8 | 9 | ### What is a ULID? 10 | 11 | ULIDs are universally Unique Lexicographically sortable IDentifiers. This library adheres to [the ULID specification](https://github.com/ulid/spec). 12 | 13 | ### Monotonicity and ULID Time in Cloudflare Workers 14 | 15 | This library breaks slightly from tradition in that it generates `monotonic` `ULID`s by default. Normally `ULID`s are lexically sortable because the time component of the `ULID` is based on a high precision timestamp that is always moving forward. It is this timestamp that allows the `ULID` to be easily sorted in those cases. 16 | 17 | However, in the context of a Cloudflare Worker this assumption of always incrementing time breaks down a little. The Workers team has chosen, for security reasons, to freeze time within the context of a single worker request/response cycle. 18 | 19 | The [Workers documentation](https://developers.cloudflare.com/workers/learning/security-model#step-1-disallow-timers-and-multi-threading) talks about the security reasons for this at length. 20 | 21 | > In Workers, you can get the current time using the JavaScript Date API, for example by calling `Date.now()`. However, the time value returned by this is not really the current time. Instead, it is the **time at which the network message was received** which caused the application to begin executing. While the application executes, time is locked in place. 22 | 23 | So if you were to generate multiple `ULID`s in a single request they would all have the same exact time component. In this case the normal behavior of other `ULID` libraries would be to have the random component be truly random. This means that if you generated 10 `ULID`s within a single request they would no longer be able to be guaranteed to be lexically sortable. Thus you lose one of the most important properties of the `ULID`. 24 | 25 | The `ULID` spec defines a method for handling this situation. You can generate a [`monotonic`](https://github.com/ulid/spec#monotonicity) `ULID` which allows for the creation of more than `2^80` `ULID`s within a single millisecond while ensuring that they remain sortable. It does this by incrementing the random component by 1 bit in the least significant bit position (with carrying). Therefore the random component remains sortable even when the timestamp components are identical. 26 | 27 | So for example, if you generated five new ULID's within the same `ms` of a time-frozen request you would see something like: 28 | 29 | ```text 30 | # Note : the random component displayed here is zero'd for 31 | # clarity and the time component is shown as 'T'. Real ULID's 32 | # would be increment the LSB of a truly random value using 33 | # the full Base32 alphabet. 34 | 35 | TTTTTTTTTT0000000000000000 36 | TTTTTTTTTT0000000000000001 37 | TTTTTTTTTT0000000000000002 38 | TTTTTTTTTT0000000000000003 39 | TTTTTTTTTT0000000000000004 40 | ``` 41 | 42 | You can see that the time component remains unchanged while the random component that follows has its least significant bit incremented by `1`, which is the next rotation in the next Base32 character set. 43 | 44 | It is for these reasons we use the [monotonic ULID factory](#monotonic-ulid-factory) by default. Of course you can also use the `non-monotonic` version just as easily. 45 | 46 | For more on the decision to fork, please also see [this discussion](https://github.com/perry-mitchell/ulidx/pull/6#issuecomment-1003190116). 47 | 48 | ### What is the behavior of the `monotonic` generator when passing a `timestamp` arg? 49 | 50 | If you pass a `timestamp` argument to the factory function to override the timestamp portion of the ULID there are a couple of interesting behaviors you might want to be aware of: 51 | 52 | 1) The function will never return a ULID where the time component is less than the highest timestamp it has been exposed to. The function has some internal state that tracks the last time it was exposed to. If asked for a ULID with `ulid(Date.now())` and then subsequently asked for a ULID with `ulid(Date.now() - 1000)` it will return a ULID with the timestamp of the former higher timestamp. This ensures that ULID's that are emitted *always* monotonically increment and ULID's generated later will always lexically sort higher than ULID's generated earlier. 53 | 54 | 2) The behavior of the monotonic function will vary based on where it is initialized and in what context it is run: 55 | * If the function is initialized as a constant __outside__ of the Cloudflare Worker handler function its internal state will persist for the lifetime of the particular instance of the Cloudflare Worker isolate it is running in. There can be many such isolates running in Cloudflare data centers around the world. So each will have its own internal state. The function will always return a timestamp that is >= the highest timestamp it has ever been exposed to. This could be long lived state if the ULID generator were to run in the context of a Cloudflare Durable Object where it may have a long lifetime and where its state may be maintained in a single isolate. 56 | * If the function is initialized as a constant __inside__ of the Cloudflare Worker handler function's request/response cycle it will be recreated on each request, and no internal state will be maintained across requests. In this case you will always get a ULID that is "fresh", meaning the state related to the last timestamp handled is reset on every request. 57 | 58 | In general you probably don't want to pass a timestamp arg to a monotonic generator unless you understand these, or other, nuances. The capability of ensuring a higher level of monotonicity is provided for those who understand these behaviors. 59 | 60 | ### Are there any concerns with using the `monotonic` generator? 61 | 62 | Generally speaking, no. 63 | 64 | However, if your use case: 65 | 66 | * generates multiple `ULID`s in the context of a single request 67 | * AND places high importance on the non-guessability of the next `ULID` in a sequence 68 | 69 | Then you might want to use the `non-monotonic` configuration, sacrificing higher sortability. As you can see from the example above, it is trivial to guess what the next `ULID` in a sequence of `ULID`s all generated within a single `ms` are going to be. 70 | 71 | We think for most use-cases for use within Cloudflare Workers these concerns are of lesser importance so we've chosen to use `monotonic` by default. 72 | 73 | ## Demonstration API 74 | 75 | If you'd like to generate `ULID`s there is a public API at [ulid.truestamp.com](https://ulid.truestamp.com/) that is implemented using a Cloudflare Worker and a global singleton Durable Object that creates all ULIDs using this library. 76 | 77 | Learn more: 78 | 79 | 80 | 81 | Example: 82 | 83 | [https://ulid.truestamp.com/?q=3](https://ulid.truestamp.com/?q=3) 84 | 85 | ```sh 86 | ❯ https --print b https://ulid.truestamp.com q==3 87 | [ 88 | { 89 | "t": 1644553645224, 90 | "ts": "2022-02-11T04:27:25.224Z", 91 | "ulid": "01FVKGJB58M3ERB35J6KFKPPK8" 92 | }, 93 | { 94 | "t": 1644553645224, 95 | "ts": "2022-02-11T04:27:25.224Z", 96 | "ulid": "01FVKGJB58M3ERB35J6KFKPPK9" 97 | }, 98 | { 99 | "t": 1644553645224, 100 | "ts": "2022-02-11T04:27:25.224Z", 101 | "ulid": "01FVKGJB58M3ERB35J6KFKPPKA" 102 | } 103 | ] 104 | ``` 105 | 106 | ## Installation 107 | 108 | Install using npm by running: 109 | 110 | ```shell 111 | npm install ulid-workers --save 112 | ``` 113 | 114 | ## Usage 115 | 116 | Import a factory function from `ulid-workers` that is used to generate new `ULID`s. 117 | 118 | You can select from a `monotonic` (the default) or `non-monotonic` factory. 119 | 120 | ### Monotonic 121 | 122 | ```typescript 123 | import { ulidFactory } from "ulid-workers"; 124 | const ulid = ulidFactory(); 125 | 126 | const id = ulid(); 127 | // 01ARYZ6S41TSV4RRFFQ69G5FAV 128 | ``` 129 | 130 | ### Non-Monotonic 131 | 132 | ```typescript 133 | import { ulidFactory } from "ulid-workers"; 134 | const ulid = ulidFactory({ monotonic: false }); 135 | 136 | const id = ulid(); 137 | // 01ARYZ6S41TSV4RRFFQ69G5FAV 138 | ``` 139 | 140 | ### Timestamp 141 | 142 | The `ULID` specification states that timestamps represent the UNIX Epoch in milliseconds. This library expects all timestamp input to also represent milliseconds since the Epoch. By default, the `ulid()` function call will use the current time for the time component of newly generated ULIDs. You can also provide a `timestamp` argument which will consistently give you the same string for the time component (the first 10 characters) of the `ULID`. 143 | 144 | Providing a timestamp value can be useful, for example, for migrating from another timestamp based ID system to `ULID` where you want to retain the same timestamp component. 145 | 146 | ```typescript 147 | // timestamp in ms since the Epoch 148 | ulid(1469918176385); 149 | ``` 150 | 151 | ### Decode ULID Timestamp 152 | 153 | Import the `decodeTime` function to extract the timestamp component embedded in a `ULID`: 154 | 155 | ```typescript 156 | import { decodeTime } from "ulid-workers"; 157 | 158 | decodeTime("01ARYZ6S41TSV4RRFFQ69G5FAV"); 159 | // 1469918176385 160 | ``` 161 | 162 | ## Pseudo-Random Number Generation (PRNG) 163 | 164 | The Cloudflare Workers runtime implements the [Web Crypto API](https://developers.cloudflare.com/workers/runtime-apis/web-crypto) `crypto.getRandomValues()` function which this library uses to generate the random portion of a `ULID`. 165 | 166 | ## Compatibility 167 | 168 | `ulid-workers` is compatible with Cloudflare Workers and Durable Objects. It is not compatible with Node.js since it does not implement `crypto.getRandomValues()`. 169 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ulid-workers", 3 | "version": "2.1.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "ulid-workers", 9 | "version": "2.1.0", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@types/expect": "^24.3.0", 13 | "@types/mocha": "^9.1.0", 14 | "@types/node": "^17.0.16", 15 | "@types/sinon": "^10.0.11", 16 | "chai": "^4.3.6", 17 | "husky": "^7.0.4", 18 | "lint-staged": "^12.3.3", 19 | "mocha": "^9.2.0", 20 | "prettier": "^2.5.1", 21 | "rimraf": "^3.0.2", 22 | "sinon": "^13.0.1", 23 | "ts-mocha": "^9.0.2", 24 | "typescript": "^4.5.5" 25 | } 26 | }, 27 | "node_modules/@babel/code-frame": { 28 | "version": "7.16.0", 29 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.16.0.tgz", 30 | "integrity": "sha512-IF4EOMEV+bfYwOmNxGzSnjR2EmQod7f1UXOpZM3l4i4o4QNwzjtJAu/HxdjHq0aYBvdqMuQEY1eg0nqW9ZPORA==", 31 | "dev": true, 32 | "dependencies": { 33 | "@babel/highlight": "^7.16.0" 34 | }, 35 | "engines": { 36 | "node": ">=6.9.0" 37 | } 38 | }, 39 | "node_modules/@babel/helper-validator-identifier": { 40 | "version": "7.15.7", 41 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.15.7.tgz", 42 | "integrity": "sha512-K4JvCtQqad9OY2+yTU8w+E82ywk/fe+ELNlt1G8z3bVGlZfn/hOcQQsUhGhW/N+tb3fxK800wLtKOE/aM0m72w==", 43 | "dev": true, 44 | "engines": { 45 | "node": ">=6.9.0" 46 | } 47 | }, 48 | "node_modules/@babel/highlight": { 49 | "version": "7.16.0", 50 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.16.0.tgz", 51 | "integrity": "sha512-t8MH41kUQylBtu2+4IQA3atqevA2lRgqA2wyVB/YiWmsDSuylZZuXOUy9ric30hfzauEFfdsuk/eXTRrGrfd0g==", 52 | "dev": true, 53 | "dependencies": { 54 | "@babel/helper-validator-identifier": "^7.15.7", 55 | "chalk": "^2.0.0", 56 | "js-tokens": "^4.0.0" 57 | }, 58 | "engines": { 59 | "node": ">=6.9.0" 60 | } 61 | }, 62 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 63 | "version": "3.2.1", 64 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 65 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 66 | "dev": true, 67 | "dependencies": { 68 | "color-convert": "^1.9.0" 69 | }, 70 | "engines": { 71 | "node": ">=4" 72 | } 73 | }, 74 | "node_modules/@babel/highlight/node_modules/chalk": { 75 | "version": "2.4.2", 76 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 77 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 78 | "dev": true, 79 | "dependencies": { 80 | "ansi-styles": "^3.2.1", 81 | "escape-string-regexp": "^1.0.5", 82 | "supports-color": "^5.3.0" 83 | }, 84 | "engines": { 85 | "node": ">=4" 86 | } 87 | }, 88 | "node_modules/@babel/highlight/node_modules/color-convert": { 89 | "version": "1.9.3", 90 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 91 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 92 | "dev": true, 93 | "dependencies": { 94 | "color-name": "1.1.3" 95 | } 96 | }, 97 | "node_modules/@babel/highlight/node_modules/color-name": { 98 | "version": "1.1.3", 99 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 100 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 101 | "dev": true 102 | }, 103 | "node_modules/@babel/highlight/node_modules/escape-string-regexp": { 104 | "version": "1.0.5", 105 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 106 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 107 | "dev": true, 108 | "engines": { 109 | "node": ">=0.8.0" 110 | } 111 | }, 112 | "node_modules/@babel/highlight/node_modules/has-flag": { 113 | "version": "3.0.0", 114 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 115 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 116 | "dev": true, 117 | "engines": { 118 | "node": ">=4" 119 | } 120 | }, 121 | "node_modules/@babel/highlight/node_modules/supports-color": { 122 | "version": "5.5.0", 123 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 124 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 125 | "dev": true, 126 | "dependencies": { 127 | "has-flag": "^3.0.0" 128 | }, 129 | "engines": { 130 | "node": ">=4" 131 | } 132 | }, 133 | "node_modules/@jest/types": { 134 | "version": "27.5.1", 135 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", 136 | "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", 137 | "dev": true, 138 | "dependencies": { 139 | "@types/istanbul-lib-coverage": "^2.0.0", 140 | "@types/istanbul-reports": "^3.0.0", 141 | "@types/node": "*", 142 | "@types/yargs": "^16.0.0", 143 | "chalk": "^4.0.0" 144 | }, 145 | "engines": { 146 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 147 | } 148 | }, 149 | "node_modules/@sinonjs/commons": { 150 | "version": "1.8.3", 151 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz", 152 | "integrity": "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==", 153 | "dev": true, 154 | "dependencies": { 155 | "type-detect": "4.0.8" 156 | } 157 | }, 158 | "node_modules/@sinonjs/fake-timers": { 159 | "version": "9.1.0", 160 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-9.1.0.tgz", 161 | "integrity": "sha512-M8vapsv9qQupMdzrVzkn5rb9jG7aUTEPAZdMtME2PuBaefksFZVE2C1g4LBRTkF/k3nRDNbDc5tp5NFC1PEYxA==", 162 | "dev": true, 163 | "dependencies": { 164 | "@sinonjs/commons": "^1.7.0" 165 | } 166 | }, 167 | "node_modules/@sinonjs/samsam": { 168 | "version": "6.1.1", 169 | "resolved": "https://registry.npmjs.org/@sinonjs/samsam/-/samsam-6.1.1.tgz", 170 | "integrity": "sha512-cZ7rKJTLiE7u7Wi/v9Hc2fs3Ucc3jrWeMgPHbbTCeVAB2S0wOBbYlkJVeNSL04i7fdhT8wIbDq1zhC/PXTD2SA==", 171 | "dev": true, 172 | "dependencies": { 173 | "@sinonjs/commons": "^1.6.0", 174 | "lodash.get": "^4.4.2", 175 | "type-detect": "^4.0.8" 176 | } 177 | }, 178 | "node_modules/@sinonjs/text-encoding": { 179 | "version": "0.7.1", 180 | "resolved": "https://registry.npmjs.org/@sinonjs/text-encoding/-/text-encoding-0.7.1.tgz", 181 | "integrity": "sha512-+iTbntw2IZPb/anVDbypzfQa+ay64MW0Zo8aJ8gZPWMMK6/OubMVb6lUPMagqjOPnmtauXnFCACVl3O7ogjeqQ==", 182 | "dev": true 183 | }, 184 | "node_modules/@types/expect": { 185 | "version": "24.3.0", 186 | "resolved": "https://registry.npmjs.org/@types/expect/-/expect-24.3.0.tgz", 187 | "integrity": "sha512-aq5Z+YFBz5o2b6Sp1jigx5nsmoZMK5Ceurjwy6PZmRv7dEi1jLtkARfvB1ME+OXJUG+7TZUDcv3WoCr/aor6dQ==", 188 | "deprecated": "This is a stub types definition. expect provides its own type definitions, so you do not need this installed.", 189 | "dev": true, 190 | "dependencies": { 191 | "expect": "*" 192 | } 193 | }, 194 | "node_modules/@types/istanbul-lib-coverage": { 195 | "version": "2.0.4", 196 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", 197 | "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", 198 | "dev": true 199 | }, 200 | "node_modules/@types/istanbul-lib-report": { 201 | "version": "3.0.0", 202 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 203 | "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", 204 | "dev": true, 205 | "dependencies": { 206 | "@types/istanbul-lib-coverage": "*" 207 | } 208 | }, 209 | "node_modules/@types/istanbul-reports": { 210 | "version": "3.0.1", 211 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", 212 | "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", 213 | "dev": true, 214 | "dependencies": { 215 | "@types/istanbul-lib-report": "*" 216 | } 217 | }, 218 | "node_modules/@types/json5": { 219 | "version": "0.0.29", 220 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 221 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 222 | "dev": true, 223 | "optional": true 224 | }, 225 | "node_modules/@types/mocha": { 226 | "version": "9.1.0", 227 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.0.tgz", 228 | "integrity": "sha512-QCWHkbMv4Y5U9oW10Uxbr45qMMSzl4OzijsozynUAgx3kEHUdXB00udx2dWDQ7f2TU2a2uuiFaRZjCe3unPpeg==", 229 | "dev": true 230 | }, 231 | "node_modules/@types/node": { 232 | "version": "17.0.16", 233 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.16.tgz", 234 | "integrity": "sha512-ydLaGVfQOQ6hI1xK2A5nVh8bl0OGoIfYMxPWHqqYe9bTkWCfqiVvZoh2I/QF2sNSkZzZyROBoTefIEI+PB6iIA==", 235 | "dev": true 236 | }, 237 | "node_modules/@types/sinon": { 238 | "version": "10.0.11", 239 | "resolved": "https://registry.npmjs.org/@types/sinon/-/sinon-10.0.11.tgz", 240 | "integrity": "sha512-dmZsHlBsKUtBpHriNjlK0ndlvEh8dcb9uV9Afsbt89QIyydpC7NcR+nWlAhASfy3GHnxTl4FX/aKE7XZUt/B4g==", 241 | "dev": true, 242 | "dependencies": { 243 | "@types/sinonjs__fake-timers": "*" 244 | } 245 | }, 246 | "node_modules/@types/sinonjs__fake-timers": { 247 | "version": "8.1.1", 248 | "resolved": "https://registry.npmjs.org/@types/sinonjs__fake-timers/-/sinonjs__fake-timers-8.1.1.tgz", 249 | "integrity": "sha512-0kSuKjAS0TrGLJ0M/+8MaFkGsQhZpB6pxOmvS3K8FYI72K//YmdfoW9X2qPsAKh1mkwxGD5zib9s1FIFed6E8g==", 250 | "dev": true 251 | }, 252 | "node_modules/@types/stack-utils": { 253 | "version": "2.0.1", 254 | "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", 255 | "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", 256 | "dev": true 257 | }, 258 | "node_modules/@types/yargs": { 259 | "version": "16.0.4", 260 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", 261 | "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", 262 | "dev": true, 263 | "dependencies": { 264 | "@types/yargs-parser": "*" 265 | } 266 | }, 267 | "node_modules/@types/yargs-parser": { 268 | "version": "20.2.1", 269 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz", 270 | "integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw==", 271 | "dev": true 272 | }, 273 | "node_modules/@ungap/promise-all-settled": { 274 | "version": "1.1.2", 275 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 276 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 277 | "dev": true 278 | }, 279 | "node_modules/aggregate-error": { 280 | "version": "3.1.0", 281 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 282 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 283 | "dev": true, 284 | "dependencies": { 285 | "clean-stack": "^2.0.0", 286 | "indent-string": "^4.0.0" 287 | }, 288 | "engines": { 289 | "node": ">=8" 290 | } 291 | }, 292 | "node_modules/ansi-colors": { 293 | "version": "4.1.1", 294 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 295 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 296 | "dev": true, 297 | "engines": { 298 | "node": ">=6" 299 | } 300 | }, 301 | "node_modules/ansi-escapes": { 302 | "version": "4.3.2", 303 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 304 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 305 | "dev": true, 306 | "dependencies": { 307 | "type-fest": "^0.21.3" 308 | }, 309 | "engines": { 310 | "node": ">=8" 311 | }, 312 | "funding": { 313 | "url": "https://github.com/sponsors/sindresorhus" 314 | } 315 | }, 316 | "node_modules/ansi-regex": { 317 | "version": "5.0.1", 318 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 319 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 320 | "dev": true, 321 | "engines": { 322 | "node": ">=8" 323 | } 324 | }, 325 | "node_modules/ansi-styles": { 326 | "version": "4.3.0", 327 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 328 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 329 | "dev": true, 330 | "dependencies": { 331 | "color-convert": "^2.0.1" 332 | }, 333 | "engines": { 334 | "node": ">=8" 335 | }, 336 | "funding": { 337 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 338 | } 339 | }, 340 | "node_modules/anymatch": { 341 | "version": "3.1.2", 342 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 343 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 344 | "dev": true, 345 | "dependencies": { 346 | "normalize-path": "^3.0.0", 347 | "picomatch": "^2.0.4" 348 | }, 349 | "engines": { 350 | "node": ">= 8" 351 | } 352 | }, 353 | "node_modules/argparse": { 354 | "version": "2.0.1", 355 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 356 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 357 | "dev": true 358 | }, 359 | "node_modules/arrify": { 360 | "version": "1.0.1", 361 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 362 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 363 | "dev": true, 364 | "engines": { 365 | "node": ">=0.10.0" 366 | } 367 | }, 368 | "node_modules/assertion-error": { 369 | "version": "1.1.0", 370 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 371 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 372 | "dev": true, 373 | "engines": { 374 | "node": "*" 375 | } 376 | }, 377 | "node_modules/astral-regex": { 378 | "version": "2.0.0", 379 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 380 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 381 | "dev": true, 382 | "engines": { 383 | "node": ">=8" 384 | } 385 | }, 386 | "node_modules/balanced-match": { 387 | "version": "1.0.2", 388 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 389 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 390 | "dev": true 391 | }, 392 | "node_modules/binary-extensions": { 393 | "version": "2.2.0", 394 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 395 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 396 | "dev": true, 397 | "engines": { 398 | "node": ">=8" 399 | } 400 | }, 401 | "node_modules/brace-expansion": { 402 | "version": "1.1.11", 403 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 404 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 405 | "dev": true, 406 | "dependencies": { 407 | "balanced-match": "^1.0.0", 408 | "concat-map": "0.0.1" 409 | } 410 | }, 411 | "node_modules/braces": { 412 | "version": "3.0.2", 413 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 414 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 415 | "dev": true, 416 | "dependencies": { 417 | "fill-range": "^7.0.1" 418 | }, 419 | "engines": { 420 | "node": ">=8" 421 | } 422 | }, 423 | "node_modules/browser-stdout": { 424 | "version": "1.3.1", 425 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 426 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 427 | "dev": true 428 | }, 429 | "node_modules/buffer-from": { 430 | "version": "1.1.2", 431 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 432 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 433 | "dev": true 434 | }, 435 | "node_modules/chai": { 436 | "version": "4.3.6", 437 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.6.tgz", 438 | "integrity": "sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q==", 439 | "dev": true, 440 | "dependencies": { 441 | "assertion-error": "^1.1.0", 442 | "check-error": "^1.0.2", 443 | "deep-eql": "^3.0.1", 444 | "get-func-name": "^2.0.0", 445 | "loupe": "^2.3.1", 446 | "pathval": "^1.1.1", 447 | "type-detect": "^4.0.5" 448 | }, 449 | "engines": { 450 | "node": ">=4" 451 | } 452 | }, 453 | "node_modules/chalk": { 454 | "version": "4.1.2", 455 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 456 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 457 | "dev": true, 458 | "dependencies": { 459 | "ansi-styles": "^4.1.0", 460 | "supports-color": "^7.1.0" 461 | }, 462 | "engines": { 463 | "node": ">=10" 464 | }, 465 | "funding": { 466 | "url": "https://github.com/chalk/chalk?sponsor=1" 467 | } 468 | }, 469 | "node_modules/check-error": { 470 | "version": "1.0.2", 471 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 472 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 473 | "dev": true, 474 | "engines": { 475 | "node": "*" 476 | } 477 | }, 478 | "node_modules/chokidar": { 479 | "version": "3.5.3", 480 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 481 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 482 | "dev": true, 483 | "funding": [ 484 | { 485 | "type": "individual", 486 | "url": "https://paulmillr.com/funding/" 487 | } 488 | ], 489 | "dependencies": { 490 | "anymatch": "~3.1.2", 491 | "braces": "~3.0.2", 492 | "glob-parent": "~5.1.2", 493 | "is-binary-path": "~2.1.0", 494 | "is-glob": "~4.0.1", 495 | "normalize-path": "~3.0.0", 496 | "readdirp": "~3.6.0" 497 | }, 498 | "engines": { 499 | "node": ">= 8.10.0" 500 | }, 501 | "optionalDependencies": { 502 | "fsevents": "~2.3.2" 503 | } 504 | }, 505 | "node_modules/clean-stack": { 506 | "version": "2.2.0", 507 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 508 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 509 | "dev": true, 510 | "engines": { 511 | "node": ">=6" 512 | } 513 | }, 514 | "node_modules/cli-cursor": { 515 | "version": "3.1.0", 516 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 517 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 518 | "dev": true, 519 | "dependencies": { 520 | "restore-cursor": "^3.1.0" 521 | }, 522 | "engines": { 523 | "node": ">=8" 524 | } 525 | }, 526 | "node_modules/cli-truncate": { 527 | "version": "3.1.0", 528 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-3.1.0.tgz", 529 | "integrity": "sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==", 530 | "dev": true, 531 | "dependencies": { 532 | "slice-ansi": "^5.0.0", 533 | "string-width": "^5.0.0" 534 | }, 535 | "engines": { 536 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 537 | }, 538 | "funding": { 539 | "url": "https://github.com/sponsors/sindresorhus" 540 | } 541 | }, 542 | "node_modules/cli-truncate/node_modules/ansi-regex": { 543 | "version": "6.0.1", 544 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 545 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 546 | "dev": true, 547 | "engines": { 548 | "node": ">=12" 549 | }, 550 | "funding": { 551 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 552 | } 553 | }, 554 | "node_modules/cli-truncate/node_modules/emoji-regex": { 555 | "version": "9.2.2", 556 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 557 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 558 | "dev": true 559 | }, 560 | "node_modules/cli-truncate/node_modules/string-width": { 561 | "version": "5.1.0", 562 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.0.tgz", 563 | "integrity": "sha512-7x54QnN21P+XL/v8SuNKvfgsUre6PXpN7mc77N3HlZv+f1SBRGmjxtOud2Z6FZ8DmdkD/IdjCaf9XXbnqmTZGQ==", 564 | "dev": true, 565 | "dependencies": { 566 | "eastasianwidth": "^0.2.0", 567 | "emoji-regex": "^9.2.2", 568 | "strip-ansi": "^7.0.1" 569 | }, 570 | "engines": { 571 | "node": ">=12" 572 | }, 573 | "funding": { 574 | "url": "https://github.com/sponsors/sindresorhus" 575 | } 576 | }, 577 | "node_modules/cli-truncate/node_modules/strip-ansi": { 578 | "version": "7.0.1", 579 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", 580 | "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", 581 | "dev": true, 582 | "dependencies": { 583 | "ansi-regex": "^6.0.1" 584 | }, 585 | "engines": { 586 | "node": ">=12" 587 | }, 588 | "funding": { 589 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 590 | } 591 | }, 592 | "node_modules/cliui": { 593 | "version": "7.0.4", 594 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 595 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 596 | "dev": true, 597 | "dependencies": { 598 | "string-width": "^4.2.0", 599 | "strip-ansi": "^6.0.0", 600 | "wrap-ansi": "^7.0.0" 601 | } 602 | }, 603 | "node_modules/color-convert": { 604 | "version": "2.0.1", 605 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 606 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 607 | "dev": true, 608 | "dependencies": { 609 | "color-name": "~1.1.4" 610 | }, 611 | "engines": { 612 | "node": ">=7.0.0" 613 | } 614 | }, 615 | "node_modules/color-name": { 616 | "version": "1.1.4", 617 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 618 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 619 | "dev": true 620 | }, 621 | "node_modules/colorette": { 622 | "version": "2.0.16", 623 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.16.tgz", 624 | "integrity": "sha512-hUewv7oMjCp+wkBv5Rm0v87eJhq4woh5rSR+42YSQJKecCqgIqNkZ6lAlQms/BwHPJA5NKMRlpxPRv0n8HQW6g==", 625 | "dev": true 626 | }, 627 | "node_modules/commander": { 628 | "version": "8.3.0", 629 | "resolved": "https://registry.npmjs.org/commander/-/commander-8.3.0.tgz", 630 | "integrity": "sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==", 631 | "dev": true, 632 | "engines": { 633 | "node": ">= 12" 634 | } 635 | }, 636 | "node_modules/concat-map": { 637 | "version": "0.0.1", 638 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 639 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 640 | "dev": true 641 | }, 642 | "node_modules/cross-spawn": { 643 | "version": "7.0.3", 644 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 645 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 646 | "dev": true, 647 | "dependencies": { 648 | "path-key": "^3.1.0", 649 | "shebang-command": "^2.0.0", 650 | "which": "^2.0.1" 651 | }, 652 | "engines": { 653 | "node": ">= 8" 654 | } 655 | }, 656 | "node_modules/debug": { 657 | "version": "4.3.3", 658 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 659 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 660 | "dev": true, 661 | "dependencies": { 662 | "ms": "2.1.2" 663 | }, 664 | "engines": { 665 | "node": ">=6.0" 666 | }, 667 | "peerDependenciesMeta": { 668 | "supports-color": { 669 | "optional": true 670 | } 671 | } 672 | }, 673 | "node_modules/deep-eql": { 674 | "version": "3.0.1", 675 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 676 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 677 | "dev": true, 678 | "dependencies": { 679 | "type-detect": "^4.0.0" 680 | }, 681 | "engines": { 682 | "node": ">=0.12" 683 | } 684 | }, 685 | "node_modules/diff": { 686 | "version": "5.0.0", 687 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 688 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 689 | "dev": true, 690 | "engines": { 691 | "node": ">=0.3.1" 692 | } 693 | }, 694 | "node_modules/diff-sequences": { 695 | "version": "27.5.1", 696 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", 697 | "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", 698 | "dev": true, 699 | "engines": { 700 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 701 | } 702 | }, 703 | "node_modules/eastasianwidth": { 704 | "version": "0.2.0", 705 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 706 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 707 | "dev": true 708 | }, 709 | "node_modules/emoji-regex": { 710 | "version": "8.0.0", 711 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 712 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 713 | "dev": true 714 | }, 715 | "node_modules/escalade": { 716 | "version": "3.1.1", 717 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 718 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 719 | "dev": true, 720 | "engines": { 721 | "node": ">=6" 722 | } 723 | }, 724 | "node_modules/escape-string-regexp": { 725 | "version": "4.0.0", 726 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 727 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 728 | "dev": true, 729 | "engines": { 730 | "node": ">=10" 731 | }, 732 | "funding": { 733 | "url": "https://github.com/sponsors/sindresorhus" 734 | } 735 | }, 736 | "node_modules/execa": { 737 | "version": "5.1.1", 738 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 739 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 740 | "dev": true, 741 | "dependencies": { 742 | "cross-spawn": "^7.0.3", 743 | "get-stream": "^6.0.0", 744 | "human-signals": "^2.1.0", 745 | "is-stream": "^2.0.0", 746 | "merge-stream": "^2.0.0", 747 | "npm-run-path": "^4.0.1", 748 | "onetime": "^5.1.2", 749 | "signal-exit": "^3.0.3", 750 | "strip-final-newline": "^2.0.0" 751 | }, 752 | "engines": { 753 | "node": ">=10" 754 | }, 755 | "funding": { 756 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 757 | } 758 | }, 759 | "node_modules/expect": { 760 | "version": "27.5.1", 761 | "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", 762 | "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", 763 | "dev": true, 764 | "dependencies": { 765 | "@jest/types": "^27.5.1", 766 | "jest-get-type": "^27.5.1", 767 | "jest-matcher-utils": "^27.5.1", 768 | "jest-message-util": "^27.5.1" 769 | }, 770 | "engines": { 771 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 772 | } 773 | }, 774 | "node_modules/fill-range": { 775 | "version": "7.0.1", 776 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 777 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 778 | "dev": true, 779 | "dependencies": { 780 | "to-regex-range": "^5.0.1" 781 | }, 782 | "engines": { 783 | "node": ">=8" 784 | } 785 | }, 786 | "node_modules/find-up": { 787 | "version": "5.0.0", 788 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 789 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 790 | "dev": true, 791 | "dependencies": { 792 | "locate-path": "^6.0.0", 793 | "path-exists": "^4.0.0" 794 | }, 795 | "engines": { 796 | "node": ">=10" 797 | }, 798 | "funding": { 799 | "url": "https://github.com/sponsors/sindresorhus" 800 | } 801 | }, 802 | "node_modules/flat": { 803 | "version": "5.0.2", 804 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 805 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 806 | "dev": true, 807 | "bin": { 808 | "flat": "cli.js" 809 | } 810 | }, 811 | "node_modules/fs.realpath": { 812 | "version": "1.0.0", 813 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 814 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 815 | "dev": true 816 | }, 817 | "node_modules/fsevents": { 818 | "version": "2.3.2", 819 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 820 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 821 | "dev": true, 822 | "hasInstallScript": true, 823 | "optional": true, 824 | "os": [ 825 | "darwin" 826 | ], 827 | "engines": { 828 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 829 | } 830 | }, 831 | "node_modules/get-caller-file": { 832 | "version": "2.0.5", 833 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 834 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 835 | "dev": true, 836 | "engines": { 837 | "node": "6.* || 8.* || >= 10.*" 838 | } 839 | }, 840 | "node_modules/get-func-name": { 841 | "version": "2.0.0", 842 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 843 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 844 | "dev": true, 845 | "engines": { 846 | "node": "*" 847 | } 848 | }, 849 | "node_modules/get-stream": { 850 | "version": "6.0.1", 851 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 852 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 853 | "dev": true, 854 | "engines": { 855 | "node": ">=10" 856 | }, 857 | "funding": { 858 | "url": "https://github.com/sponsors/sindresorhus" 859 | } 860 | }, 861 | "node_modules/glob": { 862 | "version": "7.2.0", 863 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 864 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 865 | "dev": true, 866 | "dependencies": { 867 | "fs.realpath": "^1.0.0", 868 | "inflight": "^1.0.4", 869 | "inherits": "2", 870 | "minimatch": "^3.0.4", 871 | "once": "^1.3.0", 872 | "path-is-absolute": "^1.0.0" 873 | }, 874 | "engines": { 875 | "node": "*" 876 | }, 877 | "funding": { 878 | "url": "https://github.com/sponsors/isaacs" 879 | } 880 | }, 881 | "node_modules/glob-parent": { 882 | "version": "5.1.2", 883 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 884 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 885 | "dev": true, 886 | "dependencies": { 887 | "is-glob": "^4.0.1" 888 | }, 889 | "engines": { 890 | "node": ">= 6" 891 | } 892 | }, 893 | "node_modules/graceful-fs": { 894 | "version": "4.2.9", 895 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 896 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", 897 | "dev": true 898 | }, 899 | "node_modules/growl": { 900 | "version": "1.10.5", 901 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 902 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 903 | "dev": true, 904 | "engines": { 905 | "node": ">=4.x" 906 | } 907 | }, 908 | "node_modules/has-flag": { 909 | "version": "4.0.0", 910 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 911 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 912 | "dev": true, 913 | "engines": { 914 | "node": ">=8" 915 | } 916 | }, 917 | "node_modules/he": { 918 | "version": "1.2.0", 919 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 920 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 921 | "dev": true, 922 | "bin": { 923 | "he": "bin/he" 924 | } 925 | }, 926 | "node_modules/human-signals": { 927 | "version": "2.1.0", 928 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 929 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 930 | "dev": true, 931 | "engines": { 932 | "node": ">=10.17.0" 933 | } 934 | }, 935 | "node_modules/husky": { 936 | "version": "7.0.4", 937 | "resolved": "https://registry.npmjs.org/husky/-/husky-7.0.4.tgz", 938 | "integrity": "sha512-vbaCKN2QLtP/vD4yvs6iz6hBEo6wkSzs8HpRah1Z6aGmF2KW5PdYuAd7uX5a+OyBZHBhd+TFLqgjUgytQr4RvQ==", 939 | "dev": true, 940 | "bin": { 941 | "husky": "lib/bin.js" 942 | }, 943 | "engines": { 944 | "node": ">=12" 945 | }, 946 | "funding": { 947 | "url": "https://github.com/sponsors/typicode" 948 | } 949 | }, 950 | "node_modules/indent-string": { 951 | "version": "4.0.0", 952 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 953 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 954 | "dev": true, 955 | "engines": { 956 | "node": ">=8" 957 | } 958 | }, 959 | "node_modules/inflight": { 960 | "version": "1.0.6", 961 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 962 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 963 | "dev": true, 964 | "dependencies": { 965 | "once": "^1.3.0", 966 | "wrappy": "1" 967 | } 968 | }, 969 | "node_modules/inherits": { 970 | "version": "2.0.4", 971 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 972 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 973 | "dev": true 974 | }, 975 | "node_modules/is-binary-path": { 976 | "version": "2.1.0", 977 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 978 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 979 | "dev": true, 980 | "dependencies": { 981 | "binary-extensions": "^2.0.0" 982 | }, 983 | "engines": { 984 | "node": ">=8" 985 | } 986 | }, 987 | "node_modules/is-extglob": { 988 | "version": "2.1.1", 989 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 990 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 991 | "dev": true, 992 | "engines": { 993 | "node": ">=0.10.0" 994 | } 995 | }, 996 | "node_modules/is-fullwidth-code-point": { 997 | "version": "3.0.0", 998 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 999 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1000 | "dev": true, 1001 | "engines": { 1002 | "node": ">=8" 1003 | } 1004 | }, 1005 | "node_modules/is-glob": { 1006 | "version": "4.0.3", 1007 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1008 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1009 | "dev": true, 1010 | "dependencies": { 1011 | "is-extglob": "^2.1.1" 1012 | }, 1013 | "engines": { 1014 | "node": ">=0.10.0" 1015 | } 1016 | }, 1017 | "node_modules/is-number": { 1018 | "version": "7.0.0", 1019 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1020 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1021 | "dev": true, 1022 | "engines": { 1023 | "node": ">=0.12.0" 1024 | } 1025 | }, 1026 | "node_modules/is-plain-obj": { 1027 | "version": "2.1.0", 1028 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1029 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1030 | "dev": true, 1031 | "engines": { 1032 | "node": ">=8" 1033 | } 1034 | }, 1035 | "node_modules/is-stream": { 1036 | "version": "2.0.1", 1037 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 1038 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 1039 | "dev": true, 1040 | "engines": { 1041 | "node": ">=8" 1042 | }, 1043 | "funding": { 1044 | "url": "https://github.com/sponsors/sindresorhus" 1045 | } 1046 | }, 1047 | "node_modules/is-unicode-supported": { 1048 | "version": "0.1.0", 1049 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1050 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1051 | "dev": true, 1052 | "engines": { 1053 | "node": ">=10" 1054 | }, 1055 | "funding": { 1056 | "url": "https://github.com/sponsors/sindresorhus" 1057 | } 1058 | }, 1059 | "node_modules/isarray": { 1060 | "version": "0.0.1", 1061 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 1062 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 1063 | "dev": true 1064 | }, 1065 | "node_modules/isexe": { 1066 | "version": "2.0.0", 1067 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1068 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1069 | "dev": true 1070 | }, 1071 | "node_modules/jest-diff": { 1072 | "version": "27.5.1", 1073 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", 1074 | "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", 1075 | "dev": true, 1076 | "dependencies": { 1077 | "chalk": "^4.0.0", 1078 | "diff-sequences": "^27.5.1", 1079 | "jest-get-type": "^27.5.1", 1080 | "pretty-format": "^27.5.1" 1081 | }, 1082 | "engines": { 1083 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 1084 | } 1085 | }, 1086 | "node_modules/jest-get-type": { 1087 | "version": "27.5.1", 1088 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", 1089 | "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", 1090 | "dev": true, 1091 | "engines": { 1092 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 1093 | } 1094 | }, 1095 | "node_modules/jest-matcher-utils": { 1096 | "version": "27.5.1", 1097 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", 1098 | "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", 1099 | "dev": true, 1100 | "dependencies": { 1101 | "chalk": "^4.0.0", 1102 | "jest-diff": "^27.5.1", 1103 | "jest-get-type": "^27.5.1", 1104 | "pretty-format": "^27.5.1" 1105 | }, 1106 | "engines": { 1107 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 1108 | } 1109 | }, 1110 | "node_modules/jest-message-util": { 1111 | "version": "27.5.1", 1112 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", 1113 | "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", 1114 | "dev": true, 1115 | "dependencies": { 1116 | "@babel/code-frame": "^7.12.13", 1117 | "@jest/types": "^27.5.1", 1118 | "@types/stack-utils": "^2.0.0", 1119 | "chalk": "^4.0.0", 1120 | "graceful-fs": "^4.2.9", 1121 | "micromatch": "^4.0.4", 1122 | "pretty-format": "^27.5.1", 1123 | "slash": "^3.0.0", 1124 | "stack-utils": "^2.0.3" 1125 | }, 1126 | "engines": { 1127 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 1128 | } 1129 | }, 1130 | "node_modules/js-tokens": { 1131 | "version": "4.0.0", 1132 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1133 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1134 | "dev": true 1135 | }, 1136 | "node_modules/js-yaml": { 1137 | "version": "4.1.0", 1138 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1139 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1140 | "dev": true, 1141 | "dependencies": { 1142 | "argparse": "^2.0.1" 1143 | }, 1144 | "bin": { 1145 | "js-yaml": "bin/js-yaml.js" 1146 | } 1147 | }, 1148 | "node_modules/just-extend": { 1149 | "version": "4.2.1", 1150 | "resolved": "https://registry.npmjs.org/just-extend/-/just-extend-4.2.1.tgz", 1151 | "integrity": "sha512-g3UB796vUFIY90VIv/WX3L2c8CS2MdWUww3CNrYmqza1Fg0DURc2K/O4YrnklBdQarSJ/y8JnJYDGc+1iumQjg==", 1152 | "dev": true 1153 | }, 1154 | "node_modules/lilconfig": { 1155 | "version": "2.0.4", 1156 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.4.tgz", 1157 | "integrity": "sha512-bfTIN7lEsiooCocSISTWXkiWJkRqtL9wYtYy+8EK3Y41qh3mpwPU0ycTOgjdY9ErwXCc8QyrQp82bdL0Xkm9yA==", 1158 | "dev": true, 1159 | "engines": { 1160 | "node": ">=10" 1161 | } 1162 | }, 1163 | "node_modules/lint-staged": { 1164 | "version": "12.3.3", 1165 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-12.3.3.tgz", 1166 | "integrity": "sha512-OqcLsqcPOqzvsfkxjeBpZylgJ3SRG1RYqc9LxC6tkt6tNsq1bNVkAixBwX09f6CobcHswzqVOCBpFR1Fck0+ag==", 1167 | "dev": true, 1168 | "dependencies": { 1169 | "cli-truncate": "^3.1.0", 1170 | "colorette": "^2.0.16", 1171 | "commander": "^8.3.0", 1172 | "debug": "^4.3.3", 1173 | "execa": "^5.1.1", 1174 | "lilconfig": "2.0.4", 1175 | "listr2": "^4.0.1", 1176 | "micromatch": "^4.0.4", 1177 | "normalize-path": "^3.0.0", 1178 | "object-inspect": "^1.12.0", 1179 | "string-argv": "^0.3.1", 1180 | "supports-color": "^9.2.1", 1181 | "yaml": "^1.10.2" 1182 | }, 1183 | "bin": { 1184 | "lint-staged": "bin/lint-staged.js" 1185 | }, 1186 | "engines": { 1187 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1188 | }, 1189 | "funding": { 1190 | "url": "https://opencollective.com/lint-staged" 1191 | } 1192 | }, 1193 | "node_modules/lint-staged/node_modules/supports-color": { 1194 | "version": "9.2.1", 1195 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-9.2.1.tgz", 1196 | "integrity": "sha512-Obv7ycoCTG51N7y175StI9BlAXrmgZrFhZOb0/PyjHBher/NmsdBgbbQ1Inhq+gIhz6+7Gb+jWF2Vqi7Mf1xnQ==", 1197 | "dev": true, 1198 | "engines": { 1199 | "node": ">=12" 1200 | }, 1201 | "funding": { 1202 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1203 | } 1204 | }, 1205 | "node_modules/listr2": { 1206 | "version": "4.0.2", 1207 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-4.0.2.tgz", 1208 | "integrity": "sha512-YcgwfCWpvPbj9FLUGqvdFvd3hrFWKpOeuXznRgfWEJ7RNr8b/IKKIKZABHx3aU+4CWN/iSAFFSReziQG6vTeIA==", 1209 | "dev": true, 1210 | "dependencies": { 1211 | "cli-truncate": "^2.1.0", 1212 | "colorette": "^2.0.16", 1213 | "log-update": "^4.0.0", 1214 | "p-map": "^4.0.0", 1215 | "rfdc": "^1.3.0", 1216 | "rxjs": "^7.5.2", 1217 | "through": "^2.3.8", 1218 | "wrap-ansi": "^7.0.0" 1219 | }, 1220 | "engines": { 1221 | "node": ">=12" 1222 | }, 1223 | "peerDependencies": { 1224 | "enquirer": ">= 2.3.0 < 3" 1225 | }, 1226 | "peerDependenciesMeta": { 1227 | "enquirer": { 1228 | "optional": true 1229 | } 1230 | } 1231 | }, 1232 | "node_modules/listr2/node_modules/cli-truncate": { 1233 | "version": "2.1.0", 1234 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 1235 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 1236 | "dev": true, 1237 | "dependencies": { 1238 | "slice-ansi": "^3.0.0", 1239 | "string-width": "^4.2.0" 1240 | }, 1241 | "engines": { 1242 | "node": ">=8" 1243 | }, 1244 | "funding": { 1245 | "url": "https://github.com/sponsors/sindresorhus" 1246 | } 1247 | }, 1248 | "node_modules/listr2/node_modules/slice-ansi": { 1249 | "version": "3.0.0", 1250 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 1251 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 1252 | "dev": true, 1253 | "dependencies": { 1254 | "ansi-styles": "^4.0.0", 1255 | "astral-regex": "^2.0.0", 1256 | "is-fullwidth-code-point": "^3.0.0" 1257 | }, 1258 | "engines": { 1259 | "node": ">=8" 1260 | } 1261 | }, 1262 | "node_modules/locate-path": { 1263 | "version": "6.0.0", 1264 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1265 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1266 | "dev": true, 1267 | "dependencies": { 1268 | "p-locate": "^5.0.0" 1269 | }, 1270 | "engines": { 1271 | "node": ">=10" 1272 | }, 1273 | "funding": { 1274 | "url": "https://github.com/sponsors/sindresorhus" 1275 | } 1276 | }, 1277 | "node_modules/lodash.get": { 1278 | "version": "4.4.2", 1279 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 1280 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=", 1281 | "dev": true 1282 | }, 1283 | "node_modules/log-symbols": { 1284 | "version": "4.1.0", 1285 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1286 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1287 | "dev": true, 1288 | "dependencies": { 1289 | "chalk": "^4.1.0", 1290 | "is-unicode-supported": "^0.1.0" 1291 | }, 1292 | "engines": { 1293 | "node": ">=10" 1294 | }, 1295 | "funding": { 1296 | "url": "https://github.com/sponsors/sindresorhus" 1297 | } 1298 | }, 1299 | "node_modules/log-update": { 1300 | "version": "4.0.0", 1301 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 1302 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 1303 | "dev": true, 1304 | "dependencies": { 1305 | "ansi-escapes": "^4.3.0", 1306 | "cli-cursor": "^3.1.0", 1307 | "slice-ansi": "^4.0.0", 1308 | "wrap-ansi": "^6.2.0" 1309 | }, 1310 | "engines": { 1311 | "node": ">=10" 1312 | }, 1313 | "funding": { 1314 | "url": "https://github.com/sponsors/sindresorhus" 1315 | } 1316 | }, 1317 | "node_modules/log-update/node_modules/slice-ansi": { 1318 | "version": "4.0.0", 1319 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1320 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1321 | "dev": true, 1322 | "dependencies": { 1323 | "ansi-styles": "^4.0.0", 1324 | "astral-regex": "^2.0.0", 1325 | "is-fullwidth-code-point": "^3.0.0" 1326 | }, 1327 | "engines": { 1328 | "node": ">=10" 1329 | }, 1330 | "funding": { 1331 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1332 | } 1333 | }, 1334 | "node_modules/log-update/node_modules/wrap-ansi": { 1335 | "version": "6.2.0", 1336 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 1337 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 1338 | "dev": true, 1339 | "dependencies": { 1340 | "ansi-styles": "^4.0.0", 1341 | "string-width": "^4.1.0", 1342 | "strip-ansi": "^6.0.0" 1343 | }, 1344 | "engines": { 1345 | "node": ">=8" 1346 | } 1347 | }, 1348 | "node_modules/loupe": { 1349 | "version": "2.3.3", 1350 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.3.tgz", 1351 | "integrity": "sha512-krIV4Cf1BIGIx2t1e6tucThhrBemUnIUjMtD2vN4mrMxnxpBvrcosBSpooqunBqP/hOEEV1w/Cr1YskGtqw5Jg==", 1352 | "dev": true, 1353 | "dependencies": { 1354 | "get-func-name": "^2.0.0" 1355 | } 1356 | }, 1357 | "node_modules/make-error": { 1358 | "version": "1.3.6", 1359 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1360 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1361 | "dev": true 1362 | }, 1363 | "node_modules/merge-stream": { 1364 | "version": "2.0.0", 1365 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1366 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1367 | "dev": true 1368 | }, 1369 | "node_modules/micromatch": { 1370 | "version": "4.0.4", 1371 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 1372 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 1373 | "dev": true, 1374 | "dependencies": { 1375 | "braces": "^3.0.1", 1376 | "picomatch": "^2.2.3" 1377 | }, 1378 | "engines": { 1379 | "node": ">=8.6" 1380 | } 1381 | }, 1382 | "node_modules/mimic-fn": { 1383 | "version": "2.1.0", 1384 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1385 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1386 | "dev": true, 1387 | "engines": { 1388 | "node": ">=6" 1389 | } 1390 | }, 1391 | "node_modules/minimatch": { 1392 | "version": "3.1.2", 1393 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1394 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1395 | "dev": true, 1396 | "dependencies": { 1397 | "brace-expansion": "^1.1.7" 1398 | }, 1399 | "engines": { 1400 | "node": "*" 1401 | } 1402 | }, 1403 | "node_modules/minimist": { 1404 | "version": "1.2.6", 1405 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1406 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1407 | "dev": true 1408 | }, 1409 | "node_modules/mkdirp": { 1410 | "version": "0.5.5", 1411 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1412 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1413 | "dev": true, 1414 | "dependencies": { 1415 | "minimist": "^1.2.5" 1416 | }, 1417 | "bin": { 1418 | "mkdirp": "bin/cmd.js" 1419 | } 1420 | }, 1421 | "node_modules/mocha": { 1422 | "version": "9.2.2", 1423 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.2.2.tgz", 1424 | "integrity": "sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g==", 1425 | "dev": true, 1426 | "dependencies": { 1427 | "@ungap/promise-all-settled": "1.1.2", 1428 | "ansi-colors": "4.1.1", 1429 | "browser-stdout": "1.3.1", 1430 | "chokidar": "3.5.3", 1431 | "debug": "4.3.3", 1432 | "diff": "5.0.0", 1433 | "escape-string-regexp": "4.0.0", 1434 | "find-up": "5.0.0", 1435 | "glob": "7.2.0", 1436 | "growl": "1.10.5", 1437 | "he": "1.2.0", 1438 | "js-yaml": "4.1.0", 1439 | "log-symbols": "4.1.0", 1440 | "minimatch": "4.2.1", 1441 | "ms": "2.1.3", 1442 | "nanoid": "3.3.1", 1443 | "serialize-javascript": "6.0.0", 1444 | "strip-json-comments": "3.1.1", 1445 | "supports-color": "8.1.1", 1446 | "which": "2.0.2", 1447 | "workerpool": "6.2.0", 1448 | "yargs": "16.2.0", 1449 | "yargs-parser": "20.2.4", 1450 | "yargs-unparser": "2.0.0" 1451 | }, 1452 | "bin": { 1453 | "_mocha": "bin/_mocha", 1454 | "mocha": "bin/mocha" 1455 | }, 1456 | "engines": { 1457 | "node": ">= 12.0.0" 1458 | }, 1459 | "funding": { 1460 | "type": "opencollective", 1461 | "url": "https://opencollective.com/mochajs" 1462 | } 1463 | }, 1464 | "node_modules/mocha/node_modules/minimatch": { 1465 | "version": "4.2.1", 1466 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-4.2.1.tgz", 1467 | "integrity": "sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g==", 1468 | "dev": true, 1469 | "dependencies": { 1470 | "brace-expansion": "^1.1.7" 1471 | }, 1472 | "engines": { 1473 | "node": ">=10" 1474 | } 1475 | }, 1476 | "node_modules/mocha/node_modules/ms": { 1477 | "version": "2.1.3", 1478 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1479 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1480 | "dev": true 1481 | }, 1482 | "node_modules/mocha/node_modules/supports-color": { 1483 | "version": "8.1.1", 1484 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1485 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1486 | "dev": true, 1487 | "dependencies": { 1488 | "has-flag": "^4.0.0" 1489 | }, 1490 | "engines": { 1491 | "node": ">=10" 1492 | }, 1493 | "funding": { 1494 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1495 | } 1496 | }, 1497 | "node_modules/ms": { 1498 | "version": "2.1.2", 1499 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1500 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1501 | "dev": true 1502 | }, 1503 | "node_modules/nanoid": { 1504 | "version": "3.3.1", 1505 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.1.tgz", 1506 | "integrity": "sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw==", 1507 | "dev": true, 1508 | "bin": { 1509 | "nanoid": "bin/nanoid.cjs" 1510 | }, 1511 | "engines": { 1512 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1513 | } 1514 | }, 1515 | "node_modules/nise": { 1516 | "version": "5.1.1", 1517 | "resolved": "https://registry.npmjs.org/nise/-/nise-5.1.1.tgz", 1518 | "integrity": "sha512-yr5kW2THW1AkxVmCnKEh4nbYkJdB3I7LUkiUgOvEkOp414mc2UMaHMA7pjq1nYowhdoJZGwEKGaQVbxfpWj10A==", 1519 | "dev": true, 1520 | "dependencies": { 1521 | "@sinonjs/commons": "^1.8.3", 1522 | "@sinonjs/fake-timers": ">=5", 1523 | "@sinonjs/text-encoding": "^0.7.1", 1524 | "just-extend": "^4.0.2", 1525 | "path-to-regexp": "^1.7.0" 1526 | } 1527 | }, 1528 | "node_modules/normalize-path": { 1529 | "version": "3.0.0", 1530 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1531 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1532 | "dev": true, 1533 | "engines": { 1534 | "node": ">=0.10.0" 1535 | } 1536 | }, 1537 | "node_modules/npm-run-path": { 1538 | "version": "4.0.1", 1539 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 1540 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 1541 | "dev": true, 1542 | "dependencies": { 1543 | "path-key": "^3.0.0" 1544 | }, 1545 | "engines": { 1546 | "node": ">=8" 1547 | } 1548 | }, 1549 | "node_modules/object-inspect": { 1550 | "version": "1.12.0", 1551 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", 1552 | "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==", 1553 | "dev": true, 1554 | "funding": { 1555 | "url": "https://github.com/sponsors/ljharb" 1556 | } 1557 | }, 1558 | "node_modules/once": { 1559 | "version": "1.4.0", 1560 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1561 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1562 | "dev": true, 1563 | "dependencies": { 1564 | "wrappy": "1" 1565 | } 1566 | }, 1567 | "node_modules/onetime": { 1568 | "version": "5.1.2", 1569 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 1570 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 1571 | "dev": true, 1572 | "dependencies": { 1573 | "mimic-fn": "^2.1.0" 1574 | }, 1575 | "engines": { 1576 | "node": ">=6" 1577 | }, 1578 | "funding": { 1579 | "url": "https://github.com/sponsors/sindresorhus" 1580 | } 1581 | }, 1582 | "node_modules/p-limit": { 1583 | "version": "3.1.0", 1584 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1585 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1586 | "dev": true, 1587 | "dependencies": { 1588 | "yocto-queue": "^0.1.0" 1589 | }, 1590 | "engines": { 1591 | "node": ">=10" 1592 | }, 1593 | "funding": { 1594 | "url": "https://github.com/sponsors/sindresorhus" 1595 | } 1596 | }, 1597 | "node_modules/p-locate": { 1598 | "version": "5.0.0", 1599 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1600 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1601 | "dev": true, 1602 | "dependencies": { 1603 | "p-limit": "^3.0.2" 1604 | }, 1605 | "engines": { 1606 | "node": ">=10" 1607 | }, 1608 | "funding": { 1609 | "url": "https://github.com/sponsors/sindresorhus" 1610 | } 1611 | }, 1612 | "node_modules/p-map": { 1613 | "version": "4.0.0", 1614 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 1615 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 1616 | "dev": true, 1617 | "dependencies": { 1618 | "aggregate-error": "^3.0.0" 1619 | }, 1620 | "engines": { 1621 | "node": ">=10" 1622 | }, 1623 | "funding": { 1624 | "url": "https://github.com/sponsors/sindresorhus" 1625 | } 1626 | }, 1627 | "node_modules/path-exists": { 1628 | "version": "4.0.0", 1629 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1630 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1631 | "dev": true, 1632 | "engines": { 1633 | "node": ">=8" 1634 | } 1635 | }, 1636 | "node_modules/path-is-absolute": { 1637 | "version": "1.0.1", 1638 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1639 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1640 | "dev": true, 1641 | "engines": { 1642 | "node": ">=0.10.0" 1643 | } 1644 | }, 1645 | "node_modules/path-key": { 1646 | "version": "3.1.1", 1647 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1648 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1649 | "dev": true, 1650 | "engines": { 1651 | "node": ">=8" 1652 | } 1653 | }, 1654 | "node_modules/path-to-regexp": { 1655 | "version": "1.8.0", 1656 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-1.8.0.tgz", 1657 | "integrity": "sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA==", 1658 | "dev": true, 1659 | "dependencies": { 1660 | "isarray": "0.0.1" 1661 | } 1662 | }, 1663 | "node_modules/pathval": { 1664 | "version": "1.1.1", 1665 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 1666 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 1667 | "dev": true, 1668 | "engines": { 1669 | "node": "*" 1670 | } 1671 | }, 1672 | "node_modules/picomatch": { 1673 | "version": "2.3.0", 1674 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1675 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1676 | "dev": true, 1677 | "engines": { 1678 | "node": ">=8.6" 1679 | }, 1680 | "funding": { 1681 | "url": "https://github.com/sponsors/jonschlinkert" 1682 | } 1683 | }, 1684 | "node_modules/prettier": { 1685 | "version": "2.5.1", 1686 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.5.1.tgz", 1687 | "integrity": "sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==", 1688 | "dev": true, 1689 | "bin": { 1690 | "prettier": "bin-prettier.js" 1691 | }, 1692 | "engines": { 1693 | "node": ">=10.13.0" 1694 | } 1695 | }, 1696 | "node_modules/pretty-format": { 1697 | "version": "27.5.1", 1698 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", 1699 | "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", 1700 | "dev": true, 1701 | "dependencies": { 1702 | "ansi-regex": "^5.0.1", 1703 | "ansi-styles": "^5.0.0", 1704 | "react-is": "^17.0.1" 1705 | }, 1706 | "engines": { 1707 | "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" 1708 | } 1709 | }, 1710 | "node_modules/pretty-format/node_modules/ansi-styles": { 1711 | "version": "5.2.0", 1712 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 1713 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 1714 | "dev": true, 1715 | "engines": { 1716 | "node": ">=10" 1717 | }, 1718 | "funding": { 1719 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1720 | } 1721 | }, 1722 | "node_modules/randombytes": { 1723 | "version": "2.1.0", 1724 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1725 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1726 | "dev": true, 1727 | "dependencies": { 1728 | "safe-buffer": "^5.1.0" 1729 | } 1730 | }, 1731 | "node_modules/react-is": { 1732 | "version": "17.0.2", 1733 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 1734 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", 1735 | "dev": true 1736 | }, 1737 | "node_modules/readdirp": { 1738 | "version": "3.6.0", 1739 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1740 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1741 | "dev": true, 1742 | "dependencies": { 1743 | "picomatch": "^2.2.1" 1744 | }, 1745 | "engines": { 1746 | "node": ">=8.10.0" 1747 | } 1748 | }, 1749 | "node_modules/require-directory": { 1750 | "version": "2.1.1", 1751 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1752 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1753 | "dev": true, 1754 | "engines": { 1755 | "node": ">=0.10.0" 1756 | } 1757 | }, 1758 | "node_modules/restore-cursor": { 1759 | "version": "3.1.0", 1760 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1761 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1762 | "dev": true, 1763 | "dependencies": { 1764 | "onetime": "^5.1.0", 1765 | "signal-exit": "^3.0.2" 1766 | }, 1767 | "engines": { 1768 | "node": ">=8" 1769 | } 1770 | }, 1771 | "node_modules/rfdc": { 1772 | "version": "1.3.0", 1773 | "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", 1774 | "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", 1775 | "dev": true 1776 | }, 1777 | "node_modules/rimraf": { 1778 | "version": "3.0.2", 1779 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1780 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1781 | "dev": true, 1782 | "dependencies": { 1783 | "glob": "^7.1.3" 1784 | }, 1785 | "bin": { 1786 | "rimraf": "bin.js" 1787 | }, 1788 | "funding": { 1789 | "url": "https://github.com/sponsors/isaacs" 1790 | } 1791 | }, 1792 | "node_modules/rxjs": { 1793 | "version": "7.5.2", 1794 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.2.tgz", 1795 | "integrity": "sha512-PwDt186XaL3QN5qXj/H9DGyHhP3/RYYgZZwqBv9Tv8rsAaiwFH1IsJJlcgD37J7UW5a6O67qX0KWKS3/pu0m4w==", 1796 | "dev": true, 1797 | "dependencies": { 1798 | "tslib": "^2.1.0" 1799 | } 1800 | }, 1801 | "node_modules/safe-buffer": { 1802 | "version": "5.1.2", 1803 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1804 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1805 | "dev": true 1806 | }, 1807 | "node_modules/serialize-javascript": { 1808 | "version": "6.0.0", 1809 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1810 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1811 | "dev": true, 1812 | "dependencies": { 1813 | "randombytes": "^2.1.0" 1814 | } 1815 | }, 1816 | "node_modules/shebang-command": { 1817 | "version": "2.0.0", 1818 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1819 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1820 | "dev": true, 1821 | "dependencies": { 1822 | "shebang-regex": "^3.0.0" 1823 | }, 1824 | "engines": { 1825 | "node": ">=8" 1826 | } 1827 | }, 1828 | "node_modules/shebang-regex": { 1829 | "version": "3.0.0", 1830 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1831 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1832 | "dev": true, 1833 | "engines": { 1834 | "node": ">=8" 1835 | } 1836 | }, 1837 | "node_modules/signal-exit": { 1838 | "version": "3.0.5", 1839 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.5.tgz", 1840 | "integrity": "sha512-KWcOiKeQj6ZyXx7zq4YxSMgHRlod4czeBQZrPb8OKcohcqAXShm7E20kEMle9WBt26hFcAf0qLOcp5zmY7kOqQ==", 1841 | "dev": true 1842 | }, 1843 | "node_modules/sinon": { 1844 | "version": "13.0.1", 1845 | "resolved": "https://registry.npmjs.org/sinon/-/sinon-13.0.1.tgz", 1846 | "integrity": "sha512-8yx2wIvkBjIq/MGY1D9h1LMraYW+z1X0mb648KZnKSdvLasvDu7maa0dFaNYdTDczFgbjNw2tOmWdTk9saVfwQ==", 1847 | "dev": true, 1848 | "dependencies": { 1849 | "@sinonjs/commons": "^1.8.3", 1850 | "@sinonjs/fake-timers": "^9.0.0", 1851 | "@sinonjs/samsam": "^6.1.1", 1852 | "diff": "^5.0.0", 1853 | "nise": "^5.1.1", 1854 | "supports-color": "^7.2.0" 1855 | }, 1856 | "funding": { 1857 | "type": "opencollective", 1858 | "url": "https://opencollective.com/sinon" 1859 | } 1860 | }, 1861 | "node_modules/slash": { 1862 | "version": "3.0.0", 1863 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1864 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1865 | "dev": true, 1866 | "engines": { 1867 | "node": ">=8" 1868 | } 1869 | }, 1870 | "node_modules/slice-ansi": { 1871 | "version": "5.0.0", 1872 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", 1873 | "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", 1874 | "dev": true, 1875 | "dependencies": { 1876 | "ansi-styles": "^6.0.0", 1877 | "is-fullwidth-code-point": "^4.0.0" 1878 | }, 1879 | "engines": { 1880 | "node": ">=12" 1881 | }, 1882 | "funding": { 1883 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1884 | } 1885 | }, 1886 | "node_modules/slice-ansi/node_modules/ansi-styles": { 1887 | "version": "6.1.0", 1888 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.1.0.tgz", 1889 | "integrity": "sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ==", 1890 | "dev": true, 1891 | "engines": { 1892 | "node": ">=12" 1893 | }, 1894 | "funding": { 1895 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1896 | } 1897 | }, 1898 | "node_modules/slice-ansi/node_modules/is-fullwidth-code-point": { 1899 | "version": "4.0.0", 1900 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", 1901 | "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", 1902 | "dev": true, 1903 | "engines": { 1904 | "node": ">=12" 1905 | }, 1906 | "funding": { 1907 | "url": "https://github.com/sponsors/sindresorhus" 1908 | } 1909 | }, 1910 | "node_modules/source-map-support": { 1911 | "version": "0.5.21", 1912 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1913 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1914 | "dev": true, 1915 | "dependencies": { 1916 | "buffer-from": "^1.0.0", 1917 | "source-map": "^0.6.0" 1918 | } 1919 | }, 1920 | "node_modules/source-map-support/node_modules/source-map": { 1921 | "version": "0.6.1", 1922 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1923 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1924 | "dev": true, 1925 | "engines": { 1926 | "node": ">=0.10.0" 1927 | } 1928 | }, 1929 | "node_modules/stack-utils": { 1930 | "version": "2.0.5", 1931 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", 1932 | "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", 1933 | "dev": true, 1934 | "dependencies": { 1935 | "escape-string-regexp": "^2.0.0" 1936 | }, 1937 | "engines": { 1938 | "node": ">=10" 1939 | } 1940 | }, 1941 | "node_modules/stack-utils/node_modules/escape-string-regexp": { 1942 | "version": "2.0.0", 1943 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 1944 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 1945 | "dev": true, 1946 | "engines": { 1947 | "node": ">=8" 1948 | } 1949 | }, 1950 | "node_modules/string-argv": { 1951 | "version": "0.3.1", 1952 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 1953 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 1954 | "dev": true, 1955 | "engines": { 1956 | "node": ">=0.6.19" 1957 | } 1958 | }, 1959 | "node_modules/string-width": { 1960 | "version": "4.2.3", 1961 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1962 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1963 | "dev": true, 1964 | "dependencies": { 1965 | "emoji-regex": "^8.0.0", 1966 | "is-fullwidth-code-point": "^3.0.0", 1967 | "strip-ansi": "^6.0.1" 1968 | }, 1969 | "engines": { 1970 | "node": ">=8" 1971 | } 1972 | }, 1973 | "node_modules/strip-ansi": { 1974 | "version": "6.0.1", 1975 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1976 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1977 | "dev": true, 1978 | "dependencies": { 1979 | "ansi-regex": "^5.0.1" 1980 | }, 1981 | "engines": { 1982 | "node": ">=8" 1983 | } 1984 | }, 1985 | "node_modules/strip-final-newline": { 1986 | "version": "2.0.0", 1987 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 1988 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 1989 | "dev": true, 1990 | "engines": { 1991 | "node": ">=6" 1992 | } 1993 | }, 1994 | "node_modules/strip-json-comments": { 1995 | "version": "3.1.1", 1996 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1997 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1998 | "dev": true, 1999 | "engines": { 2000 | "node": ">=8" 2001 | }, 2002 | "funding": { 2003 | "url": "https://github.com/sponsors/sindresorhus" 2004 | } 2005 | }, 2006 | "node_modules/supports-color": { 2007 | "version": "7.2.0", 2008 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2009 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2010 | "dev": true, 2011 | "dependencies": { 2012 | "has-flag": "^4.0.0" 2013 | }, 2014 | "engines": { 2015 | "node": ">=8" 2016 | } 2017 | }, 2018 | "node_modules/through": { 2019 | "version": "2.3.8", 2020 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2021 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2022 | "dev": true 2023 | }, 2024 | "node_modules/to-regex-range": { 2025 | "version": "5.0.1", 2026 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2027 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2028 | "dev": true, 2029 | "dependencies": { 2030 | "is-number": "^7.0.0" 2031 | }, 2032 | "engines": { 2033 | "node": ">=8.0" 2034 | } 2035 | }, 2036 | "node_modules/ts-mocha": { 2037 | "version": "9.0.2", 2038 | "resolved": "https://registry.npmjs.org/ts-mocha/-/ts-mocha-9.0.2.tgz", 2039 | "integrity": "sha512-WyQjvnzwrrubl0JT7EC1yWmNpcsU3fOuBFfdps30zbmFBgKniSaSOyZMZx+Wq7kytUs5CY+pEbSYEbGfIKnXTw==", 2040 | "dev": true, 2041 | "dependencies": { 2042 | "ts-node": "7.0.1" 2043 | }, 2044 | "bin": { 2045 | "ts-mocha": "bin/ts-mocha" 2046 | }, 2047 | "engines": { 2048 | "node": ">= 6.X.X" 2049 | }, 2050 | "optionalDependencies": { 2051 | "tsconfig-paths": "^3.5.0" 2052 | }, 2053 | "peerDependencies": { 2054 | "mocha": "^3.X.X || ^4.X.X || ^5.X.X || ^6.X.X || ^7.X.X || ^8.X.X || ^9.X.X" 2055 | } 2056 | }, 2057 | "node_modules/ts-node": { 2058 | "version": "7.0.1", 2059 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-7.0.1.tgz", 2060 | "integrity": "sha512-BVwVbPJRspzNh2yfslyT1PSbl5uIk03EZlb493RKHN4qej/D06n1cEhjlOJG69oFsE7OT8XjpTUcYf6pKTLMhw==", 2061 | "dev": true, 2062 | "dependencies": { 2063 | "arrify": "^1.0.0", 2064 | "buffer-from": "^1.1.0", 2065 | "diff": "^3.1.0", 2066 | "make-error": "^1.1.1", 2067 | "minimist": "^1.2.0", 2068 | "mkdirp": "^0.5.1", 2069 | "source-map-support": "^0.5.6", 2070 | "yn": "^2.0.0" 2071 | }, 2072 | "bin": { 2073 | "ts-node": "dist/bin.js" 2074 | }, 2075 | "engines": { 2076 | "node": ">=4.2.0" 2077 | } 2078 | }, 2079 | "node_modules/ts-node/node_modules/diff": { 2080 | "version": "3.5.0", 2081 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 2082 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 2083 | "dev": true, 2084 | "engines": { 2085 | "node": ">=0.3.1" 2086 | } 2087 | }, 2088 | "node_modules/tsconfig-paths": { 2089 | "version": "3.12.0", 2090 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.12.0.tgz", 2091 | "integrity": "sha512-e5adrnOYT6zqVnWqZu7i/BQ3BnhzvGbjEjejFXO20lKIKpwTaupkCPgEfv4GZK1IBciJUEhYs3J3p75FdaTFVg==", 2092 | "dev": true, 2093 | "optional": true, 2094 | "dependencies": { 2095 | "@types/json5": "^0.0.29", 2096 | "json5": "^1.0.1", 2097 | "minimist": "^1.2.0", 2098 | "strip-bom": "^3.0.0" 2099 | } 2100 | }, 2101 | "node_modules/tsconfig-paths/node_modules/json5": { 2102 | "version": "1.0.1", 2103 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 2104 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 2105 | "dev": true, 2106 | "optional": true, 2107 | "dependencies": { 2108 | "minimist": "^1.2.0" 2109 | }, 2110 | "bin": { 2111 | "json5": "lib/cli.js" 2112 | } 2113 | }, 2114 | "node_modules/tsconfig-paths/node_modules/strip-bom": { 2115 | "version": "3.0.0", 2116 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2117 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2118 | "dev": true, 2119 | "optional": true, 2120 | "engines": { 2121 | "node": ">=4" 2122 | } 2123 | }, 2124 | "node_modules/tslib": { 2125 | "version": "2.3.1", 2126 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 2127 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 2128 | "dev": true 2129 | }, 2130 | "node_modules/type-detect": { 2131 | "version": "4.0.8", 2132 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2133 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2134 | "dev": true, 2135 | "engines": { 2136 | "node": ">=4" 2137 | } 2138 | }, 2139 | "node_modules/type-fest": { 2140 | "version": "0.21.3", 2141 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 2142 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 2143 | "dev": true, 2144 | "engines": { 2145 | "node": ">=10" 2146 | }, 2147 | "funding": { 2148 | "url": "https://github.com/sponsors/sindresorhus" 2149 | } 2150 | }, 2151 | "node_modules/typescript": { 2152 | "version": "4.5.5", 2153 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.5.tgz", 2154 | "integrity": "sha512-TCTIul70LyWe6IJWT8QSYeA54WQe8EjQFU4wY52Fasj5UKx88LNYKCgBEHcOMOrFF1rKGbD8v/xcNWVUq9SymA==", 2155 | "dev": true, 2156 | "bin": { 2157 | "tsc": "bin/tsc", 2158 | "tsserver": "bin/tsserver" 2159 | }, 2160 | "engines": { 2161 | "node": ">=4.2.0" 2162 | } 2163 | }, 2164 | "node_modules/which": { 2165 | "version": "2.0.2", 2166 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2167 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2168 | "dev": true, 2169 | "dependencies": { 2170 | "isexe": "^2.0.0" 2171 | }, 2172 | "bin": { 2173 | "node-which": "bin/node-which" 2174 | }, 2175 | "engines": { 2176 | "node": ">= 8" 2177 | } 2178 | }, 2179 | "node_modules/workerpool": { 2180 | "version": "6.2.0", 2181 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.0.tgz", 2182 | "integrity": "sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A==", 2183 | "dev": true 2184 | }, 2185 | "node_modules/wrap-ansi": { 2186 | "version": "7.0.0", 2187 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2188 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2189 | "dev": true, 2190 | "dependencies": { 2191 | "ansi-styles": "^4.0.0", 2192 | "string-width": "^4.1.0", 2193 | "strip-ansi": "^6.0.0" 2194 | }, 2195 | "engines": { 2196 | "node": ">=10" 2197 | }, 2198 | "funding": { 2199 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2200 | } 2201 | }, 2202 | "node_modules/wrappy": { 2203 | "version": "1.0.2", 2204 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2205 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2206 | "dev": true 2207 | }, 2208 | "node_modules/y18n": { 2209 | "version": "5.0.8", 2210 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2211 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2212 | "dev": true, 2213 | "engines": { 2214 | "node": ">=10" 2215 | } 2216 | }, 2217 | "node_modules/yaml": { 2218 | "version": "1.10.2", 2219 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 2220 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 2221 | "dev": true, 2222 | "engines": { 2223 | "node": ">= 6" 2224 | } 2225 | }, 2226 | "node_modules/yargs": { 2227 | "version": "16.2.0", 2228 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2229 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2230 | "dev": true, 2231 | "dependencies": { 2232 | "cliui": "^7.0.2", 2233 | "escalade": "^3.1.1", 2234 | "get-caller-file": "^2.0.5", 2235 | "require-directory": "^2.1.1", 2236 | "string-width": "^4.2.0", 2237 | "y18n": "^5.0.5", 2238 | "yargs-parser": "^20.2.2" 2239 | }, 2240 | "engines": { 2241 | "node": ">=10" 2242 | } 2243 | }, 2244 | "node_modules/yargs-parser": { 2245 | "version": "20.2.4", 2246 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 2247 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 2248 | "dev": true, 2249 | "engines": { 2250 | "node": ">=10" 2251 | } 2252 | }, 2253 | "node_modules/yargs-unparser": { 2254 | "version": "2.0.0", 2255 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 2256 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 2257 | "dev": true, 2258 | "dependencies": { 2259 | "camelcase": "^6.0.0", 2260 | "decamelize": "^4.0.0", 2261 | "flat": "^5.0.2", 2262 | "is-plain-obj": "^2.1.0" 2263 | }, 2264 | "engines": { 2265 | "node": ">=10" 2266 | } 2267 | }, 2268 | "node_modules/yargs-unparser/node_modules/camelcase": { 2269 | "version": "6.2.0", 2270 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 2271 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 2272 | "dev": true, 2273 | "engines": { 2274 | "node": ">=10" 2275 | }, 2276 | "funding": { 2277 | "url": "https://github.com/sponsors/sindresorhus" 2278 | } 2279 | }, 2280 | "node_modules/yargs-unparser/node_modules/decamelize": { 2281 | "version": "4.0.0", 2282 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 2283 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 2284 | "dev": true, 2285 | "engines": { 2286 | "node": ">=10" 2287 | }, 2288 | "funding": { 2289 | "url": "https://github.com/sponsors/sindresorhus" 2290 | } 2291 | }, 2292 | "node_modules/yn": { 2293 | "version": "2.0.0", 2294 | "resolved": "https://registry.npmjs.org/yn/-/yn-2.0.0.tgz", 2295 | "integrity": "sha1-5a2ryKz0CPY4X8dklWhMiOavaJo=", 2296 | "dev": true, 2297 | "engines": { 2298 | "node": ">=4" 2299 | } 2300 | }, 2301 | "node_modules/yocto-queue": { 2302 | "version": "0.1.0", 2303 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2304 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2305 | "dev": true, 2306 | "engines": { 2307 | "node": ">=10" 2308 | }, 2309 | "funding": { 2310 | "url": "https://github.com/sponsors/sindresorhus" 2311 | } 2312 | } 2313 | }, 2314 | "dependencies": { 2315 | "@babel/code-frame": { 2316 | "version": "7.16.0", 2317 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.16.0.tgz", 2318 | "integrity": "sha512-IF4EOMEV+bfYwOmNxGzSnjR2EmQod7f1UXOpZM3l4i4o4QNwzjtJAu/HxdjHq0aYBvdqMuQEY1eg0nqW9ZPORA==", 2319 | "dev": true, 2320 | "requires": { 2321 | "@babel/highlight": "^7.16.0" 2322 | } 2323 | }, 2324 | "@babel/helper-validator-identifier": { 2325 | "version": "7.15.7", 2326 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.15.7.tgz", 2327 | "integrity": "sha512-K4JvCtQqad9OY2+yTU8w+E82ywk/fe+ELNlt1G8z3bVGlZfn/hOcQQsUhGhW/N+tb3fxK800wLtKOE/aM0m72w==", 2328 | "dev": true 2329 | }, 2330 | "@babel/highlight": { 2331 | "version": "7.16.0", 2332 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.16.0.tgz", 2333 | "integrity": "sha512-t8MH41kUQylBtu2+4IQA3atqevA2lRgqA2wyVB/YiWmsDSuylZZuXOUy9ric30hfzauEFfdsuk/eXTRrGrfd0g==", 2334 | "dev": true, 2335 | "requires": { 2336 | "@babel/helper-validator-identifier": "^7.15.7", 2337 | "chalk": "^2.0.0", 2338 | "js-tokens": "^4.0.0" 2339 | }, 2340 | "dependencies": { 2341 | "ansi-styles": { 2342 | "version": "3.2.1", 2343 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2344 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2345 | "dev": true, 2346 | "requires": { 2347 | "color-convert": "^1.9.0" 2348 | } 2349 | }, 2350 | "chalk": { 2351 | "version": "2.4.2", 2352 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2353 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2354 | "dev": true, 2355 | "requires": { 2356 | "ansi-styles": "^3.2.1", 2357 | "escape-string-regexp": "^1.0.5", 2358 | "supports-color": "^5.3.0" 2359 | } 2360 | }, 2361 | "color-convert": { 2362 | "version": "1.9.3", 2363 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2364 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2365 | "dev": true, 2366 | "requires": { 2367 | "color-name": "1.1.3" 2368 | } 2369 | }, 2370 | "color-name": { 2371 | "version": "1.1.3", 2372 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2373 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2374 | "dev": true 2375 | }, 2376 | "escape-string-regexp": { 2377 | "version": "1.0.5", 2378 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2379 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 2380 | "dev": true 2381 | }, 2382 | "has-flag": { 2383 | "version": "3.0.0", 2384 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2385 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2386 | "dev": true 2387 | }, 2388 | "supports-color": { 2389 | "version": "5.5.0", 2390 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2391 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2392 | "dev": true, 2393 | "requires": { 2394 | "has-flag": "^3.0.0" 2395 | } 2396 | } 2397 | } 2398 | }, 2399 | "@jest/types": { 2400 | "version": "27.5.1", 2401 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", 2402 | "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", 2403 | "dev": true, 2404 | "requires": { 2405 | "@types/istanbul-lib-coverage": "^2.0.0", 2406 | "@types/istanbul-reports": "^3.0.0", 2407 | "@types/node": "*", 2408 | "@types/yargs": "^16.0.0", 2409 | "chalk": "^4.0.0" 2410 | } 2411 | }, 2412 | "@sinonjs/commons": { 2413 | "version": "1.8.3", 2414 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz", 2415 | "integrity": "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==", 2416 | "dev": true, 2417 | "requires": { 2418 | "type-detect": "4.0.8" 2419 | } 2420 | }, 2421 | "@sinonjs/fake-timers": { 2422 | "version": "9.1.0", 2423 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-9.1.0.tgz", 2424 | "integrity": "sha512-M8vapsv9qQupMdzrVzkn5rb9jG7aUTEPAZdMtME2PuBaefksFZVE2C1g4LBRTkF/k3nRDNbDc5tp5NFC1PEYxA==", 2425 | "dev": true, 2426 | "requires": { 2427 | "@sinonjs/commons": "^1.7.0" 2428 | } 2429 | }, 2430 | "@sinonjs/samsam": { 2431 | "version": "6.1.1", 2432 | "resolved": "https://registry.npmjs.org/@sinonjs/samsam/-/samsam-6.1.1.tgz", 2433 | "integrity": "sha512-cZ7rKJTLiE7u7Wi/v9Hc2fs3Ucc3jrWeMgPHbbTCeVAB2S0wOBbYlkJVeNSL04i7fdhT8wIbDq1zhC/PXTD2SA==", 2434 | "dev": true, 2435 | "requires": { 2436 | "@sinonjs/commons": "^1.6.0", 2437 | "lodash.get": "^4.4.2", 2438 | "type-detect": "^4.0.8" 2439 | } 2440 | }, 2441 | "@sinonjs/text-encoding": { 2442 | "version": "0.7.1", 2443 | "resolved": "https://registry.npmjs.org/@sinonjs/text-encoding/-/text-encoding-0.7.1.tgz", 2444 | "integrity": "sha512-+iTbntw2IZPb/anVDbypzfQa+ay64MW0Zo8aJ8gZPWMMK6/OubMVb6lUPMagqjOPnmtauXnFCACVl3O7ogjeqQ==", 2445 | "dev": true 2446 | }, 2447 | "@types/expect": { 2448 | "version": "24.3.0", 2449 | "resolved": "https://registry.npmjs.org/@types/expect/-/expect-24.3.0.tgz", 2450 | "integrity": "sha512-aq5Z+YFBz5o2b6Sp1jigx5nsmoZMK5Ceurjwy6PZmRv7dEi1jLtkARfvB1ME+OXJUG+7TZUDcv3WoCr/aor6dQ==", 2451 | "dev": true, 2452 | "requires": { 2453 | "expect": "*" 2454 | } 2455 | }, 2456 | "@types/istanbul-lib-coverage": { 2457 | "version": "2.0.4", 2458 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", 2459 | "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", 2460 | "dev": true 2461 | }, 2462 | "@types/istanbul-lib-report": { 2463 | "version": "3.0.0", 2464 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 2465 | "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", 2466 | "dev": true, 2467 | "requires": { 2468 | "@types/istanbul-lib-coverage": "*" 2469 | } 2470 | }, 2471 | "@types/istanbul-reports": { 2472 | "version": "3.0.1", 2473 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", 2474 | "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", 2475 | "dev": true, 2476 | "requires": { 2477 | "@types/istanbul-lib-report": "*" 2478 | } 2479 | }, 2480 | "@types/json5": { 2481 | "version": "0.0.29", 2482 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 2483 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 2484 | "dev": true, 2485 | "optional": true 2486 | }, 2487 | "@types/mocha": { 2488 | "version": "9.1.0", 2489 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.0.tgz", 2490 | "integrity": "sha512-QCWHkbMv4Y5U9oW10Uxbr45qMMSzl4OzijsozynUAgx3kEHUdXB00udx2dWDQ7f2TU2a2uuiFaRZjCe3unPpeg==", 2491 | "dev": true 2492 | }, 2493 | "@types/node": { 2494 | "version": "17.0.16", 2495 | "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.16.tgz", 2496 | "integrity": "sha512-ydLaGVfQOQ6hI1xK2A5nVh8bl0OGoIfYMxPWHqqYe9bTkWCfqiVvZoh2I/QF2sNSkZzZyROBoTefIEI+PB6iIA==", 2497 | "dev": true 2498 | }, 2499 | "@types/sinon": { 2500 | "version": "10.0.11", 2501 | "resolved": "https://registry.npmjs.org/@types/sinon/-/sinon-10.0.11.tgz", 2502 | "integrity": "sha512-dmZsHlBsKUtBpHriNjlK0ndlvEh8dcb9uV9Afsbt89QIyydpC7NcR+nWlAhASfy3GHnxTl4FX/aKE7XZUt/B4g==", 2503 | "dev": true, 2504 | "requires": { 2505 | "@types/sinonjs__fake-timers": "*" 2506 | } 2507 | }, 2508 | "@types/sinonjs__fake-timers": { 2509 | "version": "8.1.1", 2510 | "resolved": "https://registry.npmjs.org/@types/sinonjs__fake-timers/-/sinonjs__fake-timers-8.1.1.tgz", 2511 | "integrity": "sha512-0kSuKjAS0TrGLJ0M/+8MaFkGsQhZpB6pxOmvS3K8FYI72K//YmdfoW9X2qPsAKh1mkwxGD5zib9s1FIFed6E8g==", 2512 | "dev": true 2513 | }, 2514 | "@types/stack-utils": { 2515 | "version": "2.0.1", 2516 | "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", 2517 | "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", 2518 | "dev": true 2519 | }, 2520 | "@types/yargs": { 2521 | "version": "16.0.4", 2522 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", 2523 | "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", 2524 | "dev": true, 2525 | "requires": { 2526 | "@types/yargs-parser": "*" 2527 | } 2528 | }, 2529 | "@types/yargs-parser": { 2530 | "version": "20.2.1", 2531 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-20.2.1.tgz", 2532 | "integrity": "sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw==", 2533 | "dev": true 2534 | }, 2535 | "@ungap/promise-all-settled": { 2536 | "version": "1.1.2", 2537 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 2538 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 2539 | "dev": true 2540 | }, 2541 | "aggregate-error": { 2542 | "version": "3.1.0", 2543 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 2544 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 2545 | "dev": true, 2546 | "requires": { 2547 | "clean-stack": "^2.0.0", 2548 | "indent-string": "^4.0.0" 2549 | } 2550 | }, 2551 | "ansi-colors": { 2552 | "version": "4.1.1", 2553 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 2554 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 2555 | "dev": true 2556 | }, 2557 | "ansi-escapes": { 2558 | "version": "4.3.2", 2559 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 2560 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 2561 | "dev": true, 2562 | "requires": { 2563 | "type-fest": "^0.21.3" 2564 | } 2565 | }, 2566 | "ansi-regex": { 2567 | "version": "5.0.1", 2568 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2569 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2570 | "dev": true 2571 | }, 2572 | "ansi-styles": { 2573 | "version": "4.3.0", 2574 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2575 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2576 | "dev": true, 2577 | "requires": { 2578 | "color-convert": "^2.0.1" 2579 | } 2580 | }, 2581 | "anymatch": { 2582 | "version": "3.1.2", 2583 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 2584 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 2585 | "dev": true, 2586 | "requires": { 2587 | "normalize-path": "^3.0.0", 2588 | "picomatch": "^2.0.4" 2589 | } 2590 | }, 2591 | "argparse": { 2592 | "version": "2.0.1", 2593 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2594 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2595 | "dev": true 2596 | }, 2597 | "arrify": { 2598 | "version": "1.0.1", 2599 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 2600 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 2601 | "dev": true 2602 | }, 2603 | "assertion-error": { 2604 | "version": "1.1.0", 2605 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 2606 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 2607 | "dev": true 2608 | }, 2609 | "astral-regex": { 2610 | "version": "2.0.0", 2611 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 2612 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 2613 | "dev": true 2614 | }, 2615 | "balanced-match": { 2616 | "version": "1.0.2", 2617 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2618 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2619 | "dev": true 2620 | }, 2621 | "binary-extensions": { 2622 | "version": "2.2.0", 2623 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2624 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2625 | "dev": true 2626 | }, 2627 | "brace-expansion": { 2628 | "version": "1.1.11", 2629 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2630 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2631 | "dev": true, 2632 | "requires": { 2633 | "balanced-match": "^1.0.0", 2634 | "concat-map": "0.0.1" 2635 | } 2636 | }, 2637 | "braces": { 2638 | "version": "3.0.2", 2639 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2640 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2641 | "dev": true, 2642 | "requires": { 2643 | "fill-range": "^7.0.1" 2644 | } 2645 | }, 2646 | "browser-stdout": { 2647 | "version": "1.3.1", 2648 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 2649 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 2650 | "dev": true 2651 | }, 2652 | "buffer-from": { 2653 | "version": "1.1.2", 2654 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 2655 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 2656 | "dev": true 2657 | }, 2658 | "chai": { 2659 | "version": "4.3.6", 2660 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.6.tgz", 2661 | "integrity": "sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q==", 2662 | "dev": true, 2663 | "requires": { 2664 | "assertion-error": "^1.1.0", 2665 | "check-error": "^1.0.2", 2666 | "deep-eql": "^3.0.1", 2667 | "get-func-name": "^2.0.0", 2668 | "loupe": "^2.3.1", 2669 | "pathval": "^1.1.1", 2670 | "type-detect": "^4.0.5" 2671 | } 2672 | }, 2673 | "chalk": { 2674 | "version": "4.1.2", 2675 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2676 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2677 | "dev": true, 2678 | "requires": { 2679 | "ansi-styles": "^4.1.0", 2680 | "supports-color": "^7.1.0" 2681 | } 2682 | }, 2683 | "check-error": { 2684 | "version": "1.0.2", 2685 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 2686 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 2687 | "dev": true 2688 | }, 2689 | "chokidar": { 2690 | "version": "3.5.3", 2691 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 2692 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 2693 | "dev": true, 2694 | "requires": { 2695 | "anymatch": "~3.1.2", 2696 | "braces": "~3.0.2", 2697 | "fsevents": "~2.3.2", 2698 | "glob-parent": "~5.1.2", 2699 | "is-binary-path": "~2.1.0", 2700 | "is-glob": "~4.0.1", 2701 | "normalize-path": "~3.0.0", 2702 | "readdirp": "~3.6.0" 2703 | } 2704 | }, 2705 | "clean-stack": { 2706 | "version": "2.2.0", 2707 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 2708 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 2709 | "dev": true 2710 | }, 2711 | "cli-cursor": { 2712 | "version": "3.1.0", 2713 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 2714 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 2715 | "dev": true, 2716 | "requires": { 2717 | "restore-cursor": "^3.1.0" 2718 | } 2719 | }, 2720 | "cli-truncate": { 2721 | "version": "3.1.0", 2722 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-3.1.0.tgz", 2723 | "integrity": "sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==", 2724 | "dev": true, 2725 | "requires": { 2726 | "slice-ansi": "^5.0.0", 2727 | "string-width": "^5.0.0" 2728 | }, 2729 | "dependencies": { 2730 | "ansi-regex": { 2731 | "version": "6.0.1", 2732 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 2733 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 2734 | "dev": true 2735 | }, 2736 | "emoji-regex": { 2737 | "version": "9.2.2", 2738 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 2739 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 2740 | "dev": true 2741 | }, 2742 | "string-width": { 2743 | "version": "5.1.0", 2744 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.0.tgz", 2745 | "integrity": "sha512-7x54QnN21P+XL/v8SuNKvfgsUre6PXpN7mc77N3HlZv+f1SBRGmjxtOud2Z6FZ8DmdkD/IdjCaf9XXbnqmTZGQ==", 2746 | "dev": true, 2747 | "requires": { 2748 | "eastasianwidth": "^0.2.0", 2749 | "emoji-regex": "^9.2.2", 2750 | "strip-ansi": "^7.0.1" 2751 | } 2752 | }, 2753 | "strip-ansi": { 2754 | "version": "7.0.1", 2755 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", 2756 | "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", 2757 | "dev": true, 2758 | "requires": { 2759 | "ansi-regex": "^6.0.1" 2760 | } 2761 | } 2762 | } 2763 | }, 2764 | "cliui": { 2765 | "version": "7.0.4", 2766 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2767 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2768 | "dev": true, 2769 | "requires": { 2770 | "string-width": "^4.2.0", 2771 | "strip-ansi": "^6.0.0", 2772 | "wrap-ansi": "^7.0.0" 2773 | } 2774 | }, 2775 | "color-convert": { 2776 | "version": "2.0.1", 2777 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2778 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2779 | "dev": true, 2780 | "requires": { 2781 | "color-name": "~1.1.4" 2782 | } 2783 | }, 2784 | "color-name": { 2785 | "version": "1.1.4", 2786 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2787 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2788 | "dev": true 2789 | }, 2790 | "colorette": { 2791 | "version": "2.0.16", 2792 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.16.tgz", 2793 | "integrity": "sha512-hUewv7oMjCp+wkBv5Rm0v87eJhq4woh5rSR+42YSQJKecCqgIqNkZ6lAlQms/BwHPJA5NKMRlpxPRv0n8HQW6g==", 2794 | "dev": true 2795 | }, 2796 | "commander": { 2797 | "version": "8.3.0", 2798 | "resolved": "https://registry.npmjs.org/commander/-/commander-8.3.0.tgz", 2799 | "integrity": "sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==", 2800 | "dev": true 2801 | }, 2802 | "concat-map": { 2803 | "version": "0.0.1", 2804 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2805 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2806 | "dev": true 2807 | }, 2808 | "cross-spawn": { 2809 | "version": "7.0.3", 2810 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2811 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2812 | "dev": true, 2813 | "requires": { 2814 | "path-key": "^3.1.0", 2815 | "shebang-command": "^2.0.0", 2816 | "which": "^2.0.1" 2817 | } 2818 | }, 2819 | "debug": { 2820 | "version": "4.3.3", 2821 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 2822 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 2823 | "dev": true, 2824 | "requires": { 2825 | "ms": "2.1.2" 2826 | } 2827 | }, 2828 | "deep-eql": { 2829 | "version": "3.0.1", 2830 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 2831 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 2832 | "dev": true, 2833 | "requires": { 2834 | "type-detect": "^4.0.0" 2835 | } 2836 | }, 2837 | "diff": { 2838 | "version": "5.0.0", 2839 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 2840 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 2841 | "dev": true 2842 | }, 2843 | "diff-sequences": { 2844 | "version": "27.5.1", 2845 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", 2846 | "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", 2847 | "dev": true 2848 | }, 2849 | "eastasianwidth": { 2850 | "version": "0.2.0", 2851 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 2852 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 2853 | "dev": true 2854 | }, 2855 | "emoji-regex": { 2856 | "version": "8.0.0", 2857 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2858 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2859 | "dev": true 2860 | }, 2861 | "escalade": { 2862 | "version": "3.1.1", 2863 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2864 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2865 | "dev": true 2866 | }, 2867 | "escape-string-regexp": { 2868 | "version": "4.0.0", 2869 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2870 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2871 | "dev": true 2872 | }, 2873 | "execa": { 2874 | "version": "5.1.1", 2875 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 2876 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 2877 | "dev": true, 2878 | "requires": { 2879 | "cross-spawn": "^7.0.3", 2880 | "get-stream": "^6.0.0", 2881 | "human-signals": "^2.1.0", 2882 | "is-stream": "^2.0.0", 2883 | "merge-stream": "^2.0.0", 2884 | "npm-run-path": "^4.0.1", 2885 | "onetime": "^5.1.2", 2886 | "signal-exit": "^3.0.3", 2887 | "strip-final-newline": "^2.0.0" 2888 | } 2889 | }, 2890 | "expect": { 2891 | "version": "27.5.1", 2892 | "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", 2893 | "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", 2894 | "dev": true, 2895 | "requires": { 2896 | "@jest/types": "^27.5.1", 2897 | "jest-get-type": "^27.5.1", 2898 | "jest-matcher-utils": "^27.5.1", 2899 | "jest-message-util": "^27.5.1" 2900 | } 2901 | }, 2902 | "fill-range": { 2903 | "version": "7.0.1", 2904 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2905 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2906 | "dev": true, 2907 | "requires": { 2908 | "to-regex-range": "^5.0.1" 2909 | } 2910 | }, 2911 | "find-up": { 2912 | "version": "5.0.0", 2913 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2914 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2915 | "dev": true, 2916 | "requires": { 2917 | "locate-path": "^6.0.0", 2918 | "path-exists": "^4.0.0" 2919 | } 2920 | }, 2921 | "flat": { 2922 | "version": "5.0.2", 2923 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 2924 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 2925 | "dev": true 2926 | }, 2927 | "fs.realpath": { 2928 | "version": "1.0.0", 2929 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2930 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2931 | "dev": true 2932 | }, 2933 | "fsevents": { 2934 | "version": "2.3.2", 2935 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2936 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2937 | "dev": true, 2938 | "optional": true 2939 | }, 2940 | "get-caller-file": { 2941 | "version": "2.0.5", 2942 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2943 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2944 | "dev": true 2945 | }, 2946 | "get-func-name": { 2947 | "version": "2.0.0", 2948 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 2949 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 2950 | "dev": true 2951 | }, 2952 | "get-stream": { 2953 | "version": "6.0.1", 2954 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 2955 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 2956 | "dev": true 2957 | }, 2958 | "glob": { 2959 | "version": "7.2.0", 2960 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 2961 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 2962 | "dev": true, 2963 | "requires": { 2964 | "fs.realpath": "^1.0.0", 2965 | "inflight": "^1.0.4", 2966 | "inherits": "2", 2967 | "minimatch": "^3.0.4", 2968 | "once": "^1.3.0", 2969 | "path-is-absolute": "^1.0.0" 2970 | } 2971 | }, 2972 | "glob-parent": { 2973 | "version": "5.1.2", 2974 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2975 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2976 | "dev": true, 2977 | "requires": { 2978 | "is-glob": "^4.0.1" 2979 | } 2980 | }, 2981 | "graceful-fs": { 2982 | "version": "4.2.9", 2983 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 2984 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", 2985 | "dev": true 2986 | }, 2987 | "growl": { 2988 | "version": "1.10.5", 2989 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 2990 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 2991 | "dev": true 2992 | }, 2993 | "has-flag": { 2994 | "version": "4.0.0", 2995 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2996 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2997 | "dev": true 2998 | }, 2999 | "he": { 3000 | "version": "1.2.0", 3001 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 3002 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 3003 | "dev": true 3004 | }, 3005 | "human-signals": { 3006 | "version": "2.1.0", 3007 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 3008 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 3009 | "dev": true 3010 | }, 3011 | "husky": { 3012 | "version": "7.0.4", 3013 | "resolved": "https://registry.npmjs.org/husky/-/husky-7.0.4.tgz", 3014 | "integrity": "sha512-vbaCKN2QLtP/vD4yvs6iz6hBEo6wkSzs8HpRah1Z6aGmF2KW5PdYuAd7uX5a+OyBZHBhd+TFLqgjUgytQr4RvQ==", 3015 | "dev": true 3016 | }, 3017 | "indent-string": { 3018 | "version": "4.0.0", 3019 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 3020 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 3021 | "dev": true 3022 | }, 3023 | "inflight": { 3024 | "version": "1.0.6", 3025 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 3026 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 3027 | "dev": true, 3028 | "requires": { 3029 | "once": "^1.3.0", 3030 | "wrappy": "1" 3031 | } 3032 | }, 3033 | "inherits": { 3034 | "version": "2.0.4", 3035 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3036 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 3037 | "dev": true 3038 | }, 3039 | "is-binary-path": { 3040 | "version": "2.1.0", 3041 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 3042 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 3043 | "dev": true, 3044 | "requires": { 3045 | "binary-extensions": "^2.0.0" 3046 | } 3047 | }, 3048 | "is-extglob": { 3049 | "version": "2.1.1", 3050 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 3051 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 3052 | "dev": true 3053 | }, 3054 | "is-fullwidth-code-point": { 3055 | "version": "3.0.0", 3056 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3057 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3058 | "dev": true 3059 | }, 3060 | "is-glob": { 3061 | "version": "4.0.3", 3062 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 3063 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 3064 | "dev": true, 3065 | "requires": { 3066 | "is-extglob": "^2.1.1" 3067 | } 3068 | }, 3069 | "is-number": { 3070 | "version": "7.0.0", 3071 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 3072 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 3073 | "dev": true 3074 | }, 3075 | "is-plain-obj": { 3076 | "version": "2.1.0", 3077 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 3078 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 3079 | "dev": true 3080 | }, 3081 | "is-stream": { 3082 | "version": "2.0.1", 3083 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 3084 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 3085 | "dev": true 3086 | }, 3087 | "is-unicode-supported": { 3088 | "version": "0.1.0", 3089 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 3090 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 3091 | "dev": true 3092 | }, 3093 | "isarray": { 3094 | "version": "0.0.1", 3095 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 3096 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 3097 | "dev": true 3098 | }, 3099 | "isexe": { 3100 | "version": "2.0.0", 3101 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 3102 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 3103 | "dev": true 3104 | }, 3105 | "jest-diff": { 3106 | "version": "27.5.1", 3107 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", 3108 | "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", 3109 | "dev": true, 3110 | "requires": { 3111 | "chalk": "^4.0.0", 3112 | "diff-sequences": "^27.5.1", 3113 | "jest-get-type": "^27.5.1", 3114 | "pretty-format": "^27.5.1" 3115 | } 3116 | }, 3117 | "jest-get-type": { 3118 | "version": "27.5.1", 3119 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", 3120 | "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", 3121 | "dev": true 3122 | }, 3123 | "jest-matcher-utils": { 3124 | "version": "27.5.1", 3125 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", 3126 | "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", 3127 | "dev": true, 3128 | "requires": { 3129 | "chalk": "^4.0.0", 3130 | "jest-diff": "^27.5.1", 3131 | "jest-get-type": "^27.5.1", 3132 | "pretty-format": "^27.5.1" 3133 | } 3134 | }, 3135 | "jest-message-util": { 3136 | "version": "27.5.1", 3137 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", 3138 | "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", 3139 | "dev": true, 3140 | "requires": { 3141 | "@babel/code-frame": "^7.12.13", 3142 | "@jest/types": "^27.5.1", 3143 | "@types/stack-utils": "^2.0.0", 3144 | "chalk": "^4.0.0", 3145 | "graceful-fs": "^4.2.9", 3146 | "micromatch": "^4.0.4", 3147 | "pretty-format": "^27.5.1", 3148 | "slash": "^3.0.0", 3149 | "stack-utils": "^2.0.3" 3150 | } 3151 | }, 3152 | "js-tokens": { 3153 | "version": "4.0.0", 3154 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 3155 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 3156 | "dev": true 3157 | }, 3158 | "js-yaml": { 3159 | "version": "4.1.0", 3160 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 3161 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 3162 | "dev": true, 3163 | "requires": { 3164 | "argparse": "^2.0.1" 3165 | } 3166 | }, 3167 | "just-extend": { 3168 | "version": "4.2.1", 3169 | "resolved": "https://registry.npmjs.org/just-extend/-/just-extend-4.2.1.tgz", 3170 | "integrity": "sha512-g3UB796vUFIY90VIv/WX3L2c8CS2MdWUww3CNrYmqza1Fg0DURc2K/O4YrnklBdQarSJ/y8JnJYDGc+1iumQjg==", 3171 | "dev": true 3172 | }, 3173 | "lilconfig": { 3174 | "version": "2.0.4", 3175 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.4.tgz", 3176 | "integrity": "sha512-bfTIN7lEsiooCocSISTWXkiWJkRqtL9wYtYy+8EK3Y41qh3mpwPU0ycTOgjdY9ErwXCc8QyrQp82bdL0Xkm9yA==", 3177 | "dev": true 3178 | }, 3179 | "lint-staged": { 3180 | "version": "12.3.3", 3181 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-12.3.3.tgz", 3182 | "integrity": "sha512-OqcLsqcPOqzvsfkxjeBpZylgJ3SRG1RYqc9LxC6tkt6tNsq1bNVkAixBwX09f6CobcHswzqVOCBpFR1Fck0+ag==", 3183 | "dev": true, 3184 | "requires": { 3185 | "cli-truncate": "^3.1.0", 3186 | "colorette": "^2.0.16", 3187 | "commander": "^8.3.0", 3188 | "debug": "^4.3.3", 3189 | "execa": "^5.1.1", 3190 | "lilconfig": "2.0.4", 3191 | "listr2": "^4.0.1", 3192 | "micromatch": "^4.0.4", 3193 | "normalize-path": "^3.0.0", 3194 | "object-inspect": "^1.12.0", 3195 | "string-argv": "^0.3.1", 3196 | "supports-color": "^9.2.1", 3197 | "yaml": "^1.10.2" 3198 | }, 3199 | "dependencies": { 3200 | "supports-color": { 3201 | "version": "9.2.1", 3202 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-9.2.1.tgz", 3203 | "integrity": "sha512-Obv7ycoCTG51N7y175StI9BlAXrmgZrFhZOb0/PyjHBher/NmsdBgbbQ1Inhq+gIhz6+7Gb+jWF2Vqi7Mf1xnQ==", 3204 | "dev": true 3205 | } 3206 | } 3207 | }, 3208 | "listr2": { 3209 | "version": "4.0.2", 3210 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-4.0.2.tgz", 3211 | "integrity": "sha512-YcgwfCWpvPbj9FLUGqvdFvd3hrFWKpOeuXznRgfWEJ7RNr8b/IKKIKZABHx3aU+4CWN/iSAFFSReziQG6vTeIA==", 3212 | "dev": true, 3213 | "requires": { 3214 | "cli-truncate": "^2.1.0", 3215 | "colorette": "^2.0.16", 3216 | "log-update": "^4.0.0", 3217 | "p-map": "^4.0.0", 3218 | "rfdc": "^1.3.0", 3219 | "rxjs": "^7.5.2", 3220 | "through": "^2.3.8", 3221 | "wrap-ansi": "^7.0.0" 3222 | }, 3223 | "dependencies": { 3224 | "cli-truncate": { 3225 | "version": "2.1.0", 3226 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 3227 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 3228 | "dev": true, 3229 | "requires": { 3230 | "slice-ansi": "^3.0.0", 3231 | "string-width": "^4.2.0" 3232 | } 3233 | }, 3234 | "slice-ansi": { 3235 | "version": "3.0.0", 3236 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 3237 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 3238 | "dev": true, 3239 | "requires": { 3240 | "ansi-styles": "^4.0.0", 3241 | "astral-regex": "^2.0.0", 3242 | "is-fullwidth-code-point": "^3.0.0" 3243 | } 3244 | } 3245 | } 3246 | }, 3247 | "locate-path": { 3248 | "version": "6.0.0", 3249 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 3250 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 3251 | "dev": true, 3252 | "requires": { 3253 | "p-locate": "^5.0.0" 3254 | } 3255 | }, 3256 | "lodash.get": { 3257 | "version": "4.4.2", 3258 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 3259 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=", 3260 | "dev": true 3261 | }, 3262 | "log-symbols": { 3263 | "version": "4.1.0", 3264 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 3265 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 3266 | "dev": true, 3267 | "requires": { 3268 | "chalk": "^4.1.0", 3269 | "is-unicode-supported": "^0.1.0" 3270 | } 3271 | }, 3272 | "log-update": { 3273 | "version": "4.0.0", 3274 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 3275 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 3276 | "dev": true, 3277 | "requires": { 3278 | "ansi-escapes": "^4.3.0", 3279 | "cli-cursor": "^3.1.0", 3280 | "slice-ansi": "^4.0.0", 3281 | "wrap-ansi": "^6.2.0" 3282 | }, 3283 | "dependencies": { 3284 | "slice-ansi": { 3285 | "version": "4.0.0", 3286 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 3287 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 3288 | "dev": true, 3289 | "requires": { 3290 | "ansi-styles": "^4.0.0", 3291 | "astral-regex": "^2.0.0", 3292 | "is-fullwidth-code-point": "^3.0.0" 3293 | } 3294 | }, 3295 | "wrap-ansi": { 3296 | "version": "6.2.0", 3297 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 3298 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 3299 | "dev": true, 3300 | "requires": { 3301 | "ansi-styles": "^4.0.0", 3302 | "string-width": "^4.1.0", 3303 | "strip-ansi": "^6.0.0" 3304 | } 3305 | } 3306 | } 3307 | }, 3308 | "loupe": { 3309 | "version": "2.3.3", 3310 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.3.tgz", 3311 | "integrity": "sha512-krIV4Cf1BIGIx2t1e6tucThhrBemUnIUjMtD2vN4mrMxnxpBvrcosBSpooqunBqP/hOEEV1w/Cr1YskGtqw5Jg==", 3312 | "dev": true, 3313 | "requires": { 3314 | "get-func-name": "^2.0.0" 3315 | } 3316 | }, 3317 | "make-error": { 3318 | "version": "1.3.6", 3319 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 3320 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 3321 | "dev": true 3322 | }, 3323 | "merge-stream": { 3324 | "version": "2.0.0", 3325 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 3326 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 3327 | "dev": true 3328 | }, 3329 | "micromatch": { 3330 | "version": "4.0.4", 3331 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 3332 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 3333 | "dev": true, 3334 | "requires": { 3335 | "braces": "^3.0.1", 3336 | "picomatch": "^2.2.3" 3337 | } 3338 | }, 3339 | "mimic-fn": { 3340 | "version": "2.1.0", 3341 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 3342 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 3343 | "dev": true 3344 | }, 3345 | "minimatch": { 3346 | "version": "3.1.2", 3347 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3348 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3349 | "dev": true, 3350 | "requires": { 3351 | "brace-expansion": "^1.1.7" 3352 | } 3353 | }, 3354 | "minimist": { 3355 | "version": "1.2.6", 3356 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 3357 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 3358 | "dev": true 3359 | }, 3360 | "mkdirp": { 3361 | "version": "0.5.5", 3362 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 3363 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 3364 | "dev": true, 3365 | "requires": { 3366 | "minimist": "^1.2.5" 3367 | } 3368 | }, 3369 | "mocha": { 3370 | "version": "9.2.2", 3371 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.2.2.tgz", 3372 | "integrity": "sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g==", 3373 | "dev": true, 3374 | "requires": { 3375 | "@ungap/promise-all-settled": "1.1.2", 3376 | "ansi-colors": "4.1.1", 3377 | "browser-stdout": "1.3.1", 3378 | "chokidar": "3.5.3", 3379 | "debug": "4.3.3", 3380 | "diff": "5.0.0", 3381 | "escape-string-regexp": "4.0.0", 3382 | "find-up": "5.0.0", 3383 | "glob": "7.2.0", 3384 | "growl": "1.10.5", 3385 | "he": "1.2.0", 3386 | "js-yaml": "4.1.0", 3387 | "log-symbols": "4.1.0", 3388 | "minimatch": "4.2.1", 3389 | "ms": "2.1.3", 3390 | "nanoid": "3.3.1", 3391 | "serialize-javascript": "6.0.0", 3392 | "strip-json-comments": "3.1.1", 3393 | "supports-color": "8.1.1", 3394 | "which": "2.0.2", 3395 | "workerpool": "6.2.0", 3396 | "yargs": "16.2.0", 3397 | "yargs-parser": "20.2.4", 3398 | "yargs-unparser": "2.0.0" 3399 | }, 3400 | "dependencies": { 3401 | "minimatch": { 3402 | "version": "4.2.1", 3403 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-4.2.1.tgz", 3404 | "integrity": "sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g==", 3405 | "dev": true, 3406 | "requires": { 3407 | "brace-expansion": "^1.1.7" 3408 | } 3409 | }, 3410 | "ms": { 3411 | "version": "2.1.3", 3412 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 3413 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 3414 | "dev": true 3415 | }, 3416 | "supports-color": { 3417 | "version": "8.1.1", 3418 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 3419 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 3420 | "dev": true, 3421 | "requires": { 3422 | "has-flag": "^4.0.0" 3423 | } 3424 | } 3425 | } 3426 | }, 3427 | "ms": { 3428 | "version": "2.1.2", 3429 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3430 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3431 | "dev": true 3432 | }, 3433 | "nanoid": { 3434 | "version": "3.3.1", 3435 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.1.tgz", 3436 | "integrity": "sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw==", 3437 | "dev": true 3438 | }, 3439 | "nise": { 3440 | "version": "5.1.1", 3441 | "resolved": "https://registry.npmjs.org/nise/-/nise-5.1.1.tgz", 3442 | "integrity": "sha512-yr5kW2THW1AkxVmCnKEh4nbYkJdB3I7LUkiUgOvEkOp414mc2UMaHMA7pjq1nYowhdoJZGwEKGaQVbxfpWj10A==", 3443 | "dev": true, 3444 | "requires": { 3445 | "@sinonjs/commons": "^1.8.3", 3446 | "@sinonjs/fake-timers": ">=5", 3447 | "@sinonjs/text-encoding": "^0.7.1", 3448 | "just-extend": "^4.0.2", 3449 | "path-to-regexp": "^1.7.0" 3450 | } 3451 | }, 3452 | "normalize-path": { 3453 | "version": "3.0.0", 3454 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3455 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 3456 | "dev": true 3457 | }, 3458 | "npm-run-path": { 3459 | "version": "4.0.1", 3460 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 3461 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 3462 | "dev": true, 3463 | "requires": { 3464 | "path-key": "^3.0.0" 3465 | } 3466 | }, 3467 | "object-inspect": { 3468 | "version": "1.12.0", 3469 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", 3470 | "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==", 3471 | "dev": true 3472 | }, 3473 | "once": { 3474 | "version": "1.4.0", 3475 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3476 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 3477 | "dev": true, 3478 | "requires": { 3479 | "wrappy": "1" 3480 | } 3481 | }, 3482 | "onetime": { 3483 | "version": "5.1.2", 3484 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 3485 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 3486 | "dev": true, 3487 | "requires": { 3488 | "mimic-fn": "^2.1.0" 3489 | } 3490 | }, 3491 | "p-limit": { 3492 | "version": "3.1.0", 3493 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3494 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3495 | "dev": true, 3496 | "requires": { 3497 | "yocto-queue": "^0.1.0" 3498 | } 3499 | }, 3500 | "p-locate": { 3501 | "version": "5.0.0", 3502 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 3503 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 3504 | "dev": true, 3505 | "requires": { 3506 | "p-limit": "^3.0.2" 3507 | } 3508 | }, 3509 | "p-map": { 3510 | "version": "4.0.0", 3511 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 3512 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 3513 | "dev": true, 3514 | "requires": { 3515 | "aggregate-error": "^3.0.0" 3516 | } 3517 | }, 3518 | "path-exists": { 3519 | "version": "4.0.0", 3520 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3521 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3522 | "dev": true 3523 | }, 3524 | "path-is-absolute": { 3525 | "version": "1.0.1", 3526 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3527 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 3528 | "dev": true 3529 | }, 3530 | "path-key": { 3531 | "version": "3.1.1", 3532 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3533 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3534 | "dev": true 3535 | }, 3536 | "path-to-regexp": { 3537 | "version": "1.8.0", 3538 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-1.8.0.tgz", 3539 | "integrity": "sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA==", 3540 | "dev": true, 3541 | "requires": { 3542 | "isarray": "0.0.1" 3543 | } 3544 | }, 3545 | "pathval": { 3546 | "version": "1.1.1", 3547 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 3548 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 3549 | "dev": true 3550 | }, 3551 | "picomatch": { 3552 | "version": "2.3.0", 3553 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 3554 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 3555 | "dev": true 3556 | }, 3557 | "prettier": { 3558 | "version": "2.5.1", 3559 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.5.1.tgz", 3560 | "integrity": "sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==", 3561 | "dev": true 3562 | }, 3563 | "pretty-format": { 3564 | "version": "27.5.1", 3565 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", 3566 | "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", 3567 | "dev": true, 3568 | "requires": { 3569 | "ansi-regex": "^5.0.1", 3570 | "ansi-styles": "^5.0.0", 3571 | "react-is": "^17.0.1" 3572 | }, 3573 | "dependencies": { 3574 | "ansi-styles": { 3575 | "version": "5.2.0", 3576 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 3577 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 3578 | "dev": true 3579 | } 3580 | } 3581 | }, 3582 | "randombytes": { 3583 | "version": "2.1.0", 3584 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 3585 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 3586 | "dev": true, 3587 | "requires": { 3588 | "safe-buffer": "^5.1.0" 3589 | } 3590 | }, 3591 | "react-is": { 3592 | "version": "17.0.2", 3593 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 3594 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", 3595 | "dev": true 3596 | }, 3597 | "readdirp": { 3598 | "version": "3.6.0", 3599 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3600 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3601 | "dev": true, 3602 | "requires": { 3603 | "picomatch": "^2.2.1" 3604 | } 3605 | }, 3606 | "require-directory": { 3607 | "version": "2.1.1", 3608 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3609 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3610 | "dev": true 3611 | }, 3612 | "restore-cursor": { 3613 | "version": "3.1.0", 3614 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 3615 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 3616 | "dev": true, 3617 | "requires": { 3618 | "onetime": "^5.1.0", 3619 | "signal-exit": "^3.0.2" 3620 | } 3621 | }, 3622 | "rfdc": { 3623 | "version": "1.3.0", 3624 | "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", 3625 | "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", 3626 | "dev": true 3627 | }, 3628 | "rimraf": { 3629 | "version": "3.0.2", 3630 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3631 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3632 | "dev": true, 3633 | "requires": { 3634 | "glob": "^7.1.3" 3635 | } 3636 | }, 3637 | "rxjs": { 3638 | "version": "7.5.2", 3639 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.2.tgz", 3640 | "integrity": "sha512-PwDt186XaL3QN5qXj/H9DGyHhP3/RYYgZZwqBv9Tv8rsAaiwFH1IsJJlcgD37J7UW5a6O67qX0KWKS3/pu0m4w==", 3641 | "dev": true, 3642 | "requires": { 3643 | "tslib": "^2.1.0" 3644 | } 3645 | }, 3646 | "safe-buffer": { 3647 | "version": "5.1.2", 3648 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3649 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 3650 | "dev": true 3651 | }, 3652 | "serialize-javascript": { 3653 | "version": "6.0.0", 3654 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 3655 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 3656 | "dev": true, 3657 | "requires": { 3658 | "randombytes": "^2.1.0" 3659 | } 3660 | }, 3661 | "shebang-command": { 3662 | "version": "2.0.0", 3663 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3664 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3665 | "dev": true, 3666 | "requires": { 3667 | "shebang-regex": "^3.0.0" 3668 | } 3669 | }, 3670 | "shebang-regex": { 3671 | "version": "3.0.0", 3672 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3673 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3674 | "dev": true 3675 | }, 3676 | "signal-exit": { 3677 | "version": "3.0.5", 3678 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.5.tgz", 3679 | "integrity": "sha512-KWcOiKeQj6ZyXx7zq4YxSMgHRlod4czeBQZrPb8OKcohcqAXShm7E20kEMle9WBt26hFcAf0qLOcp5zmY7kOqQ==", 3680 | "dev": true 3681 | }, 3682 | "sinon": { 3683 | "version": "13.0.1", 3684 | "resolved": "https://registry.npmjs.org/sinon/-/sinon-13.0.1.tgz", 3685 | "integrity": "sha512-8yx2wIvkBjIq/MGY1D9h1LMraYW+z1X0mb648KZnKSdvLasvDu7maa0dFaNYdTDczFgbjNw2tOmWdTk9saVfwQ==", 3686 | "dev": true, 3687 | "requires": { 3688 | "@sinonjs/commons": "^1.8.3", 3689 | "@sinonjs/fake-timers": "^9.0.0", 3690 | "@sinonjs/samsam": "^6.1.1", 3691 | "diff": "^5.0.0", 3692 | "nise": "^5.1.1", 3693 | "supports-color": "^7.2.0" 3694 | } 3695 | }, 3696 | "slash": { 3697 | "version": "3.0.0", 3698 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3699 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3700 | "dev": true 3701 | }, 3702 | "slice-ansi": { 3703 | "version": "5.0.0", 3704 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", 3705 | "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", 3706 | "dev": true, 3707 | "requires": { 3708 | "ansi-styles": "^6.0.0", 3709 | "is-fullwidth-code-point": "^4.0.0" 3710 | }, 3711 | "dependencies": { 3712 | "ansi-styles": { 3713 | "version": "6.1.0", 3714 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.1.0.tgz", 3715 | "integrity": "sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ==", 3716 | "dev": true 3717 | }, 3718 | "is-fullwidth-code-point": { 3719 | "version": "4.0.0", 3720 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", 3721 | "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", 3722 | "dev": true 3723 | } 3724 | } 3725 | }, 3726 | "source-map-support": { 3727 | "version": "0.5.21", 3728 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 3729 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 3730 | "dev": true, 3731 | "requires": { 3732 | "buffer-from": "^1.0.0", 3733 | "source-map": "^0.6.0" 3734 | }, 3735 | "dependencies": { 3736 | "source-map": { 3737 | "version": "0.6.1", 3738 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3739 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3740 | "dev": true 3741 | } 3742 | } 3743 | }, 3744 | "stack-utils": { 3745 | "version": "2.0.5", 3746 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", 3747 | "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", 3748 | "dev": true, 3749 | "requires": { 3750 | "escape-string-regexp": "^2.0.0" 3751 | }, 3752 | "dependencies": { 3753 | "escape-string-regexp": { 3754 | "version": "2.0.0", 3755 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 3756 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 3757 | "dev": true 3758 | } 3759 | } 3760 | }, 3761 | "string-argv": { 3762 | "version": "0.3.1", 3763 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 3764 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 3765 | "dev": true 3766 | }, 3767 | "string-width": { 3768 | "version": "4.2.3", 3769 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3770 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3771 | "dev": true, 3772 | "requires": { 3773 | "emoji-regex": "^8.0.0", 3774 | "is-fullwidth-code-point": "^3.0.0", 3775 | "strip-ansi": "^6.0.1" 3776 | } 3777 | }, 3778 | "strip-ansi": { 3779 | "version": "6.0.1", 3780 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3781 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3782 | "dev": true, 3783 | "requires": { 3784 | "ansi-regex": "^5.0.1" 3785 | } 3786 | }, 3787 | "strip-final-newline": { 3788 | "version": "2.0.0", 3789 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3790 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3791 | "dev": true 3792 | }, 3793 | "strip-json-comments": { 3794 | "version": "3.1.1", 3795 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3796 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3797 | "dev": true 3798 | }, 3799 | "supports-color": { 3800 | "version": "7.2.0", 3801 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3802 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3803 | "dev": true, 3804 | "requires": { 3805 | "has-flag": "^4.0.0" 3806 | } 3807 | }, 3808 | "through": { 3809 | "version": "2.3.8", 3810 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3811 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3812 | "dev": true 3813 | }, 3814 | "to-regex-range": { 3815 | "version": "5.0.1", 3816 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3817 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3818 | "dev": true, 3819 | "requires": { 3820 | "is-number": "^7.0.0" 3821 | } 3822 | }, 3823 | "ts-mocha": { 3824 | "version": "9.0.2", 3825 | "resolved": "https://registry.npmjs.org/ts-mocha/-/ts-mocha-9.0.2.tgz", 3826 | "integrity": "sha512-WyQjvnzwrrubl0JT7EC1yWmNpcsU3fOuBFfdps30zbmFBgKniSaSOyZMZx+Wq7kytUs5CY+pEbSYEbGfIKnXTw==", 3827 | "dev": true, 3828 | "requires": { 3829 | "ts-node": "7.0.1", 3830 | "tsconfig-paths": "^3.5.0" 3831 | } 3832 | }, 3833 | "ts-node": { 3834 | "version": "7.0.1", 3835 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-7.0.1.tgz", 3836 | "integrity": "sha512-BVwVbPJRspzNh2yfslyT1PSbl5uIk03EZlb493RKHN4qej/D06n1cEhjlOJG69oFsE7OT8XjpTUcYf6pKTLMhw==", 3837 | "dev": true, 3838 | "requires": { 3839 | "arrify": "^1.0.0", 3840 | "buffer-from": "^1.1.0", 3841 | "diff": "^3.1.0", 3842 | "make-error": "^1.1.1", 3843 | "minimist": "^1.2.0", 3844 | "mkdirp": "^0.5.1", 3845 | "source-map-support": "^0.5.6", 3846 | "yn": "^2.0.0" 3847 | }, 3848 | "dependencies": { 3849 | "diff": { 3850 | "version": "3.5.0", 3851 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 3852 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 3853 | "dev": true 3854 | } 3855 | } 3856 | }, 3857 | "tsconfig-paths": { 3858 | "version": "3.12.0", 3859 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.12.0.tgz", 3860 | "integrity": "sha512-e5adrnOYT6zqVnWqZu7i/BQ3BnhzvGbjEjejFXO20lKIKpwTaupkCPgEfv4GZK1IBciJUEhYs3J3p75FdaTFVg==", 3861 | "dev": true, 3862 | "optional": true, 3863 | "requires": { 3864 | "@types/json5": "^0.0.29", 3865 | "json5": "^1.0.1", 3866 | "minimist": "^1.2.0", 3867 | "strip-bom": "^3.0.0" 3868 | }, 3869 | "dependencies": { 3870 | "json5": { 3871 | "version": "1.0.1", 3872 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 3873 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 3874 | "dev": true, 3875 | "optional": true, 3876 | "requires": { 3877 | "minimist": "^1.2.0" 3878 | } 3879 | }, 3880 | "strip-bom": { 3881 | "version": "3.0.0", 3882 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3883 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 3884 | "dev": true, 3885 | "optional": true 3886 | } 3887 | } 3888 | }, 3889 | "tslib": { 3890 | "version": "2.3.1", 3891 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 3892 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 3893 | "dev": true 3894 | }, 3895 | "type-detect": { 3896 | "version": "4.0.8", 3897 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3898 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3899 | "dev": true 3900 | }, 3901 | "type-fest": { 3902 | "version": "0.21.3", 3903 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3904 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3905 | "dev": true 3906 | }, 3907 | "typescript": { 3908 | "version": "4.5.5", 3909 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.5.tgz", 3910 | "integrity": "sha512-TCTIul70LyWe6IJWT8QSYeA54WQe8EjQFU4wY52Fasj5UKx88LNYKCgBEHcOMOrFF1rKGbD8v/xcNWVUq9SymA==", 3911 | "dev": true 3912 | }, 3913 | "which": { 3914 | "version": "2.0.2", 3915 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3916 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3917 | "dev": true, 3918 | "requires": { 3919 | "isexe": "^2.0.0" 3920 | } 3921 | }, 3922 | "workerpool": { 3923 | "version": "6.2.0", 3924 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.0.tgz", 3925 | "integrity": "sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A==", 3926 | "dev": true 3927 | }, 3928 | "wrap-ansi": { 3929 | "version": "7.0.0", 3930 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3931 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3932 | "dev": true, 3933 | "requires": { 3934 | "ansi-styles": "^4.0.0", 3935 | "string-width": "^4.1.0", 3936 | "strip-ansi": "^6.0.0" 3937 | } 3938 | }, 3939 | "wrappy": { 3940 | "version": "1.0.2", 3941 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3942 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3943 | "dev": true 3944 | }, 3945 | "y18n": { 3946 | "version": "5.0.8", 3947 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3948 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3949 | "dev": true 3950 | }, 3951 | "yaml": { 3952 | "version": "1.10.2", 3953 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 3954 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 3955 | "dev": true 3956 | }, 3957 | "yargs": { 3958 | "version": "16.2.0", 3959 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3960 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3961 | "dev": true, 3962 | "requires": { 3963 | "cliui": "^7.0.2", 3964 | "escalade": "^3.1.1", 3965 | "get-caller-file": "^2.0.5", 3966 | "require-directory": "^2.1.1", 3967 | "string-width": "^4.2.0", 3968 | "y18n": "^5.0.5", 3969 | "yargs-parser": "^20.2.2" 3970 | } 3971 | }, 3972 | "yargs-parser": { 3973 | "version": "20.2.4", 3974 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3975 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3976 | "dev": true 3977 | }, 3978 | "yargs-unparser": { 3979 | "version": "2.0.0", 3980 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3981 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3982 | "dev": true, 3983 | "requires": { 3984 | "camelcase": "^6.0.0", 3985 | "decamelize": "^4.0.0", 3986 | "flat": "^5.0.2", 3987 | "is-plain-obj": "^2.1.0" 3988 | }, 3989 | "dependencies": { 3990 | "camelcase": { 3991 | "version": "6.2.0", 3992 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 3993 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 3994 | "dev": true 3995 | }, 3996 | "decamelize": { 3997 | "version": "4.0.0", 3998 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 3999 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 4000 | "dev": true 4001 | } 4002 | } 4003 | }, 4004 | "yn": { 4005 | "version": "2.0.0", 4006 | "resolved": "https://registry.npmjs.org/yn/-/yn-2.0.0.tgz", 4007 | "integrity": "sha1-5a2ryKz0CPY4X8dklWhMiOavaJo=", 4008 | "dev": true 4009 | }, 4010 | "yocto-queue": { 4011 | "version": "0.1.0", 4012 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4013 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4014 | "dev": true 4015 | } 4016 | } 4017 | } 4018 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ulid-workers", 3 | "version": "2.1.0", 4 | "description": "ULID generator for Cloudflare workers", 5 | "main": "dist/index.js", 6 | "types": "dist/index.d.ts", 7 | "scripts": { 8 | "build": "npm run clean && tsc", 9 | "clean": "rimraf dist", 10 | "format": "prettier --write \"{src,test}/**/*.ts\"", 11 | "prepublishOnly": "npm run build", 12 | "test": "npm run build && npm run test:format && npm run test:specs", 13 | "test:format": "prettier --check \"{src,test}/**/*.ts\"", 14 | "test:specs": "npx ts-mocha -t 10000 --check-leaks --global crypto test/**/*.spec.ts", 15 | "prepare": "husky install" 16 | }, 17 | "files": [ 18 | "dist/**/*", 19 | "CHANGELOG.md" 20 | ], 21 | "lint-staged": { 22 | "{source,test}/**/*.{js,ts}": [ 23 | "prettier --write" 24 | ] 25 | }, 26 | "repository": { 27 | "type": "git", 28 | "url": "git+https://github.com/ryan-mars/ulid-workers.git" 29 | }, 30 | "keywords": [ 31 | "ulid", 32 | "uuid", 33 | "id", 34 | "generator", 35 | "guid" 36 | ], 37 | "author": "Ryan Marsh ", 38 | "contributors": [ 39 | "Glenn Rempe " 40 | ], 41 | "license": "MIT", 42 | "bugs": { 43 | "url": "https://github.com/ryan-mars/ulid-workers/issues" 44 | }, 45 | "homepage": "https://github.com/ryan-mars/ulid-workers#readme", 46 | "devDependencies": { 47 | "@types/expect": "^24.3.0", 48 | "@types/mocha": "^9.1.0", 49 | "@types/node": "^17.0.16", 50 | "@types/sinon": "^10.0.11", 51 | "chai": "^4.3.6", 52 | "husky": "^7.0.4", 53 | "lint-staged": "^12.3.3", 54 | "mocha": "^9.2.0", 55 | "prettier": "^2.5.1", 56 | "rimraf": "^3.0.2", 57 | "sinon": "^13.0.1", 58 | "ts-mocha": "^9.0.2", 59 | "typescript": "^4.5.5" 60 | } 61 | } 62 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | export { decodeTime, encodeTime, ulidFactory } from "./ulid"; 2 | export type { ULID, ULIDFactory, ULIDFactoryArgs } from "./ulid"; 3 | -------------------------------------------------------------------------------- /src/ulid.ts: -------------------------------------------------------------------------------- 1 | // Adapted from https://github.com/perry-mitchell/ulidx for use with Cloudflare 2 | // Workers and Durable Objects 3 | 4 | export type ULID = string; 5 | export type ULIDFactoryArgs = { 6 | monotonic?: boolean; 7 | }; 8 | export type ULIDFactory = (timestamp?: number) => ULID; 9 | 10 | // These values should NEVER change. The values are precisely for 11 | // generating ULIDs. 12 | const ENCODING = "0123456789ABCDEFGHJKMNPQRSTVWXYZ"; // Crockford's Base32 13 | const ENCODING_LEN = ENCODING.length; 14 | const TIME_MAX = Math.pow(2, 48) - 1; 15 | const TIME_LEN = 10; 16 | const RANDOM_LEN = 16; 17 | 18 | // The Cloudflare Workers Runtime implements the Web Crypto API 19 | // `crypto.getRandomValues` function to retrieve fast and secure 20 | // randomness. This function is not available in the Node.js 21 | // See : https://developers.cloudflare.com/workers/runtime-apis/web-crypto#methods 22 | function webCryptoPRNG() { 23 | const buffer = new Uint8Array(1); 24 | crypto.getRandomValues(buffer); 25 | return buffer[0] / 0xff; // divide by 0xff to get a number between 0 and 1 26 | } 27 | 28 | function encodeRandom(len: number): string { 29 | let str = ""; 30 | for (; len > 0; len--) { 31 | str = randomChar() + str; 32 | } 33 | return str; 34 | } 35 | 36 | function validateTimestamp(timestamp: number): void { 37 | if (isNaN(timestamp)) { 38 | throw new Error(`timestamp must be a number: ${timestamp}`); 39 | } else if (timestamp > TIME_MAX) { 40 | throw new Error( 41 | `cannot encode a timestamp larger than 2^48 - 1 (${TIME_MAX}) : ${timestamp}` 42 | ); 43 | } else if (timestamp < 0) { 44 | throw new Error(`timestamp must be positive: ${timestamp}`); 45 | } else if (Number.isInteger(timestamp) === false) { 46 | throw new Error(`timestamp must be an integer: ${timestamp}`); 47 | } 48 | } 49 | 50 | export function encodeTime(timestamp: number): string { 51 | validateTimestamp(timestamp); 52 | 53 | let mod: number; 54 | let str: string = ""; 55 | 56 | for (let tLen: number = TIME_LEN; tLen > 0; tLen--) { 57 | mod = timestamp % ENCODING_LEN; 58 | str = ENCODING.charAt(mod) + str; 59 | timestamp = (timestamp - mod) / ENCODING_LEN; 60 | } 61 | 62 | return str; 63 | } 64 | 65 | function incrementBase32(str: string): string { 66 | let done: string | undefined = undefined, 67 | index = str.length, 68 | char: string, 69 | charIndex: number, 70 | output = str; 71 | const maxCharIndex = ENCODING_LEN - 1; 72 | 73 | if (str.length > RANDOM_LEN) { 74 | throw new Error(`Base32 value to increment cannot be longer than ${RANDOM_LEN} characters`); 75 | } 76 | 77 | if (str === "Z".repeat(RANDOM_LEN)) { 78 | throw new Error(`Cannot increment Base32 maximum value ${"Z".repeat(RANDOM_LEN)}`); 79 | } 80 | 81 | while (!done && index-- >= 0) { 82 | char = output[index]; 83 | charIndex = ENCODING.indexOf(char); 84 | if (charIndex === -1) { 85 | throw new Error("Incorrectly encoded string"); 86 | } 87 | if (charIndex === maxCharIndex) { 88 | output = replaceCharAt(output, index, ENCODING[0]); 89 | continue; 90 | } 91 | done = replaceCharAt(output, index, ENCODING[charIndex + 1]); 92 | } 93 | if (typeof done === "string") { 94 | return done; 95 | } 96 | throw new Error("Failed incrementing string"); 97 | } 98 | 99 | function randomChar(): string { 100 | let rand = Math.floor(webCryptoPRNG() * ENCODING_LEN); 101 | if (rand === ENCODING_LEN) { 102 | rand = ENCODING_LEN - 1; 103 | } 104 | return ENCODING.charAt(rand); 105 | } 106 | 107 | function replaceCharAt(str: string, index: number, char: string): string { 108 | if (index > str.length - 1) { 109 | return str; 110 | } 111 | return str.substring(0, index) + char + str.substring(index + 1); 112 | } 113 | 114 | /** 115 | * Decode the time component of a ULID to a number representing the UNIX epoch timestamp in milliseconds. 116 | * @param {string} id - A ULID string. 117 | * @returns {number} The UNIX epoch timestamp in milliseconds. 118 | */ 119 | export function decodeTime(id: string): number { 120 | if (id.length !== TIME_LEN + RANDOM_LEN) { 121 | throw new Error("Malformed ULID"); 122 | } 123 | 124 | const time = id 125 | .substring(0, TIME_LEN) 126 | .split("") 127 | .reverse() 128 | .reduce((carry, char, index) => { 129 | const encodingIndex = ENCODING.indexOf(char); 130 | if (encodingIndex === -1) { 131 | throw new Error(`Time decode error: Invalid character: ${char}`); 132 | } 133 | return (carry += encodingIndex * Math.pow(ENCODING_LEN, index)); 134 | }, 0); 135 | 136 | if (time > TIME_MAX) { 137 | throw new Error(`Malformed ULID: timestamp too large: ${time}`); 138 | } 139 | 140 | return time; 141 | } 142 | 143 | /** 144 | * @param {ULIDFactoryArgs} args - An Object representing valid arguments for the ULID factory. 145 | * @returns {ULIDFactory} A function that generates ULIDs. 146 | */ 147 | export const ulidFactory = (args?: ULIDFactoryArgs): ULIDFactory => { 148 | const monotonic = args?.monotonic ?? true; 149 | 150 | if (monotonic) { 151 | return (function () { 152 | let lastTime: number = 0; 153 | let lastRandom: string; 154 | return function (timestamp?: number): ULID { 155 | let timestampOrNow: number = timestamp || Date.now(); 156 | validateTimestamp(timestampOrNow); 157 | 158 | if (timestampOrNow > lastTime) { 159 | lastTime = timestampOrNow; 160 | const random = encodeRandom(RANDOM_LEN); 161 | lastRandom = random; 162 | return encodeTime(timestampOrNow) + random; 163 | } else { 164 | // <= lastTime : increment lastRandom 165 | const random = incrementBase32(lastRandom); 166 | lastRandom = random; 167 | return encodeTime(lastTime) + random; 168 | } 169 | }; 170 | })(); 171 | } else { 172 | return (function () { 173 | return function (timestamp?: number): ULID { 174 | let timestampOrNow: number = timestamp || Date.now(); 175 | validateTimestamp(timestampOrNow); 176 | return encodeTime(timestampOrNow) + encodeRandom(RANDOM_LEN); 177 | }; 178 | })(); 179 | } 180 | }; 181 | 182 | // Don't publicly export private functions, but allow them to be tested. 183 | export const exportedForTesting = { 184 | encodeRandom, 185 | incrementBase32, 186 | randomChar, 187 | replaceCharAt, 188 | validateTimestamp, 189 | webCryptoPRNG, 190 | }; 191 | -------------------------------------------------------------------------------- /test/ulid.spec.ts: -------------------------------------------------------------------------------- 1 | // must use require() 2 | const nodeCrypto = require("crypto"); 3 | const sinon = require("sinon"); 4 | 5 | import { expect } from "chai"; 6 | import { decodeTime, encodeTime, ulidFactory } from "../src/index"; 7 | import { exportedForTesting } from "../src/ulid"; 8 | 9 | const { encodeRandom, incrementBase32, randomChar, validateTimestamp, webCryptoPRNG } = 10 | exportedForTesting; 11 | 12 | const TIME_LEN = 10; 13 | const RANDOM_LEN = 16; 14 | const TEST_ULID = "01ARYZ6S41TSV4RRFFQ69G5FAV"; 15 | const TEST_TIME_EPOCH_MS = 1469918176385; 16 | const TEST_TIME_ENCODED = TEST_ULID.substring(0, TIME_LEN); 17 | 18 | describe("ulid", function () { 19 | before(function () { 20 | // Web Crypto, specifically crypto.getRandomValues is not available in 21 | // Node.js. Stub out getRandomValues() using node crypto for local tests. 22 | // @ts-ignore-next-line 23 | global.crypto = { 24 | getRandomValues: function (buf) { 25 | if (!(buf instanceof Uint8Array)) { 26 | throw new TypeError("expected Uint8Array"); 27 | } 28 | const bytes = nodeCrypto.randomBytes(buf.length); 29 | buf.set(bytes); 30 | return buf; 31 | }, 32 | }; 33 | }); 34 | 35 | describe("decodeTime", function () { 36 | it("should return correct timestamp", function () { 37 | const timestamp = Date.now(); 38 | const ulid = ulidFactory({ monotonic: false }); 39 | const id = ulid(timestamp); 40 | expect(decodeTime(id)).to.equal(timestamp); 41 | }); 42 | 43 | // https://github.com/ulid/spec 44 | it("should return correct timestamp for README example", function () { 45 | expect(decodeTime(TEST_ULID)).to.equal(TEST_TIME_EPOCH_MS); 46 | }); 47 | 48 | it("should accept the maximum allowed timestamp", function () { 49 | expect(decodeTime("7ZZZZZZZZZZZZZZZZZZZZZZZZZ")).to.equal(281474976710655); 50 | }); 51 | 52 | describe("should reject", function () { 53 | it("malformed strings of incorrect length", function () { 54 | expect(() => { 55 | decodeTime("FFFF"); 56 | }).to.throw(/Malformed ULID/); 57 | }); 58 | 59 | it("strings with timestamps that are too high", function () { 60 | expect(() => { 61 | decodeTime("80000000000000000000000000"); 62 | }).to.throw(/Malformed ULID: timestamp too large/); 63 | }); 64 | }); 65 | }); 66 | 67 | describe("encodeRandom", function () { 68 | it("should return correct length", function () { 69 | expect(encodeRandom(12)).to.have.a.lengthOf(12); 70 | }); 71 | }); 72 | 73 | describe("encodeTime", function () { 74 | it("should return expected encoded result", function () { 75 | expect(encodeTime(TEST_TIME_EPOCH_MS)).to.equal(TEST_TIME_ENCODED); 76 | }); 77 | 78 | describe("should throw an error", function () { 79 | it("if validateTimestamp is being called", function () { 80 | expect(() => { 81 | encodeTime(Math.pow(2, 48)); 82 | }).to.throw(/cannot encode a timestamp larger than/); 83 | }); 84 | }); 85 | }); 86 | 87 | describe("incrementBase32", function () { 88 | it("should return expected result", function () { 89 | expect(incrementBase32("0".repeat(RANDOM_LEN))).to.equal("0000000000000001"); 90 | }); 91 | 92 | it("should return expected result", function () { 93 | expect(incrementBase32("0000000000000009")).to.equal("000000000000000A"); 94 | }); 95 | 96 | it("should return expected result", function () { 97 | expect(incrementBase32("000000000000000Z")).to.equal("0000000000000010"); 98 | }); 99 | 100 | describe("should throw an error", function () { 101 | it("if Base32 value length > RANDOM_LEN", function () { 102 | expect(() => { 103 | incrementBase32("0".repeat(RANDOM_LEN + 1)); 104 | }).to.throw(/Base32 value to increment cannot be longer than 16/); 105 | }); 106 | 107 | it("if at max random Base32 value", function () { 108 | expect(() => { 109 | incrementBase32("Z".repeat(RANDOM_LEN)); 110 | }).to.throw(/Cannot increment Base32 maximum value/); 111 | }); 112 | }); 113 | }); 114 | 115 | describe("validateTimestamp", function () { 116 | it("should return nothing for a valid timestamp", function () { 117 | expect(validateTimestamp(Date.now())).to.equal(undefined); 118 | }); 119 | 120 | describe("should throw an error", function () { 121 | it("if time greater than (2 ^ 48) - 1", function () { 122 | expect(() => { 123 | validateTimestamp(Math.pow(2, 48)); 124 | }).to.throw(/cannot encode a timestamp larger than/); 125 | }); 126 | 127 | it("if time is not a number", function () { 128 | expect(() => { 129 | //@ts-ignore 130 | validateTimestamp("test"); 131 | //@ts-check 132 | }).to.throw(/timestamp must be a number/); 133 | }); 134 | 135 | it("if time is infinity", function () { 136 | expect(() => { 137 | validateTimestamp(Infinity); 138 | }).to.throw(/cannot encode a timestamp larger than/); 139 | }); 140 | 141 | it("if time is negative", function () { 142 | expect(() => { 143 | validateTimestamp(-1); 144 | }).to.throw(/timestamp must be positive/); 145 | }); 146 | 147 | it("if time is a float", function () { 148 | expect(() => { 149 | validateTimestamp(100.1); 150 | }).to.throw(/timestamp must be an integer/); 151 | }); 152 | }); 153 | }); 154 | 155 | describe("randomChar", function () { 156 | it("should never return undefined or an empty string", function () { 157 | for (let x = 0; x < 10000; x++) { 158 | const randChar = randomChar(); 159 | expect(randChar).to.not.be.undefined; 160 | expect(randChar).to.not.equal(""); 161 | } 162 | }); 163 | }); 164 | 165 | describe("ulidFactory", function () { 166 | it("outputs a function with no args", function () { 167 | expect(ulidFactory()).to.be.a("function"); 168 | }); 169 | 170 | it("outputs a function with monotonic false", function () { 171 | expect(ulidFactory({ monotonic: false })).to.be.a("function"); 172 | }); 173 | 174 | it("outputs a function with monotonic true", function () { 175 | expect(ulidFactory({ monotonic: true })).to.be.a("function"); 176 | }); 177 | }); 178 | 179 | describe("ulid non-monotonic", function () { 180 | before(function () { 181 | // Stub out web crypto.getRandomValues() to always return the same value 182 | // @ts-ignore-next-line 183 | global.crypto = { 184 | getRandomValues: function (buf) { 185 | if (!(buf instanceof Uint8Array)) { 186 | throw new TypeError("expected Uint8Array"); 187 | } 188 | const zeroBytes = Buffer.alloc(buf.length); // zero-filled Buffer of the correct length for these tests 189 | buf.set(zeroBytes); 190 | return buf; 191 | }, 192 | }; 193 | 194 | this.ulid = ulidFactory({ monotonic: false }); 195 | }); 196 | 197 | it("should return correct length", function () { 198 | expect(this.ulid()).to.have.a.lengthOf(TIME_LEN + RANDOM_LEN); 199 | }); 200 | 201 | describe("with timestamp", function () { 202 | it("should return expected encoded time component result", function () { 203 | expect(this.ulid(TEST_TIME_EPOCH_MS).substring(0, TIME_LEN)).to.equal( 204 | TEST_TIME_ENCODED 205 | ); 206 | }); 207 | 208 | it("should always return the same value when time and randomness are frozen", function () { 209 | // both time seed and the random component are frozen for this test 210 | for (let x = 0; x < 10; x++) { 211 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 212 | TEST_TIME_ENCODED + "0000000000000000" 213 | ); 214 | } 215 | }); 216 | 217 | describe("should throw an error", function () { 218 | it("if validateTimestamp is being called", function () { 219 | expect(() => { 220 | encodeTime(Math.pow(2, 48)); 221 | }).to.throw(/cannot encode a timestamp larger than/); 222 | }); 223 | }); 224 | }); 225 | 226 | describe("without timestamp", function () { 227 | before(function () { 228 | this.clock = sinon.useFakeTimers({ 229 | now: TEST_TIME_EPOCH_MS, 230 | toFake: ["Date"], 231 | }); 232 | }); 233 | 234 | after(function () { 235 | this.clock.restore(); 236 | }); 237 | 238 | it("should always return the same value", function () { 239 | // both time and the random component are frozen for this test 240 | for (let x = 0; x < 10; x++) { 241 | expect(this.ulid()).to.equal(TEST_TIME_ENCODED + "0000000000000000"); 242 | } 243 | }); 244 | }); 245 | }); 246 | 247 | describe("ulid monotonic", function () { 248 | before(function () { 249 | // Stub out web crypto.getRandomValues() to always return the same value 250 | // @ts-ignore-next-line 251 | global.crypto = { 252 | getRandomValues: function (buf) { 253 | if (!(buf instanceof Uint8Array)) { 254 | throw new TypeError("expected Uint8Array"); 255 | } 256 | const zeroBytes = Buffer.alloc(buf.length); // zero-filled Buffer of the correct length for these tests 257 | buf.set(zeroBytes); 258 | return buf; 259 | }, 260 | }; 261 | }); 262 | 263 | it("should return correct length", function () { 264 | const ulid = ulidFactory({ monotonic: true }); 265 | expect(ulid()).to.have.a.lengthOf(TIME_LEN + RANDOM_LEN); 266 | }); 267 | 268 | describe("with timestamp should never step backwards in lexical sort", function () { 269 | before(function () { 270 | this.ulid = ulidFactory({ monotonic: true }); 271 | }); 272 | 273 | it("first call", function () { 274 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 275 | TEST_TIME_ENCODED + "0000000000000000" 276 | ); 277 | }); 278 | 279 | it("second call with older timestamp returns current timestamp and incremented random", function () { 280 | // the value of the ULIDs time component was not pushed backwards 281 | expect(this.ulid(TEST_TIME_EPOCH_MS - 1000)).to.equal( 282 | TEST_TIME_ENCODED + "0000000000000001" 283 | ); 284 | }); 285 | 286 | it("third call", function () { 287 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 288 | TEST_TIME_ENCODED + "0000000000000002" 289 | ); 290 | }); 291 | 292 | it("fourth call with even older timestamp returns current timestamp and incremented random", function () { 293 | // the value of the ULIDs time component was not pushed backwards 294 | expect(this.ulid(TEST_TIME_EPOCH_MS - 86400)).to.equal( 295 | TEST_TIME_ENCODED + "0000000000000003" 296 | ); 297 | }); 298 | 299 | describe("should throw an error", function () { 300 | it("if validateTimestamp is being called", function () { 301 | expect(() => { 302 | encodeTime(Math.pow(2, 48)); 303 | }).to.throw(/cannot encode a timestamp larger than/); 304 | }); 305 | }); 306 | }); 307 | 308 | describe("without timestamp", function () { 309 | before(function () { 310 | this.clock = sinon.useFakeTimers({ 311 | now: TEST_TIME_EPOCH_MS, 312 | toFake: ["Date"], 313 | }); 314 | }); 315 | 316 | before(function () { 317 | this.ulid = ulidFactory({ monotonic: true }); 318 | }); 319 | 320 | after(function () { 321 | this.clock.restore(); 322 | }); 323 | 324 | it("first call", function () { 325 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 326 | TEST_TIME_ENCODED + "0000000000000000" 327 | ); 328 | }); 329 | 330 | it("second call", function () { 331 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 332 | TEST_TIME_ENCODED + "0000000000000001" 333 | ); 334 | }); 335 | 336 | it("third call", function () { 337 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 338 | TEST_TIME_ENCODED + "0000000000000002" 339 | ); 340 | }); 341 | 342 | it("fourth call", function () { 343 | expect(this.ulid(TEST_TIME_EPOCH_MS)).to.equal( 344 | TEST_TIME_ENCODED + "0000000000000003" 345 | ); 346 | }); 347 | }); 348 | }); 349 | 350 | describe("webCryptoPRNG", function () { 351 | it("should return a function", function () { 352 | expect(webCryptoPRNG).to.be.a("function"); 353 | }); 354 | 355 | describe("returned function", function () { 356 | it("should produce a number", function () { 357 | expect(webCryptoPRNG()).to.be.a("number"); 358 | expect(webCryptoPRNG()).to.satisfy((num) => !isNaN(num)); 359 | }); 360 | 361 | it("should be between 0 and 1", function () { 362 | expect(webCryptoPRNG()).to.satisfy((num) => num >= 0 && num <= 1); 363 | }); 364 | }); 365 | }); 366 | }); 367 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "outDir": "./dist", 4 | "module": "commonjs", 5 | "declaration": true, 6 | "target": "es2020", 7 | "types": [ 8 | "node" 9 | ] 10 | }, 11 | "include": [ 12 | "src/**/*" 13 | ], 14 | "exclude": [ 15 | "node_modules" 16 | ] 17 | } --------------------------------------------------------------------------------