├── .eslintrc.js ├── .github └── workflows │ ├── dependabot.yml │ ├── main.yml │ └── package-audit.yml ├── .gitignore ├── .pre-commit-config.yaml ├── LICENSE ├── README.md ├── index.js ├── index.test.js ├── package-lock.json ├── package.json └── resources.yml /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | "env":{ 3 | "browser":true, 4 | "commonjs":true, 5 | "es2021":true 6 | }, 7 | "extends":[ 8 | "airbnb-base" 9 | ], 10 | "parserOptions":{ 11 | "ecmaVersion":"latest" 12 | }, 13 | "rules":{ 14 | 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /.github/workflows/dependabot.yml: -------------------------------------------------------------------------------- 1 | # To get started with Dependabot version updates, you'll need to specify which 2 | # package ecosystems to update and where the package manifests are located. 3 | # Please see the documentation for all configuration options: 4 | # https://docs.github.com/github/administering-a-repository/configuration-options-for-dependency-updates 5 | 6 | version: 2 7 | updates: 8 | - package-ecosystem: "" # See documentation for possible values 9 | directory: "/" # Location of package manifests 10 | schedule: 11 | interval: "weekly" 12 | -------------------------------------------------------------------------------- /.github/workflows/main.yml: -------------------------------------------------------------------------------- 1 | name: CI 2 | 3 | on: 4 | push: 5 | branches: [ main ] 6 | pull_request: 7 | branches: [ main ] 8 | workflow_dispatch: 9 | inputs: 10 | logLevel: 11 | description: 'Log level' 12 | required: true 13 | default: 'warning' 14 | 15 | jobs: 16 | publish: 17 | runs-on: ubuntu-latest 18 | steps: 19 | - uses: actions/checkout@v3 20 | - uses: actions/setup-node@v3 21 | with: 22 | node-version: 12 23 | - run: npm install 24 | - run: npm run test-unit 25 | - name: 'Automated Version Bump' 26 | uses: 'phips28/gh-action-bump-version@master' 27 | env: 28 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} 29 | with: 30 | commit-message: 'CI: bumps version to {{version}} [skip ci]' 31 | - uses: JS-DevTools/npm-publish@v1 32 | with: 33 | token: ${{ secrets.NPM_TOKEN }} 34 | - name: Check if version has been updated 35 | id: check 36 | uses: EndBug/version-check@v2.1.0 37 | with: 38 | file-url: https://unpkg.com/serverless-aws-function-url-custom-domain/package.json 39 | - name: Log when changed 40 | if: steps.check.outputs.changed == 'true' 41 | run: 'echo "Version change found in commit ${{ steps.check.outputs.commit }}! New version: ${{ steps.check.outputs.version }} (${{ steps.check.outputs.type }})"' 42 | 43 | - name: Log when unchanged 44 | if: steps.check.outputs.changed == 'false' 45 | run: 'echo "No version change :/"' 46 | -------------------------------------------------------------------------------- /.github/workflows/package-audit.yml: -------------------------------------------------------------------------------- 1 | name: NPM audit 2 | 3 | on: 4 | schedule: 5 | - cron: '0 0 1 * *' 6 | workflow_dispatch: 7 | inputs: 8 | logLevel: 9 | description: 'Log level' 10 | required: true 11 | default: 'warning' 12 | 13 | jobs: 14 | npm-audit: 15 | runs-on: ubuntu-latest 16 | name: NPM Audit (and fix) 17 | steps: 18 | - name: Checkout 19 | uses: actions/checkout@v2 20 | - name: NPM Audit 21 | uses: 'luisfontes19/npm-audit-action@v0.1.0' 22 | with: 23 | project-path: "." 24 | only: prod 25 | fix: true 26 | package-lock-only: false 27 | force: true 28 | git-user: action-npm-audit 29 | git-email: action-npm-audit 30 | git-message: npm fix run from npm-audit action 31 | git-pr-title: "[SECURITY] NPM audit fix" 32 | git-branch: npm-audit-action 33 | git-remote: origin 34 | github-token: ${{ secrets.GITHUB_TOKEN }} 35 | - name: outdated version 36 | uses: ycjcl868/outdated-version-action@v1 37 | with: 38 | token: ${{ secrets.GITHUB_TOKEN }} 39 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # package directories 2 | /node_modules/ 3 | jspm_packages 4 | build 5 | coverage 6 | .nyc_output 7 | coverage 8 | .coverage-cache 9 | 10 | *.log 11 | .DS_STORE 12 | .vscode 13 | 14 | # Serverless directories 15 | .serverless 16 | .eslintcache 17 | -------------------------------------------------------------------------------- /.pre-commit-config.yaml: -------------------------------------------------------------------------------- 1 | # See https://pre-commit.com for more information 2 | # See https://pre-commit.com/hooks.html for more hooks 3 | repos: 4 | - repo: https://github.com/pre-commit/pre-commit-hooks 5 | rev: v4.5.0 6 | hooks: 7 | - id: trailing-whitespace 8 | - id: end-of-file-fixer 9 | - id: check-yaml 10 | - id: check-added-large-files 11 | - id: check-json 12 | - id: detect-private-key 13 | - id: pretty-format-json 14 | args: [ --autofix, --no-sort-keys ] 15 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 wangsha. 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![serverless](http://public.serverless.com/badges/v3.svg)](http://www.serverless.com) 2 | [![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg)]([https://raw.githubusercontent.com/Droplr/serverless-api-cloudfront/master/LICENSE](https://raw.githubusercontent.com/wangsha/serverless-aws-function-url-custom-domain/main/LICENSE)) 3 | [![npm version](https://badge.fury.io/js/serverless-aws-function-url-custom-domain.svg)](https://badge.fury.io/js/serverless-aws-function-url-custom-domain) 4 | [![npm downloads](https://img.shields.io/npm/dt/serverless-aws-function-url-custom-domain.svg?style=flat)](https://www.npmjs.com/package/serverless-aws-function-url-custom-domain) 5 | [![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://github.com/pre-commit/pre-commit) 6 | 7 | 8 | # serverless-aws-function-url-custom-domain 9 | 10 | Automatically creates AWS CloudFront distribution and Route 53 records to AWS Lambda with [Function URL](https://aws.amazon.com/fr/blogs/aws/announcing-aws-lambda-function-urls-built-in-https-endpoints-for-single-function-microservices/) (no api gateway). 11 | 12 | ## Installation 13 | ```bash 14 | npm install --save-dev serverless-aws-function-url-custom-domain 15 | ``` 16 | 17 | ## Configuration 18 | This plugin assumes your domain is hosted and managed with AWS Route53. SSL certificate is managed via certificate manager. 19 | 20 | ```yaml 21 | # add in your serverless.yml 22 | 23 | plugins: 24 | - serverless-aws-function-url-custom-domain 25 | 26 | 27 | custom: 28 | urlDomain: 29 | domains: 30 | - ${env:SUBDOMAIN}.yourdomain.com # custom domain 1 31 | - ${env:SUBDOMAIN}-alt.yourdomain.com # custom domain 2 32 | hostedZoneName: yourdomain.com. # your domain Route 53 hosted zone name 33 | certificateArn: 'arn:aws:acm:us-east-1:xxxxx:certificate/xxxxx' # need to be located at NVirgina 34 | route53: false # disable route 53 integration 35 | functions: 36 | api: 37 | handler: wsgi_handler.handler 38 | url: true # activate function URL! 39 | 40 | ``` 41 | 42 | ### Deploy 43 | ```javascript 44 | serverless deploy 45 | ``` 46 | 47 | ### Inspect Result 48 | ```javascript 49 | serverless info --verbose 50 | ``` 51 | 52 | ```bash 53 | Output: 54 | 55 | 56 | CloudFront domain name 57 | xxxxx.cloudfront.net (CNAME: ${env:SUBDOMAIN}.yourdomain.com) 58 | 59 | ``` 60 | 61 | ### IAM Policy 62 | 63 | In order to make this plugin work as expected a few additional IAM Policies might be needed on your AWS profile. 64 | 65 | More specifically this plugin needs the following policies attached: 66 | 67 | * `cloudfront:CreateDistribution` 68 | * `cloudfront:GetDistribution` 69 | * `cloudfront:UpdateDistribution` 70 | * `cloudfront:DeleteDistribution` 71 | * `cloudfront:TagResource` 72 | * `route53:ListHostedZones` 73 | * `route53:ChangeResourceRecordSets` 74 | * `route53:GetHostedZone` 75 | * `route53:ListResourceRecordSets` 76 | * `acm:ListCertificates` 77 | 78 | You can read more about IAM profiles and policies in the [Serverless documentation](https://serverless.com/framework/docs/providers/aws/guide/credentials#creating-aws-access-keys). 79 | 80 | 81 | ## References 82 | - [serverless framework example integration](https://medium.com/@walid.karray/configuring-a-custom-domain-for-aws-lambda-function-url-with-serverless-framework-c0d78abdc253) 83 | - [AWS Lambda Function URLs](https://aws.amazon.com/fr/blogs/aws/announcing-aws-lambda-function-urls-built-in-https-endpoints-for-single-function-microservices/) 84 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | const _ = require('lodash'); 3 | const yaml = require('js-yaml'); 4 | const fs = require('fs'); 5 | const Mustache = require('mustache'); 6 | 7 | class ServerlessAWSFunctionURLCustomDomainPlugin { 8 | constructor(serverless, options) { 9 | this.serverless = serverless; 10 | this.options = options; 11 | 12 | this.hooks = { 13 | 'before:package:finalize': this.createDeploymentArtifacts.bind(this), 14 | 'aws:info:displayStackOutputs': this.printSummary.bind(this), 15 | }; 16 | } 17 | 18 | createDeploymentArtifacts() { 19 | const baseResources = this.serverless.service.provider.compiledCloudFormationTemplate; 20 | 21 | var functionURLResourceName = null; 22 | for(var key in baseResources.Resources) { 23 | if (baseResources.Resources[key]['Type'] === "AWS::Lambda::Url") { 24 | functionURLResourceName = key 25 | } 26 | } 27 | 28 | if (functionURLResourceName === null) { 29 | this.serverless.cli.consoleLog("no function url defined"); 30 | return baseResources; 31 | } 32 | 33 | const config = this.serverless.service.custom.urlDomain; 34 | config['lambdaFunctionUrl'] = functionURLResourceName 35 | 36 | const resources = this.prepareResources(config); 37 | 38 | const combinedResouces = _.merge(baseResources, resources); 39 | 40 | return combinedResouces; 41 | } 42 | 43 | printSummary() { 44 | 45 | const awsInfo = _.find(this.serverless.pluginManager.getPlugins(), (plugin) => plugin.constructor.name === 'AwsInfo'); 46 | 47 | if (!awsInfo || !awsInfo.gatheredData) { 48 | return; 49 | } 50 | 51 | const { outputs } = awsInfo.gatheredData; 52 | const apiDistributionDomain = _.find(outputs, (output) => output.OutputKey === 'CloudFrontDistributionDomain'); 53 | 54 | if (!apiDistributionDomain || !apiDistributionDomain.OutputValue) { 55 | return; 56 | } 57 | 58 | const cnameDomain = this.getConfig('domains', []); 59 | 60 | this.serverless.cli.consoleLog('CloudFront domain name'); 61 | this.serverless.cli.consoleLog(`${apiDistributionDomain.OutputValue} (CNAME: ${cnameDomain})`); 62 | } 63 | 64 | prepareResources(config) { 65 | 66 | const route53 = this.getConfig('route53', true); 67 | var resources = this.getCloudfrontResources(config); 68 | if (route53) { 69 | resources = _.merge(resources, this.getRoute53Resources(config)); 70 | } 71 | return resources 72 | } 73 | 74 | getCloudfrontResources(config) { 75 | const filename = path.resolve(__dirname, 'resources.yml'); 76 | const content = fs.readFileSync(filename, 'utf-8'); 77 | const resources = yaml.load(content, { 78 | filename, 79 | }); 80 | var output = Mustache.render(JSON.stringify(resources), config); 81 | output = JSON.parse(output) 82 | output['Resources']['CloudFrontDistribution']['Properties']['DistributionConfig']['Aliases'] = config['domains'] 83 | return output; 84 | } 85 | 86 | getRoute53Resources(config) { 87 | const domains = this.getConfig('domains', null); 88 | const hostedZoneName = this.getConfig('hostedZoneName', null); 89 | 90 | const template = JSON.stringify({ 91 | "Type": "AWS::Route53::RecordSetGroup", 92 | "DeletionPolicy": "Delete", 93 | "DependsOn": [ 94 | "CloudFrontDistribution" 95 | ], 96 | "Properties": { 97 | "HostedZoneName": hostedZoneName, 98 | "RecordSets": [ 99 | { 100 | "Name": "{{{ domain }}}", 101 | "Type": "A", 102 | "AliasTarget": { 103 | "HostedZoneId": "Z2FDTNDATAQYW2", 104 | "DNSName": { 105 | "Fn::GetAtt": [ 106 | "CloudFrontDistribution", 107 | "DomainName" 108 | ] 109 | } 110 | } 111 | } 112 | ] 113 | } 114 | }) 115 | var resources = {} 116 | for (var idx in domains) { 117 | var output = Mustache.render(template, {'domain': domains[idx]}); 118 | resources[`Route53Record${idx}`] = JSON.parse(output); 119 | } 120 | return {'Resources': resources} 121 | } 122 | 123 | getConfig(field, defaultValue) { 124 | return _.get(this.serverless, `service.custom.urlDomain.${field}`, defaultValue); 125 | } 126 | } 127 | 128 | module.exports = ServerlessAWSFunctionURLCustomDomainPlugin; 129 | -------------------------------------------------------------------------------- /index.test.js: -------------------------------------------------------------------------------- 1 | var assert = require('assert'); 2 | describe('Array', function () { 3 | describe('#getCloudfrontResources()', function () { 4 | it('domains should be a list', function () { 5 | const ServerlessAWSFunctionURLCustomDomainPlugin = require('./index') 6 | config = { 7 | domains: ['sudomain1.yourdomain.com', 'subdomain2.yourdomain.com'], 8 | hostedZoneName: 'yourdomain.com.', 9 | certificateArn: 'arn:aws:acm:us-east-1:xxxxx:certificate/xxxxxxx', 10 | route53: true 11 | } 12 | var plugin = new ServerlessAWSFunctionURLCustomDomainPlugin(); 13 | var resources = plugin.getCloudfrontResources(config); 14 | console.log(resources['Resources']['CloudFrontDistribution']['Properties']['DistributionConfig']['Comment']) 15 | assert(resources['Resources']['CloudFrontDistribution']['Properties']['DistributionConfig']['Aliases'] == config['domains']); 16 | 17 | }); 18 | }); 19 | }); 20 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "serverless-aws-function-url-custom-domain", 3 | "version": "0.9.28", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@eslint/eslintrc": { 8 | "version": "1.3.2", 9 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.2.tgz", 10 | "integrity": "sha512-AXYd23w1S/bv3fTs3Lz0vjiYemS08jWkI3hYyS9I1ry+0f+Yjs1wm+sU0BS8qDOPrBIkp4qHYC16I8uVtpLajQ==", 11 | "dev": true, 12 | "requires": { 13 | "ajv": "^6.12.4", 14 | "debug": "^4.3.2", 15 | "espree": "^9.4.0", 16 | "globals": "^13.15.0", 17 | "ignore": "^5.2.0", 18 | "import-fresh": "^3.2.1", 19 | "js-yaml": "^4.1.0", 20 | "minimatch": "^3.1.2", 21 | "strip-json-comments": "^3.1.1" 22 | } 23 | }, 24 | "@humanwhocodes/config-array": { 25 | "version": "0.10.7", 26 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.10.7.tgz", 27 | "integrity": "sha512-MDl6D6sBsaV452/QSdX+4CXIjZhIcI0PELsxUjk4U828yd58vk3bTIvk/6w5FY+4hIy9sLW0sfrV7K7Kc++j/w==", 28 | "dev": true, 29 | "requires": { 30 | "@humanwhocodes/object-schema": "^1.2.1", 31 | "debug": "^4.1.1", 32 | "minimatch": "^3.0.4" 33 | } 34 | }, 35 | "@humanwhocodes/gitignore-to-minimatch": { 36 | "version": "1.0.2", 37 | "resolved": "https://registry.npmjs.org/@humanwhocodes/gitignore-to-minimatch/-/gitignore-to-minimatch-1.0.2.tgz", 38 | "integrity": "sha512-rSqmMJDdLFUsyxR6FMtD00nfQKKLFb1kv+qBbOVKqErvloEIJLo5bDTJTQNTYgeyp78JsA7u/NPi5jT1GR/MuA==", 39 | "dev": true 40 | }, 41 | "@humanwhocodes/module-importer": { 42 | "version": "1.0.1", 43 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 44 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 45 | "dev": true 46 | }, 47 | "@humanwhocodes/object-schema": { 48 | "version": "1.2.1", 49 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 50 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 51 | "dev": true 52 | }, 53 | "@nodelib/fs.scandir": { 54 | "version": "2.1.5", 55 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 56 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 57 | "dev": true, 58 | "requires": { 59 | "@nodelib/fs.stat": "2.0.5", 60 | "run-parallel": "^1.1.9" 61 | } 62 | }, 63 | "@nodelib/fs.stat": { 64 | "version": "2.0.5", 65 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 66 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 67 | "dev": true 68 | }, 69 | "@nodelib/fs.walk": { 70 | "version": "1.2.8", 71 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 72 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 73 | "dev": true, 74 | "requires": { 75 | "@nodelib/fs.scandir": "2.1.5", 76 | "fastq": "^1.6.0" 77 | } 78 | }, 79 | "@types/json5": { 80 | "version": "0.0.29", 81 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 82 | "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", 83 | "dev": true 84 | }, 85 | "@ungap/promise-all-settled": { 86 | "version": "1.1.2", 87 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 88 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 89 | "dev": true 90 | }, 91 | "acorn": { 92 | "version": "8.8.0", 93 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.0.tgz", 94 | "integrity": "sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w==", 95 | "dev": true 96 | }, 97 | "acorn-jsx": { 98 | "version": "5.3.2", 99 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 100 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 101 | "dev": true 102 | }, 103 | "ajv": { 104 | "version": "6.12.6", 105 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 106 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 107 | "dev": true, 108 | "requires": { 109 | "fast-deep-equal": "^3.1.1", 110 | "fast-json-stable-stringify": "^2.0.0", 111 | "json-schema-traverse": "^0.4.1", 112 | "uri-js": "^4.2.2" 113 | } 114 | }, 115 | "ansi-colors": { 116 | "version": "4.1.1", 117 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 118 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 119 | "dev": true 120 | }, 121 | "ansi-regex": { 122 | "version": "5.0.1", 123 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 124 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 125 | "dev": true 126 | }, 127 | "ansi-styles": { 128 | "version": "4.3.0", 129 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 130 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 131 | "dev": true, 132 | "requires": { 133 | "color-convert": "^2.0.1" 134 | } 135 | }, 136 | "anymatch": { 137 | "version": "3.1.2", 138 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 139 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 140 | "dev": true, 141 | "requires": { 142 | "normalize-path": "^3.0.0", 143 | "picomatch": "^2.0.4" 144 | } 145 | }, 146 | "argparse": { 147 | "version": "2.0.1", 148 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 149 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" 150 | }, 151 | "array-includes": { 152 | "version": "3.1.5", 153 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.5.tgz", 154 | "integrity": "sha512-iSDYZMMyTPkiFasVqfuAQnWAYcvO/SeBSCGKePoEthjp4LEMTe4uLc7b025o4jAZpHhihh8xPo99TNWUWWkGDQ==", 155 | "dev": true, 156 | "requires": { 157 | "call-bind": "^1.0.2", 158 | "define-properties": "^1.1.4", 159 | "es-abstract": "^1.19.5", 160 | "get-intrinsic": "^1.1.1", 161 | "is-string": "^1.0.7" 162 | } 163 | }, 164 | "array-union": { 165 | "version": "2.1.0", 166 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 167 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 168 | "dev": true 169 | }, 170 | "array.prototype.flat": { 171 | "version": "1.3.0", 172 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.0.tgz", 173 | "integrity": "sha512-12IUEkHsAhA4DY5s0FPgNXIdc8VRSqD9Zp78a5au9abH/SOBrsp082JOWFNTjkMozh8mqcdiKuaLGhPeYztxSw==", 174 | "dev": true, 175 | "requires": { 176 | "call-bind": "^1.0.2", 177 | "define-properties": "^1.1.3", 178 | "es-abstract": "^1.19.2", 179 | "es-shim-unscopables": "^1.0.0" 180 | } 181 | }, 182 | "balanced-match": { 183 | "version": "1.0.2", 184 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 185 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 186 | "dev": true 187 | }, 188 | "binary-extensions": { 189 | "version": "2.2.0", 190 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 191 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 192 | "dev": true 193 | }, 194 | "brace-expansion": { 195 | "version": "1.1.11", 196 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 197 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 198 | "dev": true, 199 | "requires": { 200 | "balanced-match": "^1.0.0", 201 | "concat-map": "0.0.1" 202 | } 203 | }, 204 | "braces": { 205 | "version": "3.0.2", 206 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 207 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 208 | "dev": true, 209 | "requires": { 210 | "fill-range": "^7.0.1" 211 | } 212 | }, 213 | "browser-stdout": { 214 | "version": "1.3.1", 215 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 216 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 217 | "dev": true 218 | }, 219 | "call-bind": { 220 | "version": "1.0.2", 221 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 222 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 223 | "dev": true, 224 | "requires": { 225 | "function-bind": "^1.1.1", 226 | "get-intrinsic": "^1.0.2" 227 | } 228 | }, 229 | "callsites": { 230 | "version": "3.1.0", 231 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 232 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 233 | "dev": true 234 | }, 235 | "camelcase": { 236 | "version": "6.3.0", 237 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 238 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 239 | "dev": true 240 | }, 241 | "chalk": { 242 | "version": "4.1.2", 243 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 244 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 245 | "dev": true, 246 | "requires": { 247 | "ansi-styles": "^4.1.0", 248 | "supports-color": "^7.1.0" 249 | } 250 | }, 251 | "chokidar": { 252 | "version": "3.5.3", 253 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 254 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 255 | "dev": true, 256 | "requires": { 257 | "anymatch": "~3.1.2", 258 | "braces": "~3.0.2", 259 | "fsevents": "~2.3.2", 260 | "glob-parent": "~5.1.2", 261 | "is-binary-path": "~2.1.0", 262 | "is-glob": "~4.0.1", 263 | "normalize-path": "~3.0.0", 264 | "readdirp": "~3.6.0" 265 | }, 266 | "dependencies": { 267 | "glob-parent": { 268 | "version": "5.1.2", 269 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 270 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 271 | "dev": true, 272 | "requires": { 273 | "is-glob": "^4.0.1" 274 | } 275 | } 276 | } 277 | }, 278 | "cliui": { 279 | "version": "7.0.4", 280 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 281 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 282 | "dev": true, 283 | "requires": { 284 | "string-width": "^4.2.0", 285 | "strip-ansi": "^6.0.0", 286 | "wrap-ansi": "^7.0.0" 287 | } 288 | }, 289 | "color-convert": { 290 | "version": "2.0.1", 291 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 292 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 293 | "dev": true, 294 | "requires": { 295 | "color-name": "~1.1.4" 296 | } 297 | }, 298 | "color-name": { 299 | "version": "1.1.4", 300 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 301 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 302 | "dev": true 303 | }, 304 | "concat-map": { 305 | "version": "0.0.1", 306 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 307 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 308 | "dev": true 309 | }, 310 | "confusing-browser-globals": { 311 | "version": "1.0.11", 312 | "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.11.tgz", 313 | "integrity": "sha512-JsPKdmh8ZkmnHxDk55FZ1TqVLvEQTvoByJZRN9jzI0UjxK/QgAmsphz7PGtqgPieQZ/CQcHWXCR7ATDNhGe+YA==", 314 | "dev": true 315 | }, 316 | "cross-spawn": { 317 | "version": "7.0.3", 318 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 319 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 320 | "dev": true, 321 | "requires": { 322 | "path-key": "^3.1.0", 323 | "shebang-command": "^2.0.0", 324 | "which": "^2.0.1" 325 | } 326 | }, 327 | "debug": { 328 | "version": "4.3.4", 329 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 330 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 331 | "dev": true, 332 | "requires": { 333 | "ms": "2.1.2" 334 | } 335 | }, 336 | "decamelize": { 337 | "version": "4.0.0", 338 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 339 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 340 | "dev": true 341 | }, 342 | "deep-is": { 343 | "version": "0.1.4", 344 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 345 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 346 | "dev": true 347 | }, 348 | "define-properties": { 349 | "version": "1.1.4", 350 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz", 351 | "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==", 352 | "dev": true, 353 | "requires": { 354 | "has-property-descriptors": "^1.0.0", 355 | "object-keys": "^1.1.1" 356 | } 357 | }, 358 | "diff": { 359 | "version": "5.0.0", 360 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 361 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 362 | "dev": true 363 | }, 364 | "dir-glob": { 365 | "version": "3.0.1", 366 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 367 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 368 | "dev": true, 369 | "requires": { 370 | "path-type": "^4.0.0" 371 | } 372 | }, 373 | "doctrine": { 374 | "version": "3.0.0", 375 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 376 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 377 | "dev": true, 378 | "requires": { 379 | "esutils": "^2.0.2" 380 | } 381 | }, 382 | "emoji-regex": { 383 | "version": "8.0.0", 384 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 385 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 386 | "dev": true 387 | }, 388 | "es-abstract": { 389 | "version": "1.20.3", 390 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.20.3.tgz", 391 | "integrity": "sha512-AyrnaKVpMzljIdwjzrj+LxGmj8ik2LckwXacHqrJJ/jxz6dDDBcZ7I7nlHM0FvEW8MfbWJwOd+yT2XzYW49Frw==", 392 | "dev": true, 393 | "requires": { 394 | "call-bind": "^1.0.2", 395 | "es-to-primitive": "^1.2.1", 396 | "function-bind": "^1.1.1", 397 | "function.prototype.name": "^1.1.5", 398 | "get-intrinsic": "^1.1.3", 399 | "get-symbol-description": "^1.0.0", 400 | "has": "^1.0.3", 401 | "has-property-descriptors": "^1.0.0", 402 | "has-symbols": "^1.0.3", 403 | "internal-slot": "^1.0.3", 404 | "is-callable": "^1.2.6", 405 | "is-negative-zero": "^2.0.2", 406 | "is-regex": "^1.1.4", 407 | "is-shared-array-buffer": "^1.0.2", 408 | "is-string": "^1.0.7", 409 | "is-weakref": "^1.0.2", 410 | "object-inspect": "^1.12.2", 411 | "object-keys": "^1.1.1", 412 | "object.assign": "^4.1.4", 413 | "regexp.prototype.flags": "^1.4.3", 414 | "safe-regex-test": "^1.0.0", 415 | "string.prototype.trimend": "^1.0.5", 416 | "string.prototype.trimstart": "^1.0.5", 417 | "unbox-primitive": "^1.0.2" 418 | } 419 | }, 420 | "es-shim-unscopables": { 421 | "version": "1.0.0", 422 | "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", 423 | "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", 424 | "dev": true, 425 | "requires": { 426 | "has": "^1.0.3" 427 | } 428 | }, 429 | "es-to-primitive": { 430 | "version": "1.2.1", 431 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 432 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 433 | "dev": true, 434 | "requires": { 435 | "is-callable": "^1.1.4", 436 | "is-date-object": "^1.0.1", 437 | "is-symbol": "^1.0.2" 438 | } 439 | }, 440 | "escalade": { 441 | "version": "3.1.1", 442 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 443 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 444 | "dev": true 445 | }, 446 | "escape-string-regexp": { 447 | "version": "4.0.0", 448 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 449 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 450 | "dev": true 451 | }, 452 | "eslint": { 453 | "version": "8.24.0", 454 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.24.0.tgz", 455 | "integrity": "sha512-dWFaPhGhTAiPcCgm3f6LI2MBWbogMnTJzFBbhXVRQDJPkr9pGZvVjlVfXd+vyDcWPA2Ic9L2AXPIQM0+vk/cSQ==", 456 | "dev": true, 457 | "requires": { 458 | "@eslint/eslintrc": "^1.3.2", 459 | "@humanwhocodes/config-array": "^0.10.5", 460 | "@humanwhocodes/gitignore-to-minimatch": "^1.0.2", 461 | "@humanwhocodes/module-importer": "^1.0.1", 462 | "ajv": "^6.10.0", 463 | "chalk": "^4.0.0", 464 | "cross-spawn": "^7.0.2", 465 | "debug": "^4.3.2", 466 | "doctrine": "^3.0.0", 467 | "escape-string-regexp": "^4.0.0", 468 | "eslint-scope": "^7.1.1", 469 | "eslint-utils": "^3.0.0", 470 | "eslint-visitor-keys": "^3.3.0", 471 | "espree": "^9.4.0", 472 | "esquery": "^1.4.0", 473 | "esutils": "^2.0.2", 474 | "fast-deep-equal": "^3.1.3", 475 | "file-entry-cache": "^6.0.1", 476 | "find-up": "^5.0.0", 477 | "glob-parent": "^6.0.1", 478 | "globals": "^13.15.0", 479 | "globby": "^11.1.0", 480 | "grapheme-splitter": "^1.0.4", 481 | "ignore": "^5.2.0", 482 | "import-fresh": "^3.0.0", 483 | "imurmurhash": "^0.1.4", 484 | "is-glob": "^4.0.0", 485 | "js-sdsl": "^4.1.4", 486 | "js-yaml": "^4.1.0", 487 | "json-stable-stringify-without-jsonify": "^1.0.1", 488 | "levn": "^0.4.1", 489 | "lodash.merge": "^4.6.2", 490 | "minimatch": "^3.1.2", 491 | "natural-compare": "^1.4.0", 492 | "optionator": "^0.9.1", 493 | "regexpp": "^3.2.0", 494 | "strip-ansi": "^6.0.1", 495 | "strip-json-comments": "^3.1.0", 496 | "text-table": "^0.2.0" 497 | } 498 | }, 499 | "eslint-config-airbnb-base": { 500 | "version": "15.0.0", 501 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", 502 | "integrity": "sha512-xaX3z4ZZIcFLvh2oUNvcX5oEofXda7giYmuplVxoOg5A7EXJMrUyqRgR+mhDhPK8LZ4PttFOBvCYDbX3sUoUig==", 503 | "dev": true, 504 | "requires": { 505 | "confusing-browser-globals": "^1.0.10", 506 | "object.assign": "^4.1.2", 507 | "object.entries": "^1.1.5", 508 | "semver": "^6.3.0" 509 | } 510 | }, 511 | "eslint-import-resolver-node": { 512 | "version": "0.3.6", 513 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz", 514 | "integrity": "sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw==", 515 | "dev": true, 516 | "requires": { 517 | "debug": "^3.2.7", 518 | "resolve": "^1.20.0" 519 | }, 520 | "dependencies": { 521 | "debug": { 522 | "version": "3.2.7", 523 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 524 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 525 | "dev": true, 526 | "requires": { 527 | "ms": "^2.1.1" 528 | } 529 | } 530 | } 531 | }, 532 | "eslint-module-utils": { 533 | "version": "2.7.4", 534 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.7.4.tgz", 535 | "integrity": "sha512-j4GT+rqzCoRKHwURX7pddtIPGySnX9Si/cgMI5ztrcqOPtk5dDEeZ34CQVPphnqkJytlc97Vuk05Um2mJ3gEQA==", 536 | "dev": true, 537 | "requires": { 538 | "debug": "^3.2.7" 539 | }, 540 | "dependencies": { 541 | "debug": { 542 | "version": "3.2.7", 543 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 544 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 545 | "dev": true, 546 | "requires": { 547 | "ms": "^2.1.1" 548 | } 549 | } 550 | } 551 | }, 552 | "eslint-plugin-import": { 553 | "version": "2.26.0", 554 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.26.0.tgz", 555 | "integrity": "sha512-hYfi3FXaM8WPLf4S1cikh/r4IxnO6zrhZbEGz2b660EJRbuxgpDS5gkCuYgGWg2xxh2rBuIr4Pvhve/7c31koA==", 556 | "dev": true, 557 | "requires": { 558 | "array-includes": "^3.1.4", 559 | "array.prototype.flat": "^1.2.5", 560 | "debug": "^2.6.9", 561 | "doctrine": "^2.1.0", 562 | "eslint-import-resolver-node": "^0.3.6", 563 | "eslint-module-utils": "^2.7.3", 564 | "has": "^1.0.3", 565 | "is-core-module": "^2.8.1", 566 | "is-glob": "^4.0.3", 567 | "minimatch": "^3.1.2", 568 | "object.values": "^1.1.5", 569 | "resolve": "^1.22.0", 570 | "tsconfig-paths": "^3.14.1" 571 | }, 572 | "dependencies": { 573 | "debug": { 574 | "version": "2.6.9", 575 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 576 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 577 | "dev": true, 578 | "requires": { 579 | "ms": "2.0.0" 580 | } 581 | }, 582 | "doctrine": { 583 | "version": "2.1.0", 584 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 585 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 586 | "dev": true, 587 | "requires": { 588 | "esutils": "^2.0.2" 589 | } 590 | }, 591 | "ms": { 592 | "version": "2.0.0", 593 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 594 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", 595 | "dev": true 596 | } 597 | } 598 | }, 599 | "eslint-scope": { 600 | "version": "7.1.1", 601 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 602 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 603 | "dev": true, 604 | "requires": { 605 | "esrecurse": "^4.3.0", 606 | "estraverse": "^5.2.0" 607 | } 608 | }, 609 | "eslint-utils": { 610 | "version": "3.0.0", 611 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 612 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 613 | "dev": true, 614 | "requires": { 615 | "eslint-visitor-keys": "^2.0.0" 616 | }, 617 | "dependencies": { 618 | "eslint-visitor-keys": { 619 | "version": "2.1.0", 620 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 621 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 622 | "dev": true 623 | } 624 | } 625 | }, 626 | "eslint-visitor-keys": { 627 | "version": "3.3.0", 628 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 629 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 630 | "dev": true 631 | }, 632 | "espree": { 633 | "version": "9.4.0", 634 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.4.0.tgz", 635 | "integrity": "sha512-DQmnRpLj7f6TgN/NYb0MTzJXL+vJF9h3pHy4JhCIs3zwcgez8xmGg3sXHcEO97BrmO2OSvCwMdfdlyl+E9KjOw==", 636 | "dev": true, 637 | "requires": { 638 | "acorn": "^8.8.0", 639 | "acorn-jsx": "^5.3.2", 640 | "eslint-visitor-keys": "^3.3.0" 641 | } 642 | }, 643 | "esquery": { 644 | "version": "1.4.0", 645 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 646 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 647 | "dev": true, 648 | "requires": { 649 | "estraverse": "^5.1.0" 650 | } 651 | }, 652 | "esrecurse": { 653 | "version": "4.3.0", 654 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 655 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 656 | "dev": true, 657 | "requires": { 658 | "estraverse": "^5.2.0" 659 | } 660 | }, 661 | "estraverse": { 662 | "version": "5.3.0", 663 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 664 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 665 | "dev": true 666 | }, 667 | "esutils": { 668 | "version": "2.0.3", 669 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 670 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 671 | "dev": true 672 | }, 673 | "fast-deep-equal": { 674 | "version": "3.1.3", 675 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 676 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 677 | "dev": true 678 | }, 679 | "fast-glob": { 680 | "version": "3.2.12", 681 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", 682 | "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", 683 | "dev": true, 684 | "requires": { 685 | "@nodelib/fs.stat": "^2.0.2", 686 | "@nodelib/fs.walk": "^1.2.3", 687 | "glob-parent": "^5.1.2", 688 | "merge2": "^1.3.0", 689 | "micromatch": "^4.0.4" 690 | }, 691 | "dependencies": { 692 | "glob-parent": { 693 | "version": "5.1.2", 694 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 695 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 696 | "dev": true, 697 | "requires": { 698 | "is-glob": "^4.0.1" 699 | } 700 | } 701 | } 702 | }, 703 | "fast-json-stable-stringify": { 704 | "version": "2.1.0", 705 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 706 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 707 | "dev": true 708 | }, 709 | "fast-levenshtein": { 710 | "version": "2.0.6", 711 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 712 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 713 | "dev": true 714 | }, 715 | "fastq": { 716 | "version": "1.13.0", 717 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 718 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 719 | "dev": true, 720 | "requires": { 721 | "reusify": "^1.0.4" 722 | } 723 | }, 724 | "file-entry-cache": { 725 | "version": "6.0.1", 726 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 727 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 728 | "dev": true, 729 | "requires": { 730 | "flat-cache": "^3.0.4" 731 | } 732 | }, 733 | "fill-range": { 734 | "version": "7.0.1", 735 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 736 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 737 | "dev": true, 738 | "requires": { 739 | "to-regex-range": "^5.0.1" 740 | } 741 | }, 742 | "find-up": { 743 | "version": "5.0.0", 744 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 745 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 746 | "dev": true, 747 | "requires": { 748 | "locate-path": "^6.0.0", 749 | "path-exists": "^4.0.0" 750 | } 751 | }, 752 | "flat": { 753 | "version": "5.0.2", 754 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 755 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 756 | "dev": true 757 | }, 758 | "flat-cache": { 759 | "version": "3.0.4", 760 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 761 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 762 | "dev": true, 763 | "requires": { 764 | "flatted": "^3.1.0", 765 | "rimraf": "^3.0.2" 766 | } 767 | }, 768 | "flatted": { 769 | "version": "3.2.7", 770 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", 771 | "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", 772 | "dev": true 773 | }, 774 | "fs.realpath": { 775 | "version": "1.0.0", 776 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 777 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 778 | "dev": true 779 | }, 780 | "fsevents": { 781 | "version": "2.3.2", 782 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 783 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 784 | "dev": true, 785 | "optional": true 786 | }, 787 | "function-bind": { 788 | "version": "1.1.1", 789 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 790 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 791 | "dev": true 792 | }, 793 | "function.prototype.name": { 794 | "version": "1.1.5", 795 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", 796 | "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", 797 | "dev": true, 798 | "requires": { 799 | "call-bind": "^1.0.2", 800 | "define-properties": "^1.1.3", 801 | "es-abstract": "^1.19.0", 802 | "functions-have-names": "^1.2.2" 803 | } 804 | }, 805 | "functions-have-names": { 806 | "version": "1.2.3", 807 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 808 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 809 | "dev": true 810 | }, 811 | "get-caller-file": { 812 | "version": "2.0.5", 813 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 814 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 815 | "dev": true 816 | }, 817 | "get-intrinsic": { 818 | "version": "1.1.3", 819 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", 820 | "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", 821 | "dev": true, 822 | "requires": { 823 | "function-bind": "^1.1.1", 824 | "has": "^1.0.3", 825 | "has-symbols": "^1.0.3" 826 | } 827 | }, 828 | "get-symbol-description": { 829 | "version": "1.0.0", 830 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 831 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 832 | "dev": true, 833 | "requires": { 834 | "call-bind": "^1.0.2", 835 | "get-intrinsic": "^1.1.1" 836 | } 837 | }, 838 | "glob": { 839 | "version": "7.2.0", 840 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 841 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 842 | "dev": true, 843 | "requires": { 844 | "fs.realpath": "^1.0.0", 845 | "inflight": "^1.0.4", 846 | "inherits": "2", 847 | "minimatch": "^3.0.4", 848 | "once": "^1.3.0", 849 | "path-is-absolute": "^1.0.0" 850 | } 851 | }, 852 | "glob-parent": { 853 | "version": "6.0.2", 854 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 855 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 856 | "dev": true, 857 | "requires": { 858 | "is-glob": "^4.0.3" 859 | } 860 | }, 861 | "globals": { 862 | "version": "13.17.0", 863 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.17.0.tgz", 864 | "integrity": "sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw==", 865 | "dev": true, 866 | "requires": { 867 | "type-fest": "^0.20.2" 868 | } 869 | }, 870 | "globby": { 871 | "version": "11.1.0", 872 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 873 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 874 | "dev": true, 875 | "requires": { 876 | "array-union": "^2.1.0", 877 | "dir-glob": "^3.0.1", 878 | "fast-glob": "^3.2.9", 879 | "ignore": "^5.2.0", 880 | "merge2": "^1.4.1", 881 | "slash": "^3.0.0" 882 | } 883 | }, 884 | "grapheme-splitter": { 885 | "version": "1.0.4", 886 | "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", 887 | "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", 888 | "dev": true 889 | }, 890 | "has": { 891 | "version": "1.0.3", 892 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 893 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 894 | "dev": true, 895 | "requires": { 896 | "function-bind": "^1.1.1" 897 | } 898 | }, 899 | "has-bigints": { 900 | "version": "1.0.2", 901 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 902 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 903 | "dev": true 904 | }, 905 | "has-flag": { 906 | "version": "4.0.0", 907 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 908 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 909 | "dev": true 910 | }, 911 | "has-property-descriptors": { 912 | "version": "1.0.0", 913 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", 914 | "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", 915 | "dev": true, 916 | "requires": { 917 | "get-intrinsic": "^1.1.1" 918 | } 919 | }, 920 | "has-symbols": { 921 | "version": "1.0.3", 922 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 923 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 924 | "dev": true 925 | }, 926 | "has-tostringtag": { 927 | "version": "1.0.0", 928 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 929 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 930 | "dev": true, 931 | "requires": { 932 | "has-symbols": "^1.0.2" 933 | } 934 | }, 935 | "he": { 936 | "version": "1.2.0", 937 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 938 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 939 | "dev": true 940 | }, 941 | "ignore": { 942 | "version": "5.2.0", 943 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 944 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 945 | "dev": true 946 | }, 947 | "import-fresh": { 948 | "version": "3.3.0", 949 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 950 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 951 | "dev": true, 952 | "requires": { 953 | "parent-module": "^1.0.0", 954 | "resolve-from": "^4.0.0" 955 | } 956 | }, 957 | "imurmurhash": { 958 | "version": "0.1.4", 959 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 960 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 961 | "dev": true 962 | }, 963 | "inflight": { 964 | "version": "1.0.6", 965 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 966 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 967 | "dev": true, 968 | "requires": { 969 | "once": "^1.3.0", 970 | "wrappy": "1" 971 | } 972 | }, 973 | "inherits": { 974 | "version": "2.0.4", 975 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 976 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 977 | "dev": true 978 | }, 979 | "internal-slot": { 980 | "version": "1.0.3", 981 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 982 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 983 | "dev": true, 984 | "requires": { 985 | "get-intrinsic": "^1.1.0", 986 | "has": "^1.0.3", 987 | "side-channel": "^1.0.4" 988 | } 989 | }, 990 | "is-bigint": { 991 | "version": "1.0.4", 992 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 993 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 994 | "dev": true, 995 | "requires": { 996 | "has-bigints": "^1.0.1" 997 | } 998 | }, 999 | "is-binary-path": { 1000 | "version": "2.1.0", 1001 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1002 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1003 | "dev": true, 1004 | "requires": { 1005 | "binary-extensions": "^2.0.0" 1006 | } 1007 | }, 1008 | "is-boolean-object": { 1009 | "version": "1.1.2", 1010 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 1011 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 1012 | "dev": true, 1013 | "requires": { 1014 | "call-bind": "^1.0.2", 1015 | "has-tostringtag": "^1.0.0" 1016 | } 1017 | }, 1018 | "is-callable": { 1019 | "version": "1.2.7", 1020 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 1021 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 1022 | "dev": true 1023 | }, 1024 | "is-core-module": { 1025 | "version": "2.10.0", 1026 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.10.0.tgz", 1027 | "integrity": "sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg==", 1028 | "dev": true, 1029 | "requires": { 1030 | "has": "^1.0.3" 1031 | } 1032 | }, 1033 | "is-date-object": { 1034 | "version": "1.0.5", 1035 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 1036 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 1037 | "dev": true, 1038 | "requires": { 1039 | "has-tostringtag": "^1.0.0" 1040 | } 1041 | }, 1042 | "is-extglob": { 1043 | "version": "2.1.1", 1044 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1045 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1046 | "dev": true 1047 | }, 1048 | "is-fullwidth-code-point": { 1049 | "version": "3.0.0", 1050 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1051 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1052 | "dev": true 1053 | }, 1054 | "is-glob": { 1055 | "version": "4.0.3", 1056 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1057 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1058 | "dev": true, 1059 | "requires": { 1060 | "is-extglob": "^2.1.1" 1061 | } 1062 | }, 1063 | "is-negative-zero": { 1064 | "version": "2.0.2", 1065 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 1066 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 1067 | "dev": true 1068 | }, 1069 | "is-number": { 1070 | "version": "7.0.0", 1071 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1072 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1073 | "dev": true 1074 | }, 1075 | "is-number-object": { 1076 | "version": "1.0.7", 1077 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 1078 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 1079 | "dev": true, 1080 | "requires": { 1081 | "has-tostringtag": "^1.0.0" 1082 | } 1083 | }, 1084 | "is-regex": { 1085 | "version": "1.1.4", 1086 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 1087 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 1088 | "dev": true, 1089 | "requires": { 1090 | "call-bind": "^1.0.2", 1091 | "has-tostringtag": "^1.0.0" 1092 | } 1093 | }, 1094 | "is-shared-array-buffer": { 1095 | "version": "1.0.2", 1096 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", 1097 | "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", 1098 | "dev": true, 1099 | "requires": { 1100 | "call-bind": "^1.0.2" 1101 | } 1102 | }, 1103 | "is-string": { 1104 | "version": "1.0.7", 1105 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 1106 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 1107 | "dev": true, 1108 | "requires": { 1109 | "has-tostringtag": "^1.0.0" 1110 | } 1111 | }, 1112 | "is-symbol": { 1113 | "version": "1.0.4", 1114 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 1115 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 1116 | "dev": true, 1117 | "requires": { 1118 | "has-symbols": "^1.0.2" 1119 | } 1120 | }, 1121 | "is-unicode-supported": { 1122 | "version": "0.1.0", 1123 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1124 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1125 | "dev": true 1126 | }, 1127 | "is-weakref": { 1128 | "version": "1.0.2", 1129 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 1130 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 1131 | "dev": true, 1132 | "requires": { 1133 | "call-bind": "^1.0.2" 1134 | } 1135 | }, 1136 | "isexe": { 1137 | "version": "2.0.0", 1138 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1139 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1140 | "dev": true 1141 | }, 1142 | "js-sdsl": { 1143 | "version": "4.1.5", 1144 | "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.1.5.tgz", 1145 | "integrity": "sha512-08bOAKweV2NUC1wqTtf3qZlnpOX/R2DU9ikpjOHs0H+ibQv3zpncVQg6um4uYtRtrwIX8M4Nh3ytK4HGlYAq7Q==", 1146 | "dev": true 1147 | }, 1148 | "js-yaml": { 1149 | "version": "4.1.0", 1150 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1151 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1152 | "requires": { 1153 | "argparse": "^2.0.1" 1154 | } 1155 | }, 1156 | "json-schema-traverse": { 1157 | "version": "0.4.1", 1158 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1159 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1160 | "dev": true 1161 | }, 1162 | "json-stable-stringify-without-jsonify": { 1163 | "version": "1.0.1", 1164 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1165 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 1166 | "dev": true 1167 | }, 1168 | "json5": { 1169 | "version": "1.0.2", 1170 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", 1171 | "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", 1172 | "dev": true, 1173 | "requires": { 1174 | "minimist": "^1.2.0" 1175 | } 1176 | }, 1177 | "levn": { 1178 | "version": "0.4.1", 1179 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1180 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1181 | "dev": true, 1182 | "requires": { 1183 | "prelude-ls": "^1.2.1", 1184 | "type-check": "~0.4.0" 1185 | } 1186 | }, 1187 | "locate-path": { 1188 | "version": "6.0.0", 1189 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1190 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1191 | "dev": true, 1192 | "requires": { 1193 | "p-locate": "^5.0.0" 1194 | } 1195 | }, 1196 | "lodash": { 1197 | "version": "4.17.21", 1198 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1199 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 1200 | }, 1201 | "lodash.merge": { 1202 | "version": "4.6.2", 1203 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1204 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1205 | "dev": true 1206 | }, 1207 | "log-symbols": { 1208 | "version": "4.1.0", 1209 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1210 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1211 | "dev": true, 1212 | "requires": { 1213 | "chalk": "^4.1.0", 1214 | "is-unicode-supported": "^0.1.0" 1215 | } 1216 | }, 1217 | "merge2": { 1218 | "version": "1.4.1", 1219 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1220 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1221 | "dev": true 1222 | }, 1223 | "micromatch": { 1224 | "version": "4.0.5", 1225 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1226 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1227 | "dev": true, 1228 | "requires": { 1229 | "braces": "^3.0.2", 1230 | "picomatch": "^2.3.1" 1231 | } 1232 | }, 1233 | "minimatch": { 1234 | "version": "3.1.2", 1235 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1236 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1237 | "dev": true, 1238 | "requires": { 1239 | "brace-expansion": "^1.1.7" 1240 | } 1241 | }, 1242 | "minimist": { 1243 | "version": "1.2.6", 1244 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1245 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1246 | "dev": true 1247 | }, 1248 | "mocha": { 1249 | "version": "10.0.0", 1250 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.0.0.tgz", 1251 | "integrity": "sha512-0Wl+elVUD43Y0BqPZBzZt8Tnkw9CMUdNYnUsTfOM1vuhJVZL+kiesFYsqwBkEEuEixaiPe5ZQdqDgX2jddhmoA==", 1252 | "dev": true, 1253 | "requires": { 1254 | "@ungap/promise-all-settled": "1.1.2", 1255 | "ansi-colors": "4.1.1", 1256 | "browser-stdout": "1.3.1", 1257 | "chokidar": "3.5.3", 1258 | "debug": "4.3.4", 1259 | "diff": "5.0.0", 1260 | "escape-string-regexp": "4.0.0", 1261 | "find-up": "5.0.0", 1262 | "glob": "7.2.0", 1263 | "he": "1.2.0", 1264 | "js-yaml": "4.1.0", 1265 | "log-symbols": "4.1.0", 1266 | "minimatch": "5.0.1", 1267 | "ms": "2.1.3", 1268 | "nanoid": "3.3.3", 1269 | "serialize-javascript": "6.0.0", 1270 | "strip-json-comments": "3.1.1", 1271 | "supports-color": "8.1.1", 1272 | "workerpool": "6.2.1", 1273 | "yargs": "16.2.0", 1274 | "yargs-parser": "20.2.4", 1275 | "yargs-unparser": "2.0.0" 1276 | }, 1277 | "dependencies": { 1278 | "brace-expansion": { 1279 | "version": "2.0.1", 1280 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1281 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1282 | "dev": true, 1283 | "requires": { 1284 | "balanced-match": "^1.0.0" 1285 | } 1286 | }, 1287 | "minimatch": { 1288 | "version": "5.0.1", 1289 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 1290 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 1291 | "dev": true, 1292 | "requires": { 1293 | "brace-expansion": "^2.0.1" 1294 | } 1295 | }, 1296 | "ms": { 1297 | "version": "2.1.3", 1298 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1299 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1300 | "dev": true 1301 | }, 1302 | "supports-color": { 1303 | "version": "8.1.1", 1304 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1305 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1306 | "dev": true, 1307 | "requires": { 1308 | "has-flag": "^4.0.0" 1309 | } 1310 | } 1311 | } 1312 | }, 1313 | "ms": { 1314 | "version": "2.1.2", 1315 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1316 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1317 | "dev": true 1318 | }, 1319 | "mustache": { 1320 | "version": "4.2.0", 1321 | "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", 1322 | "integrity": "sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==" 1323 | }, 1324 | "nanoid": { 1325 | "version": "3.3.3", 1326 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 1327 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 1328 | "dev": true 1329 | }, 1330 | "natural-compare": { 1331 | "version": "1.4.0", 1332 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1333 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 1334 | "dev": true 1335 | }, 1336 | "normalize-path": { 1337 | "version": "3.0.0", 1338 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1339 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1340 | "dev": true 1341 | }, 1342 | "object-inspect": { 1343 | "version": "1.12.2", 1344 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", 1345 | "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", 1346 | "dev": true 1347 | }, 1348 | "object-keys": { 1349 | "version": "1.1.1", 1350 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1351 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1352 | "dev": true 1353 | }, 1354 | "object.assign": { 1355 | "version": "4.1.4", 1356 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", 1357 | "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", 1358 | "dev": true, 1359 | "requires": { 1360 | "call-bind": "^1.0.2", 1361 | "define-properties": "^1.1.4", 1362 | "has-symbols": "^1.0.3", 1363 | "object-keys": "^1.1.1" 1364 | } 1365 | }, 1366 | "object.entries": { 1367 | "version": "1.1.5", 1368 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.5.tgz", 1369 | "integrity": "sha512-TyxmjUoZggd4OrrU1W66FMDG6CuqJxsFvymeyXI51+vQLN67zYfZseptRge703kKQdo4uccgAKebXFcRCzk4+g==", 1370 | "dev": true, 1371 | "requires": { 1372 | "call-bind": "^1.0.2", 1373 | "define-properties": "^1.1.3", 1374 | "es-abstract": "^1.19.1" 1375 | } 1376 | }, 1377 | "object.values": { 1378 | "version": "1.1.5", 1379 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.5.tgz", 1380 | "integrity": "sha512-QUZRW0ilQ3PnPpbNtgdNV1PDbEqLIiSFB3l+EnGtBQ/8SUTLj1PZwtQHABZtLgwpJZTSZhuGLOGk57Drx2IvYg==", 1381 | "dev": true, 1382 | "requires": { 1383 | "call-bind": "^1.0.2", 1384 | "define-properties": "^1.1.3", 1385 | "es-abstract": "^1.19.1" 1386 | } 1387 | }, 1388 | "once": { 1389 | "version": "1.4.0", 1390 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1391 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1392 | "dev": true, 1393 | "requires": { 1394 | "wrappy": "1" 1395 | } 1396 | }, 1397 | "optionator": { 1398 | "version": "0.9.1", 1399 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1400 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1401 | "dev": true, 1402 | "requires": { 1403 | "deep-is": "^0.1.3", 1404 | "fast-levenshtein": "^2.0.6", 1405 | "levn": "^0.4.1", 1406 | "prelude-ls": "^1.2.1", 1407 | "type-check": "^0.4.0", 1408 | "word-wrap": "^1.2.3" 1409 | } 1410 | }, 1411 | "p-limit": { 1412 | "version": "3.1.0", 1413 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1414 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1415 | "dev": true, 1416 | "requires": { 1417 | "yocto-queue": "^0.1.0" 1418 | } 1419 | }, 1420 | "p-locate": { 1421 | "version": "5.0.0", 1422 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1423 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1424 | "dev": true, 1425 | "requires": { 1426 | "p-limit": "^3.0.2" 1427 | } 1428 | }, 1429 | "parent-module": { 1430 | "version": "1.0.1", 1431 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1432 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1433 | "dev": true, 1434 | "requires": { 1435 | "callsites": "^3.0.0" 1436 | } 1437 | }, 1438 | "path-exists": { 1439 | "version": "4.0.0", 1440 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1441 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1442 | "dev": true 1443 | }, 1444 | "path-is-absolute": { 1445 | "version": "1.0.1", 1446 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1447 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1448 | "dev": true 1449 | }, 1450 | "path-key": { 1451 | "version": "3.1.1", 1452 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1453 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1454 | "dev": true 1455 | }, 1456 | "path-parse": { 1457 | "version": "1.0.7", 1458 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1459 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1460 | "dev": true 1461 | }, 1462 | "path-type": { 1463 | "version": "4.0.0", 1464 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1465 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1466 | "dev": true 1467 | }, 1468 | "picomatch": { 1469 | "version": "2.3.1", 1470 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1471 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1472 | "dev": true 1473 | }, 1474 | "prelude-ls": { 1475 | "version": "1.2.1", 1476 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1477 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1478 | "dev": true 1479 | }, 1480 | "punycode": { 1481 | "version": "2.1.1", 1482 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1483 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1484 | "dev": true 1485 | }, 1486 | "queue-microtask": { 1487 | "version": "1.2.3", 1488 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1489 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1490 | "dev": true 1491 | }, 1492 | "randombytes": { 1493 | "version": "2.1.0", 1494 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1495 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1496 | "dev": true, 1497 | "requires": { 1498 | "safe-buffer": "^5.1.0" 1499 | } 1500 | }, 1501 | "readdirp": { 1502 | "version": "3.6.0", 1503 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1504 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1505 | "dev": true, 1506 | "requires": { 1507 | "picomatch": "^2.2.1" 1508 | } 1509 | }, 1510 | "regexp.prototype.flags": { 1511 | "version": "1.4.3", 1512 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz", 1513 | "integrity": "sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA==", 1514 | "dev": true, 1515 | "requires": { 1516 | "call-bind": "^1.0.2", 1517 | "define-properties": "^1.1.3", 1518 | "functions-have-names": "^1.2.2" 1519 | } 1520 | }, 1521 | "regexpp": { 1522 | "version": "3.2.0", 1523 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1524 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1525 | "dev": true 1526 | }, 1527 | "require-directory": { 1528 | "version": "2.1.1", 1529 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1530 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1531 | "dev": true 1532 | }, 1533 | "resolve": { 1534 | "version": "1.22.1", 1535 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", 1536 | "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", 1537 | "dev": true, 1538 | "requires": { 1539 | "is-core-module": "^2.9.0", 1540 | "path-parse": "^1.0.7", 1541 | "supports-preserve-symlinks-flag": "^1.0.0" 1542 | } 1543 | }, 1544 | "resolve-from": { 1545 | "version": "4.0.0", 1546 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1547 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1548 | "dev": true 1549 | }, 1550 | "reusify": { 1551 | "version": "1.0.4", 1552 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1553 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1554 | "dev": true 1555 | }, 1556 | "rimraf": { 1557 | "version": "3.0.2", 1558 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1559 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1560 | "dev": true, 1561 | "requires": { 1562 | "glob": "^7.1.3" 1563 | } 1564 | }, 1565 | "run-parallel": { 1566 | "version": "1.2.0", 1567 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1568 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1569 | "dev": true, 1570 | "requires": { 1571 | "queue-microtask": "^1.2.2" 1572 | } 1573 | }, 1574 | "safe-buffer": { 1575 | "version": "5.2.1", 1576 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1577 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1578 | "dev": true 1579 | }, 1580 | "safe-regex-test": { 1581 | "version": "1.0.0", 1582 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", 1583 | "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", 1584 | "dev": true, 1585 | "requires": { 1586 | "call-bind": "^1.0.2", 1587 | "get-intrinsic": "^1.1.3", 1588 | "is-regex": "^1.1.4" 1589 | } 1590 | }, 1591 | "semver": { 1592 | "version": "6.3.0", 1593 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1594 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1595 | "dev": true 1596 | }, 1597 | "serialize-javascript": { 1598 | "version": "6.0.0", 1599 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1600 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1601 | "dev": true, 1602 | "requires": { 1603 | "randombytes": "^2.1.0" 1604 | } 1605 | }, 1606 | "shebang-command": { 1607 | "version": "2.0.0", 1608 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1609 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1610 | "dev": true, 1611 | "requires": { 1612 | "shebang-regex": "^3.0.0" 1613 | } 1614 | }, 1615 | "shebang-regex": { 1616 | "version": "3.0.0", 1617 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1618 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1619 | "dev": true 1620 | }, 1621 | "side-channel": { 1622 | "version": "1.0.4", 1623 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1624 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1625 | "dev": true, 1626 | "requires": { 1627 | "call-bind": "^1.0.0", 1628 | "get-intrinsic": "^1.0.2", 1629 | "object-inspect": "^1.9.0" 1630 | } 1631 | }, 1632 | "slash": { 1633 | "version": "3.0.0", 1634 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1635 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1636 | "dev": true 1637 | }, 1638 | "string-width": { 1639 | "version": "4.2.3", 1640 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1641 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1642 | "dev": true, 1643 | "requires": { 1644 | "emoji-regex": "^8.0.0", 1645 | "is-fullwidth-code-point": "^3.0.0", 1646 | "strip-ansi": "^6.0.1" 1647 | } 1648 | }, 1649 | "string.prototype.trimend": { 1650 | "version": "1.0.5", 1651 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.5.tgz", 1652 | "integrity": "sha512-I7RGvmjV4pJ7O3kdf+LXFpVfdNOxtCW/2C8f6jNiW4+PQchwxkCDzlk1/7p+Wl4bqFIZeF47qAHXLuHHWKAxog==", 1653 | "dev": true, 1654 | "requires": { 1655 | "call-bind": "^1.0.2", 1656 | "define-properties": "^1.1.4", 1657 | "es-abstract": "^1.19.5" 1658 | } 1659 | }, 1660 | "string.prototype.trimstart": { 1661 | "version": "1.0.5", 1662 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.5.tgz", 1663 | "integrity": "sha512-THx16TJCGlsN0o6dl2o6ncWUsdgnLRSA23rRE5pyGBw/mLr3Ej/R2LaqCtgP8VNMGZsvMWnf9ooZPyY2bHvUFg==", 1664 | "dev": true, 1665 | "requires": { 1666 | "call-bind": "^1.0.2", 1667 | "define-properties": "^1.1.4", 1668 | "es-abstract": "^1.19.5" 1669 | } 1670 | }, 1671 | "strip-ansi": { 1672 | "version": "6.0.1", 1673 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1674 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1675 | "dev": true, 1676 | "requires": { 1677 | "ansi-regex": "^5.0.1" 1678 | } 1679 | }, 1680 | "strip-bom": { 1681 | "version": "3.0.0", 1682 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1683 | "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", 1684 | "dev": true 1685 | }, 1686 | "strip-json-comments": { 1687 | "version": "3.1.1", 1688 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1689 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1690 | "dev": true 1691 | }, 1692 | "supports-color": { 1693 | "version": "7.2.0", 1694 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1695 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1696 | "dev": true, 1697 | "requires": { 1698 | "has-flag": "^4.0.0" 1699 | } 1700 | }, 1701 | "supports-preserve-symlinks-flag": { 1702 | "version": "1.0.0", 1703 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1704 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1705 | "dev": true 1706 | }, 1707 | "text-table": { 1708 | "version": "0.2.0", 1709 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1710 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 1711 | "dev": true 1712 | }, 1713 | "to-regex-range": { 1714 | "version": "5.0.1", 1715 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1716 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1717 | "dev": true, 1718 | "requires": { 1719 | "is-number": "^7.0.0" 1720 | } 1721 | }, 1722 | "tsconfig-paths": { 1723 | "version": "3.14.1", 1724 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.1.tgz", 1725 | "integrity": "sha512-fxDhWnFSLt3VuTwtvJt5fpwxBHg5AdKWMsgcPOOIilyjymcYVZoCQF8fvFRezCNfblEXmi+PcM1eYHeOAgXCOQ==", 1726 | "dev": true, 1727 | "requires": { 1728 | "@types/json5": "^0.0.29", 1729 | "json5": "^1.0.1", 1730 | "minimist": "^1.2.6", 1731 | "strip-bom": "^3.0.0" 1732 | } 1733 | }, 1734 | "type-check": { 1735 | "version": "0.4.0", 1736 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1737 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1738 | "dev": true, 1739 | "requires": { 1740 | "prelude-ls": "^1.2.1" 1741 | } 1742 | }, 1743 | "type-fest": { 1744 | "version": "0.20.2", 1745 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1746 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1747 | "dev": true 1748 | }, 1749 | "unbox-primitive": { 1750 | "version": "1.0.2", 1751 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 1752 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 1753 | "dev": true, 1754 | "requires": { 1755 | "call-bind": "^1.0.2", 1756 | "has-bigints": "^1.0.2", 1757 | "has-symbols": "^1.0.3", 1758 | "which-boxed-primitive": "^1.0.2" 1759 | } 1760 | }, 1761 | "uri-js": { 1762 | "version": "4.4.1", 1763 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1764 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1765 | "dev": true, 1766 | "requires": { 1767 | "punycode": "^2.1.0" 1768 | } 1769 | }, 1770 | "which": { 1771 | "version": "2.0.2", 1772 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1773 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1774 | "dev": true, 1775 | "requires": { 1776 | "isexe": "^2.0.0" 1777 | } 1778 | }, 1779 | "which-boxed-primitive": { 1780 | "version": "1.0.2", 1781 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 1782 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 1783 | "dev": true, 1784 | "requires": { 1785 | "is-bigint": "^1.0.1", 1786 | "is-boolean-object": "^1.1.0", 1787 | "is-number-object": "^1.0.4", 1788 | "is-string": "^1.0.5", 1789 | "is-symbol": "^1.0.3" 1790 | } 1791 | }, 1792 | "word-wrap": { 1793 | "version": "1.2.3", 1794 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1795 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1796 | "dev": true 1797 | }, 1798 | "workerpool": { 1799 | "version": "6.2.1", 1800 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 1801 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 1802 | "dev": true 1803 | }, 1804 | "wrap-ansi": { 1805 | "version": "7.0.0", 1806 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1807 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1808 | "dev": true, 1809 | "requires": { 1810 | "ansi-styles": "^4.0.0", 1811 | "string-width": "^4.1.0", 1812 | "strip-ansi": "^6.0.0" 1813 | } 1814 | }, 1815 | "wrappy": { 1816 | "version": "1.0.2", 1817 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1818 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1819 | "dev": true 1820 | }, 1821 | "y18n": { 1822 | "version": "5.0.8", 1823 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1824 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1825 | "dev": true 1826 | }, 1827 | "yargs": { 1828 | "version": "16.2.0", 1829 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1830 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1831 | "dev": true, 1832 | "requires": { 1833 | "cliui": "^7.0.2", 1834 | "escalade": "^3.1.1", 1835 | "get-caller-file": "^2.0.5", 1836 | "require-directory": "^2.1.1", 1837 | "string-width": "^4.2.0", 1838 | "y18n": "^5.0.5", 1839 | "yargs-parser": "^20.2.2" 1840 | } 1841 | }, 1842 | "yargs-parser": { 1843 | "version": "20.2.4", 1844 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1845 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1846 | "dev": true 1847 | }, 1848 | "yargs-unparser": { 1849 | "version": "2.0.0", 1850 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1851 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1852 | "dev": true, 1853 | "requires": { 1854 | "camelcase": "^6.0.0", 1855 | "decamelize": "^4.0.0", 1856 | "flat": "^5.0.2", 1857 | "is-plain-obj": "^2.1.0" 1858 | }, 1859 | "dependencies": { 1860 | "is-plain-obj": { 1861 | "version": "2.1.0", 1862 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1863 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1864 | "dev": true 1865 | } 1866 | } 1867 | }, 1868 | "yocto-queue": { 1869 | "version": "0.1.0", 1870 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1871 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1872 | "dev": true 1873 | } 1874 | } 1875 | } 1876 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "serverless-aws-function-url-custom-domain", 3 | "version": "0.9.28", 4 | "description": "Serverless AWS Lambda URL custom domain configuration via cloudfront distribution and route 53.", 5 | "main": "index.js", 6 | "repository": { 7 | "type": "git", 8 | "url": "https://github.com/wangsha/serverless-aws-function-url-custom-domain" 9 | }, 10 | "scripts": { 11 | "test": "npm run test-lint && npm run test-unit", 12 | "test-lint": "eslint *.js", 13 | "test-unit": "./node_modules/mocha/bin/mocha.js index.test.js" 14 | }, 15 | "author": "wangsha", 16 | "keywords": [ 17 | "serverless", 18 | "serverless plugin", 19 | "cloudfront", 20 | "function url", 21 | "lambda", 22 | "aws", 23 | "aws lambda", 24 | "amazon web services", 25 | "serverless.com" 26 | ], 27 | "dependencies": { 28 | "js-yaml": "^4.1.0", 29 | "lodash": "^4.17.21", 30 | "mustache": "^4.2.0" 31 | }, 32 | "peerDependencies": { 33 | "serverless": "3.x" 34 | }, 35 | "engines": { 36 | "node": ">=10.0" 37 | }, 38 | "license": "MIT", 39 | "devDependencies": { 40 | "eslint": "^8.17.0", 41 | "eslint-config-airbnb-base": "^15.0.0", 42 | "eslint-plugin-import": "^2.26.0", 43 | "mocha": "^10.0.0" 44 | } 45 | } 46 | -------------------------------------------------------------------------------- /resources.yml: -------------------------------------------------------------------------------- 1 | --- 2 | Resources: 3 | CloudFrontDistribution: 4 | Type: AWS::CloudFront::Distribution 5 | DeletionPolicy: Delete 6 | Properties: 7 | DistributionConfig: 8 | Enabled: true 9 | PriceClass: PriceClass_100 10 | HttpVersion: http2 11 | Comment: "Lambda FunctionURL {{{ domains }}}" 12 | Origins: 13 | - Id: LambdaFunctionURL 14 | DomainName: { "Fn::Select": [2, {'Fn::Split': ["/", {'Fn::GetAtt': ["{{{ lambdaFunctionUrl }}}", FunctionUrl]}]}]} # extract function url form your lambda resource 15 | OriginPath: '' 16 | CustomOriginConfig: 17 | HTTPPort: 80 18 | HTTPSPort: 443 19 | OriginProtocolPolicy: https-only 20 | OriginSSLProtocols: [TLSv1, TLSv1.1, TLSv1.2] 21 | DefaultCacheBehavior: 22 | TargetOriginId: LambdaFunctionURL 23 | ViewerProtocolPolicy: redirect-to-https 24 | Compress: true 25 | DefaultTTL: 0 26 | AllowedMethods: 27 | - HEAD 28 | - DELETE 29 | - POST 30 | - GET 31 | - OPTIONS 32 | - PUT 33 | - PATCH 34 | CachedMethods: 35 | - HEAD 36 | - OPTIONS 37 | - GET 38 | ForwardedValues: 39 | QueryString: true 40 | Headers: 41 | - Accept 42 | - x-api-key 43 | - Authorization 44 | Cookies: 45 | Forward: all 46 | Aliases: "{{{ domains }}}" 47 | ViewerCertificate: 48 | SslSupportMethod: sni-only 49 | MinimumProtocolVersion: TLSv1.2_2021 50 | AcmCertificateArn: "{{{certificateArn}}}" 51 | Outputs: 52 | CloudFrontDistributionDomain: 53 | Value: 54 | Fn::GetAtt: [ CloudFrontDistribution, DomainName ] 55 | --------------------------------------------------------------------------------