├── .gitignore ├── CODE_OF_CONDUCT.md ├── CONTRIBUTING.md ├── LICENSE ├── README.md ├── backend ├── .eslintrc.json ├── assets │ ├── client.png │ └── pat.png ├── dynamodb.json.template ├── package-lock.json ├── package.json ├── src │ ├── FeatureFlagLayer │ │ ├── getConfig.js │ │ ├── getFeature.js │ │ └── package.json │ ├── getAllProducts │ │ ├── getAllProducts.js │ │ └── package.json │ ├── getFeatureFlags │ │ ├── getFeatureFlags.js │ │ └── package.json │ └── package.json └── template.yaml └── frontend ├── .gitignore ├── package-lock.json ├── package.json ├── public ├── favicon.ico ├── favicon.png ├── images │ ├── header-bkg.png │ ├── misc │ │ ├── amex.gif │ │ ├── card.png │ │ └── mobile.png │ ├── products │ │ ├── five.png │ │ ├── four.png │ │ ├── one.png │ │ ├── seven.png │ │ ├── six.png │ │ ├── three.png │ │ └── two.png │ └── store-logo.svg ├── index.html ├── manifest.json └── robots.txt └── src ├── App.css ├── App.js ├── components ├── CheckoutBanner.js ├── CheckoutPayment.js ├── CheckoutSummary.js ├── Feature.js ├── ItemTable.js ├── ProductItem.js └── TopMenu.js ├── config.json.template ├── context ├── AppContext.js └── AppProvider.js ├── index.css ├── index.js ├── pages ├── Checkout.js ├── InitState.js ├── PlacedOrder.js └── Product.js ├── serviceWorker.js └── services └── currency.js /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | */**/node_modules 3 | */**/dist 4 | .aws-sam 5 | 6 | # local env files 7 | .env.local 8 | .env.*.local 9 | 10 | # Log files 11 | npm-debug.log* 12 | yarn-debug.log* 13 | yarn-error.log* 14 | 15 | # Editor directories and files 16 | .idea 17 | .vscode 18 | *.suo 19 | *.ntvs* 20 | *.njsproj 21 | *.sln 22 | *.sw? 23 | *.toml 24 | 25 | config.json 26 | dynamodb.json -------------------------------------------------------------------------------- /CODE_OF_CONDUCT.md: -------------------------------------------------------------------------------- 1 | ## Code of Conduct 2 | This project has adopted the [Amazon Open Source Code of Conduct](https://aws.github.io/code-of-conduct). 3 | For more information see the [Code of Conduct FAQ](https://aws.github.io/code-of-conduct-faq) or contact 4 | opensource-codeofconduct@amazon.com with any additional questions or comments. 5 | -------------------------------------------------------------------------------- /CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | # Contributing Guidelines 2 | 3 | Thank you for your interest in contributing to our project. Whether it's a bug report, new feature, correction, or additional 4 | documentation, we greatly value feedback and contributions from our community. 5 | 6 | Please read through this document before submitting any issues or pull requests to ensure we have all the necessary 7 | information to effectively respond to your bug report or contribution. 8 | 9 | 10 | ## Reporting Bugs/Feature Requests 11 | 12 | We welcome you to use the GitHub issue tracker to report bugs or suggest features. 13 | 14 | When filing an issue, please check existing open, or recently closed, issues to make sure somebody else hasn't already 15 | reported the issue. Please try to include as much information as you can. Details like these are incredibly useful: 16 | 17 | * A reproducible test case or series of steps 18 | * The version of our code being used 19 | * Any modifications you've made relevant to the bug 20 | * Anything unusual about your environment or deployment 21 | 22 | 23 | ## Contributing via Pull Requests 24 | Contributions via pull requests are much appreciated. Before sending us a pull request, please ensure that: 25 | 26 | 1. You are working against the latest source on the *main* branch. 27 | 2. You check existing open, and recently merged, pull requests to make sure someone else hasn't addressed the problem already. 28 | 3. You open an issue to discuss any significant work - we would hate for your time to be wasted. 29 | 30 | To send us a pull request, please: 31 | 32 | 1. Fork the repository. 33 | 2. Modify the source; please focus on the specific change you are contributing. If you also reformat all the code, it will be hard for us to focus on your change. 34 | 3. Ensure local tests pass. 35 | 4. Commit to your fork using clear commit messages. 36 | 5. Send us a pull request, answering any default questions in the pull request interface. 37 | 6. Pay attention to any automated CI failures reported in the pull request, and stay involved in the conversation. 38 | 39 | GitHub provides additional document on [forking a repository](https://help.github.com/articles/fork-a-repo/) and 40 | [creating a pull request](https://help.github.com/articles/creating-a-pull-request/). 41 | 42 | 43 | ## Finding contributions to work on 44 | Looking at the existing issues is a great way to find something to contribute on. As our projects, by default, use the default GitHub issue labels (enhancement/bug/duplicate/help wanted/invalid/question/wontfix), looking at any 'help wanted' issues is a great place to start. 45 | 46 | 47 | ## Code of Conduct 48 | This project has adopted the [Amazon Open Source Code of Conduct](https://aws.github.io/code-of-conduct). 49 | For more information see the [Code of Conduct FAQ](https://aws.github.io/code-of-conduct-faq) or contact 50 | opensource-codeofconduct@amazon.com with any additional questions or comments. 51 | 52 | 53 | ## Security issue notifications 54 | If you discover a potential security issue in this project we ask that you notify AWS/Amazon Security via our [vulnerability reporting page](http://aws.amazon.com/security/vulnerability-reporting/). Please do **not** create a public github issue. 55 | 56 | 57 | ## Licensing 58 | 59 | See the [LICENSE](LICENSE) file for our project's licensing. We will ask you to confirm the licensing of your contribution. 60 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy of 4 | this software and associated documentation files (the "Software"), to deal in 5 | the Software without restriction, including without limitation the rights to 6 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 7 | the Software, and to permit persons to whom the Software is furnished to do so. 8 | 9 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 10 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 11 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 12 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 13 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 14 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 15 | 16 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # AWS AppConfig Feature Flags example 2 | 3 | ## Description 4 | AWS AppConfig Feature Flags provide customers with the control to roll out new features at the rate that they want to introduce the change to their application. Customers can validate these changes to make sure that they are free of errors and match the expected input of their application. While deploying new values gradually, in case there is an error, AWS AppConfig can roll back the changes automatically to prevent any application outages. 5 | 6 | To introduce you to AWS AppConfig Feature Flags, we’ll build a sample application that takes advantage of feature flags and show how the new managed experience works. 7 | 8 | Read more in the blog post Introducing AWS AppConfig Feature Flags In Preview: https://aws.amazon.com/blogs/mt/introducing-aws-appconfig-feature-flags-in-preview/ 9 | 10 | ## Install the backend application 11 | 12 | 1. Clone the repo onto your local development machine. 13 | ```bash 14 | git clone https://github.com/aws-samples/aws-appconfig-feature-flags.git 15 | ``` 16 | 2. Run the following commands to change to the backend directory and install dependencies. 17 | ```bash 18 | cd aws-appconfig-feature-flags 19 | cd backend 20 | npm install 21 | ``` 22 | 3. Process and build your application using the AWS SAM template file. 23 | ```bash 24 | sam build 25 | ``` 26 | 4. Deploy the backend application using the following command and follow the prompts. 27 | ```bash 28 | sam deploy --guided 29 | ``` 30 | 5. Add the IDs of the AppConfig Application, Environment, and Configuration Profile when prompted, and confirm all of the deployment prompts. 31 | 6. In the output of the deployment, note the DynamoDBTableName key and the HTTPApiUrl key. You will get the output similar to the following: 32 | ```bash 33 | Key DynamoDBTableName Description The name of your DynamoDB table Value sam-app-DynamoDBTable-XXXXXXXXXXX 34 | Key HttpApiUrl Description URL of your API endpoint Value https://XXXXXXXX.execute-api.XX-XXXXXXXX-1.amazonaws.com 35 | ``` 36 | 37 | ## Populate DynamoDB table with sample data 38 | 39 | 1. Open the template file dynamodb.json.template and replace YOUR_DYNAMODB_TABLE_NAME with the DynamoDBTableName key from sam deploy output. Save the file as dynamodb.json. 40 | 2. Run the following command to populate the DynamoDB table with sample data: 41 | ```bash 42 | aws dynamodb batch-write-item --request-items file://dynamodb.json 43 | ``` 44 | 3. You will get the following output: 45 | ```bash 46 | { 47 | "UnprocessedItems": {} 48 | } 49 | ``` 50 | 51 | ## Install the front-end application 52 | 53 | 1. Change to the frontend directory and install the dependencies using 54 | ```bash 55 | cd frontend 56 | npm install 57 | ``` 58 | 2. Open the template file config.json.template in the folder src and replace YOUR_API_ENDPOINT with the HTTPApiUrl key from sam deploy output. Save the file as config.json. 59 | 3. Start the local development server. 60 | ```bash 61 | npm start 62 | ``` 63 | 4. Open http://localhost:3000/ in your browser to view the web application. 64 | 65 | ## Remove the sample application 66 | Delete the CloudFormation stack via CLI: 67 | ```bash 68 | aws cloudformation delete-stack --stack-name YOUR-STACK-NAME 69 | ``` 70 | 71 | ## Security 72 | 73 | See [CONTRIBUTING](CONTRIBUTING.md#security-issue-notifications) for more information. 74 | 75 | ## License 76 | 77 | This library is licensed under the MIT-0 License. See the LICENSE file. 78 | -------------------------------------------------------------------------------- /backend/.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "strongloop", 3 | "parserOptions": { 4 | "ecmaVersion": 8 5 | } 6 | } -------------------------------------------------------------------------------- /backend/assets/client.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/backend/assets/client.png -------------------------------------------------------------------------------- /backend/assets/pat.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/backend/assets/pat.png -------------------------------------------------------------------------------- /backend/dynamodb.json.template: -------------------------------------------------------------------------------- 1 | { 2 | "YOUR_DYNAMODB_TABLE_NAME": [ 3 | { 4 | "PutRequest": { 5 | "Item": { 6 | "itemName": { 7 | "S": "Product One" 8 | }, 9 | "id": { 10 | "N": "1" 11 | }, 12 | "itemImage": { 13 | "S": "one.png" 14 | }, 15 | "itemPrice": { 16 | "N": "10.99" 17 | }, 18 | "itemStock": { 19 | "N": "5" 20 | }, 21 | "itemDesc": { 22 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 23 | } 24 | } 25 | } 26 | }, 27 | { 28 | "PutRequest": { 29 | "Item": { 30 | "itemName": { 31 | "S": "Product Two" 32 | }, 33 | "id": { 34 | "N": "2" 35 | }, 36 | "itemImage": { 37 | "S": "two.png" 38 | }, 39 | "itemPrice": { 40 | "N": "19.50" 41 | }, 42 | "itemStock": { 43 | "N": "8" 44 | }, 45 | "itemDesc": { 46 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 47 | } 48 | } 49 | } 50 | }, 51 | { 52 | "PutRequest": { 53 | "Item": { 54 | "itemName": { 55 | "S": "Product three" 56 | }, 57 | "id": { 58 | "N": "3" 59 | }, 60 | "itemImage": { 61 | "S": "three.png" 62 | }, 63 | "itemPrice": { 64 | "N": "32.00" 65 | }, 66 | "itemStock": { 67 | "N": "10" 68 | }, 69 | "itemDesc": { 70 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 71 | } 72 | } 73 | } 74 | }, 75 | { 76 | "PutRequest": { 77 | "Item": { 78 | "itemName": { 79 | "S": "Product Four" 80 | }, 81 | "id": { 82 | "N": "4" 83 | }, 84 | "itemImage": { 85 | "S": "four.png" 86 | }, 87 | "itemPrice": { 88 | "N": "8.99" 89 | }, 90 | "itemStock": { 91 | "N": "2" 92 | }, 93 | "itemDesc": { 94 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 95 | } 96 | } 97 | } 98 | }, 99 | { 100 | "PutRequest": { 101 | "Item": { 102 | "itemName": { 103 | "S": "Product Five" 104 | }, 105 | "id": { 106 | "N": "5" 107 | }, 108 | "itemImage": { 109 | "S": "five.png" 110 | }, 111 | "itemPrice": { 112 | "N": "21.50" 113 | }, 114 | "itemStock": { 115 | "N": "22" 116 | }, 117 | "itemDesc": { 118 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 119 | } 120 | } 121 | } 122 | }, 123 | { 124 | "PutRequest": { 125 | "Item": { 126 | "itemName": { 127 | "S": "Product Six" 128 | }, 129 | "id": { 130 | "N": "6" 131 | }, 132 | "itemImage": { 133 | "S": "six.png" 134 | }, 135 | "itemPrice": { 136 | "N": "5.50" 137 | }, 138 | "itemStock": { 139 | "N": "18" 140 | }, 141 | "itemDesc": { 142 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 143 | } 144 | } 145 | } 146 | }, 147 | { 148 | "PutRequest": { 149 | "Item": { 150 | "itemName": { 151 | "S": "Product Seven" 152 | }, 153 | "id": { 154 | "N": "7" 155 | }, 156 | "itemImage": { 157 | "S": "seven.png" 158 | }, 159 | "itemPrice": { 160 | "N": "29.99" 161 | }, 162 | "itemStock": { 163 | "N": "14" 164 | }, 165 | "itemDesc": { 166 | "S": "Sed at sapien in turpis blandit tempor et a lacus. Aenean mollis tempor tortor eu tincidunt. " 167 | } 168 | } 169 | } 170 | } 171 | ] 172 | } 173 | -------------------------------------------------------------------------------- /backend/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "appconfig-feature-flags", 9 | "version": "1.0.0", 10 | "devDependencies": { 11 | "eslint": "^8.1.0", 12 | "eslint-config-strongloop": "^2.1.0", 13 | "eslint-plugin-import": "^2.25.2" 14 | } 15 | }, 16 | "node_modules/@eslint/eslintrc": { 17 | "version": "1.0.4", 18 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.4.tgz", 19 | "integrity": "sha512-h8Vx6MdxwWI2WM8/zREHMoqdgLNXEL4QX3MWSVMdyNJGvXVOs+6lp+m2hc3FnuMHDc4poxFNI20vCk0OmI4G0Q==", 20 | "dev": true, 21 | "dependencies": { 22 | "ajv": "^6.12.4", 23 | "debug": "^4.3.2", 24 | "espree": "^9.0.0", 25 | "globals": "^13.9.0", 26 | "ignore": "^4.0.6", 27 | "import-fresh": "^3.2.1", 28 | "js-yaml": "^4.1.0", 29 | "minimatch": "^3.0.4", 30 | "strip-json-comments": "^3.1.1" 31 | }, 32 | "engines": { 33 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 34 | } 35 | }, 36 | "node_modules/@humanwhocodes/config-array": { 37 | "version": "0.6.0", 38 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.6.0.tgz", 39 | "integrity": "sha512-JQlEKbcgEUjBFhLIF4iqM7u/9lwgHRBcpHrmUNCALK0Q3amXN6lxdoXLnF0sm11E9VqTmBALR87IlUg1bZ8A9A==", 40 | "dev": true, 41 | "dependencies": { 42 | "@humanwhocodes/object-schema": "^1.2.0", 43 | "debug": "^4.1.1", 44 | "minimatch": "^3.0.4" 45 | }, 46 | "engines": { 47 | "node": ">=10.10.0" 48 | } 49 | }, 50 | "node_modules/@humanwhocodes/object-schema": { 51 | "version": "1.2.1", 52 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 53 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 54 | "dev": true 55 | }, 56 | "node_modules/@types/json5": { 57 | "version": "0.0.29", 58 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 59 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 60 | "dev": true 61 | }, 62 | "node_modules/acorn": { 63 | "version": "8.6.0", 64 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.6.0.tgz", 65 | "integrity": "sha512-U1riIR+lBSNi3IbxtaHOIKdH8sLFv3NYfNv8sg7ZsNhcfl4HF2++BfqqrNAxoCLQW1iiylOj76ecnaUxz+z9yw==", 66 | "dev": true, 67 | "bin": { 68 | "acorn": "bin/acorn" 69 | }, 70 | "engines": { 71 | "node": ">=0.4.0" 72 | } 73 | }, 74 | "node_modules/acorn-jsx": { 75 | "version": "5.3.2", 76 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 77 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 78 | "dev": true, 79 | "peerDependencies": { 80 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 81 | } 82 | }, 83 | "node_modules/ajv": { 84 | "version": "6.12.6", 85 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 86 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 87 | "dev": true, 88 | "dependencies": { 89 | "fast-deep-equal": "^3.1.1", 90 | "fast-json-stable-stringify": "^2.0.0", 91 | "json-schema-traverse": "^0.4.1", 92 | "uri-js": "^4.2.2" 93 | }, 94 | "funding": { 95 | "type": "github", 96 | "url": "https://github.com/sponsors/epoberezkin" 97 | } 98 | }, 99 | "node_modules/ansi-colors": { 100 | "version": "4.1.1", 101 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 102 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 103 | "dev": true, 104 | "engines": { 105 | "node": ">=6" 106 | } 107 | }, 108 | "node_modules/ansi-regex": { 109 | "version": "5.0.1", 110 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 111 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 112 | "dev": true, 113 | "engines": { 114 | "node": ">=8" 115 | } 116 | }, 117 | "node_modules/ansi-styles": { 118 | "version": "4.3.0", 119 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 120 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 121 | "dev": true, 122 | "dependencies": { 123 | "color-convert": "^2.0.1" 124 | }, 125 | "engines": { 126 | "node": ">=8" 127 | }, 128 | "funding": { 129 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 130 | } 131 | }, 132 | "node_modules/argparse": { 133 | "version": "2.0.1", 134 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 135 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 136 | "dev": true 137 | }, 138 | "node_modules/array-includes": { 139 | "version": "3.1.4", 140 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.4.tgz", 141 | "integrity": "sha512-ZTNSQkmWumEbiHO2GF4GmWxYVTiQyJy2XOTa15sdQSrvKn7l+180egQMqlrMOUMCyLMD7pmyQe4mMDUT6Behrw==", 142 | "dev": true, 143 | "dependencies": { 144 | "call-bind": "^1.0.2", 145 | "define-properties": "^1.1.3", 146 | "es-abstract": "^1.19.1", 147 | "get-intrinsic": "^1.1.1", 148 | "is-string": "^1.0.7" 149 | }, 150 | "engines": { 151 | "node": ">= 0.4" 152 | }, 153 | "funding": { 154 | "url": "https://github.com/sponsors/ljharb" 155 | } 156 | }, 157 | "node_modules/array.prototype.flat": { 158 | "version": "1.2.5", 159 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.5.tgz", 160 | "integrity": "sha512-KaYU+S+ndVqyUnignHftkwc58o3uVU1jzczILJ1tN2YaIZpFIKBiP/x/j97E5MVPsaCloPbqWLB/8qCTVvT2qg==", 161 | "dev": true, 162 | "dependencies": { 163 | "call-bind": "^1.0.2", 164 | "define-properties": "^1.1.3", 165 | "es-abstract": "^1.19.0" 166 | }, 167 | "engines": { 168 | "node": ">= 0.4" 169 | }, 170 | "funding": { 171 | "url": "https://github.com/sponsors/ljharb" 172 | } 173 | }, 174 | "node_modules/balanced-match": { 175 | "version": "1.0.2", 176 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 177 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 178 | "dev": true 179 | }, 180 | "node_modules/brace-expansion": { 181 | "version": "1.1.11", 182 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 183 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 184 | "dev": true, 185 | "dependencies": { 186 | "balanced-match": "^1.0.0", 187 | "concat-map": "0.0.1" 188 | } 189 | }, 190 | "node_modules/call-bind": { 191 | "version": "1.0.2", 192 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 193 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 194 | "dev": true, 195 | "dependencies": { 196 | "function-bind": "^1.1.1", 197 | "get-intrinsic": "^1.0.2" 198 | }, 199 | "funding": { 200 | "url": "https://github.com/sponsors/ljharb" 201 | } 202 | }, 203 | "node_modules/callsites": { 204 | "version": "3.1.0", 205 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 206 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 207 | "dev": true, 208 | "engines": { 209 | "node": ">=6" 210 | } 211 | }, 212 | "node_modules/chalk": { 213 | "version": "4.1.2", 214 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 215 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 216 | "dev": true, 217 | "dependencies": { 218 | "ansi-styles": "^4.1.0", 219 | "supports-color": "^7.1.0" 220 | }, 221 | "engines": { 222 | "node": ">=10" 223 | }, 224 | "funding": { 225 | "url": "https://github.com/chalk/chalk?sponsor=1" 226 | } 227 | }, 228 | "node_modules/color-convert": { 229 | "version": "2.0.1", 230 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 231 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 232 | "dev": true, 233 | "dependencies": { 234 | "color-name": "~1.1.4" 235 | }, 236 | "engines": { 237 | "node": ">=7.0.0" 238 | } 239 | }, 240 | "node_modules/color-name": { 241 | "version": "1.1.4", 242 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 243 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 244 | "dev": true 245 | }, 246 | "node_modules/concat-map": { 247 | "version": "0.0.1", 248 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 249 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 250 | "dev": true 251 | }, 252 | "node_modules/cross-spawn": { 253 | "version": "7.0.3", 254 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 255 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 256 | "dev": true, 257 | "dependencies": { 258 | "path-key": "^3.1.0", 259 | "shebang-command": "^2.0.0", 260 | "which": "^2.0.1" 261 | }, 262 | "engines": { 263 | "node": ">= 8" 264 | } 265 | }, 266 | "node_modules/debug": { 267 | "version": "4.3.2", 268 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 269 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 270 | "dev": true, 271 | "dependencies": { 272 | "ms": "2.1.2" 273 | }, 274 | "engines": { 275 | "node": ">=6.0" 276 | }, 277 | "peerDependenciesMeta": { 278 | "supports-color": { 279 | "optional": true 280 | } 281 | } 282 | }, 283 | "node_modules/deep-is": { 284 | "version": "0.1.4", 285 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 286 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 287 | "dev": true 288 | }, 289 | "node_modules/define-properties": { 290 | "version": "1.1.3", 291 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 292 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 293 | "dev": true, 294 | "dependencies": { 295 | "object-keys": "^1.0.12" 296 | }, 297 | "engines": { 298 | "node": ">= 0.4" 299 | } 300 | }, 301 | "node_modules/doctrine": { 302 | "version": "3.0.0", 303 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 304 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 305 | "dev": true, 306 | "dependencies": { 307 | "esutils": "^2.0.2" 308 | }, 309 | "engines": { 310 | "node": ">=6.0.0" 311 | } 312 | }, 313 | "node_modules/enquirer": { 314 | "version": "2.3.6", 315 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 316 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 317 | "dev": true, 318 | "dependencies": { 319 | "ansi-colors": "^4.1.1" 320 | }, 321 | "engines": { 322 | "node": ">=8.6" 323 | } 324 | }, 325 | "node_modules/es-abstract": { 326 | "version": "1.19.1", 327 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", 328 | "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", 329 | "dev": true, 330 | "dependencies": { 331 | "call-bind": "^1.0.2", 332 | "es-to-primitive": "^1.2.1", 333 | "function-bind": "^1.1.1", 334 | "get-intrinsic": "^1.1.1", 335 | "get-symbol-description": "^1.0.0", 336 | "has": "^1.0.3", 337 | "has-symbols": "^1.0.2", 338 | "internal-slot": "^1.0.3", 339 | "is-callable": "^1.2.4", 340 | "is-negative-zero": "^2.0.1", 341 | "is-regex": "^1.1.4", 342 | "is-shared-array-buffer": "^1.0.1", 343 | "is-string": "^1.0.7", 344 | "is-weakref": "^1.0.1", 345 | "object-inspect": "^1.11.0", 346 | "object-keys": "^1.1.1", 347 | "object.assign": "^4.1.2", 348 | "string.prototype.trimend": "^1.0.4", 349 | "string.prototype.trimstart": "^1.0.4", 350 | "unbox-primitive": "^1.0.1" 351 | }, 352 | "engines": { 353 | "node": ">= 0.4" 354 | }, 355 | "funding": { 356 | "url": "https://github.com/sponsors/ljharb" 357 | } 358 | }, 359 | "node_modules/es-to-primitive": { 360 | "version": "1.2.1", 361 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 362 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 363 | "dev": true, 364 | "dependencies": { 365 | "is-callable": "^1.1.4", 366 | "is-date-object": "^1.0.1", 367 | "is-symbol": "^1.0.2" 368 | }, 369 | "engines": { 370 | "node": ">= 0.4" 371 | }, 372 | "funding": { 373 | "url": "https://github.com/sponsors/ljharb" 374 | } 375 | }, 376 | "node_modules/escape-string-regexp": { 377 | "version": "4.0.0", 378 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 379 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 380 | "dev": true, 381 | "engines": { 382 | "node": ">=10" 383 | }, 384 | "funding": { 385 | "url": "https://github.com/sponsors/sindresorhus" 386 | } 387 | }, 388 | "node_modules/eslint": { 389 | "version": "8.2.0", 390 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.2.0.tgz", 391 | "integrity": "sha512-erw7XmM+CLxTOickrimJ1SiF55jiNlVSp2qqm0NuBWPtHYQCegD5ZMaW0c3i5ytPqL+SSLaCxdvQXFPLJn+ABw==", 392 | "dev": true, 393 | "dependencies": { 394 | "@eslint/eslintrc": "^1.0.4", 395 | "@humanwhocodes/config-array": "^0.6.0", 396 | "ajv": "^6.10.0", 397 | "chalk": "^4.0.0", 398 | "cross-spawn": "^7.0.2", 399 | "debug": "^4.3.2", 400 | "doctrine": "^3.0.0", 401 | "enquirer": "^2.3.5", 402 | "escape-string-regexp": "^4.0.0", 403 | "eslint-scope": "^6.0.0", 404 | "eslint-utils": "^3.0.0", 405 | "eslint-visitor-keys": "^3.0.0", 406 | "espree": "^9.0.0", 407 | "esquery": "^1.4.0", 408 | "esutils": "^2.0.2", 409 | "fast-deep-equal": "^3.1.3", 410 | "file-entry-cache": "^6.0.1", 411 | "functional-red-black-tree": "^1.0.1", 412 | "glob-parent": "^6.0.1", 413 | "globals": "^13.6.0", 414 | "ignore": "^4.0.6", 415 | "import-fresh": "^3.0.0", 416 | "imurmurhash": "^0.1.4", 417 | "is-glob": "^4.0.0", 418 | "js-yaml": "^4.1.0", 419 | "json-stable-stringify-without-jsonify": "^1.0.1", 420 | "levn": "^0.4.1", 421 | "lodash.merge": "^4.6.2", 422 | "minimatch": "^3.0.4", 423 | "natural-compare": "^1.4.0", 424 | "optionator": "^0.9.1", 425 | "progress": "^2.0.0", 426 | "regexpp": "^3.2.0", 427 | "semver": "^7.2.1", 428 | "strip-ansi": "^6.0.1", 429 | "strip-json-comments": "^3.1.0", 430 | "text-table": "^0.2.0", 431 | "v8-compile-cache": "^2.0.3" 432 | }, 433 | "bin": { 434 | "eslint": "bin/eslint.js" 435 | }, 436 | "engines": { 437 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 438 | }, 439 | "funding": { 440 | "url": "https://opencollective.com/eslint" 441 | } 442 | }, 443 | "node_modules/eslint-config-strongloop": { 444 | "version": "2.1.0", 445 | "resolved": "https://registry.npmjs.org/eslint-config-strongloop/-/eslint-config-strongloop-2.1.0.tgz", 446 | "integrity": "sha1-dj3Rmt/OiNewBR5uJV8a43eDtMY=", 447 | "dev": true 448 | }, 449 | "node_modules/eslint-import-resolver-node": { 450 | "version": "0.3.6", 451 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz", 452 | "integrity": "sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw==", 453 | "dev": true, 454 | "dependencies": { 455 | "debug": "^3.2.7", 456 | "resolve": "^1.20.0" 457 | } 458 | }, 459 | "node_modules/eslint-import-resolver-node/node_modules/debug": { 460 | "version": "3.2.7", 461 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 462 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 463 | "dev": true, 464 | "dependencies": { 465 | "ms": "^2.1.1" 466 | } 467 | }, 468 | "node_modules/eslint-module-utils": { 469 | "version": "2.7.1", 470 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.7.1.tgz", 471 | "integrity": "sha512-fjoetBXQZq2tSTWZ9yWVl2KuFrTZZH3V+9iD1V1RfpDgxzJR+mPd/KZmMiA8gbPqdBzpNiEHOuT7IYEWxrH0zQ==", 472 | "dev": true, 473 | "dependencies": { 474 | "debug": "^3.2.7", 475 | "find-up": "^2.1.0", 476 | "pkg-dir": "^2.0.0" 477 | }, 478 | "engines": { 479 | "node": ">=4" 480 | } 481 | }, 482 | "node_modules/eslint-module-utils/node_modules/debug": { 483 | "version": "3.2.7", 484 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 485 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 486 | "dev": true, 487 | "dependencies": { 488 | "ms": "^2.1.1" 489 | } 490 | }, 491 | "node_modules/eslint-plugin-import": { 492 | "version": "2.25.3", 493 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.25.3.tgz", 494 | "integrity": "sha512-RzAVbby+72IB3iOEL8clzPLzL3wpDrlwjsTBAQXgyp5SeTqqY+0bFubwuo+y/HLhNZcXV4XqTBO4LGsfyHIDXg==", 495 | "dev": true, 496 | "dependencies": { 497 | "array-includes": "^3.1.4", 498 | "array.prototype.flat": "^1.2.5", 499 | "debug": "^2.6.9", 500 | "doctrine": "^2.1.0", 501 | "eslint-import-resolver-node": "^0.3.6", 502 | "eslint-module-utils": "^2.7.1", 503 | "has": "^1.0.3", 504 | "is-core-module": "^2.8.0", 505 | "is-glob": "^4.0.3", 506 | "minimatch": "^3.0.4", 507 | "object.values": "^1.1.5", 508 | "resolve": "^1.20.0", 509 | "tsconfig-paths": "^3.11.0" 510 | }, 511 | "engines": { 512 | "node": ">=4" 513 | }, 514 | "peerDependencies": { 515 | "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" 516 | } 517 | }, 518 | "node_modules/eslint-plugin-import/node_modules/debug": { 519 | "version": "2.6.9", 520 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 521 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 522 | "dev": true, 523 | "dependencies": { 524 | "ms": "2.0.0" 525 | } 526 | }, 527 | "node_modules/eslint-plugin-import/node_modules/doctrine": { 528 | "version": "2.1.0", 529 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 530 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 531 | "dev": true, 532 | "dependencies": { 533 | "esutils": "^2.0.2" 534 | }, 535 | "engines": { 536 | "node": ">=0.10.0" 537 | } 538 | }, 539 | "node_modules/eslint-plugin-import/node_modules/ms": { 540 | "version": "2.0.0", 541 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 542 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 543 | "dev": true 544 | }, 545 | "node_modules/eslint-scope": { 546 | "version": "6.0.0", 547 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-6.0.0.tgz", 548 | "integrity": "sha512-uRDL9MWmQCkaFus8RF5K9/L/2fn+80yoW3jkD53l4shjCh26fCtvJGasxjUqP5OT87SYTxCVA3BwTUzuELx9kA==", 549 | "dev": true, 550 | "dependencies": { 551 | "esrecurse": "^4.3.0", 552 | "estraverse": "^5.2.0" 553 | }, 554 | "engines": { 555 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 556 | } 557 | }, 558 | "node_modules/eslint-utils": { 559 | "version": "3.0.0", 560 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 561 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 562 | "dev": true, 563 | "dependencies": { 564 | "eslint-visitor-keys": "^2.0.0" 565 | }, 566 | "engines": { 567 | "node": "^10.0.0 || ^12.0.0 || >= 14.0.0" 568 | }, 569 | "funding": { 570 | "url": "https://github.com/sponsors/mysticatea" 571 | }, 572 | "peerDependencies": { 573 | "eslint": ">=5" 574 | } 575 | }, 576 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 577 | "version": "2.1.0", 578 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 579 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 580 | "dev": true, 581 | "engines": { 582 | "node": ">=10" 583 | } 584 | }, 585 | "node_modules/eslint-visitor-keys": { 586 | "version": "3.1.0", 587 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz", 588 | "integrity": "sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA==", 589 | "dev": true, 590 | "engines": { 591 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 592 | } 593 | }, 594 | "node_modules/espree": { 595 | "version": "9.0.0", 596 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.0.0.tgz", 597 | "integrity": "sha512-r5EQJcYZ2oaGbeR0jR0fFVijGOcwai07/690YRXLINuhmVeRY4UKSAsQPe/0BNuDgwP7Ophoc1PRsr2E3tkbdQ==", 598 | "dev": true, 599 | "dependencies": { 600 | "acorn": "^8.5.0", 601 | "acorn-jsx": "^5.3.1", 602 | "eslint-visitor-keys": "^3.0.0" 603 | }, 604 | "engines": { 605 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 606 | } 607 | }, 608 | "node_modules/esquery": { 609 | "version": "1.4.0", 610 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 611 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 612 | "dev": true, 613 | "dependencies": { 614 | "estraverse": "^5.1.0" 615 | }, 616 | "engines": { 617 | "node": ">=0.10" 618 | } 619 | }, 620 | "node_modules/esrecurse": { 621 | "version": "4.3.0", 622 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 623 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 624 | "dev": true, 625 | "dependencies": { 626 | "estraverse": "^5.2.0" 627 | }, 628 | "engines": { 629 | "node": ">=4.0" 630 | } 631 | }, 632 | "node_modules/estraverse": { 633 | "version": "5.3.0", 634 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 635 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 636 | "dev": true, 637 | "engines": { 638 | "node": ">=4.0" 639 | } 640 | }, 641 | "node_modules/esutils": { 642 | "version": "2.0.3", 643 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 644 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 645 | "dev": true, 646 | "engines": { 647 | "node": ">=0.10.0" 648 | } 649 | }, 650 | "node_modules/fast-deep-equal": { 651 | "version": "3.1.3", 652 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 653 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 654 | "dev": true 655 | }, 656 | "node_modules/fast-json-stable-stringify": { 657 | "version": "2.1.0", 658 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 659 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 660 | "dev": true 661 | }, 662 | "node_modules/fast-levenshtein": { 663 | "version": "2.0.6", 664 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 665 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 666 | "dev": true 667 | }, 668 | "node_modules/file-entry-cache": { 669 | "version": "6.0.1", 670 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 671 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 672 | "dev": true, 673 | "dependencies": { 674 | "flat-cache": "^3.0.4" 675 | }, 676 | "engines": { 677 | "node": "^10.12.0 || >=12.0.0" 678 | } 679 | }, 680 | "node_modules/find-up": { 681 | "version": "2.1.0", 682 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 683 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 684 | "dev": true, 685 | "dependencies": { 686 | "locate-path": "^2.0.0" 687 | }, 688 | "engines": { 689 | "node": ">=4" 690 | } 691 | }, 692 | "node_modules/flat-cache": { 693 | "version": "3.0.4", 694 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 695 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 696 | "dev": true, 697 | "dependencies": { 698 | "flatted": "^3.1.0", 699 | "rimraf": "^3.0.2" 700 | }, 701 | "engines": { 702 | "node": "^10.12.0 || >=12.0.0" 703 | } 704 | }, 705 | "node_modules/flatted": { 706 | "version": "3.2.4", 707 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", 708 | "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", 709 | "dev": true 710 | }, 711 | "node_modules/fs.realpath": { 712 | "version": "1.0.0", 713 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 714 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 715 | "dev": true 716 | }, 717 | "node_modules/function-bind": { 718 | "version": "1.1.1", 719 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 720 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 721 | "dev": true 722 | }, 723 | "node_modules/functional-red-black-tree": { 724 | "version": "1.0.1", 725 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 726 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 727 | "dev": true 728 | }, 729 | "node_modules/get-intrinsic": { 730 | "version": "1.1.1", 731 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 732 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 733 | "dev": true, 734 | "dependencies": { 735 | "function-bind": "^1.1.1", 736 | "has": "^1.0.3", 737 | "has-symbols": "^1.0.1" 738 | }, 739 | "funding": { 740 | "url": "https://github.com/sponsors/ljharb" 741 | } 742 | }, 743 | "node_modules/get-symbol-description": { 744 | "version": "1.0.0", 745 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 746 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 747 | "dev": true, 748 | "dependencies": { 749 | "call-bind": "^1.0.2", 750 | "get-intrinsic": "^1.1.1" 751 | }, 752 | "engines": { 753 | "node": ">= 0.4" 754 | }, 755 | "funding": { 756 | "url": "https://github.com/sponsors/ljharb" 757 | } 758 | }, 759 | "node_modules/glob": { 760 | "version": "7.2.0", 761 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 762 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 763 | "dev": true, 764 | "dependencies": { 765 | "fs.realpath": "^1.0.0", 766 | "inflight": "^1.0.4", 767 | "inherits": "2", 768 | "minimatch": "^3.0.4", 769 | "once": "^1.3.0", 770 | "path-is-absolute": "^1.0.0" 771 | }, 772 | "engines": { 773 | "node": "*" 774 | }, 775 | "funding": { 776 | "url": "https://github.com/sponsors/isaacs" 777 | } 778 | }, 779 | "node_modules/glob-parent": { 780 | "version": "6.0.2", 781 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 782 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 783 | "dev": true, 784 | "dependencies": { 785 | "is-glob": "^4.0.3" 786 | }, 787 | "engines": { 788 | "node": ">=10.13.0" 789 | } 790 | }, 791 | "node_modules/globals": { 792 | "version": "13.12.0", 793 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 794 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 795 | "dev": true, 796 | "dependencies": { 797 | "type-fest": "^0.20.2" 798 | }, 799 | "engines": { 800 | "node": ">=8" 801 | }, 802 | "funding": { 803 | "url": "https://github.com/sponsors/sindresorhus" 804 | } 805 | }, 806 | "node_modules/has": { 807 | "version": "1.0.3", 808 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 809 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 810 | "dev": true, 811 | "dependencies": { 812 | "function-bind": "^1.1.1" 813 | }, 814 | "engines": { 815 | "node": ">= 0.4.0" 816 | } 817 | }, 818 | "node_modules/has-bigints": { 819 | "version": "1.0.1", 820 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", 821 | "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", 822 | "dev": true, 823 | "funding": { 824 | "url": "https://github.com/sponsors/ljharb" 825 | } 826 | }, 827 | "node_modules/has-flag": { 828 | "version": "4.0.0", 829 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 830 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 831 | "dev": true, 832 | "engines": { 833 | "node": ">=8" 834 | } 835 | }, 836 | "node_modules/has-symbols": { 837 | "version": "1.0.2", 838 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 839 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 840 | "dev": true, 841 | "engines": { 842 | "node": ">= 0.4" 843 | }, 844 | "funding": { 845 | "url": "https://github.com/sponsors/ljharb" 846 | } 847 | }, 848 | "node_modules/has-tostringtag": { 849 | "version": "1.0.0", 850 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 851 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 852 | "dev": true, 853 | "dependencies": { 854 | "has-symbols": "^1.0.2" 855 | }, 856 | "engines": { 857 | "node": ">= 0.4" 858 | }, 859 | "funding": { 860 | "url": "https://github.com/sponsors/ljharb" 861 | } 862 | }, 863 | "node_modules/ignore": { 864 | "version": "4.0.6", 865 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 866 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 867 | "dev": true, 868 | "engines": { 869 | "node": ">= 4" 870 | } 871 | }, 872 | "node_modules/import-fresh": { 873 | "version": "3.3.0", 874 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 875 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 876 | "dev": true, 877 | "dependencies": { 878 | "parent-module": "^1.0.0", 879 | "resolve-from": "^4.0.0" 880 | }, 881 | "engines": { 882 | "node": ">=6" 883 | }, 884 | "funding": { 885 | "url": "https://github.com/sponsors/sindresorhus" 886 | } 887 | }, 888 | "node_modules/imurmurhash": { 889 | "version": "0.1.4", 890 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 891 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 892 | "dev": true, 893 | "engines": { 894 | "node": ">=0.8.19" 895 | } 896 | }, 897 | "node_modules/inflight": { 898 | "version": "1.0.6", 899 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 900 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 901 | "dev": true, 902 | "dependencies": { 903 | "once": "^1.3.0", 904 | "wrappy": "1" 905 | } 906 | }, 907 | "node_modules/inherits": { 908 | "version": "2.0.4", 909 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 910 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 911 | "dev": true 912 | }, 913 | "node_modules/internal-slot": { 914 | "version": "1.0.3", 915 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 916 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 917 | "dev": true, 918 | "dependencies": { 919 | "get-intrinsic": "^1.1.0", 920 | "has": "^1.0.3", 921 | "side-channel": "^1.0.4" 922 | }, 923 | "engines": { 924 | "node": ">= 0.4" 925 | } 926 | }, 927 | "node_modules/is-bigint": { 928 | "version": "1.0.4", 929 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 930 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 931 | "dev": true, 932 | "dependencies": { 933 | "has-bigints": "^1.0.1" 934 | }, 935 | "funding": { 936 | "url": "https://github.com/sponsors/ljharb" 937 | } 938 | }, 939 | "node_modules/is-boolean-object": { 940 | "version": "1.1.2", 941 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 942 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 943 | "dev": true, 944 | "dependencies": { 945 | "call-bind": "^1.0.2", 946 | "has-tostringtag": "^1.0.0" 947 | }, 948 | "engines": { 949 | "node": ">= 0.4" 950 | }, 951 | "funding": { 952 | "url": "https://github.com/sponsors/ljharb" 953 | } 954 | }, 955 | "node_modules/is-callable": { 956 | "version": "1.2.4", 957 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", 958 | "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", 959 | "dev": true, 960 | "engines": { 961 | "node": ">= 0.4" 962 | }, 963 | "funding": { 964 | "url": "https://github.com/sponsors/ljharb" 965 | } 966 | }, 967 | "node_modules/is-core-module": { 968 | "version": "2.8.0", 969 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.0.tgz", 970 | "integrity": "sha512-vd15qHsaqrRL7dtH6QNuy0ndJmRDrS9HAM1CAiSifNUFv4x1a0CCVsj18hJ1mShxIG6T2i1sO78MkP56r0nYRw==", 971 | "dev": true, 972 | "dependencies": { 973 | "has": "^1.0.3" 974 | }, 975 | "funding": { 976 | "url": "https://github.com/sponsors/ljharb" 977 | } 978 | }, 979 | "node_modules/is-date-object": { 980 | "version": "1.0.5", 981 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 982 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 983 | "dev": true, 984 | "dependencies": { 985 | "has-tostringtag": "^1.0.0" 986 | }, 987 | "engines": { 988 | "node": ">= 0.4" 989 | }, 990 | "funding": { 991 | "url": "https://github.com/sponsors/ljharb" 992 | } 993 | }, 994 | "node_modules/is-extglob": { 995 | "version": "2.1.1", 996 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 997 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 998 | "dev": true, 999 | "engines": { 1000 | "node": ">=0.10.0" 1001 | } 1002 | }, 1003 | "node_modules/is-glob": { 1004 | "version": "4.0.3", 1005 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1006 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1007 | "dev": true, 1008 | "dependencies": { 1009 | "is-extglob": "^2.1.1" 1010 | }, 1011 | "engines": { 1012 | "node": ">=0.10.0" 1013 | } 1014 | }, 1015 | "node_modules/is-negative-zero": { 1016 | "version": "2.0.1", 1017 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz", 1018 | "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==", 1019 | "dev": true, 1020 | "engines": { 1021 | "node": ">= 0.4" 1022 | }, 1023 | "funding": { 1024 | "url": "https://github.com/sponsors/ljharb" 1025 | } 1026 | }, 1027 | "node_modules/is-number-object": { 1028 | "version": "1.0.6", 1029 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", 1030 | "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", 1031 | "dev": true, 1032 | "dependencies": { 1033 | "has-tostringtag": "^1.0.0" 1034 | }, 1035 | "engines": { 1036 | "node": ">= 0.4" 1037 | }, 1038 | "funding": { 1039 | "url": "https://github.com/sponsors/ljharb" 1040 | } 1041 | }, 1042 | "node_modules/is-regex": { 1043 | "version": "1.1.4", 1044 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 1045 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 1046 | "dev": true, 1047 | "dependencies": { 1048 | "call-bind": "^1.0.2", 1049 | "has-tostringtag": "^1.0.0" 1050 | }, 1051 | "engines": { 1052 | "node": ">= 0.4" 1053 | }, 1054 | "funding": { 1055 | "url": "https://github.com/sponsors/ljharb" 1056 | } 1057 | }, 1058 | "node_modules/is-shared-array-buffer": { 1059 | "version": "1.0.1", 1060 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", 1061 | "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==", 1062 | "dev": true, 1063 | "funding": { 1064 | "url": "https://github.com/sponsors/ljharb" 1065 | } 1066 | }, 1067 | "node_modules/is-string": { 1068 | "version": "1.0.7", 1069 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 1070 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 1071 | "dev": true, 1072 | "dependencies": { 1073 | "has-tostringtag": "^1.0.0" 1074 | }, 1075 | "engines": { 1076 | "node": ">= 0.4" 1077 | }, 1078 | "funding": { 1079 | "url": "https://github.com/sponsors/ljharb" 1080 | } 1081 | }, 1082 | "node_modules/is-symbol": { 1083 | "version": "1.0.4", 1084 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 1085 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 1086 | "dev": true, 1087 | "dependencies": { 1088 | "has-symbols": "^1.0.2" 1089 | }, 1090 | "engines": { 1091 | "node": ">= 0.4" 1092 | }, 1093 | "funding": { 1094 | "url": "https://github.com/sponsors/ljharb" 1095 | } 1096 | }, 1097 | "node_modules/is-weakref": { 1098 | "version": "1.0.1", 1099 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.1.tgz", 1100 | "integrity": "sha512-b2jKc2pQZjaeFYWEf7ScFj+Be1I+PXmlu572Q8coTXZ+LD/QQZ7ShPMst8h16riVgyXTQwUsFEl74mDvc/3MHQ==", 1101 | "dev": true, 1102 | "dependencies": { 1103 | "call-bind": "^1.0.0" 1104 | }, 1105 | "funding": { 1106 | "url": "https://github.com/sponsors/ljharb" 1107 | } 1108 | }, 1109 | "node_modules/isexe": { 1110 | "version": "2.0.0", 1111 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1112 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1113 | "dev": true 1114 | }, 1115 | "node_modules/js-yaml": { 1116 | "version": "4.1.0", 1117 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1118 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1119 | "dev": true, 1120 | "dependencies": { 1121 | "argparse": "^2.0.1" 1122 | }, 1123 | "bin": { 1124 | "js-yaml": "bin/js-yaml.js" 1125 | } 1126 | }, 1127 | "node_modules/json-schema-traverse": { 1128 | "version": "0.4.1", 1129 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1130 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1131 | "dev": true 1132 | }, 1133 | "node_modules/json-stable-stringify-without-jsonify": { 1134 | "version": "1.0.1", 1135 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1136 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1137 | "dev": true 1138 | }, 1139 | "node_modules/json5": { 1140 | "version": "1.0.1", 1141 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 1142 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 1143 | "dev": true, 1144 | "dependencies": { 1145 | "minimist": "^1.2.0" 1146 | }, 1147 | "bin": { 1148 | "json5": "lib/cli.js" 1149 | } 1150 | }, 1151 | "node_modules/levn": { 1152 | "version": "0.4.1", 1153 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1154 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1155 | "dev": true, 1156 | "dependencies": { 1157 | "prelude-ls": "^1.2.1", 1158 | "type-check": "~0.4.0" 1159 | }, 1160 | "engines": { 1161 | "node": ">= 0.8.0" 1162 | } 1163 | }, 1164 | "node_modules/locate-path": { 1165 | "version": "2.0.0", 1166 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1167 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1168 | "dev": true, 1169 | "dependencies": { 1170 | "p-locate": "^2.0.0", 1171 | "path-exists": "^3.0.0" 1172 | }, 1173 | "engines": { 1174 | "node": ">=4" 1175 | } 1176 | }, 1177 | "node_modules/lodash.merge": { 1178 | "version": "4.6.2", 1179 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1180 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1181 | "dev": true 1182 | }, 1183 | "node_modules/lru-cache": { 1184 | "version": "6.0.0", 1185 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1186 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1187 | "dev": true, 1188 | "dependencies": { 1189 | "yallist": "^4.0.0" 1190 | }, 1191 | "engines": { 1192 | "node": ">=10" 1193 | } 1194 | }, 1195 | "node_modules/minimatch": { 1196 | "version": "3.0.4", 1197 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1198 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1199 | "dev": true, 1200 | "dependencies": { 1201 | "brace-expansion": "^1.1.7" 1202 | }, 1203 | "engines": { 1204 | "node": "*" 1205 | } 1206 | }, 1207 | "node_modules/minimist": { 1208 | "version": "1.2.6", 1209 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1210 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1211 | "dev": true 1212 | }, 1213 | "node_modules/ms": { 1214 | "version": "2.1.2", 1215 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1216 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1217 | "dev": true 1218 | }, 1219 | "node_modules/natural-compare": { 1220 | "version": "1.4.0", 1221 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1222 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1223 | "dev": true 1224 | }, 1225 | "node_modules/object-inspect": { 1226 | "version": "1.11.0", 1227 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", 1228 | "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==", 1229 | "dev": true, 1230 | "funding": { 1231 | "url": "https://github.com/sponsors/ljharb" 1232 | } 1233 | }, 1234 | "node_modules/object-keys": { 1235 | "version": "1.1.1", 1236 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1237 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1238 | "dev": true, 1239 | "engines": { 1240 | "node": ">= 0.4" 1241 | } 1242 | }, 1243 | "node_modules/object.assign": { 1244 | "version": "4.1.2", 1245 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 1246 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 1247 | "dev": true, 1248 | "dependencies": { 1249 | "call-bind": "^1.0.0", 1250 | "define-properties": "^1.1.3", 1251 | "has-symbols": "^1.0.1", 1252 | "object-keys": "^1.1.1" 1253 | }, 1254 | "engines": { 1255 | "node": ">= 0.4" 1256 | }, 1257 | "funding": { 1258 | "url": "https://github.com/sponsors/ljharb" 1259 | } 1260 | }, 1261 | "node_modules/object.values": { 1262 | "version": "1.1.5", 1263 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.5.tgz", 1264 | "integrity": "sha512-QUZRW0ilQ3PnPpbNtgdNV1PDbEqLIiSFB3l+EnGtBQ/8SUTLj1PZwtQHABZtLgwpJZTSZhuGLOGk57Drx2IvYg==", 1265 | "dev": true, 1266 | "dependencies": { 1267 | "call-bind": "^1.0.2", 1268 | "define-properties": "^1.1.3", 1269 | "es-abstract": "^1.19.1" 1270 | }, 1271 | "engines": { 1272 | "node": ">= 0.4" 1273 | }, 1274 | "funding": { 1275 | "url": "https://github.com/sponsors/ljharb" 1276 | } 1277 | }, 1278 | "node_modules/once": { 1279 | "version": "1.4.0", 1280 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1281 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1282 | "dev": true, 1283 | "dependencies": { 1284 | "wrappy": "1" 1285 | } 1286 | }, 1287 | "node_modules/optionator": { 1288 | "version": "0.9.1", 1289 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1290 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1291 | "dev": true, 1292 | "dependencies": { 1293 | "deep-is": "^0.1.3", 1294 | "fast-levenshtein": "^2.0.6", 1295 | "levn": "^0.4.1", 1296 | "prelude-ls": "^1.2.1", 1297 | "type-check": "^0.4.0", 1298 | "word-wrap": "^1.2.3" 1299 | }, 1300 | "engines": { 1301 | "node": ">= 0.8.0" 1302 | } 1303 | }, 1304 | "node_modules/p-limit": { 1305 | "version": "1.3.0", 1306 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1307 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1308 | "dev": true, 1309 | "dependencies": { 1310 | "p-try": "^1.0.0" 1311 | }, 1312 | "engines": { 1313 | "node": ">=4" 1314 | } 1315 | }, 1316 | "node_modules/p-locate": { 1317 | "version": "2.0.0", 1318 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1319 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1320 | "dev": true, 1321 | "dependencies": { 1322 | "p-limit": "^1.1.0" 1323 | }, 1324 | "engines": { 1325 | "node": ">=4" 1326 | } 1327 | }, 1328 | "node_modules/p-try": { 1329 | "version": "1.0.0", 1330 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1331 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1332 | "dev": true, 1333 | "engines": { 1334 | "node": ">=4" 1335 | } 1336 | }, 1337 | "node_modules/parent-module": { 1338 | "version": "1.0.1", 1339 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1340 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1341 | "dev": true, 1342 | "dependencies": { 1343 | "callsites": "^3.0.0" 1344 | }, 1345 | "engines": { 1346 | "node": ">=6" 1347 | } 1348 | }, 1349 | "node_modules/path-exists": { 1350 | "version": "3.0.0", 1351 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1352 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1353 | "dev": true, 1354 | "engines": { 1355 | "node": ">=4" 1356 | } 1357 | }, 1358 | "node_modules/path-is-absolute": { 1359 | "version": "1.0.1", 1360 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1361 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1362 | "dev": true, 1363 | "engines": { 1364 | "node": ">=0.10.0" 1365 | } 1366 | }, 1367 | "node_modules/path-key": { 1368 | "version": "3.1.1", 1369 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1370 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1371 | "dev": true, 1372 | "engines": { 1373 | "node": ">=8" 1374 | } 1375 | }, 1376 | "node_modules/path-parse": { 1377 | "version": "1.0.7", 1378 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1379 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1380 | "dev": true 1381 | }, 1382 | "node_modules/pkg-dir": { 1383 | "version": "2.0.0", 1384 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1385 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1386 | "dev": true, 1387 | "dependencies": { 1388 | "find-up": "^2.1.0" 1389 | }, 1390 | "engines": { 1391 | "node": ">=4" 1392 | } 1393 | }, 1394 | "node_modules/prelude-ls": { 1395 | "version": "1.2.1", 1396 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1397 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1398 | "dev": true, 1399 | "engines": { 1400 | "node": ">= 0.8.0" 1401 | } 1402 | }, 1403 | "node_modules/progress": { 1404 | "version": "2.0.3", 1405 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1406 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1407 | "dev": true, 1408 | "engines": { 1409 | "node": ">=0.4.0" 1410 | } 1411 | }, 1412 | "node_modules/punycode": { 1413 | "version": "2.1.1", 1414 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1415 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1416 | "dev": true, 1417 | "engines": { 1418 | "node": ">=6" 1419 | } 1420 | }, 1421 | "node_modules/regexpp": { 1422 | "version": "3.2.0", 1423 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1424 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1425 | "dev": true, 1426 | "engines": { 1427 | "node": ">=8" 1428 | }, 1429 | "funding": { 1430 | "url": "https://github.com/sponsors/mysticatea" 1431 | } 1432 | }, 1433 | "node_modules/resolve": { 1434 | "version": "1.20.0", 1435 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 1436 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 1437 | "dev": true, 1438 | "dependencies": { 1439 | "is-core-module": "^2.2.0", 1440 | "path-parse": "^1.0.6" 1441 | }, 1442 | "funding": { 1443 | "url": "https://github.com/sponsors/ljharb" 1444 | } 1445 | }, 1446 | "node_modules/resolve-from": { 1447 | "version": "4.0.0", 1448 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1449 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1450 | "dev": true, 1451 | "engines": { 1452 | "node": ">=4" 1453 | } 1454 | }, 1455 | "node_modules/rimraf": { 1456 | "version": "3.0.2", 1457 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1458 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1459 | "dev": true, 1460 | "dependencies": { 1461 | "glob": "^7.1.3" 1462 | }, 1463 | "bin": { 1464 | "rimraf": "bin.js" 1465 | }, 1466 | "funding": { 1467 | "url": "https://github.com/sponsors/isaacs" 1468 | } 1469 | }, 1470 | "node_modules/semver": { 1471 | "version": "7.3.5", 1472 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1473 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1474 | "dev": true, 1475 | "dependencies": { 1476 | "lru-cache": "^6.0.0" 1477 | }, 1478 | "bin": { 1479 | "semver": "bin/semver.js" 1480 | }, 1481 | "engines": { 1482 | "node": ">=10" 1483 | } 1484 | }, 1485 | "node_modules/shebang-command": { 1486 | "version": "2.0.0", 1487 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1488 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1489 | "dev": true, 1490 | "dependencies": { 1491 | "shebang-regex": "^3.0.0" 1492 | }, 1493 | "engines": { 1494 | "node": ">=8" 1495 | } 1496 | }, 1497 | "node_modules/shebang-regex": { 1498 | "version": "3.0.0", 1499 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1500 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1501 | "dev": true, 1502 | "engines": { 1503 | "node": ">=8" 1504 | } 1505 | }, 1506 | "node_modules/side-channel": { 1507 | "version": "1.0.4", 1508 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1509 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1510 | "dev": true, 1511 | "dependencies": { 1512 | "call-bind": "^1.0.0", 1513 | "get-intrinsic": "^1.0.2", 1514 | "object-inspect": "^1.9.0" 1515 | }, 1516 | "funding": { 1517 | "url": "https://github.com/sponsors/ljharb" 1518 | } 1519 | }, 1520 | "node_modules/string.prototype.trimend": { 1521 | "version": "1.0.4", 1522 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", 1523 | "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", 1524 | "dev": true, 1525 | "dependencies": { 1526 | "call-bind": "^1.0.2", 1527 | "define-properties": "^1.1.3" 1528 | }, 1529 | "funding": { 1530 | "url": "https://github.com/sponsors/ljharb" 1531 | } 1532 | }, 1533 | "node_modules/string.prototype.trimstart": { 1534 | "version": "1.0.4", 1535 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", 1536 | "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", 1537 | "dev": true, 1538 | "dependencies": { 1539 | "call-bind": "^1.0.2", 1540 | "define-properties": "^1.1.3" 1541 | }, 1542 | "funding": { 1543 | "url": "https://github.com/sponsors/ljharb" 1544 | } 1545 | }, 1546 | "node_modules/strip-ansi": { 1547 | "version": "6.0.1", 1548 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1549 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1550 | "dev": true, 1551 | "dependencies": { 1552 | "ansi-regex": "^5.0.1" 1553 | }, 1554 | "engines": { 1555 | "node": ">=8" 1556 | } 1557 | }, 1558 | "node_modules/strip-bom": { 1559 | "version": "3.0.0", 1560 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1561 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1562 | "dev": true, 1563 | "engines": { 1564 | "node": ">=4" 1565 | } 1566 | }, 1567 | "node_modules/strip-json-comments": { 1568 | "version": "3.1.1", 1569 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1570 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1571 | "dev": true, 1572 | "engines": { 1573 | "node": ">=8" 1574 | }, 1575 | "funding": { 1576 | "url": "https://github.com/sponsors/sindresorhus" 1577 | } 1578 | }, 1579 | "node_modules/supports-color": { 1580 | "version": "7.2.0", 1581 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1582 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1583 | "dev": true, 1584 | "dependencies": { 1585 | "has-flag": "^4.0.0" 1586 | }, 1587 | "engines": { 1588 | "node": ">=8" 1589 | } 1590 | }, 1591 | "node_modules/text-table": { 1592 | "version": "0.2.0", 1593 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1594 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1595 | "dev": true 1596 | }, 1597 | "node_modules/tsconfig-paths": { 1598 | "version": "3.11.0", 1599 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.11.0.tgz", 1600 | "integrity": "sha512-7ecdYDnIdmv639mmDwslG6KQg1Z9STTz1j7Gcz0xa+nshh/gKDAHcPxRbWOsA3SPp0tXP2leTcY9Kw+NAkfZzA==", 1601 | "dev": true, 1602 | "dependencies": { 1603 | "@types/json5": "^0.0.29", 1604 | "json5": "^1.0.1", 1605 | "minimist": "^1.2.0", 1606 | "strip-bom": "^3.0.0" 1607 | } 1608 | }, 1609 | "node_modules/type-check": { 1610 | "version": "0.4.0", 1611 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1612 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1613 | "dev": true, 1614 | "dependencies": { 1615 | "prelude-ls": "^1.2.1" 1616 | }, 1617 | "engines": { 1618 | "node": ">= 0.8.0" 1619 | } 1620 | }, 1621 | "node_modules/type-fest": { 1622 | "version": "0.20.2", 1623 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1624 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1625 | "dev": true, 1626 | "engines": { 1627 | "node": ">=10" 1628 | }, 1629 | "funding": { 1630 | "url": "https://github.com/sponsors/sindresorhus" 1631 | } 1632 | }, 1633 | "node_modules/unbox-primitive": { 1634 | "version": "1.0.1", 1635 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", 1636 | "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", 1637 | "dev": true, 1638 | "dependencies": { 1639 | "function-bind": "^1.1.1", 1640 | "has-bigints": "^1.0.1", 1641 | "has-symbols": "^1.0.2", 1642 | "which-boxed-primitive": "^1.0.2" 1643 | }, 1644 | "funding": { 1645 | "url": "https://github.com/sponsors/ljharb" 1646 | } 1647 | }, 1648 | "node_modules/uri-js": { 1649 | "version": "4.4.1", 1650 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1651 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1652 | "dev": true, 1653 | "dependencies": { 1654 | "punycode": "^2.1.0" 1655 | } 1656 | }, 1657 | "node_modules/v8-compile-cache": { 1658 | "version": "2.3.0", 1659 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 1660 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 1661 | "dev": true 1662 | }, 1663 | "node_modules/which": { 1664 | "version": "2.0.2", 1665 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1666 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1667 | "dev": true, 1668 | "dependencies": { 1669 | "isexe": "^2.0.0" 1670 | }, 1671 | "bin": { 1672 | "node-which": "bin/node-which" 1673 | }, 1674 | "engines": { 1675 | "node": ">= 8" 1676 | } 1677 | }, 1678 | "node_modules/which-boxed-primitive": { 1679 | "version": "1.0.2", 1680 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 1681 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 1682 | "dev": true, 1683 | "dependencies": { 1684 | "is-bigint": "^1.0.1", 1685 | "is-boolean-object": "^1.1.0", 1686 | "is-number-object": "^1.0.4", 1687 | "is-string": "^1.0.5", 1688 | "is-symbol": "^1.0.3" 1689 | }, 1690 | "funding": { 1691 | "url": "https://github.com/sponsors/ljharb" 1692 | } 1693 | }, 1694 | "node_modules/word-wrap": { 1695 | "version": "1.2.3", 1696 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1697 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1698 | "dev": true, 1699 | "engines": { 1700 | "node": ">=0.10.0" 1701 | } 1702 | }, 1703 | "node_modules/wrappy": { 1704 | "version": "1.0.2", 1705 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1706 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1707 | "dev": true 1708 | }, 1709 | "node_modules/yallist": { 1710 | "version": "4.0.0", 1711 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1712 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1713 | "dev": true 1714 | } 1715 | }, 1716 | "dependencies": { 1717 | "@eslint/eslintrc": { 1718 | "version": "1.0.4", 1719 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.4.tgz", 1720 | "integrity": "sha512-h8Vx6MdxwWI2WM8/zREHMoqdgLNXEL4QX3MWSVMdyNJGvXVOs+6lp+m2hc3FnuMHDc4poxFNI20vCk0OmI4G0Q==", 1721 | "dev": true, 1722 | "requires": { 1723 | "ajv": "^6.12.4", 1724 | "debug": "^4.3.2", 1725 | "espree": "^9.0.0", 1726 | "globals": "^13.9.0", 1727 | "ignore": "^4.0.6", 1728 | "import-fresh": "^3.2.1", 1729 | "js-yaml": "^4.1.0", 1730 | "minimatch": "^3.0.4", 1731 | "strip-json-comments": "^3.1.1" 1732 | } 1733 | }, 1734 | "@humanwhocodes/config-array": { 1735 | "version": "0.6.0", 1736 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.6.0.tgz", 1737 | "integrity": "sha512-JQlEKbcgEUjBFhLIF4iqM7u/9lwgHRBcpHrmUNCALK0Q3amXN6lxdoXLnF0sm11E9VqTmBALR87IlUg1bZ8A9A==", 1738 | "dev": true, 1739 | "requires": { 1740 | "@humanwhocodes/object-schema": "^1.2.0", 1741 | "debug": "^4.1.1", 1742 | "minimatch": "^3.0.4" 1743 | } 1744 | }, 1745 | "@humanwhocodes/object-schema": { 1746 | "version": "1.2.1", 1747 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 1748 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 1749 | "dev": true 1750 | }, 1751 | "@types/json5": { 1752 | "version": "0.0.29", 1753 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 1754 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 1755 | "dev": true 1756 | }, 1757 | "acorn": { 1758 | "version": "8.6.0", 1759 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.6.0.tgz", 1760 | "integrity": "sha512-U1riIR+lBSNi3IbxtaHOIKdH8sLFv3NYfNv8sg7ZsNhcfl4HF2++BfqqrNAxoCLQW1iiylOj76ecnaUxz+z9yw==", 1761 | "dev": true 1762 | }, 1763 | "acorn-jsx": { 1764 | "version": "5.3.2", 1765 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1766 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1767 | "dev": true, 1768 | "requires": {} 1769 | }, 1770 | "ajv": { 1771 | "version": "6.12.6", 1772 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1773 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1774 | "dev": true, 1775 | "requires": { 1776 | "fast-deep-equal": "^3.1.1", 1777 | "fast-json-stable-stringify": "^2.0.0", 1778 | "json-schema-traverse": "^0.4.1", 1779 | "uri-js": "^4.2.2" 1780 | } 1781 | }, 1782 | "ansi-colors": { 1783 | "version": "4.1.1", 1784 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 1785 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 1786 | "dev": true 1787 | }, 1788 | "ansi-regex": { 1789 | "version": "5.0.1", 1790 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1791 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1792 | "dev": true 1793 | }, 1794 | "ansi-styles": { 1795 | "version": "4.3.0", 1796 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1797 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1798 | "dev": true, 1799 | "requires": { 1800 | "color-convert": "^2.0.1" 1801 | } 1802 | }, 1803 | "argparse": { 1804 | "version": "2.0.1", 1805 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1806 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1807 | "dev": true 1808 | }, 1809 | "array-includes": { 1810 | "version": "3.1.4", 1811 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.4.tgz", 1812 | "integrity": "sha512-ZTNSQkmWumEbiHO2GF4GmWxYVTiQyJy2XOTa15sdQSrvKn7l+180egQMqlrMOUMCyLMD7pmyQe4mMDUT6Behrw==", 1813 | "dev": true, 1814 | "requires": { 1815 | "call-bind": "^1.0.2", 1816 | "define-properties": "^1.1.3", 1817 | "es-abstract": "^1.19.1", 1818 | "get-intrinsic": "^1.1.1", 1819 | "is-string": "^1.0.7" 1820 | } 1821 | }, 1822 | "array.prototype.flat": { 1823 | "version": "1.2.5", 1824 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.5.tgz", 1825 | "integrity": "sha512-KaYU+S+ndVqyUnignHftkwc58o3uVU1jzczILJ1tN2YaIZpFIKBiP/x/j97E5MVPsaCloPbqWLB/8qCTVvT2qg==", 1826 | "dev": true, 1827 | "requires": { 1828 | "call-bind": "^1.0.2", 1829 | "define-properties": "^1.1.3", 1830 | "es-abstract": "^1.19.0" 1831 | } 1832 | }, 1833 | "balanced-match": { 1834 | "version": "1.0.2", 1835 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1836 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1837 | "dev": true 1838 | }, 1839 | "brace-expansion": { 1840 | "version": "1.1.11", 1841 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1842 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1843 | "dev": true, 1844 | "requires": { 1845 | "balanced-match": "^1.0.0", 1846 | "concat-map": "0.0.1" 1847 | } 1848 | }, 1849 | "call-bind": { 1850 | "version": "1.0.2", 1851 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1852 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1853 | "dev": true, 1854 | "requires": { 1855 | "function-bind": "^1.1.1", 1856 | "get-intrinsic": "^1.0.2" 1857 | } 1858 | }, 1859 | "callsites": { 1860 | "version": "3.1.0", 1861 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1862 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1863 | "dev": true 1864 | }, 1865 | "chalk": { 1866 | "version": "4.1.2", 1867 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1868 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1869 | "dev": true, 1870 | "requires": { 1871 | "ansi-styles": "^4.1.0", 1872 | "supports-color": "^7.1.0" 1873 | } 1874 | }, 1875 | "color-convert": { 1876 | "version": "2.0.1", 1877 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1878 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1879 | "dev": true, 1880 | "requires": { 1881 | "color-name": "~1.1.4" 1882 | } 1883 | }, 1884 | "color-name": { 1885 | "version": "1.1.4", 1886 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1887 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1888 | "dev": true 1889 | }, 1890 | "concat-map": { 1891 | "version": "0.0.1", 1892 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1893 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1894 | "dev": true 1895 | }, 1896 | "cross-spawn": { 1897 | "version": "7.0.3", 1898 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1899 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1900 | "dev": true, 1901 | "requires": { 1902 | "path-key": "^3.1.0", 1903 | "shebang-command": "^2.0.0", 1904 | "which": "^2.0.1" 1905 | } 1906 | }, 1907 | "debug": { 1908 | "version": "4.3.2", 1909 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 1910 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 1911 | "dev": true, 1912 | "requires": { 1913 | "ms": "2.1.2" 1914 | } 1915 | }, 1916 | "deep-is": { 1917 | "version": "0.1.4", 1918 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1919 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1920 | "dev": true 1921 | }, 1922 | "define-properties": { 1923 | "version": "1.1.3", 1924 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 1925 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 1926 | "dev": true, 1927 | "requires": { 1928 | "object-keys": "^1.0.12" 1929 | } 1930 | }, 1931 | "doctrine": { 1932 | "version": "3.0.0", 1933 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1934 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1935 | "dev": true, 1936 | "requires": { 1937 | "esutils": "^2.0.2" 1938 | } 1939 | }, 1940 | "enquirer": { 1941 | "version": "2.3.6", 1942 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 1943 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 1944 | "dev": true, 1945 | "requires": { 1946 | "ansi-colors": "^4.1.1" 1947 | } 1948 | }, 1949 | "es-abstract": { 1950 | "version": "1.19.1", 1951 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", 1952 | "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", 1953 | "dev": true, 1954 | "requires": { 1955 | "call-bind": "^1.0.2", 1956 | "es-to-primitive": "^1.2.1", 1957 | "function-bind": "^1.1.1", 1958 | "get-intrinsic": "^1.1.1", 1959 | "get-symbol-description": "^1.0.0", 1960 | "has": "^1.0.3", 1961 | "has-symbols": "^1.0.2", 1962 | "internal-slot": "^1.0.3", 1963 | "is-callable": "^1.2.4", 1964 | "is-negative-zero": "^2.0.1", 1965 | "is-regex": "^1.1.4", 1966 | "is-shared-array-buffer": "^1.0.1", 1967 | "is-string": "^1.0.7", 1968 | "is-weakref": "^1.0.1", 1969 | "object-inspect": "^1.11.0", 1970 | "object-keys": "^1.1.1", 1971 | "object.assign": "^4.1.2", 1972 | "string.prototype.trimend": "^1.0.4", 1973 | "string.prototype.trimstart": "^1.0.4", 1974 | "unbox-primitive": "^1.0.1" 1975 | } 1976 | }, 1977 | "es-to-primitive": { 1978 | "version": "1.2.1", 1979 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 1980 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 1981 | "dev": true, 1982 | "requires": { 1983 | "is-callable": "^1.1.4", 1984 | "is-date-object": "^1.0.1", 1985 | "is-symbol": "^1.0.2" 1986 | } 1987 | }, 1988 | "escape-string-regexp": { 1989 | "version": "4.0.0", 1990 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1991 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1992 | "dev": true 1993 | }, 1994 | "eslint": { 1995 | "version": "8.2.0", 1996 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.2.0.tgz", 1997 | "integrity": "sha512-erw7XmM+CLxTOickrimJ1SiF55jiNlVSp2qqm0NuBWPtHYQCegD5ZMaW0c3i5ytPqL+SSLaCxdvQXFPLJn+ABw==", 1998 | "dev": true, 1999 | "requires": { 2000 | "@eslint/eslintrc": "^1.0.4", 2001 | "@humanwhocodes/config-array": "^0.6.0", 2002 | "ajv": "^6.10.0", 2003 | "chalk": "^4.0.0", 2004 | "cross-spawn": "^7.0.2", 2005 | "debug": "^4.3.2", 2006 | "doctrine": "^3.0.0", 2007 | "enquirer": "^2.3.5", 2008 | "escape-string-regexp": "^4.0.0", 2009 | "eslint-scope": "^6.0.0", 2010 | "eslint-utils": "^3.0.0", 2011 | "eslint-visitor-keys": "^3.0.0", 2012 | "espree": "^9.0.0", 2013 | "esquery": "^1.4.0", 2014 | "esutils": "^2.0.2", 2015 | "fast-deep-equal": "^3.1.3", 2016 | "file-entry-cache": "^6.0.1", 2017 | "functional-red-black-tree": "^1.0.1", 2018 | "glob-parent": "^6.0.1", 2019 | "globals": "^13.6.0", 2020 | "ignore": "^4.0.6", 2021 | "import-fresh": "^3.0.0", 2022 | "imurmurhash": "^0.1.4", 2023 | "is-glob": "^4.0.0", 2024 | "js-yaml": "^4.1.0", 2025 | "json-stable-stringify-without-jsonify": "^1.0.1", 2026 | "levn": "^0.4.1", 2027 | "lodash.merge": "^4.6.2", 2028 | "minimatch": "^3.0.4", 2029 | "natural-compare": "^1.4.0", 2030 | "optionator": "^0.9.1", 2031 | "progress": "^2.0.0", 2032 | "regexpp": "^3.2.0", 2033 | "semver": "^7.2.1", 2034 | "strip-ansi": "^6.0.1", 2035 | "strip-json-comments": "^3.1.0", 2036 | "text-table": "^0.2.0", 2037 | "v8-compile-cache": "^2.0.3" 2038 | } 2039 | }, 2040 | "eslint-config-strongloop": { 2041 | "version": "2.1.0", 2042 | "resolved": "https://registry.npmjs.org/eslint-config-strongloop/-/eslint-config-strongloop-2.1.0.tgz", 2043 | "integrity": "sha1-dj3Rmt/OiNewBR5uJV8a43eDtMY=", 2044 | "dev": true 2045 | }, 2046 | "eslint-import-resolver-node": { 2047 | "version": "0.3.6", 2048 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz", 2049 | "integrity": "sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw==", 2050 | "dev": true, 2051 | "requires": { 2052 | "debug": "^3.2.7", 2053 | "resolve": "^1.20.0" 2054 | }, 2055 | "dependencies": { 2056 | "debug": { 2057 | "version": "3.2.7", 2058 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 2059 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 2060 | "dev": true, 2061 | "requires": { 2062 | "ms": "^2.1.1" 2063 | } 2064 | } 2065 | } 2066 | }, 2067 | "eslint-module-utils": { 2068 | "version": "2.7.1", 2069 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.7.1.tgz", 2070 | "integrity": "sha512-fjoetBXQZq2tSTWZ9yWVl2KuFrTZZH3V+9iD1V1RfpDgxzJR+mPd/KZmMiA8gbPqdBzpNiEHOuT7IYEWxrH0zQ==", 2071 | "dev": true, 2072 | "requires": { 2073 | "debug": "^3.2.7", 2074 | "find-up": "^2.1.0", 2075 | "pkg-dir": "^2.0.0" 2076 | }, 2077 | "dependencies": { 2078 | "debug": { 2079 | "version": "3.2.7", 2080 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 2081 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 2082 | "dev": true, 2083 | "requires": { 2084 | "ms": "^2.1.1" 2085 | } 2086 | } 2087 | } 2088 | }, 2089 | "eslint-plugin-import": { 2090 | "version": "2.25.3", 2091 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.25.3.tgz", 2092 | "integrity": "sha512-RzAVbby+72IB3iOEL8clzPLzL3wpDrlwjsTBAQXgyp5SeTqqY+0bFubwuo+y/HLhNZcXV4XqTBO4LGsfyHIDXg==", 2093 | "dev": true, 2094 | "requires": { 2095 | "array-includes": "^3.1.4", 2096 | "array.prototype.flat": "^1.2.5", 2097 | "debug": "^2.6.9", 2098 | "doctrine": "^2.1.0", 2099 | "eslint-import-resolver-node": "^0.3.6", 2100 | "eslint-module-utils": "^2.7.1", 2101 | "has": "^1.0.3", 2102 | "is-core-module": "^2.8.0", 2103 | "is-glob": "^4.0.3", 2104 | "minimatch": "^3.0.4", 2105 | "object.values": "^1.1.5", 2106 | "resolve": "^1.20.0", 2107 | "tsconfig-paths": "^3.11.0" 2108 | }, 2109 | "dependencies": { 2110 | "debug": { 2111 | "version": "2.6.9", 2112 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2113 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2114 | "dev": true, 2115 | "requires": { 2116 | "ms": "2.0.0" 2117 | } 2118 | }, 2119 | "doctrine": { 2120 | "version": "2.1.0", 2121 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 2122 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 2123 | "dev": true, 2124 | "requires": { 2125 | "esutils": "^2.0.2" 2126 | } 2127 | }, 2128 | "ms": { 2129 | "version": "2.0.0", 2130 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2131 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 2132 | "dev": true 2133 | } 2134 | } 2135 | }, 2136 | "eslint-scope": { 2137 | "version": "6.0.0", 2138 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-6.0.0.tgz", 2139 | "integrity": "sha512-uRDL9MWmQCkaFus8RF5K9/L/2fn+80yoW3jkD53l4shjCh26fCtvJGasxjUqP5OT87SYTxCVA3BwTUzuELx9kA==", 2140 | "dev": true, 2141 | "requires": { 2142 | "esrecurse": "^4.3.0", 2143 | "estraverse": "^5.2.0" 2144 | } 2145 | }, 2146 | "eslint-utils": { 2147 | "version": "3.0.0", 2148 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 2149 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 2150 | "dev": true, 2151 | "requires": { 2152 | "eslint-visitor-keys": "^2.0.0" 2153 | }, 2154 | "dependencies": { 2155 | "eslint-visitor-keys": { 2156 | "version": "2.1.0", 2157 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 2158 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 2159 | "dev": true 2160 | } 2161 | } 2162 | }, 2163 | "eslint-visitor-keys": { 2164 | "version": "3.1.0", 2165 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz", 2166 | "integrity": "sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA==", 2167 | "dev": true 2168 | }, 2169 | "espree": { 2170 | "version": "9.0.0", 2171 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.0.0.tgz", 2172 | "integrity": "sha512-r5EQJcYZ2oaGbeR0jR0fFVijGOcwai07/690YRXLINuhmVeRY4UKSAsQPe/0BNuDgwP7Ophoc1PRsr2E3tkbdQ==", 2173 | "dev": true, 2174 | "requires": { 2175 | "acorn": "^8.5.0", 2176 | "acorn-jsx": "^5.3.1", 2177 | "eslint-visitor-keys": "^3.0.0" 2178 | } 2179 | }, 2180 | "esquery": { 2181 | "version": "1.4.0", 2182 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 2183 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 2184 | "dev": true, 2185 | "requires": { 2186 | "estraverse": "^5.1.0" 2187 | } 2188 | }, 2189 | "esrecurse": { 2190 | "version": "4.3.0", 2191 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2192 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2193 | "dev": true, 2194 | "requires": { 2195 | "estraverse": "^5.2.0" 2196 | } 2197 | }, 2198 | "estraverse": { 2199 | "version": "5.3.0", 2200 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2201 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2202 | "dev": true 2203 | }, 2204 | "esutils": { 2205 | "version": "2.0.3", 2206 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2207 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2208 | "dev": true 2209 | }, 2210 | "fast-deep-equal": { 2211 | "version": "3.1.3", 2212 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2213 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2214 | "dev": true 2215 | }, 2216 | "fast-json-stable-stringify": { 2217 | "version": "2.1.0", 2218 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2219 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2220 | "dev": true 2221 | }, 2222 | "fast-levenshtein": { 2223 | "version": "2.0.6", 2224 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2225 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2226 | "dev": true 2227 | }, 2228 | "file-entry-cache": { 2229 | "version": "6.0.1", 2230 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2231 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2232 | "dev": true, 2233 | "requires": { 2234 | "flat-cache": "^3.0.4" 2235 | } 2236 | }, 2237 | "find-up": { 2238 | "version": "2.1.0", 2239 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 2240 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 2241 | "dev": true, 2242 | "requires": { 2243 | "locate-path": "^2.0.0" 2244 | } 2245 | }, 2246 | "flat-cache": { 2247 | "version": "3.0.4", 2248 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2249 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2250 | "dev": true, 2251 | "requires": { 2252 | "flatted": "^3.1.0", 2253 | "rimraf": "^3.0.2" 2254 | } 2255 | }, 2256 | "flatted": { 2257 | "version": "3.2.4", 2258 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", 2259 | "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", 2260 | "dev": true 2261 | }, 2262 | "fs.realpath": { 2263 | "version": "1.0.0", 2264 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2265 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2266 | "dev": true 2267 | }, 2268 | "function-bind": { 2269 | "version": "1.1.1", 2270 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2271 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 2272 | "dev": true 2273 | }, 2274 | "functional-red-black-tree": { 2275 | "version": "1.0.1", 2276 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2277 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2278 | "dev": true 2279 | }, 2280 | "get-intrinsic": { 2281 | "version": "1.1.1", 2282 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 2283 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 2284 | "dev": true, 2285 | "requires": { 2286 | "function-bind": "^1.1.1", 2287 | "has": "^1.0.3", 2288 | "has-symbols": "^1.0.1" 2289 | } 2290 | }, 2291 | "get-symbol-description": { 2292 | "version": "1.0.0", 2293 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 2294 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 2295 | "dev": true, 2296 | "requires": { 2297 | "call-bind": "^1.0.2", 2298 | "get-intrinsic": "^1.1.1" 2299 | } 2300 | }, 2301 | "glob": { 2302 | "version": "7.2.0", 2303 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 2304 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 2305 | "dev": true, 2306 | "requires": { 2307 | "fs.realpath": "^1.0.0", 2308 | "inflight": "^1.0.4", 2309 | "inherits": "2", 2310 | "minimatch": "^3.0.4", 2311 | "once": "^1.3.0", 2312 | "path-is-absolute": "^1.0.0" 2313 | } 2314 | }, 2315 | "glob-parent": { 2316 | "version": "6.0.2", 2317 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2318 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2319 | "dev": true, 2320 | "requires": { 2321 | "is-glob": "^4.0.3" 2322 | } 2323 | }, 2324 | "globals": { 2325 | "version": "13.12.0", 2326 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 2327 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 2328 | "dev": true, 2329 | "requires": { 2330 | "type-fest": "^0.20.2" 2331 | } 2332 | }, 2333 | "has": { 2334 | "version": "1.0.3", 2335 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2336 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2337 | "dev": true, 2338 | "requires": { 2339 | "function-bind": "^1.1.1" 2340 | } 2341 | }, 2342 | "has-bigints": { 2343 | "version": "1.0.1", 2344 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", 2345 | "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", 2346 | "dev": true 2347 | }, 2348 | "has-flag": { 2349 | "version": "4.0.0", 2350 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2351 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2352 | "dev": true 2353 | }, 2354 | "has-symbols": { 2355 | "version": "1.0.2", 2356 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 2357 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 2358 | "dev": true 2359 | }, 2360 | "has-tostringtag": { 2361 | "version": "1.0.0", 2362 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 2363 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 2364 | "dev": true, 2365 | "requires": { 2366 | "has-symbols": "^1.0.2" 2367 | } 2368 | }, 2369 | "ignore": { 2370 | "version": "4.0.6", 2371 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 2372 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 2373 | "dev": true 2374 | }, 2375 | "import-fresh": { 2376 | "version": "3.3.0", 2377 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2378 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2379 | "dev": true, 2380 | "requires": { 2381 | "parent-module": "^1.0.0", 2382 | "resolve-from": "^4.0.0" 2383 | } 2384 | }, 2385 | "imurmurhash": { 2386 | "version": "0.1.4", 2387 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2388 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2389 | "dev": true 2390 | }, 2391 | "inflight": { 2392 | "version": "1.0.6", 2393 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2394 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2395 | "dev": true, 2396 | "requires": { 2397 | "once": "^1.3.0", 2398 | "wrappy": "1" 2399 | } 2400 | }, 2401 | "inherits": { 2402 | "version": "2.0.4", 2403 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2404 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2405 | "dev": true 2406 | }, 2407 | "internal-slot": { 2408 | "version": "1.0.3", 2409 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 2410 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 2411 | "dev": true, 2412 | "requires": { 2413 | "get-intrinsic": "^1.1.0", 2414 | "has": "^1.0.3", 2415 | "side-channel": "^1.0.4" 2416 | } 2417 | }, 2418 | "is-bigint": { 2419 | "version": "1.0.4", 2420 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 2421 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 2422 | "dev": true, 2423 | "requires": { 2424 | "has-bigints": "^1.0.1" 2425 | } 2426 | }, 2427 | "is-boolean-object": { 2428 | "version": "1.1.2", 2429 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 2430 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 2431 | "dev": true, 2432 | "requires": { 2433 | "call-bind": "^1.0.2", 2434 | "has-tostringtag": "^1.0.0" 2435 | } 2436 | }, 2437 | "is-callable": { 2438 | "version": "1.2.4", 2439 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", 2440 | "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", 2441 | "dev": true 2442 | }, 2443 | "is-core-module": { 2444 | "version": "2.8.0", 2445 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.0.tgz", 2446 | "integrity": "sha512-vd15qHsaqrRL7dtH6QNuy0ndJmRDrS9HAM1CAiSifNUFv4x1a0CCVsj18hJ1mShxIG6T2i1sO78MkP56r0nYRw==", 2447 | "dev": true, 2448 | "requires": { 2449 | "has": "^1.0.3" 2450 | } 2451 | }, 2452 | "is-date-object": { 2453 | "version": "1.0.5", 2454 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 2455 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 2456 | "dev": true, 2457 | "requires": { 2458 | "has-tostringtag": "^1.0.0" 2459 | } 2460 | }, 2461 | "is-extglob": { 2462 | "version": "2.1.1", 2463 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2464 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2465 | "dev": true 2466 | }, 2467 | "is-glob": { 2468 | "version": "4.0.3", 2469 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2470 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2471 | "dev": true, 2472 | "requires": { 2473 | "is-extglob": "^2.1.1" 2474 | } 2475 | }, 2476 | "is-negative-zero": { 2477 | "version": "2.0.1", 2478 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz", 2479 | "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==", 2480 | "dev": true 2481 | }, 2482 | "is-number-object": { 2483 | "version": "1.0.6", 2484 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", 2485 | "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", 2486 | "dev": true, 2487 | "requires": { 2488 | "has-tostringtag": "^1.0.0" 2489 | } 2490 | }, 2491 | "is-regex": { 2492 | "version": "1.1.4", 2493 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 2494 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 2495 | "dev": true, 2496 | "requires": { 2497 | "call-bind": "^1.0.2", 2498 | "has-tostringtag": "^1.0.0" 2499 | } 2500 | }, 2501 | "is-shared-array-buffer": { 2502 | "version": "1.0.1", 2503 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", 2504 | "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==", 2505 | "dev": true 2506 | }, 2507 | "is-string": { 2508 | "version": "1.0.7", 2509 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 2510 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 2511 | "dev": true, 2512 | "requires": { 2513 | "has-tostringtag": "^1.0.0" 2514 | } 2515 | }, 2516 | "is-symbol": { 2517 | "version": "1.0.4", 2518 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 2519 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 2520 | "dev": true, 2521 | "requires": { 2522 | "has-symbols": "^1.0.2" 2523 | } 2524 | }, 2525 | "is-weakref": { 2526 | "version": "1.0.1", 2527 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.1.tgz", 2528 | "integrity": "sha512-b2jKc2pQZjaeFYWEf7ScFj+Be1I+PXmlu572Q8coTXZ+LD/QQZ7ShPMst8h16riVgyXTQwUsFEl74mDvc/3MHQ==", 2529 | "dev": true, 2530 | "requires": { 2531 | "call-bind": "^1.0.0" 2532 | } 2533 | }, 2534 | "isexe": { 2535 | "version": "2.0.0", 2536 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2537 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2538 | "dev": true 2539 | }, 2540 | "js-yaml": { 2541 | "version": "4.1.0", 2542 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2543 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2544 | "dev": true, 2545 | "requires": { 2546 | "argparse": "^2.0.1" 2547 | } 2548 | }, 2549 | "json-schema-traverse": { 2550 | "version": "0.4.1", 2551 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2552 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2553 | "dev": true 2554 | }, 2555 | "json-stable-stringify-without-jsonify": { 2556 | "version": "1.0.1", 2557 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2558 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2559 | "dev": true 2560 | }, 2561 | "json5": { 2562 | "version": "1.0.1", 2563 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 2564 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 2565 | "dev": true, 2566 | "requires": { 2567 | "minimist": "^1.2.0" 2568 | } 2569 | }, 2570 | "levn": { 2571 | "version": "0.4.1", 2572 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2573 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2574 | "dev": true, 2575 | "requires": { 2576 | "prelude-ls": "^1.2.1", 2577 | "type-check": "~0.4.0" 2578 | } 2579 | }, 2580 | "locate-path": { 2581 | "version": "2.0.0", 2582 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 2583 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 2584 | "dev": true, 2585 | "requires": { 2586 | "p-locate": "^2.0.0", 2587 | "path-exists": "^3.0.0" 2588 | } 2589 | }, 2590 | "lodash.merge": { 2591 | "version": "4.6.2", 2592 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2593 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2594 | "dev": true 2595 | }, 2596 | "lru-cache": { 2597 | "version": "6.0.0", 2598 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2599 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2600 | "dev": true, 2601 | "requires": { 2602 | "yallist": "^4.0.0" 2603 | } 2604 | }, 2605 | "minimatch": { 2606 | "version": "3.0.4", 2607 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2608 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2609 | "dev": true, 2610 | "requires": { 2611 | "brace-expansion": "^1.1.7" 2612 | } 2613 | }, 2614 | "minimist": { 2615 | "version": "1.2.6", 2616 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 2617 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 2618 | "dev": true 2619 | }, 2620 | "ms": { 2621 | "version": "2.1.2", 2622 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2623 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2624 | "dev": true 2625 | }, 2626 | "natural-compare": { 2627 | "version": "1.4.0", 2628 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2629 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2630 | "dev": true 2631 | }, 2632 | "object-inspect": { 2633 | "version": "1.11.0", 2634 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.11.0.tgz", 2635 | "integrity": "sha512-jp7ikS6Sd3GxQfZJPyH3cjcbJF6GZPClgdV+EFygjFLQ5FmW/dRUnTd9PQ9k0JhoNDabWFbpF1yCdSWCC6gexg==", 2636 | "dev": true 2637 | }, 2638 | "object-keys": { 2639 | "version": "1.1.1", 2640 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2641 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2642 | "dev": true 2643 | }, 2644 | "object.assign": { 2645 | "version": "4.1.2", 2646 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 2647 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 2648 | "dev": true, 2649 | "requires": { 2650 | "call-bind": "^1.0.0", 2651 | "define-properties": "^1.1.3", 2652 | "has-symbols": "^1.0.1", 2653 | "object-keys": "^1.1.1" 2654 | } 2655 | }, 2656 | "object.values": { 2657 | "version": "1.1.5", 2658 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.5.tgz", 2659 | "integrity": "sha512-QUZRW0ilQ3PnPpbNtgdNV1PDbEqLIiSFB3l+EnGtBQ/8SUTLj1PZwtQHABZtLgwpJZTSZhuGLOGk57Drx2IvYg==", 2660 | "dev": true, 2661 | "requires": { 2662 | "call-bind": "^1.0.2", 2663 | "define-properties": "^1.1.3", 2664 | "es-abstract": "^1.19.1" 2665 | } 2666 | }, 2667 | "once": { 2668 | "version": "1.4.0", 2669 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2670 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2671 | "dev": true, 2672 | "requires": { 2673 | "wrappy": "1" 2674 | } 2675 | }, 2676 | "optionator": { 2677 | "version": "0.9.1", 2678 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2679 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2680 | "dev": true, 2681 | "requires": { 2682 | "deep-is": "^0.1.3", 2683 | "fast-levenshtein": "^2.0.6", 2684 | "levn": "^0.4.1", 2685 | "prelude-ls": "^1.2.1", 2686 | "type-check": "^0.4.0", 2687 | "word-wrap": "^1.2.3" 2688 | } 2689 | }, 2690 | "p-limit": { 2691 | "version": "1.3.0", 2692 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 2693 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 2694 | "dev": true, 2695 | "requires": { 2696 | "p-try": "^1.0.0" 2697 | } 2698 | }, 2699 | "p-locate": { 2700 | "version": "2.0.0", 2701 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 2702 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 2703 | "dev": true, 2704 | "requires": { 2705 | "p-limit": "^1.1.0" 2706 | } 2707 | }, 2708 | "p-try": { 2709 | "version": "1.0.0", 2710 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 2711 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 2712 | "dev": true 2713 | }, 2714 | "parent-module": { 2715 | "version": "1.0.1", 2716 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2717 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2718 | "dev": true, 2719 | "requires": { 2720 | "callsites": "^3.0.0" 2721 | } 2722 | }, 2723 | "path-exists": { 2724 | "version": "3.0.0", 2725 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2726 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2727 | "dev": true 2728 | }, 2729 | "path-is-absolute": { 2730 | "version": "1.0.1", 2731 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2732 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2733 | "dev": true 2734 | }, 2735 | "path-key": { 2736 | "version": "3.1.1", 2737 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2738 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2739 | "dev": true 2740 | }, 2741 | "path-parse": { 2742 | "version": "1.0.7", 2743 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2744 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2745 | "dev": true 2746 | }, 2747 | "pkg-dir": { 2748 | "version": "2.0.0", 2749 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 2750 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 2751 | "dev": true, 2752 | "requires": { 2753 | "find-up": "^2.1.0" 2754 | } 2755 | }, 2756 | "prelude-ls": { 2757 | "version": "1.2.1", 2758 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2759 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2760 | "dev": true 2761 | }, 2762 | "progress": { 2763 | "version": "2.0.3", 2764 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2765 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2766 | "dev": true 2767 | }, 2768 | "punycode": { 2769 | "version": "2.1.1", 2770 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2771 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2772 | "dev": true 2773 | }, 2774 | "regexpp": { 2775 | "version": "3.2.0", 2776 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 2777 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 2778 | "dev": true 2779 | }, 2780 | "resolve": { 2781 | "version": "1.20.0", 2782 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 2783 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 2784 | "dev": true, 2785 | "requires": { 2786 | "is-core-module": "^2.2.0", 2787 | "path-parse": "^1.0.6" 2788 | } 2789 | }, 2790 | "resolve-from": { 2791 | "version": "4.0.0", 2792 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2793 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2794 | "dev": true 2795 | }, 2796 | "rimraf": { 2797 | "version": "3.0.2", 2798 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2799 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2800 | "dev": true, 2801 | "requires": { 2802 | "glob": "^7.1.3" 2803 | } 2804 | }, 2805 | "semver": { 2806 | "version": "7.3.5", 2807 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 2808 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 2809 | "dev": true, 2810 | "requires": { 2811 | "lru-cache": "^6.0.0" 2812 | } 2813 | }, 2814 | "shebang-command": { 2815 | "version": "2.0.0", 2816 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2817 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2818 | "dev": true, 2819 | "requires": { 2820 | "shebang-regex": "^3.0.0" 2821 | } 2822 | }, 2823 | "shebang-regex": { 2824 | "version": "3.0.0", 2825 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2826 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2827 | "dev": true 2828 | }, 2829 | "side-channel": { 2830 | "version": "1.0.4", 2831 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2832 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2833 | "dev": true, 2834 | "requires": { 2835 | "call-bind": "^1.0.0", 2836 | "get-intrinsic": "^1.0.2", 2837 | "object-inspect": "^1.9.0" 2838 | } 2839 | }, 2840 | "string.prototype.trimend": { 2841 | "version": "1.0.4", 2842 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", 2843 | "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", 2844 | "dev": true, 2845 | "requires": { 2846 | "call-bind": "^1.0.2", 2847 | "define-properties": "^1.1.3" 2848 | } 2849 | }, 2850 | "string.prototype.trimstart": { 2851 | "version": "1.0.4", 2852 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", 2853 | "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", 2854 | "dev": true, 2855 | "requires": { 2856 | "call-bind": "^1.0.2", 2857 | "define-properties": "^1.1.3" 2858 | } 2859 | }, 2860 | "strip-ansi": { 2861 | "version": "6.0.1", 2862 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2863 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2864 | "dev": true, 2865 | "requires": { 2866 | "ansi-regex": "^5.0.1" 2867 | } 2868 | }, 2869 | "strip-bom": { 2870 | "version": "3.0.0", 2871 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2872 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2873 | "dev": true 2874 | }, 2875 | "strip-json-comments": { 2876 | "version": "3.1.1", 2877 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2878 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2879 | "dev": true 2880 | }, 2881 | "supports-color": { 2882 | "version": "7.2.0", 2883 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2884 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2885 | "dev": true, 2886 | "requires": { 2887 | "has-flag": "^4.0.0" 2888 | } 2889 | }, 2890 | "text-table": { 2891 | "version": "0.2.0", 2892 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2893 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2894 | "dev": true 2895 | }, 2896 | "tsconfig-paths": { 2897 | "version": "3.11.0", 2898 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.11.0.tgz", 2899 | "integrity": "sha512-7ecdYDnIdmv639mmDwslG6KQg1Z9STTz1j7Gcz0xa+nshh/gKDAHcPxRbWOsA3SPp0tXP2leTcY9Kw+NAkfZzA==", 2900 | "dev": true, 2901 | "requires": { 2902 | "@types/json5": "^0.0.29", 2903 | "json5": "^1.0.1", 2904 | "minimist": "^1.2.0", 2905 | "strip-bom": "^3.0.0" 2906 | } 2907 | }, 2908 | "type-check": { 2909 | "version": "0.4.0", 2910 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2911 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2912 | "dev": true, 2913 | "requires": { 2914 | "prelude-ls": "^1.2.1" 2915 | } 2916 | }, 2917 | "type-fest": { 2918 | "version": "0.20.2", 2919 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2920 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2921 | "dev": true 2922 | }, 2923 | "unbox-primitive": { 2924 | "version": "1.0.1", 2925 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", 2926 | "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", 2927 | "dev": true, 2928 | "requires": { 2929 | "function-bind": "^1.1.1", 2930 | "has-bigints": "^1.0.1", 2931 | "has-symbols": "^1.0.2", 2932 | "which-boxed-primitive": "^1.0.2" 2933 | } 2934 | }, 2935 | "uri-js": { 2936 | "version": "4.4.1", 2937 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2938 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2939 | "dev": true, 2940 | "requires": { 2941 | "punycode": "^2.1.0" 2942 | } 2943 | }, 2944 | "v8-compile-cache": { 2945 | "version": "2.3.0", 2946 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 2947 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 2948 | "dev": true 2949 | }, 2950 | "which": { 2951 | "version": "2.0.2", 2952 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2953 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2954 | "dev": true, 2955 | "requires": { 2956 | "isexe": "^2.0.0" 2957 | } 2958 | }, 2959 | "which-boxed-primitive": { 2960 | "version": "1.0.2", 2961 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 2962 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 2963 | "dev": true, 2964 | "requires": { 2965 | "is-bigint": "^1.0.1", 2966 | "is-boolean-object": "^1.1.0", 2967 | "is-number-object": "^1.0.4", 2968 | "is-string": "^1.0.5", 2969 | "is-symbol": "^1.0.3" 2970 | } 2971 | }, 2972 | "word-wrap": { 2973 | "version": "1.2.3", 2974 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2975 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2976 | "dev": true 2977 | }, 2978 | "wrappy": { 2979 | "version": "1.0.2", 2980 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2981 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2982 | "dev": true 2983 | }, 2984 | "yallist": { 2985 | "version": "4.0.0", 2986 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2987 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2988 | "dev": true 2989 | } 2990 | } 2991 | } 2992 | -------------------------------------------------------------------------------- /backend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "description": "appconfig-feature-flags", 4 | "version": "1.0.0", 5 | "private": true, 6 | "dependencies": {}, 7 | "devDependencies": { 8 | "eslint": "^8.1.0", 9 | "eslint-config-strongloop": "^2.1.0", 10 | "eslint-plugin-import": "^2.25.2" 11 | } 12 | } 13 | -------------------------------------------------------------------------------- /backend/src/FeatureFlagLayer/getConfig.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const fetch = require('node-fetch'); 3 | 4 | async function getConfig() { 5 | let appconfigPort = 2772; 6 | try { 7 | if (process.env.AWS_APPCONFIG_EXTENSION_HTTP_PORT) { 8 | appconfigPort = process.env.APPCONFIG_EXTENSION_HTTP_PORT; 9 | } 10 | const url = `http://localhost:${appconfigPort}` 11 | + `/applications/${process.env.APPCONFIG_APPLICATION}` 12 | + `/environments/${process.env.APPCONFIG_ENVIRONMENT}` 13 | + `/configurations/${process.env.APPCONFIG_CONFIGURATION}`; 14 | const response = await fetch(url); 15 | const json = await response.json(); 16 | return json; 17 | } catch (err) { 18 | console.error(err); 19 | throw err; 20 | } 21 | } 22 | 23 | module.exports = getConfig; 24 | -------------------------------------------------------------------------------- /backend/src/FeatureFlagLayer/getFeature.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | async function getFeature(name, features) { 3 | let featureArray = []; 4 | featureArray.push(features); 5 | const feature=featureArray[0][name]; 6 | if (feature) { 7 | if (feature.enabled) { 8 | return true; 9 | } 10 | } 11 | if (!feature) { 12 | console.error( 13 | `There is no feature named "${name}"`, 14 | ); 15 | return false; 16 | } 17 | return false; 18 | } 19 | 20 | module.exports = getFeature; 21 | -------------------------------------------------------------------------------- /backend/src/FeatureFlagLayer/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "description": "appconfig-feature-flags", 4 | "version": "0.0.1", 5 | "private": true, 6 | "dependencies": { 7 | "node-fetch": "^2.6.6" 8 | } 9 | } 10 | -------------------------------------------------------------------------------- /backend/src/getAllProducts/getAllProducts.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const dynamodb = require('aws-sdk/clients/dynamodb'); 3 | const getConfig = require('/opt/nodejs/getConfig'); 4 | const getFeature = require('/opt/nodejs/getFeature'); 5 | 6 | const docClient = new dynamodb.DocumentClient(); 7 | const tableName = process.env.PRODUCT_TABLE; 8 | 9 | async function getProducts() { 10 | const config = await getConfig(); 11 | const flag = await getFeature('show_stock', config); 12 | let attributesToGet = ''; 13 | if (flag) { 14 | attributesToGet = ['id', 'itemDesc', 'itemName', 'itemPrice', 'itemImage', 'itemStock']; 15 | } else { 16 | attributesToGet = ['id', 'itemDesc', 'itemName', 'itemPrice', 'itemImage']; 17 | } 18 | const params = { 19 | TableName: tableName, 20 | AttributesToGet: attributesToGet, 21 | }; 22 | const data = await docClient.scan(params).promise(); 23 | return data; 24 | } 25 | 26 | exports.handler = async(event) => { 27 | const data = await getProducts(); 28 | 29 | const response = { 30 | statusCode: 200, 31 | body: JSON.stringify(data.Items), 32 | }; 33 | 34 | return response; 35 | }; 36 | -------------------------------------------------------------------------------- /backend/src/getAllProducts/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "description": "appconfig-feature-flags", 4 | "version": "0.0.1", 5 | "private": true, 6 | "dependencies": {} 7 | } 8 | -------------------------------------------------------------------------------- /backend/src/getFeatureFlags/getFeatureFlags.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const getConfig = require('/opt/nodejs/getConfig'); 3 | 4 | exports.handler = async(event) => { 5 | const config = await getConfig(); 6 | const response = { 7 | statusCode: 200, 8 | body: JSON.stringify(config), 9 | }; 10 | return response; 11 | }; 12 | -------------------------------------------------------------------------------- /backend/src/getFeatureFlags/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "description": "appconfig-feature-flags", 4 | "version": "0.0.1", 5 | "private": true, 6 | "dependencies": {} 7 | } 8 | -------------------------------------------------------------------------------- /backend/src/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "description": "appconfig-feature-flags", 4 | "version": "0.0.1", 5 | "private": true, 6 | "dependencies": {} 7 | } 8 | -------------------------------------------------------------------------------- /backend/template.yaml: -------------------------------------------------------------------------------- 1 | # Copyright 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved. 2 | # SPDX-License-Identifier: MIT-0 3 | # 4 | # Permission is hereby granted, free of charge, to any person obtaining a copy of this 5 | # software and associated documentation files (the "Software"), to deal in the Software 6 | # without restriction, including without limitation the rights to use, copy, modify, 7 | # merge, publish, distribute, sublicense, and/or sell copies of the Software, and to 8 | # permit persons to whom the Software is furnished to do so. 9 | # 10 | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, 11 | # INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A 12 | # PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 13 | # HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 14 | # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 15 | # SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 16 | 17 | AWSTemplateFormatVersion: '2010-09-09' 18 | Transform: AWS::Serverless-2016-10-31 19 | Description: AWS AppConfig Feature Flags example 20 | 21 | ################################################################################################### 22 | ## Template Parameters ## 23 | ################################################################################################### 24 | Parameters: 25 | AppName: 26 | Type: String 27 | Description: Name of application (no spaces). Value must be globally unique 28 | Default: appconfig-feature-flags 29 | AppConfigApplication: 30 | Type: String 31 | Description: Id of AppConfig Application 32 | AppConfigEnvironment: 33 | Type: String 34 | Description: Id of AppConfig Environment 35 | AppConfigConfigurationProfile: 36 | Type: String 37 | Description: Id of AppConfig Configuration Profile 38 | ClientDomains: 39 | Type: CommaDelimitedList 40 | Description: Array of domains allowed to use the API 41 | Default: '*' 42 | 43 | ################################################################################################### 44 | ## Template Resources ## 45 | ################################################################################################### 46 | Resources: 47 | ## Feature Flags Function 48 | getFeatureFlags: 49 | Type: AWS::Serverless::Function 50 | Properties: 51 | Handler: getFeatureFlags.handler 52 | CodeUri: src/getFeatureFlags/ 53 | Runtime: nodejs14.x 54 | MemorySize: 128 55 | Timeout: 100 56 | Layers: 57 | - !FindInMap [AppConfigLayer, !Ref "AWS::Region", ARN] 58 | - !Ref FeatureFlagLayer 59 | Policies: 60 | - Version: '2012-10-17' 61 | Statement: 62 | - Effect: Allow 63 | Action: 64 | - appconfig:GetLatestConfiguration 65 | - appconfig:StartConfigurationSession 66 | Resource: 67 | - !Sub 'arn:aws:appconfig:*:*:application/${AppConfigApplication}/environment/${AppConfigEnvironment}/configuration/${AppConfigConfigurationProfile}' 68 | Environment: 69 | Variables: 70 | APPCONFIG_APPLICATION: !Ref AppConfigApplication 71 | APPCONFIG_ENVIRONMENT: !Ref AppConfigEnvironment 72 | APPCONFIG_CONFIGURATION: !Ref AppConfigConfigurationProfile 73 | # AWS_APPCONFIG_EXTENSION_POLL_INTERVAL_SECONDS: 45 74 | # AWS_APPCONFIG_EXTENSION_POLL_TIMEOUT_MILLIS: 3000 75 | # AWS_APPCONFIG_EXTENSION_HTTP_PORT: 2772 76 | Events: 77 | Api: 78 | Type: HttpApi 79 | Properties: 80 | Path: /flags 81 | Method: GET 82 | ApiId: !Ref HttpApi 83 | 84 | ## Products Function 85 | getAllProducts: 86 | Type: AWS::Serverless::Function 87 | Properties: 88 | Handler: getAllProducts.handler 89 | CodeUri: src/getAllProducts/ 90 | Runtime: nodejs14.x 91 | MemorySize: 128 92 | Timeout: 100 93 | Layers: 94 | - !FindInMap [AppConfigLayer, !Ref "AWS::Region", ARN] 95 | - !Ref FeatureFlagLayer 96 | Policies: 97 | - DynamoDBReadPolicy: 98 | TableName: !Ref DynamoDBTable 99 | - Version: '2012-10-17' 100 | Statement: 101 | - Effect: Allow 102 | Action: 103 | - appconfig:GetLatestConfiguration 104 | - appconfig:StartConfigurationSession 105 | Resource: 106 | - !Sub 'arn:aws:appconfig:*:*:application/${AppConfigApplication}/environment/${AppConfigEnvironment}/configuration/${AppConfigConfigurationProfile}' 107 | Environment: 108 | Variables: 109 | PRODUCT_TABLE: !Ref DynamoDBTable 110 | APPCONFIG_APPLICATION: !Ref AppConfigApplication 111 | APPCONFIG_ENVIRONMENT: !Ref AppConfigEnvironment 112 | APPCONFIG_CONFIGURATION: !Ref AppConfigConfigurationProfile 113 | AWS_APPCONFIG_EXTENSION_POLL_INTERVAL_SECONDS: 15 114 | # AWS_APPCONFIG_EXTENSION_POLL_TIMEOUT_MILLIS: 3000 115 | # AWS_APPCONFIG_EXTENSION_HTTP_PORT: 2772 116 | Events: 117 | Api: 118 | Type: HttpApi 119 | Properties: 120 | Path: /products 121 | Method: GET 122 | ApiId: !Ref HttpApi 123 | 124 | ## Shared libraries layer 125 | FeatureFlagLayer: 126 | Type: AWS::Serverless::LayerVersion 127 | Properties: 128 | ContentUri: src/FeatureFlagLayer/. 129 | CompatibleRuntimes: 130 | - nodejs14.x 131 | RetentionPolicy: Delete 132 | Metadata: 133 | BuildMethod: nodejs14.x 134 | 135 | ## API Gateway 136 | HttpApi: 137 | Type: AWS::Serverless::HttpApi 138 | Properties: 139 | CorsConfiguration: 140 | AllowMethods: 141 | - GET 142 | AllowHeaders: 143 | - '*' 144 | AllowOrigins: !Ref ClientDomains 145 | 146 | ## Products Table 147 | DynamoDBTable: 148 | Type: 'AWS::DynamoDB::Table' 149 | DeletionPolicy: Delete 150 | Properties: 151 | AttributeDefinitions: 152 | - 153 | AttributeName: id 154 | AttributeType: N 155 | KeySchema: 156 | - 157 | AttributeName: id 158 | KeyType: HASH 159 | BillingMode: PAY_PER_REQUEST 160 | 161 | ################################################################################################### 162 | ## Mappings ## 163 | ################################################################################################### 164 | 165 | Mappings: 166 | ## See layer ARNs https://docs.aws.amazon.com/appconfig/latest/userguide/appconfig-integration-lambda-extensions.html 167 | AppConfigLayer: 168 | ap-east-1: 169 | ARN: arn:aws:lambda:ap-east-1:630222743974:layer:AWS-AppConfig-Extension:44 170 | ap-northeast-3: 171 | ARN: arn:aws:lambda:ap-northeast-3:706869817123:layer:AWS-AppConfig-Extension:42 172 | us-east-1: 173 | ARN: arn:aws:lambda:us-east-1:027255383542:layer:AWS-AppConfig-Extension:61 174 | us-east-2: 175 | ARN: arn:aws:lambda:us-east-2:728743619870:layer:AWS-AppConfig-Extension:47 176 | eu-north-1: 177 | ARN: arn:aws:lambda:eu-north-1:646970417810:layer:AWS-AppConfig-Extension:86 178 | ap-northeast-2: 179 | ARN: arn:aws:lambda:ap-northeast-2:826293736237:layer:AWS-AppConfig-Extension:54 180 | us-west-2: 181 | ARN: arn:aws:lambda:us-west-2:359756378197:layer:AWS-AppConfig-Extension:89 182 | us-west-1: 183 | ARN: arn:aws:lambda:us-west-1:958113053741:layer:AWS-AppConfig-Extension:61 184 | ap-northeast-1: 185 | ARN: arn:aws:lambda:ap-northeast-1:980059726660:layer:AWS-AppConfig-Extension:45 186 | us-gov-east-1: 187 | ARN: arn:aws-us-gov:lambda:us-gov-east-1:946561847325:layer:AWS-AppConfig-Extension:20 188 | af-south-1: 189 | ARN: arn:aws:lambda:af-south-1:574348263942:layer:AWS-AppConfig-Extension:44 190 | us-gov-west-1: 191 | ARN: arn:aws-us-gov:lambda:us-gov-west-1:946746059096:layer:AWS-AppConfig-Extension:20 192 | ap-southeast-1: 193 | ARN: arn:aws:lambda:ap-southeast-1:421114256042:layer:AWS-AppConfig-Extension:45 194 | ap-southeast-2: 195 | ARN: arn:aws:lambda:ap-southeast-2:080788657173:layer:AWS-AppConfig-Extension:54 196 | ap-south-1: 197 | ARN: arn:aws:lambda:ap-south-1:554480029851:layer:AWS-AppConfig-Extension:55 198 | eu-west-1: 199 | ARN: arn:aws:lambda:eu-west-1:434848589818:layer:AWS-AppConfig-Extension:59 200 | eu-west-2: 201 | ARN: arn:aws:lambda:eu-west-2:282860088358:layer:AWS-AppConfig-Extension:47 202 | eu-west-3: 203 | ARN: arn:aws:lambda:eu-west-3:493207061005:layer:AWS-AppConfig-Extension:48" 204 | eu-south-1: 205 | ARN: arn:aws:lambda:eu-south-1:203683718741:layer:AWS-AppConfig-Extension:44 206 | eu-central-1: 207 | ARN: arn:aws:lambda:eu-central-1:066940009817:layer:AWS-AppConfig-Extension:54 208 | cn-northwest-1: 209 | ARN: arn:aws-cn:lambda:cn-northwest-1:615084187847:layer:AWS-AppConfig-Extension:43 210 | ca-central-1: 211 | ARN: arn:aws:lambda:ca-central-1:039592058896:layer:AWS-AppConfig-Extension:47 212 | me-south-1: 213 | ARN: arn:aws:lambda:me-south-1:559955524753:layer:AWS-AppConfig-Extension:44 214 | cn-north-1: 215 | ARN: arn:aws-cn:lambda:cn-north-1:615057806174:layer:AWS-AppConfig-Extension:43 216 | sa-east-1: 217 | ARN: arn:aws:lambda:sa-east-1:000010852771:layer:AWS-AppConfig-Extension:61 218 | 219 | ################################################################################################### 220 | ## Template outputs ## 221 | ################################################################################################### 222 | 223 | Outputs: 224 | HttpApiUrl: 225 | Description: URL of your API endpoint 226 | Value: 227 | Fn::Sub: 'https://${HttpApi}.execute-api.${AWS::Region}.${AWS::URLSuffix}' 228 | DynamoDBTableName: 229 | Description: The name of your DynamoDB table 230 | Value: !Ref DynamoDBTable -------------------------------------------------------------------------------- /frontend/.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | /.pnp 6 | .pnp.js 7 | 8 | # testing 9 | /coverage 10 | 11 | # production 12 | /build 13 | 14 | # misc 15 | .DS_Store 16 | .env.local 17 | .env.development.local 18 | .env.test.local 19 | .env.production.local 20 | .vscode 21 | 22 | npm-debug.log* 23 | yarn-debug.log* 24 | yarn-error.log* 25 | 26 | #amplify 27 | amplify/\#current-cloud-backend 28 | amplify/.config/local-* 29 | amplify/team-provider-info.json 30 | amplify/mock-data 31 | amplify/backend/amplify-meta.json 32 | amplify/backend/awscloudformation 33 | build/ 34 | dist/ 35 | node_modules/ 36 | aws-exports.js 37 | awsconfiguration.json 38 | event.json -------------------------------------------------------------------------------- /frontend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "appconfig-feature-flags", 3 | "version": "0.1.0", 4 | "private": true, 5 | "dependencies": { 6 | "aws-amplify": "^4.3.18", 7 | "aws-amplify-react": "^5.1.9", 8 | "react": "^17.0.2", 9 | "react-dom": "^17.0.2", 10 | "react-router-dom": "^5.3.0", 11 | "react-scripts": "^4.0.3", 12 | "semantic-ui-react": "^2.1.2", 13 | "styled-components": "^5.3.5" 14 | }, 15 | "scripts": { 16 | "start": "react-scripts start", 17 | "build": "react-scripts build", 18 | "test": "react-scripts test", 19 | "eject": "react-scripts eject" 20 | }, 21 | "eslintConfig": { 22 | "extends": "react-app" 23 | }, 24 | "browserslist": { 25 | "production": [ 26 | ">0.2%", 27 | "not dead", 28 | "not op_mini all" 29 | ], 30 | "development": [ 31 | "last 1 chrome version", 32 | "last 1 firefox version", 33 | "last 1 safari version" 34 | ] 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /frontend/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/favicon.ico -------------------------------------------------------------------------------- /frontend/public/favicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/favicon.png -------------------------------------------------------------------------------- /frontend/public/images/header-bkg.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/header-bkg.png -------------------------------------------------------------------------------- /frontend/public/images/misc/amex.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/misc/amex.gif -------------------------------------------------------------------------------- /frontend/public/images/misc/card.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/misc/card.png -------------------------------------------------------------------------------- /frontend/public/images/misc/mobile.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/misc/mobile.png -------------------------------------------------------------------------------- /frontend/public/images/products/five.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/five.png -------------------------------------------------------------------------------- /frontend/public/images/products/four.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/four.png -------------------------------------------------------------------------------- /frontend/public/images/products/one.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/one.png -------------------------------------------------------------------------------- /frontend/public/images/products/seven.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/seven.png -------------------------------------------------------------------------------- /frontend/public/images/products/six.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/six.png -------------------------------------------------------------------------------- /frontend/public/images/products/three.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/three.png -------------------------------------------------------------------------------- /frontend/public/images/products/two.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/aws-samples/aws-appconfig-feature-flags/d36b3e7b262d55ca9b2fd3afa9ddb63864fb7b3b/frontend/public/images/products/two.png -------------------------------------------------------------------------------- /frontend/public/images/store-logo.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /frontend/public/index.html: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | 6 |
7 | 8 | 9 | 10 | 11 | 15 | 16 | 20 | 21 | 30 |