diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 0000000..36d76d7 --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,50 @@ +{ + "env": { + "browser": true, + "commonjs": true, + "es2021": true + }, + "extends": [ + "airbnb-base", + "airbnb-typescript/base", + "prettier" + ], + "parser": "@typescript-eslint/parser", + "parserOptions": { + "ecmaVersion": "latest", + "sourceType": "module", + "project": "./tsconfig.eslint.json" + }, + "plugins": [ + "@typescript-eslint", + "prettier" + ], + "rules": { + "no-console": "off", + "max-len": [ + "error", + { + "code": 150, + "ignoreComments": true, + "ignoreRegExpLiterals": true, + "ignoreStrings": true, + "ignoreTemplateLiterals": true + } + ], + "prettier/prettier": "error", + "@typescript-eslint/dot-notation": "off", + "import/prefer-default-export": "off" + }, + "settings": { + "import/resolver": { + "node": { + "extensions": [ + ".js", + ".jsx", + ".ts", + ".tsx" + ] + } + } + } +} diff --git a/.github/workflows/build-checks.yml b/.github/workflows/build-checks.yml new file mode 100644 index 0000000..10aff5c --- /dev/null +++ b/.github/workflows/build-checks.yml @@ -0,0 +1,35 @@ +name: Release Checks + +on: + push: + branches: + - main + +jobs: + github-publish: + runs-on: ubuntu-latest + + steps: + + - name: Checkout Repository & Submo + uses: actions/checkout@v2 + with: + submodules: recursive + + - name: Setup Node + uses: actions/setup-node@v2 + with: + node-version: '16' + cache: 'npm' + cache-dependency-path: '**/package-lock.json' + + - name: Install dependencies + run: npm install + + # TODO: Finish fixing eslint issues + # - name: Run ESLint check + # run: npm run lint:ci + + - name: Run Test & Coverage check + run: npm run test + diff --git a/.github/workflows/pr-checks.yml b/.github/workflows/pr-checks.yml index 1522dae..7aaa365 100644 --- a/.github/workflows/pr-checks.yml +++ b/.github/workflows/pr-checks.yml @@ -20,8 +20,9 @@ jobs: - name: Install dependencies run: npm install - - name: Run ESLint check - run: npm run lint:ci + # TODO: Finish fixing eslint issues + # - name: Run ESLint check + # run: npm run lint:ci - name: Run Test & Coverage check run: npm run test diff --git a/.prettierrc.json b/.prettierrc.json new file mode 100644 index 0000000..b09cba1 --- /dev/null +++ b/.prettierrc.json @@ -0,0 +1,26 @@ +{ + "printWidth": 100, + "tabWidth": 2, + "useTabs": false, + "semi": true, + "singleQuote": true, + "quoteProps": "as-needed", + "jsxSingleQuote": false, + "trailingComma": "all", + "bracketSpacing": true, + "arrowParens": "always", + "overrides": [ + { + "files": ".editorconfig", + "options": { + "parser": "yaml" + } + }, + { + "files": "LICENSE", + "options": { + "parser": "markdown" + } + } + ] +} diff --git a/examples/README.md b/examples/README.md new file mode 100644 index 0000000..e48003f --- /dev/null +++ b/examples/README.md @@ -0,0 +1,23 @@ +# @dopplerhq/node-sdk-example +A basic example of how to use the @dopplerhq/node-sdk package. + +## Installation + +In the event `@dopplerhq/node-sdk` is not published to npm, you can install it locally by running the following command in the examples folder: +```sh +npm run setup +``` + +This will rebuild the parent package and install it locally. + +Otherwise you can install it from npm: +```sh +npm install @dopplerhq/node-sdk +``` + +## Usage + +To run the example, run the following command in the examples folder: +```sh +npm run start +``` diff --git a/examples/package.json b/examples/package.json new file mode 100644 index 0000000..d1a8b41 --- /dev/null +++ b/examples/package.json @@ -0,0 +1,17 @@ +{ + "name": "@dopplerhq/node-sdk-example", + "version": "1.0.0", + "private": true, + "dependencies": { + "@dopplerhq/node-sdk": "file:../" + }, + "scripts": { + "setup": "npm --prefix ../ install && npm --prefix ../ run build && npm install", + "start": "tsc && node dist/index.js", + "dev": "ts-node src/index.ts" + }, + "devDependencies": { + "ts-node": "^10.9.1", + "typescript": "4.8.4" + } +} diff --git a/examples/src/index.ts b/examples/src/index.ts new file mode 100644 index 0000000..07e65d6 --- /dev/null +++ b/examples/src/index.ts @@ -0,0 +1,9 @@ +import { DopplerSDK } from '@dopplerhq/node-sdk'; + +const DOPPLERSDK_BEARER_TOKEN = ''; +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.projects.list(); + console.log(result); +})(); diff --git a/examples/tsconfig.json b/examples/tsconfig.json new file mode 100644 index 0000000..6cb81ed --- /dev/null +++ b/examples/tsconfig.json @@ -0,0 +1,103 @@ +{ + "compilerOptions": { + /* Visit https://aka.ms/tsconfig to read more about this file */ + + /* Projects */ + // "incremental": true, /* Save .tsbuildinfo files to allow for incremental compilation of projects. */ + // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ + // "tsBuildInfoFile": "./.tsbuildinfo", /* Specify the path to .tsbuildinfo incremental compilation file. */ + // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects. */ + // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ + // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ + + /* Language and Environment */ + "target": "es2016", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */ + // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */ + // "jsx": "preserve", /* Specify what JSX code is generated. */ + // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ + // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ + // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h'. */ + // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ + // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using 'jsx: react-jsx*'. */ + // "reactNamespace": "", /* Specify the object invoked for 'createElement'. This only applies when targeting 'react' JSX emit. */ + // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ + // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ + // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */ + + /* Modules */ + "module": "commonjs", /* Specify what module code is generated. */ + "rootDir": "./src", /* Specify the root folder within your source files. */ + // "moduleResolution": "node", /* Specify how TypeScript looks up a file from a given module specifier. */ + // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ + // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ + // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ + // "typeRoots": [], /* Specify multiple folders that act like './node_modules/@types'. */ + // "types": [], /* Specify type package names to be included without being referenced in a source file. */ + // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ + // "moduleSuffixes": [], /* List of file name suffixes to search when resolving a module. */ + // "resolveJsonModule": true, /* Enable importing .json files. */ + // "noResolve": true, /* Disallow 'import's, 'require's or ''s from expanding the number of files TypeScript should add to a project. */ + + /* JavaScript Support */ + // "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */ + // "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */ + // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */ + + /* Emit */ + // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ + // "declarationMap": true, /* Create sourcemaps for d.ts files. */ + // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ + // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ + // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If 'declaration' is true, also designates a file that bundles all .d.ts output. */ + "outDir": "./dist", /* Specify an output folder for all emitted files. */ + // "removeComments": true, /* Disable emitting comments. */ + // "noEmit": true, /* Disable emitting files from a compilation. */ + // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ + // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types. */ + // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ + // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ + // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ + // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ + // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ + // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ + // "newLine": "crlf", /* Set the newline character for emitting files. */ + // "stripInternal": true, /* Disable emitting declarations that have '@internal' in their JSDoc comments. */ + // "noEmitHelpers": true, /* Disable generating custom helper functions like '__extends' in compiled output. */ + // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ + // "preserveConstEnums": true, /* Disable erasing 'const enum' declarations in generated code. */ + // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ + // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ + + /* Interop Constraints */ + // "isolatedModules": true, /* Ensure that each file can be safely transpiled without relying on other imports. */ + // "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */ + "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */ + // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ + "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */ + + /* Type Checking */ + "strict": true, /* Enable all strict type-checking options. */ + // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied 'any' type. */ + // "strictNullChecks": true, /* When type checking, take into account 'null' and 'undefined'. */ + // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ + // "strictBindCallApply": true, /* Check that the arguments for 'bind', 'call', and 'apply' methods match the original function. */ + // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ + // "noImplicitThis": true, /* Enable error reporting when 'this' is given the type 'any'. */ + // "useUnknownInCatchVariables": true, /* Default catch clause variables as 'unknown' instead of 'any'. */ + // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ + // "noUnusedLocals": true, /* Enable error reporting when local variables aren't read. */ + // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read. */ + // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ + // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ + // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ + // "noUncheckedIndexedAccess": true, /* Add 'undefined' to a type when accessed using an index. */ + // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ + // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type. */ + // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ + // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ + + /* Completeness */ + // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ + "skipLibCheck": true /* Skip type checking all .d.ts files. */ + } +} diff --git a/install.sh b/install.sh new file mode 100644 index 0000000..1885626 --- /dev/null +++ b/install.sh @@ -0,0 +1,2 @@ +npm install +npm run test diff --git a/jest.config.json b/jest.config.json new file mode 100644 index 0000000..4ab2aeb --- /dev/null +++ b/jest.config.json @@ -0,0 +1,7 @@ +{ + "preset": "ts-jest", + "testEnvironment": "node", + "moduleNameMapper": { + "axios": "axios/dist/node/axios.cjs" + } +} diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..276fb0e --- /dev/null +++ b/package-lock.json @@ -0,0 +1,7270 @@ +{ + "name": "@dopplerhq/node-sdk", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "@dopplerhq/node-sdk", + "version": "1.0.0", + "devDependencies": { + "@types/jest": "^27.4.1", + "@types/node": "^17.0.23", + "@typescript-eslint/eslint-plugin": "^5.43.0", + "@typescript-eslint/parser": "^5.43.0", + "eslint": "^8.20.0", + "eslint-config-airbnb-base": "^15.0.0", + "eslint-config-airbnb-typescript": "^17.0.0", + "eslint-config-prettier": "^8.5.0", + "eslint-plugin-import": "^2.26.0", + "eslint-plugin-prettier": "^4.2.1", + "jest": "^27.5.1", + "nock": "^13.2.4", + "prettier": "^2.6.2", + "ts-jest": "^27.0.3", + "tsup": "^6.7.0", + "typescript": "4.8.4" + } + }, + "node_modules/@aashutoshrathi/word-wrap": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", + "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/@ampproject/remapping": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", + "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.0", + "@jridgewell/trace-mapping": "^0.3.9" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.5.tgz", + "integrity": "sha512-Xmwn266vad+6DAqEB2A6V/CcZVp62BbwVmcOJc2RPuwih1kw02TjQvWVWlcKGbBPd+8/0V5DEkOcizRGYsspYQ==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.22.9", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", + "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.22.9", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", + "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "^2.2.0", + "@babel/code-frame": "^7.22.5", + "@babel/generator": "^7.22.9", + "@babel/helper-compilation-targets": "^7.22.9", + "@babel/helper-module-transforms": "^7.22.9", + "@babel/helpers": "^7.22.6", + "@babel/parser": "^7.22.7", + "@babel/template": "^7.22.5", + "@babel/traverse": "^7.22.8", + "@babel/types": "^7.22.5", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.2", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/core/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/generator": { + "version": "7.22.9", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.9.tgz", + "integrity": "sha512-KtLMbmicyuK2Ak/FTCJVbDnkN1SlT8/kceFTiuDiiRUUSMnHMidxSCdG4ndkTOHHpoomWe/4xkvHkEOncwjYIw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5", + "@jridgewell/gen-mapping": "^0.3.2", + "@jridgewell/trace-mapping": "^0.3.17", + "jsesc": "^2.5.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.22.9", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", + "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.22.9", + "@babel/helper-validator-option": "^7.22.5", + "browserslist": "^4.21.9", + "lru-cache": "^5.1.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-compilation-targets/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/@babel/helper-environment-visitor": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", + "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-function-name": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.22.5.tgz", + "integrity": "sha512-wtHSq6jMRE3uF2otvfuD3DIvVhOsSNshQl0Qrd7qC9oQJzHvOL4qQXlQn2916+CXGywIjpGuIkoyZRRxHPiNQQ==", + "dev": true, + "dependencies": { + "@babel/template": "^7.22.5", + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-hoist-variables": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", + "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", + "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.22.9", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", + "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.22.5", + "@babel/helper-module-imports": "^7.22.5", + "@babel/helper-simple-access": "^7.22.5", + "@babel/helper-split-export-declaration": "^7.22.6", + "@babel/helper-validator-identifier": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", + "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", + "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-split-export-declaration": { + "version": "7.22.6", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", + "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", + "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz", + "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", + "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.22.6", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", + "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", + "dev": true, + "dependencies": { + "@babel/template": "^7.22.5", + "@babel/traverse": "^7.22.6", + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.5.tgz", + "integrity": "sha512-BSKlD1hgnedS5XRnGOljZawtag7H1yPfQp0tdNJCHoH6AZ+Pcm9VvkrK59/Yy593Ypg0zMxH2BxD1VPYUQ7UIw==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.22.5", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight/node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/@babel/highlight/node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "node_modules/@babel/highlight/node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/@babel/highlight/node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/parser": { + "version": "7.22.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.7.tgz", + "integrity": "sha512-7NF8pOkHP5o2vpmGgNGcfAeCvOYhGLyA3Z4eBQkT1RJlWu47n63bCs93QfJ2hIAFCil7L5P2IWhs1oToVgrL0Q==", + "dev": true, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-bigint": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", + "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.12.13" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-meta": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", + "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-typescript": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.22.5.tgz", + "integrity": "sha512-1mS2o03i7t1c6VzH6fdQ3OA8tcEIxwG18zIPRp+UY1Ihv6W+XZzBCVxExF9upussPXJ0xE9XRHwMoNs1ep/nRQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/template": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz", + "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.22.5", + "@babel/parser": "^7.22.5", + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.22.8", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.8.tgz", + "integrity": "sha512-y6LPR+wpM2I3qJrsheCTwhIinzkETbplIgPBbwvqPKc+uljeA5gP+3nP8irdYt1mjQaDnlIcG+dw8OjAco4GXw==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.22.5", + "@babel/generator": "^7.22.7", + "@babel/helper-environment-visitor": "^7.22.5", + "@babel/helper-function-name": "^7.22.5", + "@babel/helper-hoist-variables": "^7.22.5", + "@babel/helper-split-export-declaration": "^7.22.6", + "@babel/parser": "^7.22.7", + "@babel/types": "^7.22.5", + "debug": "^4.1.0", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse/node_modules/globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/types": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.5.tgz", + "integrity": "sha512-zo3MIHGOkPOfoRXitsgHLjEXmlDaD/5KU1Uzuc9GNiZPhSqVxVRtxuPaSBZDsYZ9qV88AjtMtWW7ww98loJ9KA==", + "dev": true, + "dependencies": { + "@babel/helper-string-parser": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.5", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@bcoe/v8-coverage": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", + "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", + "dev": true + }, + "node_modules/@esbuild/android-arm": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", + "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", + "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", + "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", + "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", + "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", + "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", + "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", + "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", + "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", + "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", + "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", + "cpu": [ + "loong64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", + "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", + "cpu": [ + "mips64el" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", + "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", + "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", + "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", + "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", + "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", + "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", + "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", + "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", + "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", + "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.6.2.tgz", + "integrity": "sha512-pPTNuaAG3QMH+buKyBIGJs3g/S5y0caxw0ygM3YyE6yJFySwiGGSzA+mM3KJ8QQvzeLh3blwgSonkFjgQdxzMw==", + "dev": true, + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.1.tgz", + "integrity": "sha512-9t7ZA7NGGK8ckelF0PQCfcxIUzs1Md5rrO6U/c+FIQNanea5UZC0wqKXH4vHBccmu4ZJgZ2idtPeW7+Q2npOEA==", + "dev": true, + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.6.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/js": { + "version": "8.46.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.46.0.tgz", + "integrity": "sha512-a8TLtmPi8xzPkCbp/OGFUo5yhRkHM2Ko9kOWP4znJr0WAhWyThaw3PnwX4vOTWOAMsV2uRt32PPDcEz63esSaA==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/@humanwhocodes/config-array": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.10.tgz", + "integrity": "sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==", + "dev": true, + "dependencies": { + "@humanwhocodes/object-schema": "^1.2.1", + "debug": "^4.1.1", + "minimatch": "^3.0.5" + }, + "engines": { + "node": ">=10.10.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/object-schema": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", + "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", + "dev": true + }, + "node_modules/@istanbuljs/load-nyc-config": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", + "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", + "dev": true, + "dependencies": { + "camelcase": "^5.3.1", + "find-up": "^4.1.0", + "get-package-type": "^0.1.0", + "js-yaml": "^3.13.1", + "resolve-from": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "dependencies": { + "sprintf-js": "~1.0.2" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "dev": true, + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dev": true, + "dependencies": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "dev": true, + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "dev": true, + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "dev": true, + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/load-nyc-config/node_modules/resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/schema": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", + "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/@jest/console": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-27.5.1.tgz", + "integrity": "sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "jest-message-util": "^27.5.1", + "jest-util": "^27.5.1", + "slash": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/core": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-27.5.1.tgz", + "integrity": "sha512-AK6/UTrvQD0Cd24NSqmIA6rKsu0tKIxfiCducZvqxYdmMisOYAsdItspT+fQDQYARPf8XgjAFZi0ogW2agH5nQ==", + "dev": true, + "dependencies": { + "@jest/console": "^27.5.1", + "@jest/reporters": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "ansi-escapes": "^4.2.1", + "chalk": "^4.0.0", + "emittery": "^0.8.1", + "exit": "^0.1.2", + "graceful-fs": "^4.2.9", + "jest-changed-files": "^27.5.1", + "jest-config": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-resolve-dependencies": "^27.5.1", + "jest-runner": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "jest-watcher": "^27.5.1", + "micromatch": "^4.0.4", + "rimraf": "^3.0.0", + "slash": "^3.0.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/@jest/environment": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-27.5.1.tgz", + "integrity": "sha512-/WQjhPJe3/ghaol/4Bq480JKXV/Rfw8nQdN7f41fM8VDHLcxKXou6QyXAh3EFr9/bVG3x74z1NWDkP87EiY8gA==", + "dev": true, + "dependencies": { + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/fake-timers": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-27.5.1.tgz", + "integrity": "sha512-/aPowoolwa07k7/oM3aASneNeBGCmGQsc3ugN4u6s4C/+s5M64MFo/+djTdiwcbQlRfFElGuDXWzaWj6QgKObQ==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@sinonjs/fake-timers": "^8.0.1", + "@types/node": "*", + "jest-message-util": "^27.5.1", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/globals": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-27.5.1.tgz", + "integrity": "sha512-ZEJNB41OBQQgGzgyInAv0UUfDDj3upmHydjieSxFvTRuZElrx7tXg/uVQ5hYVEwiXs3+aMsAeEc9X7xiSKCm4Q==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/types": "^27.5.1", + "expect": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/reporters": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-27.5.1.tgz", + "integrity": "sha512-cPXh9hWIlVJMQkVk84aIvXuBB4uQQmFqZiacloFuGiP3ah1sbCxCosidXFDfqG8+6fO1oR2dTJTlsOy4VFmUfw==", + "dev": true, + "dependencies": { + "@bcoe/v8-coverage": "^0.2.3", + "@jest/console": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "collect-v8-coverage": "^1.0.0", + "exit": "^0.1.2", + "glob": "^7.1.2", + "graceful-fs": "^4.2.9", + "istanbul-lib-coverage": "^3.0.0", + "istanbul-lib-instrument": "^5.1.0", + "istanbul-lib-report": "^3.0.0", + "istanbul-lib-source-maps": "^4.0.0", + "istanbul-reports": "^3.1.3", + "jest-haste-map": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "slash": "^3.0.0", + "source-map": "^0.6.0", + "string-length": "^4.0.1", + "terminal-link": "^2.0.0", + "v8-to-istanbul": "^8.1.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/@jest/source-map": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-27.5.1.tgz", + "integrity": "sha512-y9NIHUYF3PJRlHk98NdC/N1gl88BL08aQQgu4k4ZopQkCw9t9cV8mtl3TV8b/YCB8XaVTFrmUTAJvjsntDireg==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0", + "graceful-fs": "^4.2.9", + "source-map": "^0.6.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/test-result": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-27.5.1.tgz", + "integrity": "sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag==", + "dev": true, + "dependencies": { + "@jest/console": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/istanbul-lib-coverage": "^2.0.0", + "collect-v8-coverage": "^1.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/test-sequencer": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-27.5.1.tgz", + "integrity": "sha512-LCheJF7WB2+9JuCS7VB/EmGIdQuhtqjRNI9A43idHv3E4KltCTsPsLxvdaubFHSYwY/fNjMWjl6vNRhDiN7vpQ==", + "dev": true, + "dependencies": { + "@jest/test-result": "^27.5.1", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-runtime": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/transform": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-27.5.1.tgz", + "integrity": "sha512-ipON6WtYgl/1329g5AIJVbUuEh0wZVbdpGwC99Jw4LwuoBNS95MVphU6zOeD9pDkon+LLbFL7lOQRapbB8SCHw==", + "dev": true, + "dependencies": { + "@babel/core": "^7.1.0", + "@jest/types": "^27.5.1", + "babel-plugin-istanbul": "^6.1.1", + "chalk": "^4.0.0", + "convert-source-map": "^1.4.0", + "fast-json-stable-stringify": "^2.0.0", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-util": "^27.5.1", + "micromatch": "^4.0.4", + "pirates": "^4.0.4", + "slash": "^3.0.0", + "source-map": "^0.6.1", + "write-file-atomic": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/types": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", + "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^16.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", + "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", + "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.15", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.18", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", + "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "3.1.0", + "@jridgewell/sourcemap-codec": "1.4.14" + } + }, + "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true + }, + "node_modules/@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@sinonjs/commons": { + "version": "1.8.6", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.6.tgz", + "integrity": "sha512-Ky+XkAkqPZSm3NLBeUng77EBQl3cmeJhITaGHdYH8kjVB+aun3S4XBRti2zt17mtt0mIUDiNxYeoJm6drVvBJQ==", + "dev": true, + "dependencies": { + "type-detect": "4.0.8" + } + }, + "node_modules/@sinonjs/fake-timers": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz", + "integrity": "sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg==", + "dev": true, + "dependencies": { + "@sinonjs/commons": "^1.7.0" + } + }, + "node_modules/@tootallnate/once": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", + "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/@types/babel__core": { + "version": "7.20.1", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.1.tgz", + "integrity": "sha512-aACu/U/omhdk15O4Nfb+fHgH/z3QsfQzpnvRZhYhThms83ZnAOZz7zZAWO7mn2yyNQaA4xTO8GLK3uqFU4bYYw==", + "dev": true, + "dependencies": { + "@babel/parser": "^7.20.7", + "@babel/types": "^7.20.7", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } + }, + "node_modules/@types/babel__generator": { + "version": "7.6.4", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", + "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.0.0" + } + }, + "node_modules/@types/babel__template": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", + "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", + "dev": true, + "dependencies": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" + } + }, + "node_modules/@types/babel__traverse": { + "version": "7.20.1", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.1.tgz", + "integrity": "sha512-MitHFXnhtgwsGZWtT68URpOvLN4EREih1u3QtQiN4VdAxWKRVvGCSvw/Qth0M0Qq3pJpnGOu5JaM/ydK7OGbqg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.20.7" + } + }, + "node_modules/@types/graceful-fs": { + "version": "4.1.6", + "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", + "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/istanbul-lib-coverage": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", + "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", + "dev": true + }, + "node_modules/@types/istanbul-lib-report": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", + "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-coverage": "*" + } + }, + "node_modules/@types/istanbul-reports": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", + "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-report": "*" + } + }, + "node_modules/@types/jest": { + "version": "27.5.2", + "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.5.2.tgz", + "integrity": "sha512-mpT8LJJ4CMeeahobofYWIjFo0xonRS/HfxnVEPMPFSQdGUt1uHCnoPT7Zhb+sjDU2wz0oKV0OLUR0WzrHNgfeA==", + "dev": true, + "dependencies": { + "jest-matcher-utils": "^27.0.0", + "pretty-format": "^27.0.0" + } + }, + "node_modules/@types/json-schema": { + "version": "7.0.12", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.12.tgz", + "integrity": "sha512-Hr5Jfhc9eYOQNPYO5WLDq/n4jqijdHNlDXjuAQkkt+mWdQR+XJToOHrsD4cPaMXpn6KO7y2+wM8AZEs8VpBLVA==", + "dev": true + }, + "node_modules/@types/json5": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", + "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", + "dev": true + }, + "node_modules/@types/node": { + "version": "17.0.45", + "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.45.tgz", + "integrity": "sha512-w+tIMs3rq2afQdsPJlODhoUEKzFP1ayaoyl1CcnwtIlsVe7K7bA1NGm4s3PraqTLlXnbIN84zuBlxBWo1u9BLw==", + "dev": true + }, + "node_modules/@types/prettier": { + "version": "2.7.3", + "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.3.tgz", + "integrity": "sha512-+68kP9yzs4LMp7VNh8gdzMSPZFL44MLGqiHWvttYJe+6qnuVr4Ek9wSBQoveqY/r+LwjCcU29kNVkidwim+kYA==", + "dev": true + }, + "node_modules/@types/semver": { + "version": "7.5.0", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.0.tgz", + "integrity": "sha512-G8hZ6XJiHnuhQKR7ZmysCeJWE08o8T0AXtk5darsCaTVsYZhhgUrq53jizaR2FvsoeCwJhlmwTjkXBY5Pn/ZHw==", + "dev": true + }, + "node_modules/@types/stack-utils": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", + "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", + "dev": true + }, + "node_modules/@types/yargs": { + "version": "16.0.5", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.5.tgz", + "integrity": "sha512-AxO/ADJOBFJScHbWhq2xAhlWP24rY4aCEG/NFaMvbT3X2MgRsLjhjQwsn0Zi5zn0LG9jUhCCZMeX9Dkuw6k+vQ==", + "dev": true, + "dependencies": { + "@types/yargs-parser": "*" + } + }, + "node_modules/@types/yargs-parser": { + "version": "21.0.0", + "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", + "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", + "dev": true + }, + "node_modules/@typescript-eslint/eslint-plugin": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.62.0.tgz", + "integrity": "sha512-TiZzBSJja/LbhNPvk6yc0JrX9XqhQ0hdh6M2svYfsHGejaKFIAGd9MQ+ERIMzLGlN/kZoYIgdxFV0PuljTKXag==", + "dev": true, + "dependencies": { + "@eslint-community/regexpp": "^4.4.0", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/type-utils": "5.62.0", + "@typescript-eslint/utils": "5.62.0", + "debug": "^4.3.4", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "natural-compare-lite": "^1.4.0", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "@typescript-eslint/parser": "^5.0.0", + "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/parser": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.62.0.tgz", + "integrity": "sha512-VlJEV0fOQ7BExOsHYAGrgbEiZoi8D+Bl2+f6V2RrXerRSylnp+ZBHmPvaIa8cz0Ajx7WO7Z5RqfgYg7ED1nRhA==", + "dev": true, + "dependencies": { + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/typescript-estree": "5.62.0", + "debug": "^4.3.4" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/scope-manager": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz", + "integrity": "sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/type-utils": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.62.0.tgz", + "integrity": "sha512-xsSQreu+VnfbqQpW5vnCJdq1Z3Q0U31qiWmRhr98ONQmcp/yhiPJFPq8MXiJVLiksmOKSjIldZzkebzHuCGzew==", + "dev": true, + "dependencies": { + "@typescript-eslint/typescript-estree": "5.62.0", + "@typescript-eslint/utils": "5.62.0", + "debug": "^4.3.4", + "tsutils": "^3.21.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "*" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/types": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.62.0.tgz", + "integrity": "sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/typescript-estree": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz", + "integrity": "sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/visitor-keys": "5.62.0", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/utils": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.62.0.tgz", + "integrity": "sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ==", + "dev": true, + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@types/json-schema": "^7.0.9", + "@types/semver": "^7.3.12", + "@typescript-eslint/scope-manager": "5.62.0", + "@typescript-eslint/types": "5.62.0", + "@typescript-eslint/typescript-estree": "5.62.0", + "eslint-scope": "^5.1.1", + "semver": "^7.3.7" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/@typescript-eslint/visitor-keys": { + "version": "5.62.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz", + "integrity": "sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "5.62.0", + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/abab": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", + "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", + "dev": true + }, + "node_modules/acorn": { + "version": "8.10.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", + "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-globals": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz", + "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==", + "dev": true, + "dependencies": { + "acorn": "^7.1.1", + "acorn-walk": "^7.1.1" + } + }, + "node_modules/acorn-globals/node_modules/acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true, + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", + "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "dev": true, + "dependencies": { + "debug": "4" + }, + "engines": { + "node": ">= 6.0.0" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.21.3" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-escapes/node_modules/type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/any-promise": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", + "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==", + "dev": true + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", + "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "is-array-buffer": "^3.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-includes": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.6.tgz", + "integrity": "sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "get-intrinsic": "^1.1.3", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-union": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", + "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/array.prototype.findlastindex": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.2.tgz", + "integrity": "sha512-tb5thFFlUcp7NdNF6/MpDk/1r/4awWG1FIz3YqDf+/zJSTezBb+/5WViH41obXULHVpDzoiCLpJ/ZO9YbJMsdw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0", + "get-intrinsic": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flat": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.1.tgz", + "integrity": "sha512-roTU0KWIOmJ4DRLmwKd19Otg0/mT3qPNt0Qb3GWW8iObuZXxrjB/pzn0R3hqpRSWg4HCwqx+0vwOnWnvlOyeIA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flatmap": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz", + "integrity": "sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.1.tgz", + "integrity": "sha512-09x0ZWFEjj4WD8PDbykUwo3t9arLn8NIzmmYEJFpYekOAQjpkGSyrQhNoRTcwwcFRu+ycWF78QZ63oWTqSjBcw==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.0", + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "get-intrinsic": "^1.2.1", + "is-array-buffer": "^3.0.2", + "is-shared-array-buffer": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "dev": true + }, + "node_modules/available-typed-arrays": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", + "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/babel-jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-27.5.1.tgz", + "integrity": "sha512-cdQ5dXjGRd0IBRATiQ4mZGlGlRE8kJpjPOixdNRdT+m3UcNqmYWN6rK6nvtXYfY3D76cb8s/O1Ss8ea24PIwcg==", + "dev": true, + "dependencies": { + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/babel__core": "^7.1.14", + "babel-plugin-istanbul": "^6.1.1", + "babel-preset-jest": "^27.5.1", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "slash": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.8.0" + } + }, + "node_modules/babel-plugin-istanbul": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", + "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.0.0", + "@istanbuljs/load-nyc-config": "^1.0.0", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-instrument": "^5.0.4", + "test-exclude": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/babel-plugin-jest-hoist": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.1.tgz", + "integrity": "sha512-50wCwD5EMNW4aRpOwtqzyZHIewTYNxLA4nhB+09d8BIssfNfzBRhkBIHiaPv1Si226TQSvp8gxAJm2iY2qs2hQ==", + "dev": true, + "dependencies": { + "@babel/template": "^7.3.3", + "@babel/types": "^7.3.3", + "@types/babel__core": "^7.0.0", + "@types/babel__traverse": "^7.0.6" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/babel-preset-current-node-syntax": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", + "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-bigint": "^7.8.3", + "@babel/plugin-syntax-class-properties": "^7.8.3", + "@babel/plugin-syntax-import-meta": "^7.8.3", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.8.3", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-top-level-await": "^7.8.3" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/babel-preset-jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-27.5.1.tgz", + "integrity": "sha512-Nptf2FzlPCWYuJg41HBqXVT8ym6bXOevuCTbhxlUpjwtysGaIWFvDEjp4y+G7fl13FgOdjs7P/DmErqH7da0Ag==", + "dev": true, + "dependencies": { + "babel-plugin-jest-hoist": "^27.5.1", + "babel-preset-current-node-syntax": "^1.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "node_modules/binary-extensions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", + "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "dependencies": { + "fill-range": "^7.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/browser-process-hrtime": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", + "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", + "dev": true + }, + "node_modules/browserslist": { + "version": "4.21.10", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.10.tgz", + "integrity": "sha512-bipEBdZfVH5/pwrvqc+Ub0kUPVfGUhlKxbvfD+z1BDnPEO/X98ruXGA1WP5ASpAFKan7Qr6j736IacbZQuAlKQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "caniuse-lite": "^1.0.30001517", + "electron-to-chromium": "^1.4.477", + "node-releases": "^2.0.13", + "update-browserslist-db": "^1.0.11" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/bs-logger": { + "version": "0.2.6", + "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz", + "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==", + "dev": true, + "dependencies": { + "fast-json-stable-stringify": "2.x" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/bser": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", + "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", + "dev": true, + "dependencies": { + "node-int64": "^0.4.0" + } + }, + "node_modules/buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", + "dev": true + }, + "node_modules/bundle-require": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/bundle-require/-/bundle-require-4.0.1.tgz", + "integrity": "sha512-9NQkRHlNdNpDBGmLpngF3EFDcwodhMUuLz9PaWYciVcQF9SE4LFjM2DB/xV1Li5JiuDMv7ZUWuC3rGbqR0MAXQ==", + "dev": true, + "dependencies": { + "load-tsconfig": "^0.2.3" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "peerDependencies": { + "esbuild": ">=0.17" + } + }, + "node_modules/cac": { + "version": "6.7.14", + "resolved": "https://registry.npmjs.org/cac/-/cac-6.7.14.tgz", + "integrity": "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001518", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001518.tgz", + "integrity": "sha512-rup09/e3I0BKjncL+FesTayKtPrdwKhUufQFd3riFw1hHg8JmIFoInYfB102cFcY/pPgGmdyl/iy+jgiDi2vdA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ] + }, + "node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/char-regex": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", + "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/chokidar": { + "version": "3.5.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", + "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ], + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/chokidar/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/ci-info": { + "version": "3.8.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", + "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/sibiraj-s" + } + ], + "engines": { + "node": ">=8" + } + }, + "node_modules/cjs-module-lexer": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz", + "integrity": "sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==", + "dev": true + }, + "node_modules/cliui": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", + "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", + "dev": true, + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^7.0.0" + } + }, + "node_modules/co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", + "dev": true, + "engines": { + "iojs": ">= 1.0.0", + "node": ">= 0.12.0" + } + }, + "node_modules/collect-v8-coverage": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.2.tgz", + "integrity": "sha512-lHl4d5/ONEbLlJvaJNtsF/Lz+WvB07u2ycqTYbdrq7UypDXailES4valYb2eWiJFxZlVmpGekfqoxQhzyFdT4Q==", + "dev": true + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commander": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", + "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "node_modules/confusing-browser-globals": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.11.tgz", + "integrity": "sha512-JsPKdmh8ZkmnHxDk55FZ1TqVLvEQTvoByJZRN9jzI0UjxK/QgAmsphz7PGtqgPieQZ/CQcHWXCR7ATDNhGe+YA==", + "dev": true + }, + "node_modules/convert-source-map": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "dev": true + }, + "node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/cssom": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", + "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", + "dev": true + }, + "node_modules/cssstyle": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", + "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", + "dev": true, + "dependencies": { + "cssom": "~0.3.6" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cssstyle/node_modules/cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", + "dev": true + }, + "node_modules/data-urls": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz", + "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==", + "dev": true, + "dependencies": { + "abab": "^2.0.3", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^8.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/decimal.js": { + "version": "10.4.3", + "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.4.3.tgz", + "integrity": "sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==", + "dev": true + }, + "node_modules/dedent": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", + "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", + "dev": true + }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "node_modules/deepmerge": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", + "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/define-properties": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.0.tgz", + "integrity": "sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA==", + "dev": true, + "dependencies": { + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/detect-newline": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", + "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/diff-sequences": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", + "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", + "dev": true, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/dir-glob": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", + "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", + "dev": true, + "dependencies": { + "path-type": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/domexception": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz", + "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==", + "dev": true, + "dependencies": { + "webidl-conversions": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/domexception/node_modules/webidl-conversions": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz", + "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/electron-to-chromium": { + "version": "1.4.478", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.478.tgz", + "integrity": "sha512-qjTA8djMXd+ruoODDFGnRCRBpID+AAfYWCyGtYTNhsuwxI19s8q19gbjKTwRS5z/LyVf5wICaIiPQGLekmbJbA==", + "dev": true + }, + "node_modules/emittery": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", + "integrity": "sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/emittery?sponsor=1" + } + }, + "node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/es-abstract": { + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.1.tgz", + "integrity": "sha512-ioRRcXMO6OFyRpyzV3kE1IIBd4WG5/kltnzdxSCqoP8CMGs/Li+M1uF5o7lOkZVFjDs+NLesthnF66Pg/0q0Lw==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.0", + "arraybuffer.prototype.slice": "^1.0.1", + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "es-set-tostringtag": "^2.0.1", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.5", + "get-intrinsic": "^1.2.1", + "get-symbol-description": "^1.0.0", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has": "^1.0.3", + "has-property-descriptors": "^1.0.0", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.5", + "is-array-buffer": "^3.0.2", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.2", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.2", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.10", + "is-weakref": "^1.0.2", + "object-inspect": "^1.12.3", + "object-keys": "^1.1.1", + "object.assign": "^4.1.4", + "regexp.prototype.flags": "^1.5.0", + "safe-array-concat": "^1.0.0", + "safe-regex-test": "^1.0.0", + "string.prototype.trim": "^1.2.7", + "string.prototype.trimend": "^1.0.6", + "string.prototype.trimstart": "^1.0.6", + "typed-array-buffer": "^1.0.0", + "typed-array-byte-length": "^1.0.0", + "typed-array-byte-offset": "^1.0.0", + "typed-array-length": "^1.0.4", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-set-tostringtag": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz", + "integrity": "sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3", + "has": "^1.0.3", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-shim-unscopables": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", + "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", + "dev": true, + "dependencies": { + "has": "^1.0.3" + } + }, + "node_modules/es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/esbuild": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", + "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", + "dev": true, + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/android-arm": "0.17.19", + "@esbuild/android-arm64": "0.17.19", + "@esbuild/android-x64": "0.17.19", + "@esbuild/darwin-arm64": "0.17.19", + "@esbuild/darwin-x64": "0.17.19", + "@esbuild/freebsd-arm64": "0.17.19", + "@esbuild/freebsd-x64": "0.17.19", + "@esbuild/linux-arm": "0.17.19", + "@esbuild/linux-arm64": "0.17.19", + "@esbuild/linux-ia32": "0.17.19", + "@esbuild/linux-loong64": "0.17.19", + "@esbuild/linux-mips64el": "0.17.19", + "@esbuild/linux-ppc64": "0.17.19", + "@esbuild/linux-riscv64": "0.17.19", + "@esbuild/linux-s390x": "0.17.19", + "@esbuild/linux-x64": "0.17.19", + "@esbuild/netbsd-x64": "0.17.19", + "@esbuild/openbsd-x64": "0.17.19", + "@esbuild/sunos-x64": "0.17.19", + "@esbuild/win32-arm64": "0.17.19", + "@esbuild/win32-ia32": "0.17.19", + "@esbuild/win32-x64": "0.17.19" + } + }, + "node_modules/escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/escodegen": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.1.0.tgz", + "integrity": "sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==", + "dev": true, + "dependencies": { + "esprima": "^4.0.1", + "estraverse": "^5.2.0", + "esutils": "^2.0.2" + }, + "bin": { + "escodegen": "bin/escodegen.js", + "esgenerate": "bin/esgenerate.js" + }, + "engines": { + "node": ">=6.0" + }, + "optionalDependencies": { + "source-map": "~0.6.1" + } + }, + "node_modules/escodegen/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/eslint": { + "version": "8.46.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.46.0.tgz", + "integrity": "sha512-cIO74PvbW0qU8e0mIvk5IV3ToWdCq5FYG6gWPHHkx6gNdjlbAYvtfHmlCMXxjcoVaIdwy/IAt3+mDkZkfvb2Dg==", + "dev": true, + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.1", + "@eslint/js": "^8.46.0", + "@humanwhocodes/config-array": "^0.11.10", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "doctrine": "^3.0.0", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.2", + "espree": "^9.6.1", + "esquery": "^1.4.2", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "js-yaml": "^4.1.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "strip-ansi": "^6.0.1", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-config-airbnb-base": { + "version": "15.0.0", + "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", + "integrity": "sha512-xaX3z4ZZIcFLvh2oUNvcX5oEofXda7giYmuplVxoOg5A7EXJMrUyqRgR+mhDhPK8LZ4PttFOBvCYDbX3sUoUig==", + "dev": true, + "dependencies": { + "confusing-browser-globals": "^1.0.10", + "object.assign": "^4.1.2", + "object.entries": "^1.1.5", + "semver": "^6.3.0" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + }, + "peerDependencies": { + "eslint": "^7.32.0 || ^8.2.0", + "eslint-plugin-import": "^2.25.2" + } + }, + "node_modules/eslint-config-airbnb-base/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/eslint-config-airbnb-typescript": { + "version": "17.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-airbnb-typescript/-/eslint-config-airbnb-typescript-17.1.0.tgz", + "integrity": "sha512-GPxI5URre6dDpJ0CtcthSZVBAfI+Uw7un5OYNVxP2EYi3H81Jw701yFP7AU+/vCE7xBtFmjge7kfhhk4+RAiig==", + "dev": true, + "dependencies": { + "eslint-config-airbnb-base": "^15.0.0" + }, + "peerDependencies": { + "@typescript-eslint/eslint-plugin": "^5.13.0 || ^6.0.0", + "@typescript-eslint/parser": "^5.0.0 || ^6.0.0", + "eslint": "^7.32.0 || ^8.2.0", + "eslint-plugin-import": "^2.25.3" + } + }, + "node_modules/eslint-config-prettier": { + "version": "8.9.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.9.0.tgz", + "integrity": "sha512-+sbni7NfVXnOpnRadUA8S28AUlsZt9GjgFvABIRL9Hkn8KqNzOp+7Lw4QWtrwn20KzU3wqu1QoOj2m+7rKRqkA==", + "dev": true, + "bin": { + "eslint-config-prettier": "bin/cli.js" + }, + "peerDependencies": { + "eslint": ">=7.0.0" + } + }, + "node_modules/eslint-import-resolver-node": { + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.7.tgz", + "integrity": "sha512-gozW2blMLJCeFpBwugLTGyvVjNoeo1knonXAcatC6bjPBZitotxdWf7Gimr25N4c0AAOo4eOUfaG82IJPDpqCA==", + "dev": true, + "dependencies": { + "debug": "^3.2.7", + "is-core-module": "^2.11.0", + "resolve": "^1.22.1" + } + }, + "node_modules/eslint-import-resolver-node/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-module-utils": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz", + "integrity": "sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==", + "dev": true, + "dependencies": { + "debug": "^3.2.7" + }, + "engines": { + "node": ">=4" + }, + "peerDependenciesMeta": { + "eslint": { + "optional": true + } + } + }, + "node_modules/eslint-module-utils/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import": { + "version": "2.28.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.28.0.tgz", + "integrity": "sha512-B8s/n+ZluN7sxj9eUf7/pRFERX0r5bnFA2dCaLHy2ZeaQEAz0k+ZZkFWRFHJAqxfxQDx6KLv9LeIki7cFdwW+Q==", + "dev": true, + "dependencies": { + "array-includes": "^3.1.6", + "array.prototype.findlastindex": "^1.2.2", + "array.prototype.flat": "^1.3.1", + "array.prototype.flatmap": "^1.3.1", + "debug": "^3.2.7", + "doctrine": "^2.1.0", + "eslint-import-resolver-node": "^0.3.7", + "eslint-module-utils": "^2.8.0", + "has": "^1.0.3", + "is-core-module": "^2.12.1", + "is-glob": "^4.0.3", + "minimatch": "^3.1.2", + "object.fromentries": "^2.0.6", + "object.groupby": "^1.0.0", + "object.values": "^1.1.6", + "resolve": "^1.22.3", + "semver": "^6.3.1", + "tsconfig-paths": "^3.14.2" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" + } + }, + "node_modules/eslint-plugin-import/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-import/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/eslint-plugin-prettier": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-4.2.1.tgz", + "integrity": "sha512-f/0rXLXUt0oFYs8ra4w49wYZBG5GKZpAYsJSm6rnYL5uVDjd+zowwMwVZHnAjf4edNrKpCDYfXDgmRE/Ak7QyQ==", + "dev": true, + "dependencies": { + "prettier-linter-helpers": "^1.0.0" + }, + "engines": { + "node": ">=12.0.0" + }, + "peerDependencies": { + "eslint": ">=7.28.0", + "prettier": ">=2.0.0" + }, + "peerDependenciesMeta": { + "eslint-config-prettier": { + "optional": true + } + } + }, + "node_modules/eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "3.4.2", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.2.tgz", + "integrity": "sha512-8drBzUEyZ2llkpCA67iYrgEssKDUu68V8ChqqOfFupIaG/LCVPUT+CoGJpT77zJprs4T/W7p07LP7zAIMuweVw==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint/node_modules/eslint-scope": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", + "dev": true, + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/espree": { + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", + "dev": true, + "dependencies": { + "acorn": "^8.9.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true, + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", + "dev": true, + "dependencies": { + "estraverse": "^5.1.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/esquery/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esrecurse/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/execa": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", + "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.0", + "human-signals": "^2.1.0", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.1", + "onetime": "^5.1.2", + "signal-exit": "^3.0.3", + "strip-final-newline": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/execa?sponsor=1" + } + }, + "node_modules/exit": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", + "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/expect": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", + "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "node_modules/fast-diff": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", + "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", + "dev": true + }, + "node_modules/fast-glob": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz", + "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + }, + "engines": { + "node": ">=8.6.0" + } + }, + "node_modules/fast-glob/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "node_modules/fastq": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", + "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", + "dev": true, + "dependencies": { + "reusify": "^1.0.4" + } + }, + "node_modules/fb-watchman": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", + "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", + "dev": true, + "dependencies": { + "bser": "2.1.1" + } + }, + "node_modules/file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "dependencies": { + "flat-cache": "^3.0.4" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "dependencies": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/flat-cache": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", + "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", + "dev": true, + "dependencies": { + "flatted": "^3.1.0", + "rimraf": "^3.0.2" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/flatted": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", + "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", + "dev": true + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/form-data": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", + "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", + "dev": true, + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "node_modules/fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, + "node_modules/function.prototype.name": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", + "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3", + "es-abstract": "^1.19.0", + "functions-have-names": "^1.2.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true, + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", + "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-package-type": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", + "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", + "dev": true, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/get-stream": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", + "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-symbol-description": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", + "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/globals": { + "version": "13.20.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz", + "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.20.2" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/globby": { + "version": "11.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", + "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", + "dev": true, + "dependencies": { + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", + "fast-glob": "^3.2.9", + "ignore": "^5.2.0", + "merge2": "^1.4.1", + "slash": "^3.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "node_modules/graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", + "dev": true + }, + "node_modules/has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.1" + }, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", + "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", + "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/html-encoding-sniffer": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz", + "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==", + "dev": true, + "dependencies": { + "whatwg-encoding": "^1.0.5" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/html-escaper": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", + "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", + "dev": true + }, + "node_modules/http-proxy-agent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", + "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", + "dev": true, + "dependencies": { + "@tootallnate/once": "1", + "agent-base": "6", + "debug": "4" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/https-proxy-agent": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", + "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", + "dev": true, + "dependencies": { + "agent-base": "6", + "debug": "4" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/human-signals": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", + "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", + "dev": true, + "engines": { + "node": ">=10.17.0" + } + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ignore": { + "version": "5.2.4", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", + "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/import-local": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", + "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", + "dev": true, + "dependencies": { + "pkg-dir": "^4.2.0", + "resolve-cwd": "^3.0.0" + }, + "bin": { + "import-local-fixture": "fixtures/cli.js" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dev": true, + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "node_modules/internal-slot": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.5.tgz", + "integrity": "sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.0", + "has": "^1.0.3", + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/is-array-buffer": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", + "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "is-typed-array": "^1.1.10" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "node_modules/is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "dependencies": { + "has-bigints": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-core-module": { + "version": "2.12.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", + "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", + "dev": true, + "dependencies": { + "has": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-generator-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", + "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-negative-zero": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", + "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-potential-custom-element-name": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", + "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", + "dev": true + }, + "node_modules/is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-shared-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", + "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-stream": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", + "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typed-array": { + "version": "1.1.12", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", + "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", + "dev": true, + "dependencies": { + "which-typed-array": "^1.1.11" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==", + "dev": true + }, + "node_modules/is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "node_modules/istanbul-lib-coverage": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", + "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-instrument": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", + "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", + "dev": true, + "dependencies": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-instrument/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/istanbul-lib-report": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", + "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", + "dev": true, + "dependencies": { + "istanbul-lib-coverage": "^3.0.0", + "make-dir": "^4.0.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-lib-source-maps": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", + "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", + "dev": true, + "dependencies": { + "debug": "^4.1.1", + "istanbul-lib-coverage": "^3.0.0", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-reports": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", + "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", + "dev": true, + "dependencies": { + "html-escaper": "^2.0.0", + "istanbul-lib-report": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest/-/jest-27.5.1.tgz", + "integrity": "sha512-Yn0mADZB89zTtjkPJEXwrac3LHudkQMR+Paqa8uxJHCBr9agxztUifWCyiYrjhMPBoUVBjyny0I7XH6ozDr7QQ==", + "dev": true, + "dependencies": { + "@jest/core": "^27.5.1", + "import-local": "^3.0.2", + "jest-cli": "^27.5.1" + }, + "bin": { + "jest": "bin/jest.js" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/jest-changed-files": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-27.5.1.tgz", + "integrity": "sha512-buBLMiByfWGCoMsLLzGUUSpAmIAGnbR2KJoMN10ziLhOLvP4e0SlypHnAel8iqQXTrcbmfEY9sSqae5sgUsTvw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "execa": "^5.0.0", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-circus": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-27.5.1.tgz", + "integrity": "sha512-D95R7x5UtlMA5iBYsOHFFbMD/GVA4R/Kdq15f7xYWUfWHBto9NYRsOvnSauTgdF+ogCpJ4tyKOXhUifxS65gdw==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "co": "^4.6.0", + "dedent": "^0.7.0", + "expect": "^27.5.1", + "is-generator-fn": "^2.0.0", + "jest-each": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "stack-utils": "^2.0.3", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-cli": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-27.5.1.tgz", + "integrity": "sha512-Hc6HOOwYq4/74/c62dEE3r5elx8wjYqxY0r0G/nFrLDPMFRu6RA/u8qINOIkvhxG7mMQ5EJsOGfRpI8L6eFUVw==", + "dev": true, + "dependencies": { + "@jest/core": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "exit": "^0.1.2", + "graceful-fs": "^4.2.9", + "import-local": "^3.0.2", + "jest-config": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "prompts": "^2.0.1", + "yargs": "^16.2.0" + }, + "bin": { + "jest": "bin/jest.js" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/jest-config": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-27.5.1.tgz", + "integrity": "sha512-5sAsjm6tGdsVbW9ahcChPAFCk4IlkQUknH5AvKjuLTSlcO/wCZKyFdn7Rg0EkC+OGgWODEy2hDpWB1PgzH0JNA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.8.0", + "@jest/test-sequencer": "^27.5.1", + "@jest/types": "^27.5.1", + "babel-jest": "^27.5.1", + "chalk": "^4.0.0", + "ci-info": "^3.2.0", + "deepmerge": "^4.2.2", + "glob": "^7.1.1", + "graceful-fs": "^4.2.9", + "jest-circus": "^27.5.1", + "jest-environment-jsdom": "^27.5.1", + "jest-environment-node": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-jasmine2": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-runner": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "micromatch": "^4.0.4", + "parse-json": "^5.2.0", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "ts-node": { + "optional": true + } + } + }, + "node_modules/jest-diff": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", + "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", + "dev": true, + "dependencies": { + "chalk": "^4.0.0", + "diff-sequences": "^27.5.1", + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-docblock": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-27.5.1.tgz", + "integrity": "sha512-rl7hlABeTsRYxKiUfpHrQrG4e2obOiTQWfMEH3PxPjOtdsfLQO4ReWSZaQ7DETm4xu07rl4q/h4zcKXyU0/OzQ==", + "dev": true, + "dependencies": { + "detect-newline": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-each": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-27.5.1.tgz", + "integrity": "sha512-1Ff6p+FbhT/bXQnEouYy00bkNSY7OUpfIcmdl8vZ31A1UUaurOLPA8a8BbJOF2RDUElwJhmeaV7LnagI+5UwNQ==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "jest-get-type": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-environment-jsdom": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-27.5.1.tgz", + "integrity": "sha512-TFBvkTC1Hnnnrka/fUb56atfDtJ9VMZ94JkjTbggl1PEpwrYtUBKMezB3inLmWqQsXYLcMwNoDQwoBTAvFfsfw==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1", + "jsdom": "^16.6.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-environment-node": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-27.5.1.tgz", + "integrity": "sha512-Jt4ZUnxdOsTGwSRAfKEnE6BcwsSPNOijjwifq5sDFSA2kesnXTvNqKHYgM0hDq3549Uf/KzdXNYn4wMZJPlFLw==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-get-type": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", + "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", + "dev": true, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-haste-map": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-27.5.1.tgz", + "integrity": "sha512-7GgkZ4Fw4NFbMSDSpZwXeBiIbx+t/46nJ2QitkOjvwPYyZmqttu2TDSimMHP1EkPOi4xUZAN1doE5Vd25H4Jng==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/graceful-fs": "^4.1.2", + "@types/node": "*", + "anymatch": "^3.0.3", + "fb-watchman": "^2.0.0", + "graceful-fs": "^4.2.9", + "jest-regex-util": "^27.5.1", + "jest-serializer": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "micromatch": "^4.0.4", + "walker": "^1.0.7" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "optionalDependencies": { + "fsevents": "^2.3.2" + } + }, + "node_modules/jest-jasmine2": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-27.5.1.tgz", + "integrity": "sha512-jtq7VVyG8SqAorDpApwiJJImd0V2wv1xzdheGHRGyuT7gZm6gG47QEskOlzsN1PG/6WNaCo5pmwMHDf3AkG2pQ==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/source-map": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "co": "^4.6.0", + "expect": "^27.5.1", + "is-generator-fn": "^2.0.0", + "jest-each": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-leak-detector": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-27.5.1.tgz", + "integrity": "sha512-POXfWAMvfU6WMUXftV4HolnJfnPOGEu10fscNCA76KBpRRhcMN2c8d3iT2pxQS3HLbA+5X4sOUPzYO2NUyIlHQ==", + "dev": true, + "dependencies": { + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-matcher-utils": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", + "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", + "dev": true, + "dependencies": { + "chalk": "^4.0.0", + "jest-diff": "^27.5.1", + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-message-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", + "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.12.13", + "@jest/types": "^27.5.1", + "@types/stack-utils": "^2.0.0", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "micromatch": "^4.0.4", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "stack-utils": "^2.0.3" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-mock": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-27.5.1.tgz", + "integrity": "sha512-K4jKbY1d4ENhbrG2zuPWaQBvDly+iZ2yAW+T1fATN78hc0sInwn7wZB8XtlNnvHug5RMwV897Xm4LqmPM4e2Og==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/node": "*" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-pnp-resolver": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", + "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", + "dev": true, + "engines": { + "node": ">=6" + }, + "peerDependencies": { + "jest-resolve": "*" + }, + "peerDependenciesMeta": { + "jest-resolve": { + "optional": true + } + } + }, + "node_modules/jest-regex-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-27.5.1.tgz", + "integrity": "sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg==", + "dev": true, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-resolve": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-27.5.1.tgz", + "integrity": "sha512-FFDy8/9E6CV83IMbDpcjOhumAQPDyETnU2KZ1O98DwTnz8AOBsW/Xv3GySr1mOZdItLR+zDZ7I/UdTFbgSOVCw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-pnp-resolver": "^1.2.2", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "resolve": "^1.20.0", + "resolve.exports": "^1.1.0", + "slash": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-resolve-dependencies": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.1.tgz", + "integrity": "sha512-QQOOdY4PE39iawDn5rzbIePNigfe5B9Z91GDD1ae/xNDlu9kaat8QQ5EKnNmVWPV54hUdxCVwwj6YMgR2O7IOg==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-snapshot": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-runner": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-27.5.1.tgz", + "integrity": "sha512-g4NPsM4mFCOwFKXO4p/H/kWGdJp9V8kURY2lX8Me2drgXqG7rrZAx5kv+5H7wtt/cdFIjhqYx1HrlqWHaOvDaQ==", + "dev": true, + "dependencies": { + "@jest/console": "^27.5.1", + "@jest/environment": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "emittery": "^0.8.1", + "graceful-fs": "^4.2.9", + "jest-docblock": "^27.5.1", + "jest-environment-jsdom": "^27.5.1", + "jest-environment-node": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-leak-detector": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "source-map-support": "^0.5.6", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-runtime": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-27.5.1.tgz", + "integrity": "sha512-o7gxw3Gf+H2IGt8fv0RiyE1+r83FJBRruoA+FXrlHw6xEyBsU8ugA6IPfTdVyA0w8HClpbK+DGJxH59UrNMx8A==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/globals": "^27.5.1", + "@jest/source-map": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "cjs-module-lexer": "^1.0.0", + "collect-v8-coverage": "^1.0.0", + "execa": "^5.0.0", + "glob": "^7.1.3", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-mock": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "slash": "^3.0.0", + "strip-bom": "^4.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-serializer": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-27.5.1.tgz", + "integrity": "sha512-jZCyo6iIxO1aqUxpuBlwTDMkzOAJS4a3eYz3YzgxxVQFwLeSA7Jfq5cbqCY+JLvTDrWirgusI/0KwxKMgrdf7w==", + "dev": true, + "dependencies": { + "@types/node": "*", + "graceful-fs": "^4.2.9" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-snapshot": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-27.5.1.tgz", + "integrity": "sha512-yYykXI5a0I31xX67mgeLw1DZ0bJB+gpq5IpSuCAoyDi0+BhgU/RIrL+RTzDmkNTchvDFWKP8lp+w/42Z3us5sA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.7.2", + "@babel/generator": "^7.7.2", + "@babel/plugin-syntax-typescript": "^7.7.2", + "@babel/traverse": "^7.7.2", + "@babel/types": "^7.0.0", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/babel__traverse": "^7.0.4", + "@types/prettier": "^2.1.5", + "babel-preset-current-node-syntax": "^1.0.0", + "chalk": "^4.0.0", + "expect": "^27.5.1", + "graceful-fs": "^4.2.9", + "jest-diff": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-util": "^27.5.1", + "natural-compare": "^1.4.0", + "pretty-format": "^27.5.1", + "semver": "^7.3.2" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.1.tgz", + "integrity": "sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "ci-info": "^3.2.0", + "graceful-fs": "^4.2.9", + "picomatch": "^2.2.3" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-validate": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-27.5.1.tgz", + "integrity": "sha512-thkNli0LYTmOI1tDB3FI1S1RTp/Bqyd9pTarJwL87OIBFuqEb5Apv5EaApEudYg4g86e3CT6kM0RowkhtEnCBQ==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "camelcase": "^6.2.0", + "chalk": "^4.0.0", + "jest-get-type": "^27.5.1", + "leven": "^3.1.0", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-validate/node_modules/camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/jest-watcher": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-27.5.1.tgz", + "integrity": "sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw==", + "dev": true, + "dependencies": { + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "ansi-escapes": "^4.2.1", + "chalk": "^4.0.0", + "jest-util": "^27.5.1", + "string-length": "^4.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-worker": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", + "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", + "dev": true, + "dependencies": { + "@types/node": "*", + "merge-stream": "^2.0.0", + "supports-color": "^8.0.0" + }, + "engines": { + "node": ">= 10.13.0" + } + }, + "node_modules/jest-worker/node_modules/supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/supports-color?sponsor=1" + } + }, + "node_modules/joycon": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/joycon/-/joycon-3.1.1.tgz", + "integrity": "sha512-34wB/Y7MW7bzjKRjUKTa46I2Z7eV62Rkhva+KkopW7Qvv/OSWBqvkSY7vusOPrNuZcUG3tApvdVgNB8POj3SPw==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsdom": { + "version": "16.7.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.7.0.tgz", + "integrity": "sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==", + "dev": true, + "dependencies": { + "abab": "^2.0.5", + "acorn": "^8.2.4", + "acorn-globals": "^6.0.0", + "cssom": "^0.4.4", + "cssstyle": "^2.3.0", + "data-urls": "^2.0.0", + "decimal.js": "^10.2.1", + "domexception": "^2.0.1", + "escodegen": "^2.0.0", + "form-data": "^3.0.0", + "html-encoding-sniffer": "^2.0.1", + "http-proxy-agent": "^4.0.1", + "https-proxy-agent": "^5.0.0", + "is-potential-custom-element-name": "^1.0.1", + "nwsapi": "^2.2.0", + "parse5": "6.0.1", + "saxes": "^5.0.1", + "symbol-tree": "^3.2.4", + "tough-cookie": "^4.0.0", + "w3c-hr-time": "^1.0.2", + "w3c-xmlserializer": "^2.0.0", + "webidl-conversions": "^6.1.0", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^8.5.0", + "ws": "^7.4.6", + "xml-name-validator": "^3.0.0" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "canvas": "^2.5.0" + }, + "peerDependenciesMeta": { + "canvas": { + "optional": true + } + } + }, + "node_modules/jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "node_modules/json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", + "dev": true + }, + "node_modules/json5": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/kleur": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", + "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/leven": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", + "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/lilconfig": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", + "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/lines-and-columns": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", + "dev": true + }, + "node_modules/load-tsconfig": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/load-tsconfig/-/load-tsconfig-0.2.5.tgz", + "integrity": "sha512-IXO6OCs9yg8tMKzfPZ1YmheJbZCiEsnBdcB03l0OcfK9prKnJb96siuHCr5Fl37/yo9DnKU+TLpxzTUspw9shg==", + "dev": true, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + } + }, + "node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "node_modules/lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==", + "dev": true + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "node_modules/lodash.sortby": { + "version": "4.7.0", + "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", + "integrity": "sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA==", + "dev": true + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/make-dir": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", + "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", + "dev": true, + "dependencies": { + "semver": "^7.5.3" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/make-error": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", + "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", + "dev": true + }, + "node_modules/makeerror": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", + "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", + "dev": true, + "dependencies": { + "tmpl": "1.0.5" + } + }, + "node_modules/merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", + "dev": true + }, + "node_modules/merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/micromatch": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", + "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", + "dev": true, + "dependencies": { + "braces": "^3.0.2", + "picomatch": "^2.3.1" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dev": true, + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", + "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/mz": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", + "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", + "dev": true, + "dependencies": { + "any-promise": "^1.0.0", + "object-assign": "^4.0.1", + "thenify-all": "^1.0.0" + } + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "node_modules/natural-compare-lite": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz", + "integrity": "sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==", + "dev": true + }, + "node_modules/nock": { + "version": "13.3.2", + "resolved": "https://registry.npmjs.org/nock/-/nock-13.3.2.tgz", + "integrity": "sha512-CwbljitiWJhF1gL83NbanhoKs1l23TDlRioNraPTZrzZIEooPemrHRj5m0FZCPkB1ecdYCSWWGcHysJgX/ngnQ==", + "dev": true, + "dependencies": { + "debug": "^4.1.0", + "json-stringify-safe": "^5.0.1", + "lodash": "^4.17.21", + "propagate": "^2.0.0" + }, + "engines": { + "node": ">= 10.13" + } + }, + "node_modules/node-int64": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", + "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", + "dev": true + }, + "node_modules/node-releases": { + "version": "2.0.13", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", + "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==", + "dev": true + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "dependencies": { + "path-key": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/nwsapi": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.7.tgz", + "integrity": "sha512-ub5E4+FBPKwAZx0UwIQOjYWGHTEq5sPqHQNRN8Z9e4A7u3Tj1weLJsL59yH9vmvqEtBHaOmT6cYQKIZOxp35FQ==", + "dev": true + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.12.3", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", + "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.assign": { + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", + "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.entries": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.6.tgz", + "integrity": "sha512-leTPzo4Zvg3pmbQ3rDK69Rl8GQvIqMWubrkxONG9/ojtFE2rD9fjMKfSI5BxW3osRH1m6VdzmqK8oAY9aT4x5w==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.fromentries": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.6.tgz", + "integrity": "sha512-VciD13dswC4j1Xt5394WR4MzmAQmlgN72phd/riNp9vtD7tp4QQWJ0R4wvclXcafgcYK8veHRed2W6XeGBvcfg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.groupby": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.0.tgz", + "integrity": "sha512-70MWG6NfRH9GnbZOikuhPPYzpUpof9iW2J9E4dW7FXTqPNb6rllE6u39SKwwiNh8lCwX3DDb5OgcKGiEBrTTyw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.21.2", + "get-intrinsic": "^1.2.1" + } + }, + "node_modules/object.values": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.6.tgz", + "integrity": "sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "dev": true, + "dependencies": { + "mimic-fn": "^2.1.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/optionator": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", + "dev": true, + "dependencies": { + "@aashutoshrathi/word-wrap": "^1.2.3", + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "dependencies": { + "yocto-queue": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/parse5": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", + "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", + "dev": true + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/picocolors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pirates": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", + "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "dev": true, + "dependencies": { + "find-up": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pkg-dir/node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "dev": true, + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pkg-dir/node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "dev": true, + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pkg-dir/node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "dev": true, + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/pkg-dir/node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "dev": true, + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/postcss-load-config": { + "version": "3.1.4", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-3.1.4.tgz", + "integrity": "sha512-6DiM4E7v4coTE4uzA8U//WhtPwyhiim3eyjEMFCnUpzbrkK9wJHgKDT2mR+HbtSrd/NubVaYTOpSpjUl8NQeRg==", + "dev": true, + "dependencies": { + "lilconfig": "^2.0.5", + "yaml": "^1.10.2" + }, + "engines": { + "node": ">= 10" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": ">=8.0.9", + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "postcss": { + "optional": true + }, + "ts-node": { + "optional": true + } + } + }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/prettier": { + "version": "2.8.8", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", + "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==", + "dev": true, + "bin": { + "prettier": "bin-prettier.js" + }, + "engines": { + "node": ">=10.13.0" + }, + "funding": { + "url": "https://github.com/prettier/prettier?sponsor=1" + } + }, + "node_modules/prettier-linter-helpers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", + "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", + "dev": true, + "dependencies": { + "fast-diff": "^1.1.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/pretty-format": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", + "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1", + "ansi-styles": "^5.0.0", + "react-is": "^17.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/pretty-format/node_modules/ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/prompts": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", + "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", + "dev": true, + "dependencies": { + "kleur": "^3.0.3", + "sisteransi": "^1.0.5" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/propagate": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/propagate/-/propagate-2.0.1.tgz", + "integrity": "sha512-vGrhOavPSTz4QVNuBNdcNXePNdNMaO1xj9yBeH1ScQPjk/rhg9sSlCXPhMkFuaNNW/syTvYqsnbIJxMBfRbbag==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/psl": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", + "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", + "dev": true + }, + "node_modules/punycode": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", + "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/querystringify": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", + "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", + "dev": true + }, + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/react-is": { + "version": "17.0.2", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", + "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", + "dev": true + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz", + "integrity": "sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", + "dev": true + }, + "node_modules/resolve": { + "version": "1.22.3", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.3.tgz", + "integrity": "sha512-P8ur/gp/AmbEzjr729bZnLjXK5Z+4P0zhIJgBgzqRih7hL7BOukHGtSTA3ACMY467GRFz3duQsi0bDZdR7DKdw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.12.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-cwd": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", + "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", + "dev": true, + "dependencies": { + "resolve-from": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/resolve-cwd/node_modules/resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/resolve.exports": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.1.tgz", + "integrity": "sha512-/NtpHNDN7jWhAaQ9BvBUYZ6YTXsRBgfqWFWP7BZBaoMJO/I3G5OFzvTuWNlZC3aPjins1F+TNrLKsGbH4rfsRQ==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true, + "engines": { + "iojs": ">=1.0.0", + "node": ">=0.10.0" + } + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rollup": { + "version": "3.27.0", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.27.0.tgz", + "integrity": "sha512-aOltLCrYZ0FhJDm7fCqwTjIUEVjWjcydKBV/Zeid6Mn8BWgDCUBBWT5beM5ieForYNo/1ZHuGJdka26kvQ3Gzg==", + "dev": true, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=14.18.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "queue-microtask": "^1.2.2" + } + }, + "node_modules/safe-array-concat": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.0.tgz", + "integrity": "sha512-9dVEFruWIsnie89yym+xWTAYASdpw3CJV7Li/6zBewGf9z2i1j31rP6jnY0pHEO4QZh6N0K11bFjWmdR8UGdPQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-regex-test": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", + "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.1.3", + "is-regex": "^1.1.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "node_modules/saxes": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz", + "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==", + "dev": true, + "dependencies": { + "xmlchars": "^2.2.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/semver": { + "version": "7.5.4", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", + "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/semver/node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/semver/node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/side-channel": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", + "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.0", + "get-intrinsic": "^1.0.2", + "object-inspect": "^1.9.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/sisteransi": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", + "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", + "dev": true + }, + "node_modules/slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dev": true, + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", + "dev": true + }, + "node_modules/stack-utils": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", + "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", + "dev": true, + "dependencies": { + "escape-string-regexp": "^2.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/stack-utils/node_modules/escape-string-regexp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", + "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-length": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", + "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", + "dev": true, + "dependencies": { + "char-regex": "^1.0.2", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string.prototype.trim": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.7.tgz", + "integrity": "sha512-p6TmeT1T3411M8Cgg9wBTMRtY2q9+PNy9EV1i2lIXUN/btt763oIfxwN3RR8VU6wHX8j/1CFy0L+YuThm6bgOg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimend": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz", + "integrity": "sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimstart": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz", + "integrity": "sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "es-abstract": "^1.20.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-bom": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", + "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", + "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/sucrase": { + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.34.0.tgz", + "integrity": "sha512-70/LQEZ07TEcxiU2dz51FKaE6hCTWC6vr7FOk3Gr0U60C3shtAN+H+BFr9XlYe5xqf3RA8nrc+VIwzCfnxuXJw==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.2", + "commander": "^4.0.0", + "glob": "7.1.6", + "lines-and-columns": "^1.1.6", + "mz": "^2.7.0", + "pirates": "^4.0.1", + "ts-interface-checker": "^0.1.9" + }, + "bin": { + "sucrase": "bin/sucrase", + "sucrase-node": "bin/sucrase-node" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/sucrase/node_modules/glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-hyperlinks": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.3.0.tgz", + "integrity": "sha512-RpsAZlpWcDwOPQA22aCH4J0t7L8JmAvsCxfOSEwm7cQs3LshN36QaTkwd70DnBOXDWGssw2eUoc8CaRWT0XunA==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0", + "supports-color": "^7.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/symbol-tree": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", + "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", + "dev": true + }, + "node_modules/terminal-link": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", + "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", + "dev": true, + "dependencies": { + "ansi-escapes": "^4.2.1", + "supports-hyperlinks": "^2.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/test-exclude": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", + "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", + "dev": true, + "dependencies": { + "@istanbuljs/schema": "^0.1.2", + "glob": "^7.1.4", + "minimatch": "^3.0.4" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "node_modules/thenify": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", + "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", + "dev": true, + "dependencies": { + "any-promise": "^1.0.0" + } + }, + "node_modules/thenify-all": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", + "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", + "dev": true, + "dependencies": { + "thenify": ">= 3.1.0 < 4" + }, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/throat": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/throat/-/throat-6.0.2.tgz", + "integrity": "sha512-WKexMoJj3vEuK0yFEapj8y64V0A6xcuPuK9Gt1d0R+dzCSJc0lHqQytAbSB4cDAK0dWh4T0E2ETkoLE2WZ41OQ==", + "dev": true + }, + "node_modules/tmpl": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", + "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", + "dev": true + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/tough-cookie": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.3.tgz", + "integrity": "sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==", + "dev": true, + "dependencies": { + "psl": "^1.1.33", + "punycode": "^2.1.1", + "universalify": "^0.2.0", + "url-parse": "^1.5.3" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/tr46": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz", + "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==", + "dev": true, + "dependencies": { + "punycode": "^2.1.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/tree-kill": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", + "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", + "dev": true, + "bin": { + "tree-kill": "cli.js" + } + }, + "node_modules/ts-interface-checker": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", + "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==", + "dev": true + }, + "node_modules/ts-jest": { + "version": "27.1.5", + "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-27.1.5.tgz", + "integrity": "sha512-Xv6jBQPoBEvBq/5i2TeSG9tt/nqkbpcurrEG1b+2yfBrcJelOZF9Ml6dmyMh7bcW9JyFbRYpR5rxROSlBLTZHA==", + "dev": true, + "dependencies": { + "bs-logger": "0.x", + "fast-json-stable-stringify": "2.x", + "jest-util": "^27.0.0", + "json5": "2.x", + "lodash.memoize": "4.x", + "make-error": "1.x", + "semver": "7.x", + "yargs-parser": "20.x" + }, + "bin": { + "ts-jest": "cli.js" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "@babel/core": ">=7.0.0-beta.0 <8", + "@types/jest": "^27.0.0", + "babel-jest": ">=27.0.0 <28", + "jest": "^27.0.0", + "typescript": ">=3.8 <5.0" + }, + "peerDependenciesMeta": { + "@babel/core": { + "optional": true + }, + "@types/jest": { + "optional": true + }, + "babel-jest": { + "optional": true + }, + "esbuild": { + "optional": true + } + } + }, + "node_modules/tsconfig-paths": { + "version": "3.14.2", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.2.tgz", + "integrity": "sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g==", + "dev": true, + "dependencies": { + "@types/json5": "^0.0.29", + "json5": "^1.0.2", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + } + }, + "node_modules/tsconfig-paths/node_modules/json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "dependencies": { + "minimist": "^1.2.0" + }, + "bin": { + "json5": "lib/cli.js" + } + }, + "node_modules/tsconfig-paths/node_modules/strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/tslib": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", + "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", + "dev": true + }, + "node_modules/tsup": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/tsup/-/tsup-6.7.0.tgz", + "integrity": "sha512-L3o8hGkaHnu5TdJns+mCqFsDBo83bJ44rlK7e6VdanIvpea4ArPcU3swWGsLVbXak1PqQx/V+SSmFPujBK+zEQ==", + "dev": true, + "dependencies": { + "bundle-require": "^4.0.0", + "cac": "^6.7.12", + "chokidar": "^3.5.1", + "debug": "^4.3.1", + "esbuild": "^0.17.6", + "execa": "^5.0.0", + "globby": "^11.0.3", + "joycon": "^3.0.1", + "postcss-load-config": "^3.0.1", + "resolve-from": "^5.0.0", + "rollup": "^3.2.5", + "source-map": "0.8.0-beta.0", + "sucrase": "^3.20.3", + "tree-kill": "^1.2.2" + }, + "bin": { + "tsup": "dist/cli-default.js", + "tsup-node": "dist/cli-node.js" + }, + "engines": { + "node": ">=14.18" + }, + "peerDependencies": { + "@swc/core": "^1", + "postcss": "^8.4.12", + "typescript": ">=4.1.0" + }, + "peerDependenciesMeta": { + "@swc/core": { + "optional": true + }, + "postcss": { + "optional": true + }, + "typescript": { + "optional": true + } + } + }, + "node_modules/tsup/node_modules/resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/tsup/node_modules/source-map": { + "version": "0.8.0-beta.0", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.8.0-beta.0.tgz", + "integrity": "sha512-2ymg6oRBpebeZi9UUNsgQ89bhx01TcTkmNTGnNO88imTmbSgy4nfujrgVEFKWpMTEGA11EDkTt7mqObTPdigIA==", + "dev": true, + "dependencies": { + "whatwg-url": "^7.0.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/tsup/node_modules/tr46": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-1.0.1.tgz", + "integrity": "sha512-dTpowEjclQ7Kgx5SdBkqRzVhERQXov8/l9Ft9dVM9fmg0W0KQSVaXX9T4i6twCPNtYiZM53lpSSUAwJbFPOHxA==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/tsup/node_modules/webidl-conversions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz", + "integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg==", + "dev": true + }, + "node_modules/tsup/node_modules/whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "dev": true, + "dependencies": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "node_modules/tsutils": { + "version": "3.21.0", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", + "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", + "dev": true, + "dependencies": { + "tslib": "^1.8.1" + }, + "engines": { + "node": ">= 6" + }, + "peerDependencies": { + "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" + } + }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/type-detect": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", + "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/typed-array-buffer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", + "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", + "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", + "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", + "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "is-typed-array": "^1.1.9" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typedarray-to-buffer": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", + "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", + "dev": true, + "dependencies": { + "is-typedarray": "^1.0.0" + } + }, + "node_modules/typescript": { + "version": "4.8.4", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.8.4.tgz", + "integrity": "sha512-QCh+85mCy+h0IGff8r5XWzOVSbBO+KfeYrMQh7NJ58QujwcE22u+NUSmUxqF+un70P9GXKxa2HCNiTTMJknyjQ==", + "dev": true, + "bin": { + "tsc": "bin/tsc", + "tsserver": "bin/tsserver" + }, + "engines": { + "node": ">=4.2.0" + } + }, + "node_modules/unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/universalify": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", + "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", + "dev": true, + "engines": { + "node": ">= 4.0.0" + } + }, + "node_modules/update-browserslist-db": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", + "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "escalade": "^3.1.1", + "picocolors": "^1.0.0" + }, + "bin": { + "update-browserslist-db": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/url-parse": { + "version": "1.5.10", + "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", + "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", + "dev": true, + "dependencies": { + "querystringify": "^2.1.1", + "requires-port": "^1.0.0" + } + }, + "node_modules/v8-to-istanbul": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz", + "integrity": "sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.1", + "convert-source-map": "^1.6.0", + "source-map": "^0.7.3" + }, + "engines": { + "node": ">=10.12.0" + } + }, + "node_modules/v8-to-istanbul/node_modules/source-map": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", + "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/w3c-hr-time": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz", + "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==", + "deprecated": "Use your platform's native performance.now() and performance.timeOrigin.", + "dev": true, + "dependencies": { + "browser-process-hrtime": "^1.0.0" + } + }, + "node_modules/w3c-xmlserializer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz", + "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==", + "dev": true, + "dependencies": { + "xml-name-validator": "^3.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/walker": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", + "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", + "dev": true, + "dependencies": { + "makeerror": "1.0.12" + } + }, + "node_modules/webidl-conversions": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz", + "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==", + "dev": true, + "engines": { + "node": ">=10.4" + } + }, + "node_modules/whatwg-encoding": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", + "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", + "dev": true, + "dependencies": { + "iconv-lite": "0.4.24" + } + }, + "node_modules/whatwg-mimetype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", + "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==", + "dev": true + }, + "node_modules/whatwg-url": { + "version": "8.7.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz", + "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==", + "dev": true, + "dependencies": { + "lodash": "^4.7.0", + "tr46": "^2.1.0", + "webidl-conversions": "^6.1.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "dependencies": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-typed-array": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.11.tgz", + "integrity": "sha512-qe9UWWpkeG5yzZ0tNYxDmd7vo58HDBc39mZ0xWWpolAGADdFOzkfamWLDxkOWcvHQKVmdTyQdLD4NOfjLWTKew==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "node_modules/write-file-atomic": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", + "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", + "dev": true, + "dependencies": { + "imurmurhash": "^0.1.4", + "is-typedarray": "^1.0.0", + "signal-exit": "^3.0.2", + "typedarray-to-buffer": "^3.1.5" + } + }, + "node_modules/ws": { + "version": "7.5.9", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz", + "integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==", + "dev": true, + "engines": { + "node": ">=8.3.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": "^5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/xml-name-validator": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", + "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==", + "dev": true + }, + "node_modules/xmlchars": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", + "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", + "dev": true + }, + "node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true + }, + "node_modules/yaml": { + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", + "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/yargs": { + "version": "16.2.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", + "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", + "dev": true, + "dependencies": { + "cliui": "^7.0.2", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.0", + "y18n": "^5.0.5", + "yargs-parser": "^20.2.2" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/yargs-parser": { + "version": "20.2.9", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", + "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..72a2f20 --- /dev/null +++ b/package.json @@ -0,0 +1,58 @@ +{ + "source": "./src/index.ts", + "exports": { + ".": { + "require": "./dist/index.cjs", + "import": "./dist/index.js", + "types": "./dist/index.d.ts" + } + }, + "main": "dist/index.cjs", + "module": "dist/index.js", + "browser": "./dist/index.umd.js", + "unpkg": "./dist/index.umd.js", + "types": "dist/index.d.ts", + "files": [ + "dist", + "src", + "README.md" + ], + "devDependencies": { + "@typescript-eslint/eslint-plugin": "^5.43.0", + "@typescript-eslint/parser": "^5.43.0", + "@types/node": "^17.0.23", + "@types/jest": "^27.4.1", + "eslint": "^8.20.0", + "eslint-config-airbnb-base": "^15.0.0", + "eslint-config-airbnb-typescript": "^17.0.0", + "eslint-config-prettier": "^8.5.0", + "eslint-plugin-import": "^2.26.0", + "eslint-plugin-prettier": "^4.2.1", + "jest": "^27.5.1", + "nock": "^13.2.4", + "prettier": "^2.6.2", + "ts-jest": "^27.0.3", + "typescript": "4.8.4", + "tsup": "^6.7.0" + }, + "scripts": { + "build": "tsup-node src/index.ts --format cjs,esm --dts --clean", + "build:cjs": "tsc --module commonjs --outDir dist/commonjs", + "build:esm": "tsc --module esnext --outDir dist/esm", + "build:umd": "tsc --module umd --outDir dist/umd", + "build:all": "npm run build:cjs && npm run build:esm && npm run build:umd", + "lint": "eslint --ext .ts,.js ./src/ --resolve-plugins-relative-to .", + "lint:ci": "eslint --ext .ts,.js ./src/ --resolve-plugins-relative-to . --cache --quiet", + "lint:fix": "eslint --ext .ts,.js ./src/ --resolve-plugins-relative-to . --cache --fix", + "rebuild": "rm -rf dist/ && tsc", + "test": "jest --detectOpenHandles", + "watch": "rm -rf dist/ && tsc -w", + "version": "tsc --version" + }, + "name": "@dopplerhq/node-sdk", + "description": "DopplerSDK", + "version": "1.0.0", + "author": "DopplerSDK", + "dependencies": {}, + "type": "module" +} diff --git a/src/hooks/Hook.ts b/src/hooks/Hook.ts new file mode 100644 index 0000000..b68e544 --- /dev/null +++ b/src/hooks/Hook.ts @@ -0,0 +1,19 @@ +export interface Request { + method: string; + url: string; + input?: object; + headers: object; +} + +export interface Response { + data: object; + headers: object; +} + +export interface Hook { + beforeRequest(request: Request): Promise; + + afterResponse(request: Request, response: Response): Promise; + + afterError(error: object): Promise; +} diff --git a/src/http/Environment.ts b/src/http/Environment.ts new file mode 100644 index 0000000..3bd4f92 --- /dev/null +++ b/src/http/Environment.ts @@ -0,0 +1,3 @@ +export enum Environment { + DEFAULT = 'https://api.doppler.com', +} diff --git a/src/http/HTTPClient.ts b/src/http/HTTPClient.ts new file mode 100644 index 0000000..d69fe43 --- /dev/null +++ b/src/http/HTTPClient.ts @@ -0,0 +1,13 @@ +/** + * Defines the basic operations for an HTTP client. + */ +export interface Headers { + [key: string]: string; +} +export default interface HTTPClient { + get(url: string, input: any, headers: Headers, retry?: boolean): Promise; + post(url: string, input: any, headers: Headers, retry?: boolean): Promise; + delete(url: string, input: any, headers: Headers, retry?: boolean): Promise; + put(url: string, input: any, headers: Headers, retry?: boolean): Promise; + patch(url: string, input: any, headers: Headers, retry?: boolean): Promise; +} diff --git a/src/http/HTTPLibrary.ts b/src/http/HTTPLibrary.ts new file mode 100644 index 0000000..61abe0d --- /dev/null +++ b/src/http/HTTPLibrary.ts @@ -0,0 +1,237 @@ +import { RequestOptions } from 'https'; + +import HTTPClient, { Headers } from './HTTPClient'; +import throwHttpError from './httpExceptions'; + +interface Response { + status: number; + headers: any; + data: string; +} + +export default class HTTPLibrary implements HTTPClient { + static readonly responseMapper: Record = { type: 'type_' }; + + private readonly requestMapper: Record = { type_: 'type' }; + + private readonly retryTimes: number = 3; + + private readonly retryDelay: number = 150; + + private userAgent: string = ''; + + constructor(userAgent: string) { + this.userAgent = userAgent; + } + + async get(url: string, input: any, headers: Headers, retry: boolean = false): Promise { + const request = () => + HTTPLibrary.httpRequest( + 'GET', + url, + { + ...HTTPLibrary.compositeHeaders(headers, this.userAgent), + 'content-type': 'application/json', + }, + Object.keys(input).length > 0 + ? JSON.stringify(HTTPLibrary.convertKeysWithMapper(input, this.requestMapper)) + : undefined, + ); + + const response = retry + ? await this.retry(this.retryTimes, request, this.retryDelay) + : await request(); + + return HTTPLibrary.handleResponse(response); + } + + async post(url: string, input: any, headers: Headers, retry: boolean = false): Promise { + const request = () => + HTTPLibrary.httpRequest( + 'POST', + url, + { + ...HTTPLibrary.compositeHeaders(headers, this.userAgent), + 'content-type': 'application/json', + }, + JSON.stringify(HTTPLibrary.convertKeysWithMapper(input, this.requestMapper)), + ); + + const response = retry + ? await this.retry(this.retryTimes, request, this.retryDelay) + : await request(); + + return HTTPLibrary.handleResponse(response); + } + + async delete(url: string, input: any, headers: Headers, retry: boolean = false): Promise { + const request = () => + HTTPLibrary.httpRequest( + 'DELETE', + url, + { + ...HTTPLibrary.compositeHeaders(headers, this.userAgent), + 'content-type': 'application/json', + }, + JSON.stringify(HTTPLibrary.convertKeysWithMapper(input, this.requestMapper)), + ); + + const response = retry + ? await this.retry(this.retryTimes, request, this.retryDelay) + : await request(); + + return HTTPLibrary.handleResponse(response); + } + + async put(url: string, input: any, headers: Headers, retry: boolean = false): Promise { + const request = () => + HTTPLibrary.httpRequest( + 'PUT', + url, + { + ...HTTPLibrary.compositeHeaders(headers, this.userAgent), + 'content-type': 'application/json', + }, + JSON.stringify(HTTPLibrary.convertKeysWithMapper(input, this.requestMapper)), + ); + + const response = retry + ? await this.retry(this.retryTimes, request, this.retryDelay) + : await request(); + + return HTTPLibrary.handleResponse(response); + } + + async patch(url: string, input: any, headers: Headers, retry: boolean = false): Promise { + const request = () => + HTTPLibrary.httpRequest( + 'PATCH', + url, + { + ...HTTPLibrary.compositeHeaders(headers, this.userAgent), + 'content-type': 'application/json', + }, + JSON.stringify(HTTPLibrary.convertKeysWithMapper(input, this.requestMapper)), + ); + + const response = retry + ? await this.retry(this.retryTimes, request, this.retryDelay) + : await request(); + + return HTTPLibrary.handleResponse(response); + } + + async retry(retries: number, callbackFn: () => any, delay: number = 500): Promise { + let result: any; + + try { + result = await callbackFn(); + + if (![500, 503, 504].includes(result.status)) { + return result; + } + if (retries > 1) { + await new Promise((resolve) => setTimeout(resolve, delay)); // eslint-disable-line no-promise-executor-return + result = await this.retry(retries - 1, callbackFn, delay * 2); + } + } catch (e) { + if (retries > 1) { + await new Promise((resolve) => setTimeout(resolve, delay)); // eslint-disable-line no-promise-executor-return + result = await this.retry(retries - 1, callbackFn, delay * 2); + } else { + throw e; + } + } + + return result; + } + + private static handleResponse(response: Response) { + if (response.status >= 400) { + throwHttpError(response); + } + + response.data = HTTPLibrary.convertKeysWithMapper(response.data, this.responseMapper); + + return { data: response.data, status: response.status }; + } + + private static async httpRequest( + method: 'GET' | 'POST' | 'DELETE' | 'PUT' | 'PATCH', + url: string, + headers: { + [key: string]: string | number; + }, + body: string = '', + ): Promise { + const parsedUrl = new URL(url); + const isHttps = parsedUrl.protocol === 'https:'; + const options: RequestOptions = { + method, + headers, + }; + + const httpModule = isHttps ? await import('https') : await import('http'); + if (isHttps) { + options.minVersion = 'TLSv1.2'; + } + return new Promise((resolve, reject) => { + const req = httpModule.request(url, options, (res: any) => { + let responseBody = ''; + res.on('data', (chunk: string) => { + responseBody += chunk; + }); + res.on('end', () => { + if (responseBody === '') { + responseBody = '{}'; + } + resolve({ + status: res.statusCode, + headers: res.headers, + data: JSON.parse(responseBody), + }); + }); + }); + req.on('error', (error: any) => { + console.log(error); + reject(error); + }); + req.write(body); + req.end(); + }); + } + + private static compositeHeaders(headers: Headers, userAgent: string): Headers { + const combinedHeaders: Headers = { ...headers }; + if (typeof window === 'undefined') { + combinedHeaders['user-agent'] = userAgent; + } + return combinedHeaders; + } + + /** + *Converts keys in an object using a provided JSON mapper. + * @param {any} obj - The object to convert keys for. + * @param {Object} jsonMapper - The JSON mapper containing key mappings. + * @returns {any} - The object with converted keys. + */ + private static convertKeysWithMapper(obj: T, jsonMapper: Record): any { + if (!obj || typeof obj !== 'object') { + return obj; + } + + if (Array.isArray(obj)) { + return obj.map((item) => HTTPLibrary.convertKeysWithMapper(item, jsonMapper)); + } + + const convertedObj: Record = {}; + Object.entries(obj).forEach(([key, value]) => { + if (value) { + const convertedKey = jsonMapper[key] || key; + convertedObj[convertedKey] = HTTPLibrary.convertKeysWithMapper(value, jsonMapper); + } + }); + + return convertedObj; + } +} diff --git a/src/http/errors/BadGateway.ts b/src/http/errors/BadGateway.ts new file mode 100644 index 0000000..9c6d289 --- /dev/null +++ b/src/http/errors/BadGateway.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class BadGateway extends BaseHTTPError { + statusCode = 502; + + title = 'Bad Gateway'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/BadRequest.ts b/src/http/errors/BadRequest.ts new file mode 100644 index 0000000..7df6dd0 --- /dev/null +++ b/src/http/errors/BadRequest.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class BadRequest extends BaseHTTPError { + statusCode = 400; + + title = 'Bad Request'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/Conflict.ts b/src/http/errors/Conflict.ts new file mode 100644 index 0000000..9f5a750 --- /dev/null +++ b/src/http/errors/Conflict.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class Conflict extends BaseHTTPError { + statusCode = 409; + + title = 'Conflict'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/ExpectationFailed.ts b/src/http/errors/ExpectationFailed.ts new file mode 100644 index 0000000..22299f5 --- /dev/null +++ b/src/http/errors/ExpectationFailed.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class ExpectationFailed extends BaseHTTPError { + statusCode = 417; + + title = 'Expectation Failed'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/FailedDependency.ts b/src/http/errors/FailedDependency.ts new file mode 100644 index 0000000..ea99d2c --- /dev/null +++ b/src/http/errors/FailedDependency.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class FailedDependency extends BaseHTTPError { + statusCode = 424; + + title = 'Failed Dependency'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/Forbidden.ts b/src/http/errors/Forbidden.ts new file mode 100644 index 0000000..82ee934 --- /dev/null +++ b/src/http/errors/Forbidden.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class Forbidden extends BaseHTTPError { + statusCode = 403; + + title = 'Forbidden'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/GatewayTimeout.ts b/src/http/errors/GatewayTimeout.ts new file mode 100644 index 0000000..daa7af6 --- /dev/null +++ b/src/http/errors/GatewayTimeout.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class GatewayTimeout extends BaseHTTPError { + statusCode = 504; + + title = 'Gateway Timeout'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/Gone.ts b/src/http/errors/Gone.ts new file mode 100644 index 0000000..a113c4d --- /dev/null +++ b/src/http/errors/Gone.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class Gone extends BaseHTTPError { + statusCode = 410; + + title = 'Gone'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/HttpVersionNotSupported.ts b/src/http/errors/HttpVersionNotSupported.ts new file mode 100644 index 0000000..4fb6f46 --- /dev/null +++ b/src/http/errors/HttpVersionNotSupported.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class HttpVersionNotSupported extends BaseHTTPError { + statusCode = 505; + + title = 'HTTP Version Not Supported'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/InternalServerError.ts b/src/http/errors/InternalServerError.ts new file mode 100644 index 0000000..a06205a --- /dev/null +++ b/src/http/errors/InternalServerError.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class InternalServerError extends BaseHTTPError { + statusCode = 500; + + title = 'Internal Server Error'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/LengthRequired.ts b/src/http/errors/LengthRequired.ts new file mode 100644 index 0000000..5fe5948 --- /dev/null +++ b/src/http/errors/LengthRequired.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class LengthRequired extends BaseHTTPError { + statusCode = 411; + + title = 'LengthRequired'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/Locked.ts b/src/http/errors/Locked.ts new file mode 100644 index 0000000..7ef8fd9 --- /dev/null +++ b/src/http/errors/Locked.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class Locked extends BaseHTTPError { + statusCode = 423; + + title = 'Locked'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/LoopDetected.ts b/src/http/errors/LoopDetected.ts new file mode 100644 index 0000000..dfb598a --- /dev/null +++ b/src/http/errors/LoopDetected.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class LoopDetected extends BaseHTTPError { + statusCode = 508; + + title = 'Loop Detected'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/MethodNotAllowed.ts b/src/http/errors/MethodNotAllowed.ts new file mode 100644 index 0000000..870e5c3 --- /dev/null +++ b/src/http/errors/MethodNotAllowed.ts @@ -0,0 +1,14 @@ +import { BaseHTTPError } from './base'; + +export default class MethodNotAllowed extends BaseHTTPError { + statusCode = 405; + + title = 'Method Not Allowed'; + + allow?: string[]; + + constructor(detail: string = '', allow?: string[]) { + super(detail); + this.allow = allow; + } +} diff --git a/src/http/errors/MisdirectedRequest.ts b/src/http/errors/MisdirectedRequest.ts new file mode 100644 index 0000000..f00f212 --- /dev/null +++ b/src/http/errors/MisdirectedRequest.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class MisdirectedRequest extends BaseHTTPError { + statusCode = 421; + + title = 'Misdirected Request'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/NetworkAuthenticationRequired.ts b/src/http/errors/NetworkAuthenticationRequired.ts new file mode 100644 index 0000000..29267f3 --- /dev/null +++ b/src/http/errors/NetworkAuthenticationRequired.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class NetworkAuthenticationRequired extends BaseHTTPError { + statusCode = 511; + + title = 'Network Authentication Required'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/NotAcceptable.ts b/src/http/errors/NotAcceptable.ts new file mode 100644 index 0000000..c2ad2e2 --- /dev/null +++ b/src/http/errors/NotAcceptable.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class NotAcceptable extends BaseHTTPError { + statusCode = 406; + + title = 'Not Acceptable'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/NotExtended.ts b/src/http/errors/NotExtended.ts new file mode 100644 index 0000000..a137834 --- /dev/null +++ b/src/http/errors/NotExtended.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class NotExtended extends BaseHTTPError { + statusCode = 510; + + title = 'Not Extended'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/NotFound.ts b/src/http/errors/NotFound.ts new file mode 100644 index 0000000..0df322b --- /dev/null +++ b/src/http/errors/NotFound.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class NotFound extends BaseHTTPError { + statusCode = 404; + + title = 'Not Found'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/NotImplemented.ts b/src/http/errors/NotImplemented.ts new file mode 100644 index 0000000..0e9e9e9 --- /dev/null +++ b/src/http/errors/NotImplemented.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class NotImplemented extends BaseHTTPError { + statusCode = 501; + + title = 'Not Implemented'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/PayloadTooLarge.ts b/src/http/errors/PayloadTooLarge.ts new file mode 100644 index 0000000..ca40131 --- /dev/null +++ b/src/http/errors/PayloadTooLarge.ts @@ -0,0 +1,14 @@ +import { BaseHTTPError } from './base'; + +export default class PayloadTooLarge extends BaseHTTPError { + statusCode = 413; + + title = 'Payload Too Large'; + + retryAfter: number | null; + + constructor(detail: string = '', retryAfter: number | null = null) { + super(detail); + this.retryAfter = retryAfter; + } +} diff --git a/src/http/errors/PaymentRequired.ts b/src/http/errors/PaymentRequired.ts new file mode 100644 index 0000000..abbabbb --- /dev/null +++ b/src/http/errors/PaymentRequired.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class PaymentRequired extends BaseHTTPError { + statusCode = 402; + + title = 'Payment Required'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/PreconditionFailed.ts b/src/http/errors/PreconditionFailed.ts new file mode 100644 index 0000000..2e0b8f9 --- /dev/null +++ b/src/http/errors/PreconditionFailed.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class PreconditionFailed extends BaseHTTPError { + statusCode = 412; + + title = 'PreconditionFailed'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/PreconditionRequired.ts b/src/http/errors/PreconditionRequired.ts new file mode 100644 index 0000000..9d7b83e --- /dev/null +++ b/src/http/errors/PreconditionRequired.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class PreconditionRequired extends BaseHTTPError { + statusCode = 428; + + title = 'Precondition Required'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/ProxyAuthenticationRequired.ts b/src/http/errors/ProxyAuthenticationRequired.ts new file mode 100644 index 0000000..26e1bd5 --- /dev/null +++ b/src/http/errors/ProxyAuthenticationRequired.ts @@ -0,0 +1,14 @@ +import { AuthenticateChallenge, BaseHTTPError } from './base'; + +export default class ProxyAuthenticationRequired extends BaseHTTPError { + statusCode = 407; + + title = 'Proxy Authentication Required'; + + proxyAuthenticate?: AuthenticateChallenge; + + constructor(detail: string = '', proxyAuthenticate?: AuthenticateChallenge) { + super(detail); + this.proxyAuthenticate = proxyAuthenticate; + } +} diff --git a/src/http/errors/RangeNotSatisfiable.ts b/src/http/errors/RangeNotSatisfiable.ts new file mode 100644 index 0000000..704e4ec --- /dev/null +++ b/src/http/errors/RangeNotSatisfiable.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class RangeNotSatisfiable extends BaseHTTPError { + statusCode = 416; + + title = 'Range Not Satisfiable'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/RequestHeaderFieldsTooLarge.ts b/src/http/errors/RequestHeaderFieldsTooLarge.ts new file mode 100644 index 0000000..4a34fb0 --- /dev/null +++ b/src/http/errors/RequestHeaderFieldsTooLarge.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class RequestHeaderFieldsTooLarge extends BaseHTTPError { + statusCode = 431; + + title = 'Request Header Fields Too Large'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/RequestTimeout.ts b/src/http/errors/RequestTimeout.ts new file mode 100644 index 0000000..ba1a5c3 --- /dev/null +++ b/src/http/errors/RequestTimeout.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class RequestTimeout extends BaseHTTPError { + statusCode = 408; + + title = 'Request Timeout'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/ServiceUnavailable.ts b/src/http/errors/ServiceUnavailable.ts new file mode 100644 index 0000000..8cd62e8 --- /dev/null +++ b/src/http/errors/ServiceUnavailable.ts @@ -0,0 +1,14 @@ +import { BaseHTTPError } from './base'; + +export default class ServiceUnavailable extends BaseHTTPError { + statusCode = 503; + + title = 'Service Unavailable'; + + retryAfter: number | null; + + constructor(detail: string = '', retryAfter: number | null = null) { + super(detail); + this.retryAfter = retryAfter; + } +} diff --git a/src/http/errors/TooEarly.ts b/src/http/errors/TooEarly.ts new file mode 100644 index 0000000..b7f99c6 --- /dev/null +++ b/src/http/errors/TooEarly.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class TooEarly extends BaseHTTPError { + statusCode = 425; + + title = 'Too Early'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/TooManyRequests.ts b/src/http/errors/TooManyRequests.ts new file mode 100644 index 0000000..eb5280d --- /dev/null +++ b/src/http/errors/TooManyRequests.ts @@ -0,0 +1,14 @@ +import { BaseHTTPError } from './base'; + +export default class TooManyRequests extends BaseHTTPError { + statusCode = 429; + + title = 'Too Many Requests'; + + retryAfter: number | null; + + constructor(detail: string = '', retryAfter: number | null = null) { + super(detail); + this.retryAfter = retryAfter; + } +} diff --git a/src/http/errors/Unauthorized.ts b/src/http/errors/Unauthorized.ts new file mode 100644 index 0000000..15da735 --- /dev/null +++ b/src/http/errors/Unauthorized.ts @@ -0,0 +1,14 @@ +import { AuthenticateChallenge, BaseHTTPError } from './base'; + +export default class Unauthorized extends BaseHTTPError { + statusCode = 401; + + title = 'Unauthorized'; + + wwwAuthenticate?: AuthenticateChallenge; + + constructor(detail: string = '', wwwAuthenticate?: AuthenticateChallenge) { + super(detail); + this.wwwAuthenticate = wwwAuthenticate; + } +} diff --git a/src/http/errors/UnavailableForLegalReasons.ts b/src/http/errors/UnavailableForLegalReasons.ts new file mode 100644 index 0000000..70e6d07 --- /dev/null +++ b/src/http/errors/UnavailableForLegalReasons.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class UnavailableForLegalReasons extends BaseHTTPError { + statusCode = 451; + + title = 'Unavailable For Legal Reasons'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/UnprocessableEntity.ts b/src/http/errors/UnprocessableEntity.ts new file mode 100644 index 0000000..70000c1 --- /dev/null +++ b/src/http/errors/UnprocessableEntity.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class UnprocessableEntity extends BaseHTTPError { + statusCode = 422; + + title = 'Unprocessable Entity'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/UnsufficientStorage.ts b/src/http/errors/UnsufficientStorage.ts new file mode 100644 index 0000000..e61e12c --- /dev/null +++ b/src/http/errors/UnsufficientStorage.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class UnsufficientStorage extends BaseHTTPError { + statusCode = 507; + + title = 'Unsufficient Storage'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/UnsupportedMediaType.ts b/src/http/errors/UnsupportedMediaType.ts new file mode 100644 index 0000000..a27f242 --- /dev/null +++ b/src/http/errors/UnsupportedMediaType.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class UnsupportedMediaType extends BaseHTTPError { + statusCode = 415; + + title = 'Unsupported Media Type'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/UpgradeRequired.ts b/src/http/errors/UpgradeRequired.ts new file mode 100644 index 0000000..0ac1743 --- /dev/null +++ b/src/http/errors/UpgradeRequired.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class UpgradeRequired extends BaseHTTPError { + statusCode = 426; + + title = 'Upgrade Required'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/UriTooLong.ts b/src/http/errors/UriTooLong.ts new file mode 100644 index 0000000..56eca8b --- /dev/null +++ b/src/http/errors/UriTooLong.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class UriTooLong extends BaseHTTPError { + statusCode = 414; + + title = 'URI Too Long'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/VariantAlsoNegotiates.ts b/src/http/errors/VariantAlsoNegotiates.ts new file mode 100644 index 0000000..079df29 --- /dev/null +++ b/src/http/errors/VariantAlsoNegotiates.ts @@ -0,0 +1,11 @@ +import { BaseHTTPError } from './base'; + +export default class VariantAlsoNegotiates extends BaseHTTPError { + statusCode = 506; + + title = 'Variant Also Negotiates'; + + constructor(detail: string = '') { + super(detail); + } +} diff --git a/src/http/errors/base.ts b/src/http/errors/base.ts new file mode 100644 index 0000000..f5ebd46 --- /dev/null +++ b/src/http/errors/base.ts @@ -0,0 +1,52 @@ +export interface IHTTPError extends Error { + statusCode: number; +} + +export interface IHTTPErrorDescription extends IHTTPError { + type?: string; + title: string; + detail?: string; + instance?: string; +} + +export function isHTTPError(error: unknown): error is IHTTPError { + if (!error) { + return false; + } + return Number.isInteger((error as IHTTPError).statusCode); +} + +export function isHTTPIssue(error: unknown): error is IHTTPErrorDescription { + if (!error) { + return false; + } + return (error as IHTTPErrorDescription).title !== undefined && isHTTPError(error); +} + +export class BaseHTTPError extends Error implements IHTTPError { + public type?: string; + + public title: string = 'Internal Server Error'; + + public detail?: string; + + public instance?: string; + + public statusCode: number = 500; + + constructor(detail: string = '') { + super(detail || 'An Unknown HTTP Error Occurred'); + this.detail = detail; + this.stack = (new Error()).stack; + } +} + +export function isClientError(error: Error): boolean { + return isHTTPError(error); +} + +export function isServerError(e: Error): boolean { + return isHTTPError(e) && e.statusCode >= 500 && e.statusCode <= 599; +} + +export type AuthenticateChallenge = string | string[]; diff --git a/src/http/httpExceptions.ts b/src/http/httpExceptions.ts new file mode 100644 index 0000000..8c59955 --- /dev/null +++ b/src/http/httpExceptions.ts @@ -0,0 +1,126 @@ +import BadRequest from './errors/BadRequest'; +import Unauthorized from './errors/Unauthorized'; +import PaymentRequired from './errors/PaymentRequired'; +import Forbidden from './errors/Forbidden'; +import NotFound from './errors/NotFound'; +import MethodNotAllowed from './errors/MethodNotAllowed'; +import NotAcceptable from './errors/NotAcceptable'; +import ProxyAuthenticationRequired from './errors/ProxyAuthenticationRequired'; +import RequestTimeout from './errors/RequestTimeout'; +import Conflict from './errors/Conflict'; +import Gone from './errors/Gone'; +import LengthRequired from './errors/LengthRequired'; +import PreconditionFailed from './errors/PreconditionFailed'; +import PayloadTooLarge from './errors/PayloadTooLarge'; +import UriTooLong from './errors/UriTooLong'; +import UnsupportedMediaType from './errors/UnsupportedMediaType'; +import RangeNotSatisfiable from './errors/RangeNotSatisfiable'; +import ExpectationFailed from './errors/ExpectationFailed'; +import MisdirectedRequest from './errors/MisdirectedRequest'; +import UnprocessableEntity from './errors/UnprocessableEntity'; +import Locked from './errors/Locked'; +import FailedDependency from './errors/FailedDependency'; +import TooEarly from './errors/TooEarly'; +import UpgradeRequired from './errors/UpgradeRequired'; +import PreconditionRequired from './errors/PreconditionRequired'; +import TooManyRequests from './errors/TooManyRequests'; +import RequestHeaderFieldsTooLarge from './errors/RequestHeaderFieldsTooLarge'; +import UnavailableForLegalReasons from './errors/UnavailableForLegalReasons'; +import InternalServerError from './errors/InternalServerError'; +import NotImplemented from './errors/NotImplemented'; +import BadGateway from './errors/BadGateway'; +import ServiceUnavailable from './errors/ServiceUnavailable'; +import GatewayTimeout from './errors/GatewayTimeout'; +import HttpVersionNotSupported from './errors/HttpVersionNotSupported'; +import VariantAlsoNegotiates from './errors/VariantAlsoNegotiates'; +import UnsufficientStorage from './errors/UnsufficientStorage'; +import LoopDetected from './errors/LoopDetected'; +import NotExtended from './errors/NotExtended'; +import NetworkAuthenticationRequired from './errors/NetworkAuthenticationRequired'; +import { BaseHTTPError } from './errors/base'; + +interface HttpResponseWithError { + status: number; + headers: any; + data?: any; +} + +interface NumberToClass { + [key: number]: any; +} + +const statusCodeToErrorFunction: NumberToClass = { + 400: BadRequest, + 401: Unauthorized, + 402: PaymentRequired, + 403: Forbidden, + 404: NotFound, + 405: MethodNotAllowed, + 406: NotAcceptable, + 407: ProxyAuthenticationRequired, + 408: RequestTimeout, + 409: Conflict, + 410: Gone, + 411: LengthRequired, + 412: PreconditionFailed, + 413: PayloadTooLarge, + 414: UriTooLong, + 415: UnsupportedMediaType, + 416: RangeNotSatisfiable, + 417: ExpectationFailed, + 421: MisdirectedRequest, + 422: UnprocessableEntity, + 423: Locked, + 424: FailedDependency, + 425: TooEarly, + 426: UpgradeRequired, + 428: PreconditionRequired, + 429: TooManyRequests, + 431: RequestHeaderFieldsTooLarge, + 451: UnavailableForLegalReasons, + 500: InternalServerError, + 501: NotImplemented, + 502: BadGateway, + 503: ServiceUnavailable, + 504: GatewayTimeout, + 505: HttpVersionNotSupported, + 506: VariantAlsoNegotiates, + 507: UnsufficientStorage, + 508: LoopDetected, + 510: NotExtended, + 511: NetworkAuthenticationRequired, +}; + +/** + * @summary This function will throw an error. + * + * @param {HttpResponseWithError} response - the response from a request, must contain a status and data fields + * @throws {Error} - an http error + */ +export default function throwHttpError(response: HttpResponseWithError): never { + // certain error codes have special handling, we try those first + switch (response.status) { + case 401: + throw new Unauthorized(response.data, response.headers['WWW-Authenticate']); + case 405: + // this indicates a bug in the spec if it allows a method that the server rejects + throw new MethodNotAllowed(response.data, response.headers.allowed); + case 407: + throw new ProxyAuthenticationRequired(response.data, response.headers['Proxy-Authenticate']); + case 413: + throw new PayloadTooLarge(response.data, response.headers['Retry-After']); + case 429: + throw new TooManyRequests(response.data, response.headers['Retry-After']); + case 503: + throw new ServiceUnavailable(response.data, response.headers['Retry-After']); + default: + if (response.status in statusCodeToErrorFunction) { + throw new statusCodeToErrorFunction[response.status](response.data); + } else { + const error = new BaseHTTPError(response.data); + error.statusCode = response.status; + error.title = 'unknown error'; + throw error; + } + } +} diff --git a/src/index.ts b/src/index.ts new file mode 100644 index 0000000..75a7666 --- /dev/null +++ b/src/index.ts @@ -0,0 +1,67 @@ +import ProjectsService from './services/Projects'; +import SecretsService from './services/Secrets'; +import ConfigLogsService from './services/ConfigLogs'; +import EnvironmentsService from './services/Environments'; +import ConfigsService from './services/Configs'; +import ActivityLogsService from './services/ActivityLogs'; +import V3Service from './services/V3'; +import ServiceTokensService from './services/ServiceTokens'; +import DynamicSecretsService from './services/DynamicSecrets'; +import IntegrationsService from './services/Integrations'; +import SyncsService from './services/Syncs'; + +export * from './models'; + +export class DopplerSDK { + public projects: ProjectsService; + + public secrets: SecretsService; + + public configLogs: ConfigLogsService; + + public environments: EnvironmentsService; + + public configs: ConfigsService; + + public activityLogs: ActivityLogsService; + + public v3: V3Service; + + public serviceTokens: ServiceTokensService; + + public dynamicSecrets: DynamicSecretsService; + + public integrations: IntegrationsService; + + public syncs: SyncsService; + + constructor(bearerToken: string = '') { + this.projects = new ProjectsService(bearerToken); + this.secrets = new SecretsService(bearerToken); + this.configLogs = new ConfigLogsService(bearerToken); + this.environments = new EnvironmentsService(bearerToken); + this.configs = new ConfigsService(bearerToken); + this.activityLogs = new ActivityLogsService(bearerToken); + this.v3 = new V3Service(bearerToken); + this.serviceTokens = new ServiceTokensService(bearerToken); + this.dynamicSecrets = new DynamicSecretsService(bearerToken); + this.integrations = new IntegrationsService(bearerToken); + this.syncs = new SyncsService(bearerToken); + } + + setBearerToken(bearerToken: string) { + this.projects.setToken(bearerToken); + this.secrets.setToken(bearerToken); + this.configLogs.setToken(bearerToken); + this.environments.setToken(bearerToken); + this.configs.setToken(bearerToken); + this.activityLogs.setToken(bearerToken); + this.v3.setToken(bearerToken); + this.serviceTokens.setToken(bearerToken); + this.dynamicSecrets.setToken(bearerToken); + this.integrations.setToken(bearerToken); + this.syncs.setToken(bearerToken); + } +} + +export default DopplerSDK; diff --git a/src/models/ActivityLogsList200Response.ts b/src/models/ActivityLogsList200Response.ts new file mode 100644 index 0000000..e9011da --- /dev/null +++ b/src/models/ActivityLogsList200Response.ts @@ -0,0 +1,36 @@ +import BaseModel from './base'; + +export namespace ActivityLogsList200Response { + export type Id = string; + export type Text = string; + export type Html = string; + export type CreatedAt = string; + export type Environment = string; + export type Project = string; + export type Email = string; + export type Name = string; + export type ProfileImageUrl = string; + export type Logs = { + id?: Id; + text?: Text; + html?: Html; + created_at?: CreatedAt; + config?: Config; + environment?: Environment; + project?: Project; + user?: User; + }[]; + + export interface Model extends BaseModel { + page?: number; + logs?: Logs; + } + export interface Config { + [k: string]: unknown; + } + export interface User { + email?: Email; + name?: Name; + profile_image_url?: ProfileImageUrl; + } +} diff --git a/src/models/ActivityLogsRetrieve200Response.ts b/src/models/ActivityLogsRetrieve200Response.ts new file mode 100644 index 0000000..c866b85 --- /dev/null +++ b/src/models/ActivityLogsRetrieve200Response.ts @@ -0,0 +1,25 @@ +import BaseModel from './base'; + +export namespace ActivityLogsRetrieve200Response { + export interface Model extends BaseModel { + log?: Log; + } + export interface Log { + id?: string; + text?: string; + html?: string; + created_at?: string; + config?: Config; + environment?: string; + project?: string; + user?: User; + } + export interface Config { + [k: string]: unknown; + } + export interface User { + email?: string; + name?: string; + profile_image_url?: string; + } +} diff --git a/src/models/ConfigLogsGet200Response.ts b/src/models/ConfigLogsGet200Response.ts new file mode 100644 index 0000000..4a99580 --- /dev/null +++ b/src/models/ConfigLogsGet200Response.ts @@ -0,0 +1,32 @@ +import BaseModel from './base'; + +export namespace ConfigLogsGet200Response { + export type Name = string; + export type Added = string; + export type Diff = { + name?: Name; + added?: Added; + }[]; + + export interface Model extends BaseModel { + log?: Log; + } + export interface Log { + id?: string; + text?: string; + html?: string; + diff?: Diff; + rollback?: boolean; + created_at?: string; + config?: string; + environment?: string; + project?: string; + user?: User; + } + export interface User { + email?: string; + name?: string; + username?: string; + profile_image_url?: string; + } +} diff --git a/src/models/ConfigLogsList200Response.ts b/src/models/ConfigLogsList200Response.ts new file mode 100644 index 0000000..a9a0b4b --- /dev/null +++ b/src/models/ConfigLogsList200Response.ts @@ -0,0 +1,38 @@ +import BaseModel from './base'; + +export namespace ConfigLogsList200Response { + export type Id = string; + export type Text = string; + export type Html = string; + export type Rollback = boolean; + export type CreatedAt = string; + export type Config = string; + export type Environment = string; + export type Project = string; + export type Email = string; + export type Name = string; + export type Username = string; + export type ProfileImageUrl = string; + export type Logs = { + id?: Id; + text?: Text; + html?: Html; + rollback?: Rollback; + created_at?: CreatedAt; + config?: Config; + environment?: Environment; + project?: Project; + user?: User; + }[]; + + export interface Model extends BaseModel { + page?: number; + logs?: Logs; + } + export interface User { + email?: Email; + name?: Name; + username?: Username; + profile_image_url?: ProfileImageUrl; + } +} diff --git a/src/models/ConfigLogsRollback200Response.ts b/src/models/ConfigLogsRollback200Response.ts new file mode 100644 index 0000000..6258e27 --- /dev/null +++ b/src/models/ConfigLogsRollback200Response.ts @@ -0,0 +1,32 @@ +import BaseModel from './base'; + +export namespace ConfigLogsRollback200Response { + export type Name = string; + export type Removed = string; + export type Diff = { + name?: Name; + removed?: Removed; + }[]; + + export interface Model extends BaseModel { + log?: Log; + } + export interface Log { + id?: string; + text?: string; + html?: string; + diff?: Diff; + rollback?: boolean; + created_at?: string; + config?: string; + environment?: string; + project?: string; + user?: User; + } + export interface User { + email?: string; + name?: string; + username?: string; + profile_image_url?: string; + } +} diff --git a/src/models/ConfigsClone200Response.ts b/src/models/ConfigsClone200Response.ts new file mode 100644 index 0000000..9bd5ea1 --- /dev/null +++ b/src/models/ConfigsClone200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace ConfigsClone200Response { + export interface Model extends BaseModel { + config?: Config; + } + export interface Config { + name?: string; + root?: boolean; + locked?: boolean; + initial_fetch_at?: string; + last_fetch_at?: string; + created_at?: string; + environment?: string; + project?: string; + } +} diff --git a/src/models/ConfigsCloneRequest.ts b/src/models/ConfigsCloneRequest.ts new file mode 100644 index 0000000..c113058 --- /dev/null +++ b/src/models/ConfigsCloneRequest.ts @@ -0,0 +1,18 @@ +import BaseModel from './base'; + +export namespace ConfigsCloneRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the branch config being cloned. + */ + config: string; + /** + * Name of the new branch config. + */ + name: string; + } +} diff --git a/src/models/ConfigsCreate200Response.ts b/src/models/ConfigsCreate200Response.ts new file mode 100644 index 0000000..f33bafa --- /dev/null +++ b/src/models/ConfigsCreate200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace ConfigsCreate200Response { + export interface Model extends BaseModel { + config?: Config; + } + export interface Config { + name?: string; + root?: boolean; + locked?: boolean; + initial_fetch_at?: string; + last_fetch_at?: string; + created_at?: string; + environment?: string; + project?: string; + } +} diff --git a/src/models/ConfigsCreateRequest.ts b/src/models/ConfigsCreateRequest.ts new file mode 100644 index 0000000..a4783aa --- /dev/null +++ b/src/models/ConfigsCreateRequest.ts @@ -0,0 +1,18 @@ +import BaseModel from './base'; + +export namespace ConfigsCreateRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Identifier for the environment object. + */ + environment: string; + /** + * Name of the new branch config. + */ + name: string; + } +} diff --git a/src/models/ConfigsDelete200Response.ts b/src/models/ConfigsDelete200Response.ts new file mode 100644 index 0000000..f85ca58 --- /dev/null +++ b/src/models/ConfigsDelete200Response.ts @@ -0,0 +1,7 @@ +import BaseModel from './base'; + +export namespace ConfigsDelete200Response { + export interface Model extends BaseModel { + success?: boolean; + } +} diff --git a/src/models/ConfigsDeleteRequest.ts b/src/models/ConfigsDeleteRequest.ts new file mode 100644 index 0000000..d37057d --- /dev/null +++ b/src/models/ConfigsDeleteRequest.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace ConfigsDeleteRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config object. + */ + config: string; + } +} diff --git a/src/models/ConfigsGet200Response.ts b/src/models/ConfigsGet200Response.ts new file mode 100644 index 0000000..e659849 --- /dev/null +++ b/src/models/ConfigsGet200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace ConfigsGet200Response { + export interface Model extends BaseModel { + config?: Config; + } + export interface Config { + name?: string; + root?: boolean; + locked?: boolean; + initial_fetch_at?: string; + last_fetch_at?: string; + created_at?: string; + environment?: string; + project?: string; + } +} diff --git a/src/models/ConfigsList200Response.ts b/src/models/ConfigsList200Response.ts new file mode 100644 index 0000000..d0b20b0 --- /dev/null +++ b/src/models/ConfigsList200Response.ts @@ -0,0 +1,27 @@ +import BaseModel from './base'; + +export namespace ConfigsList200Response { + export type Name = string; + export type Root = boolean; + export type Locked = boolean; + export type InitialFetchAt = string; + export type LastFetchAt = string; + export type CreatedAt = string; + export type Environment = string; + export type Project = string; + export type Configs = { + name?: Name; + root?: Root; + locked?: Locked; + initial_fetch_at?: InitialFetchAt; + last_fetch_at?: LastFetchAt; + created_at?: CreatedAt; + environment?: Environment; + project?: Project; + }[]; + + export interface Model extends BaseModel { + page?: number; + configs?: Configs; + } +} diff --git a/src/models/ConfigsLock200Response.ts b/src/models/ConfigsLock200Response.ts new file mode 100644 index 0000000..fcbc23c --- /dev/null +++ b/src/models/ConfigsLock200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace ConfigsLock200Response { + export interface Model extends BaseModel { + config?: Config; + } + export interface Config { + name?: string; + root?: boolean; + locked?: boolean; + initial_fetch_at?: string; + last_fetch_at?: string; + created_at?: string; + environment?: string; + project?: string; + } +} diff --git a/src/models/ConfigsLockRequest.ts b/src/models/ConfigsLockRequest.ts new file mode 100644 index 0000000..90c04f1 --- /dev/null +++ b/src/models/ConfigsLockRequest.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace ConfigsLockRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config. + */ + config: string; + } +} diff --git a/src/models/ConfigsUnlock200Response.ts b/src/models/ConfigsUnlock200Response.ts new file mode 100644 index 0000000..4ef2006 --- /dev/null +++ b/src/models/ConfigsUnlock200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace ConfigsUnlock200Response { + export interface Model extends BaseModel { + config?: Config; + } + export interface Config { + name?: string; + root?: boolean; + locked?: boolean; + initial_fetch_at?: string; + last_fetch_at?: string; + created_at?: string; + environment?: string; + project?: string; + } +} diff --git a/src/models/ConfigsUnlockRequest.ts b/src/models/ConfigsUnlockRequest.ts new file mode 100644 index 0000000..d55c316 --- /dev/null +++ b/src/models/ConfigsUnlockRequest.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace ConfigsUnlockRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config. + */ + config: string; + } +} diff --git a/src/models/ConfigsUpdate200Response.ts b/src/models/ConfigsUpdate200Response.ts new file mode 100644 index 0000000..afe0dbe --- /dev/null +++ b/src/models/ConfigsUpdate200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace ConfigsUpdate200Response { + export interface Model extends BaseModel { + config?: Config; + } + export interface Config { + name?: string; + root?: boolean; + locked?: boolean; + initial_fetch_at?: string; + last_fetch_at?: string; + created_at?: string; + environment?: string; + project?: string; + } +} diff --git a/src/models/ConfigsUpdateRequest.ts b/src/models/ConfigsUpdateRequest.ts new file mode 100644 index 0000000..b0af407 --- /dev/null +++ b/src/models/ConfigsUpdateRequest.ts @@ -0,0 +1,18 @@ +import BaseModel from './base'; + +export namespace ConfigsUpdateRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config object. + */ + config: string; + /** + * The new name of config. + */ + name: string; + } +} diff --git a/src/models/DynamicSecretsIssueLeaseRequest.ts b/src/models/DynamicSecretsIssueLeaseRequest.ts new file mode 100644 index 0000000..231febf --- /dev/null +++ b/src/models/DynamicSecretsIssueLeaseRequest.ts @@ -0,0 +1,22 @@ +import BaseModel from './base'; + +export namespace DynamicSecretsIssueLeaseRequest { + export interface Model extends BaseModel { + /** + * The project where the dynamic secret is located + */ + project: string; + /** + * The config where the dynamic secret is located + */ + config: string; + /** + * The name of the dynamic secret for which to issue this lease + */ + dynamic_secret: string; + /** + * The number of seconds until this lease is automatically revoked + */ + ttl_sec: number; + } +} diff --git a/src/models/DynamicSecretsRevokeLease200Response.ts b/src/models/DynamicSecretsRevokeLease200Response.ts new file mode 100644 index 0000000..42393f4 --- /dev/null +++ b/src/models/DynamicSecretsRevokeLease200Response.ts @@ -0,0 +1,7 @@ +import BaseModel from './base'; + +export namespace DynamicSecretsRevokeLease200Response { + export interface Model extends BaseModel { + success?: boolean; + } +} diff --git a/src/models/DynamicSecretsRevokeLeaseRequest.ts b/src/models/DynamicSecretsRevokeLeaseRequest.ts new file mode 100644 index 0000000..7810acf --- /dev/null +++ b/src/models/DynamicSecretsRevokeLeaseRequest.ts @@ -0,0 +1,22 @@ +import BaseModel from './base'; + +export namespace DynamicSecretsRevokeLeaseRequest { + export interface Model extends BaseModel { + /** + * The project where the dynamic secret is located + */ + project: string; + /** + * The config where the dynamic secret is located + */ + config: string; + /** + * The name of the dynamic secret from which this lease was issued + */ + dynamic_secret: string; + /** + * The slug of the lease to revoke + */ + slug: string; + } +} diff --git a/src/models/EnvironmentsCreate200Response.ts b/src/models/EnvironmentsCreate200Response.ts new file mode 100644 index 0000000..70ac4ce --- /dev/null +++ b/src/models/EnvironmentsCreate200Response.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace EnvironmentsCreate200Response { + export interface Model extends BaseModel { + environment?: Environment; + } + export interface Environment { + id?: string; + name?: string; + initial_fetch_at?: string; + created_at?: string; + project?: string; + } +} diff --git a/src/models/EnvironmentsCreateRequest.ts b/src/models/EnvironmentsCreateRequest.ts new file mode 100644 index 0000000..883688d --- /dev/null +++ b/src/models/EnvironmentsCreateRequest.ts @@ -0,0 +1,8 @@ +import BaseModel from './base'; + +export namespace EnvironmentsCreateRequest { + export interface Model extends BaseModel { + name: string; + slug: string; + } +} diff --git a/src/models/EnvironmentsGet200Response.ts b/src/models/EnvironmentsGet200Response.ts new file mode 100644 index 0000000..0fcb830 --- /dev/null +++ b/src/models/EnvironmentsGet200Response.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace EnvironmentsGet200Response { + export interface Model extends BaseModel { + environment?: Environment; + } + export interface Environment { + id?: string; + name?: string; + initial_fetch_at?: string; + created_at?: string; + project?: string; + } +} diff --git a/src/models/EnvironmentsList200Response.ts b/src/models/EnvironmentsList200Response.ts new file mode 100644 index 0000000..97044fe --- /dev/null +++ b/src/models/EnvironmentsList200Response.ts @@ -0,0 +1,21 @@ +import BaseModel from './base'; + +export namespace EnvironmentsList200Response { + export type Id = string; + export type Name = string; + export type InitialFetchAt = string; + export type CreatedAt = string; + export type Project = string; + export type Environments = { + id?: Id; + name?: Name; + initial_fetch_at?: InitialFetchAt; + created_at?: CreatedAt; + project?: Project; + }[]; + + export interface Model extends BaseModel { + environments?: Environments; + page?: number; + } +} diff --git a/src/models/EnvironmentsRename200Response.ts b/src/models/EnvironmentsRename200Response.ts new file mode 100644 index 0000000..332d78c --- /dev/null +++ b/src/models/EnvironmentsRename200Response.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace EnvironmentsRename200Response { + export interface Model extends BaseModel { + environment?: Environment; + } + export interface Environment { + id?: string; + name?: string; + initial_fetch_at?: string; + created_at?: string; + project?: string; + } +} diff --git a/src/models/EnvironmentsRenameRequest.ts b/src/models/EnvironmentsRenameRequest.ts new file mode 100644 index 0000000..251f322 --- /dev/null +++ b/src/models/EnvironmentsRenameRequest.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace EnvironmentsRenameRequest { + export interface Model extends BaseModel { + /** + * Desired name + */ + name?: string; + /** + * Desired slug + */ + slug?: string; + } +} diff --git a/src/models/IntegrationsCreate200Response.ts b/src/models/IntegrationsCreate200Response.ts new file mode 100644 index 0000000..ea6b6bd --- /dev/null +++ b/src/models/IntegrationsCreate200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace IntegrationsCreate200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/IntegrationsCreateRequest.ts b/src/models/IntegrationsCreateRequest.ts new file mode 100644 index 0000000..4596482 --- /dev/null +++ b/src/models/IntegrationsCreateRequest.ts @@ -0,0 +1,19 @@ +import BaseModel from './base'; + +export namespace IntegrationsCreateRequest { + export interface Model extends BaseModel { + /** + * The name of the integration + */ + name: string; + data?: Data; + /** + * The integration type + */ + type_: string; + } + /** + * The authentication data for the integration + */ + export interface Data {} +} diff --git a/src/models/IntegrationsDelete200Response.ts b/src/models/IntegrationsDelete200Response.ts new file mode 100644 index 0000000..1bb67a3 --- /dev/null +++ b/src/models/IntegrationsDelete200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace IntegrationsDelete200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/IntegrationsGet200Response.ts b/src/models/IntegrationsGet200Response.ts new file mode 100644 index 0000000..cae6a87 --- /dev/null +++ b/src/models/IntegrationsGet200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace IntegrationsGet200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/IntegrationsUpdate200Response.ts b/src/models/IntegrationsUpdate200Response.ts new file mode 100644 index 0000000..369c6c2 --- /dev/null +++ b/src/models/IntegrationsUpdate200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace IntegrationsUpdate200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/IntegrationsUpdateRequest.ts b/src/models/IntegrationsUpdateRequest.ts new file mode 100644 index 0000000..ae9bbc0 --- /dev/null +++ b/src/models/IntegrationsUpdateRequest.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace IntegrationsUpdateRequest { + export interface Model extends BaseModel { + /** + * The new name of the integration + */ + name?: string; + /** + * The new authentication data for the integration + */ + data?: string; + } +} diff --git a/src/models/ProjectsCreate200Response.ts b/src/models/ProjectsCreate200Response.ts new file mode 100644 index 0000000..f063f8b --- /dev/null +++ b/src/models/ProjectsCreate200Response.ts @@ -0,0 +1,13 @@ +import BaseModel from './base'; + +export namespace ProjectsCreate200Response { + export interface Model extends BaseModel { + project?: Project; + } + export interface Project { + id?: string; + name?: string; + description?: string; + created_at?: string; + } +} diff --git a/src/models/ProjectsCreateRequest.ts b/src/models/ProjectsCreateRequest.ts new file mode 100644 index 0000000..4f9b92e --- /dev/null +++ b/src/models/ProjectsCreateRequest.ts @@ -0,0 +1,14 @@ +import BaseModel from './base'; + +export namespace ProjectsCreateRequest { + export interface Model extends BaseModel { + /** + * Name of project + */ + name: string; + /** + * Description of project + */ + description?: string; + } +} diff --git a/src/models/ProjectsDeleteRequest.ts b/src/models/ProjectsDeleteRequest.ts new file mode 100644 index 0000000..a1f75f5 --- /dev/null +++ b/src/models/ProjectsDeleteRequest.ts @@ -0,0 +1,10 @@ +import BaseModel from './base'; + +export namespace ProjectsDeleteRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + } +} diff --git a/src/models/ProjectsGet200Response.ts b/src/models/ProjectsGet200Response.ts new file mode 100644 index 0000000..e03fb78 --- /dev/null +++ b/src/models/ProjectsGet200Response.ts @@ -0,0 +1,13 @@ +import BaseModel from './base'; + +export namespace ProjectsGet200Response { + export interface Model extends BaseModel { + project?: Project; + } + export interface Project { + id?: string; + name?: string; + description?: string; + created_at?: string; + } +} diff --git a/src/models/ProjectsList200Response.ts b/src/models/ProjectsList200Response.ts new file mode 100644 index 0000000..fc3ad08 --- /dev/null +++ b/src/models/ProjectsList200Response.ts @@ -0,0 +1,21 @@ +import BaseModel from './base'; + +export namespace ProjectsList200Response { + export type Id = string; + export type Slug = string; + export type Name = string; + export type Description = string; + export type CreatedAt = string; + export type Projects = { + id?: Id; + slug?: Slug; + name?: Name; + description?: Description; + created_at?: CreatedAt; + }[]; + + export interface Model extends BaseModel { + page?: number; + projects?: Projects; + } +} diff --git a/src/models/ProjectsUpdate200Response.ts b/src/models/ProjectsUpdate200Response.ts new file mode 100644 index 0000000..89fe3eb --- /dev/null +++ b/src/models/ProjectsUpdate200Response.ts @@ -0,0 +1,13 @@ +import BaseModel from './base'; + +export namespace ProjectsUpdate200Response { + export interface Model extends BaseModel { + project?: Project; + } + export interface Project { + id?: string; + name?: string; + description?: string; + created_at?: string; + } +} diff --git a/src/models/ProjectsUpdateRequest.ts b/src/models/ProjectsUpdateRequest.ts new file mode 100644 index 0000000..17140b7 --- /dev/null +++ b/src/models/ProjectsUpdateRequest.ts @@ -0,0 +1,18 @@ +import BaseModel from './base'; + +export namespace ProjectsUpdateRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the project. + */ + name: string; + /** + * Description of the project. + */ + description?: string; + } +} diff --git a/src/models/README.MD b/src/models/README.MD new file mode 100644 index 0000000..946fa3e --- /dev/null +++ b/src/models/README.MD @@ -0,0 +1,174 @@ +# DopplerSDK Models + +A list of all models. +- [ProjectsList200Response](#projectslist200response) +- [ProjectsCreate200Response](#projectscreate200response) +- [ProjectsCreateRequest](#projectscreaterequest) +- [SecretsUpdate200Response](#secretsupdate200response) +- [SecretsUpdateRequest](#secretsupdaterequest) +- [ConfigLogsList200Response](#configlogslist200response) +- [ConfigLogsGet200Response](#configlogsget200response) +- [EnvironmentsGet200Response](#environmentsget200response) +- [EnvironmentsRename200Response](#environmentsrename200response) +- [EnvironmentsRenameRequest](#environmentsrenamerequest) +- [ProjectsGet200Response](#projectsget200response) +- [ProjectsUpdate200Response](#projectsupdate200response) +- [ProjectsUpdateRequest](#projectsupdaterequest) +- [ProjectsDeleteRequest](#projectsdeleterequest) +- [ConfigsList200Response](#configslist200response) +- [ConfigsCreate200Response](#configscreate200response) +- [ConfigsCreateRequest](#configscreaterequest) +- [ConfigsGet200Response](#configsget200response) +- [ConfigsUpdate200Response](#configsupdate200response) +- [ConfigsUpdateRequest](#configsupdaterequest) +- [ConfigsDelete200Response](#configsdelete200response) +- [ConfigsDeleteRequest](#configsdeleterequest) +- [EnvironmentsList200Response](#environmentslist200response) +- [EnvironmentsCreate200Response](#environmentscreate200response) +- [EnvironmentsCreateRequest](#environmentscreaterequest) +- [ConfigLogsRollback200Response](#configlogsrollback200response) +- [ActivityLogsRetrieve200Response](#activitylogsretrieve200response) +- [ActivityLogsList200Response](#activitylogslist200response) +- [SecretsGet200Response](#secretsget200response) +- [ServiceTokensCreateRequest](#servicetokenscreaterequest) +- [ServiceTokensDelete200Response](#servicetokensdelete200response) +- [ServiceTokensDeleteRequest](#servicetokensdeleterequest) +- [ConfigsClone200Response](#configsclone200response) +- [ConfigsCloneRequest](#configsclonerequest) +- [ConfigsLock200Response](#configslock200response) +- [ConfigsLockRequest](#configslockrequest) +- [ConfigsUnlock200Response](#configsunlock200response) +- [ConfigsUnlockRequest](#configsunlockrequest) +- [SecretsDownload200Response](#secretsdownload200response) +- [DynamicSecretsIssueLeaseRequest](#dynamicsecretsissueleaserequest) +- [DynamicSecretsRevokeLease200Response](#dynamicsecretsrevokelease200response) +- [DynamicSecretsRevokeLeaseRequest](#dynamicsecretsrevokeleaserequest) +- [SecretsListNames200Response](#secretslistnames200response) +- [SecretsUpdateNote200Response](#secretsupdatenote200response) +- [SecretsUpdateNoteRequest](#secretsupdatenoterequest) +- [IntegrationsCreate200Response](#integrationscreate200response) +- [IntegrationsCreateRequest](#integrationscreaterequest) +- [IntegrationsGet200Response](#integrationsget200response) +- [IntegrationsUpdate200Response](#integrationsupdate200response) +- [IntegrationsUpdateRequest](#integrationsupdaterequest) +- [IntegrationsDelete200Response](#integrationsdelete200response) +- [SyncsCreate200Response](#syncscreate200response) +- [SyncsCreateRequest](#syncscreaterequest) +- [SyncsGet200Response](#syncsget200response) +- [SyncsDelete200Response](#syncsdelete200response) +- [V3Me200Response](#v3me200response) + +## ProjectsList200Response + +## ProjectsCreate200Response + +## ProjectsCreateRequest + +## SecretsUpdate200Response + +## SecretsUpdateRequest + +## ConfigLogsList200Response + +## ConfigLogsGet200Response + +## EnvironmentsGet200Response + +## EnvironmentsRename200Response + +## EnvironmentsRenameRequest + +## ProjectsGet200Response + +## ProjectsUpdate200Response + +## ProjectsUpdateRequest + +## ProjectsDeleteRequest + +## ConfigsList200Response + +## ConfigsCreate200Response + +## ConfigsCreateRequest + +## ConfigsGet200Response + +## ConfigsUpdate200Response + +## ConfigsUpdateRequest + +## ConfigsDelete200Response + +## ConfigsDeleteRequest + +## EnvironmentsList200Response + +## EnvironmentsCreate200Response + +## EnvironmentsCreateRequest + +## ConfigLogsRollback200Response + +## ActivityLogsRetrieve200Response + +## ActivityLogsList200Response + +## SecretsGet200Response + +## ServiceTokensCreateRequest + +## ServiceTokensDelete200Response + +## ServiceTokensDeleteRequest + +## ConfigsClone200Response + +## ConfigsCloneRequest + +## ConfigsLock200Response + +## ConfigsLockRequest + +## ConfigsUnlock200Response + +## ConfigsUnlockRequest + +## SecretsDownload200Response + +## DynamicSecretsIssueLeaseRequest + +## DynamicSecretsRevokeLease200Response + +## DynamicSecretsRevokeLeaseRequest + +## SecretsListNames200Response + +## SecretsUpdateNote200Response + +## SecretsUpdateNoteRequest + +## IntegrationsCreate200Response + +## IntegrationsCreateRequest + +## IntegrationsGet200Response + +## IntegrationsUpdate200Response + +## IntegrationsUpdateRequest + +## IntegrationsDelete200Response + +## SyncsCreate200Response + +## SyncsCreateRequest + +## SyncsGet200Response + +## SyncsDelete200Response + +## V3Me200Response + + + diff --git a/src/models/SecretsDownload200Response.ts b/src/models/SecretsDownload200Response.ts new file mode 100644 index 0000000..ab28289 --- /dev/null +++ b/src/models/SecretsDownload200Response.ts @@ -0,0 +1,10 @@ +import BaseModel from './base'; + +export namespace SecretsDownload200Response { + export interface Model extends BaseModel { + STRIPE?: string; + ALGOLIA?: string; + DATABASE?: string; + USER?: string; + } +} diff --git a/src/models/SecretsGet200Response.ts b/src/models/SecretsGet200Response.ts new file mode 100644 index 0000000..d1ac0ed --- /dev/null +++ b/src/models/SecretsGet200Response.ts @@ -0,0 +1,13 @@ +import BaseModel from './base'; + +export namespace SecretsGet200Response { + export interface Model extends BaseModel { + name?: string; + value?: Value; + } + export interface Value { + raw?: string; + computed?: string; + note?: string; + } +} diff --git a/src/models/SecretsListNames200Response.ts b/src/models/SecretsListNames200Response.ts new file mode 100644 index 0000000..3e00203 --- /dev/null +++ b/src/models/SecretsListNames200Response.ts @@ -0,0 +1,9 @@ +import BaseModel from './base'; + +export namespace SecretsListNames200Response { + export type Names = string[]; + + export interface Model extends BaseModel { + names?: Names; + } +} diff --git a/src/models/SecretsUpdate200Response.ts b/src/models/SecretsUpdate200Response.ts new file mode 100644 index 0000000..e3a229b --- /dev/null +++ b/src/models/SecretsUpdate200Response.ts @@ -0,0 +1,27 @@ +import BaseModel from './base'; + +export namespace SecretsUpdate200Response { + export interface Model extends BaseModel { + secrets?: Secrets; + } + export interface Secrets { + STRIPE?: Stripe; + ALGOLIA?: Algolia; + DATABASE?: Database; + } + export interface Stripe { + raw?: string; + computed?: string; + note?: string; + } + export interface Algolia { + raw?: string; + computed?: string; + note?: string; + } + export interface Database { + raw?: string; + computed?: string; + note?: string; + } +} diff --git a/src/models/SecretsUpdateNote200Response.ts b/src/models/SecretsUpdateNote200Response.ts new file mode 100644 index 0000000..8a064b3 --- /dev/null +++ b/src/models/SecretsUpdateNote200Response.ts @@ -0,0 +1,8 @@ +import BaseModel from './base'; + +export namespace SecretsUpdateNote200Response { + export interface Model extends BaseModel { + secret?: string; + note?: string; + } +} diff --git a/src/models/SecretsUpdateNoteRequest.ts b/src/models/SecretsUpdateNoteRequest.ts new file mode 100644 index 0000000..7419775 --- /dev/null +++ b/src/models/SecretsUpdateNoteRequest.ts @@ -0,0 +1,16 @@ +import BaseModel from './base'; + +export namespace SecretsUpdateNoteRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config object. + */ + config: string; + secret: string; + note: string; + } +} diff --git a/src/models/SecretsUpdateRequest.ts b/src/models/SecretsUpdateRequest.ts new file mode 100644 index 0000000..c3b3308 --- /dev/null +++ b/src/models/SecretsUpdateRequest.ts @@ -0,0 +1,23 @@ +import BaseModel from './base'; + +export namespace SecretsUpdateRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config object. + */ + config: string; + secrets: Secrets; + } + /** + * Object of secrets you would like to save to the config. Try it with the sample secrets below: + */ + export interface Secrets { + STRIPE: string; + ALGOLIA?: string; + DATABASE?: string; + } +} diff --git a/src/models/ServiceTokensCreateRequest.ts b/src/models/ServiceTokensCreateRequest.ts new file mode 100644 index 0000000..50c2862 --- /dev/null +++ b/src/models/ServiceTokensCreateRequest.ts @@ -0,0 +1,28 @@ +import BaseModel from './base'; + +export namespace ServiceTokensCreateRequest { + /** + * Token's capabilities. + */ + export type Access = 'read' | 'read/write'; + + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config object. + */ + config: string; + /** + * Name of the service token. + */ + name: string; + /** + * Unix timestamp of when token should expire. + */ + expire_at?: string; + access?: Access; + } +} diff --git a/src/models/ServiceTokensDelete200Response.ts b/src/models/ServiceTokensDelete200Response.ts new file mode 100644 index 0000000..4b11551 --- /dev/null +++ b/src/models/ServiceTokensDelete200Response.ts @@ -0,0 +1,7 @@ +import BaseModel from './base'; + +export namespace ServiceTokensDelete200Response { + export interface Model extends BaseModel { + success?: boolean; + } +} diff --git a/src/models/ServiceTokensDeleteRequest.ts b/src/models/ServiceTokensDeleteRequest.ts new file mode 100644 index 0000000..2f497ca --- /dev/null +++ b/src/models/ServiceTokensDeleteRequest.ts @@ -0,0 +1,22 @@ +import BaseModel from './base'; + +export namespace ServiceTokensDeleteRequest { + export interface Model extends BaseModel { + /** + * Unique identifier for the project object. + */ + project: string; + /** + * Name of the config object. + */ + config: string; + /** + * The slug of the service token. + */ + slug?: string; + /** + * The token value. + */ + token?: string; + } +} diff --git a/src/models/SyncsCreate200Response.ts b/src/models/SyncsCreate200Response.ts new file mode 100644 index 0000000..47af48d --- /dev/null +++ b/src/models/SyncsCreate200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace SyncsCreate200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/SyncsCreateRequest.ts b/src/models/SyncsCreateRequest.ts new file mode 100644 index 0000000..0ce557c --- /dev/null +++ b/src/models/SyncsCreateRequest.ts @@ -0,0 +1,21 @@ +import BaseModel from './base'; + +export namespace SyncsCreateRequest { + /** + * An option indicating if and how Doppler should attempt to import secrets from the sync destination + */ + export type ImportOption = 'none' | 'prefer_doppler' | 'prefer_integration'; + + export interface Model extends BaseModel { + /** + * The integration slug which the sync will use + */ + integration: string; + data: Data; + import_option?: ImportOption; + } + /** + * Configuration data for the sync + */ + export interface Data {} +} diff --git a/src/models/SyncsDelete200Response.ts b/src/models/SyncsDelete200Response.ts new file mode 100644 index 0000000..34aacff --- /dev/null +++ b/src/models/SyncsDelete200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace SyncsDelete200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/SyncsGet200Response.ts b/src/models/SyncsGet200Response.ts new file mode 100644 index 0000000..1a56be7 --- /dev/null +++ b/src/models/SyncsGet200Response.ts @@ -0,0 +1,5 @@ +import BaseModel from './base'; + +export namespace SyncsGet200Response { + export interface Model extends BaseModel {} +} diff --git a/src/models/V3Me200Response.ts b/src/models/V3Me200Response.ts new file mode 100644 index 0000000..da3fbd2 --- /dev/null +++ b/src/models/V3Me200Response.ts @@ -0,0 +1,17 @@ +import BaseModel from './base'; + +export namespace V3Me200Response { + export interface Model extends BaseModel { + slug?: string; + name?: string; + created_at?: string; + last_seen_at?: string; + token_preview?: string; + workplace?: Workplace; + type_?: string; + } + export interface Workplace { + slug?: string; + name?: string; + } +} diff --git a/src/models/base.ts b/src/models/base.ts new file mode 100644 index 0000000..4602860 --- /dev/null +++ b/src/models/base.ts @@ -0,0 +1 @@ +export default interface BaseModel {} diff --git a/src/models/index.ts b/src/models/index.ts new file mode 100644 index 0000000..5e38abb --- /dev/null +++ b/src/models/index.ts @@ -0,0 +1,56 @@ +export * from './ProjectsList200Response'; +export * from './ProjectsCreate200Response'; +export * from './ProjectsCreateRequest'; +export * from './SecretsUpdate200Response'; +export * from './SecretsUpdateRequest'; +export * from './ConfigLogsList200Response'; +export * from './ConfigLogsGet200Response'; +export * from './EnvironmentsGet200Response'; +export * from './EnvironmentsRename200Response'; +export * from './EnvironmentsRenameRequest'; +export * from './ProjectsGet200Response'; +export * from './ProjectsUpdate200Response'; +export * from './ProjectsUpdateRequest'; +export * from './ProjectsDeleteRequest'; +export * from './ConfigsList200Response'; +export * from './ConfigsCreate200Response'; +export * from './ConfigsCreateRequest'; +export * from './ConfigsGet200Response'; +export * from './ConfigsUpdate200Response'; +export * from './ConfigsUpdateRequest'; +export * from './ConfigsDelete200Response'; +export * from './ConfigsDeleteRequest'; +export * from './EnvironmentsList200Response'; +export * from './EnvironmentsCreate200Response'; +export * from './EnvironmentsCreateRequest'; +export * from './ConfigLogsRollback200Response'; +export * from './ActivityLogsRetrieve200Response'; +export * from './ActivityLogsList200Response'; +export * from './SecretsGet200Response'; +export * from './ServiceTokensCreateRequest'; +export * from './ServiceTokensDelete200Response'; +export * from './ServiceTokensDeleteRequest'; +export * from './ConfigsClone200Response'; +export * from './ConfigsCloneRequest'; +export * from './ConfigsLock200Response'; +export * from './ConfigsLockRequest'; +export * from './ConfigsUnlock200Response'; +export * from './ConfigsUnlockRequest'; +export * from './SecretsDownload200Response'; +export * from './DynamicSecretsIssueLeaseRequest'; +export * from './DynamicSecretsRevokeLease200Response'; +export * from './DynamicSecretsRevokeLeaseRequest'; +export * from './SecretsListNames200Response'; +export * from './SecretsUpdateNote200Response'; +export * from './SecretsUpdateNoteRequest'; +export * from './IntegrationsCreate200Response'; +export * from './IntegrationsCreateRequest'; +export * from './IntegrationsGet200Response'; +export * from './IntegrationsUpdate200Response'; +export * from './IntegrationsUpdateRequest'; +export * from './IntegrationsDelete200Response'; +export * from './SyncsCreate200Response'; +export * from './SyncsCreateRequest'; +export * from './SyncsGet200Response'; +export * from './SyncsDelete200Response'; +export * from './V3Me200Response'; diff --git a/src/services/ActivityLogs.ts b/src/services/ActivityLogs.ts new file mode 100644 index 0000000..824e921 --- /dev/null +++ b/src/services/ActivityLogs.ts @@ -0,0 +1,71 @@ +import BaseService from './base'; + +import { ActivityLogsRetrieve200Response } from '../models/ActivityLogsRetrieve200Response'; +import { ActivityLogsList200Response } from '../models/ActivityLogsList200Response'; + +export default class ActivityLogsService extends BaseService { + /** + * @summary Retrieve + * @description Activity Log + + * @param log Unique identifier for the log object. + * @returns {Promise} - The promise with the result + */ + async retrieve(log: string): Promise { + if (log === undefined) { + throw new Error('The following parameter is required: log, cannot be empty or blank'); + } + const queryParams: string[] = []; + if (log) { + queryParams.push(`log=${log}`); + } + const urlEndpoint = '/v3/logs/log'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ActivityLogsRetrieve200Response.Model; + return responseModel; + } + + /** + * @summary List + * @description Activity Logs + + * @param optionalParams - Optional parameters + * @param optionalParams.page - Page number + * @param optionalParams.perPage - Items per page + * @returns {Promise} - The promise with the result + */ + async list( + optionalParams: { page?: string; perPage?: number } = {}, + ): Promise { + const { page, perPage } = optionalParams; + + const queryParams: string[] = []; + if (page) { + queryParams.push(`page=${page}`); + } + if (perPage) { + queryParams.push(`per_page=${perPage}`); + } + const urlEndpoint = '/v3/logs'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ActivityLogsList200Response.Model; + return responseModel; + } +} diff --git a/src/services/ConfigLogs.ts b/src/services/ConfigLogs.ts new file mode 100644 index 0000000..4af33c4 --- /dev/null +++ b/src/services/ConfigLogs.ts @@ -0,0 +1,139 @@ +import BaseService from './base'; + +import { ConfigLogsList200Response } from '../models/ConfigLogsList200Response'; +import { ConfigLogsGet200Response } from '../models/ConfigLogsGet200Response'; +import { ConfigLogsRollback200Response } from '../models/ConfigLogsRollback200Response'; + +export default class ConfigLogsService extends BaseService { + /** + * @summary List + * @description Config Logs + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @param optionalParams - Optional parameters + * @param optionalParams.page - Page number + * @param optionalParams.perPage - Items per page + * @returns {Promise} - The promise with the result + */ + async list( + project: string, + config: string, + optionalParams: { page?: number; perPage?: number } = {}, + ): Promise { + const { page, perPage } = optionalParams; + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (page) { + queryParams.push(`page=${page}`); + } + if (perPage) { + queryParams.push(`per_page=${perPage}`); + } + const urlEndpoint = '/v3/configs/config/logs'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigLogsList200Response.Model; + return responseModel; + } + + /** + * @summary Retrieve + * @description Config Log + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @param log Unique identifier for the log object. + * @returns {Promise} - The promise with the result + */ + async get(project: string, config: string, log: string): Promise { + if (project === undefined || config === undefined || log === undefined) { + throw new Error( + 'The following are required parameters: project,config,log, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (log) { + queryParams.push(`log=${log}`); + } + const urlEndpoint = '/v3/configs/config/logs/log'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigLogsGet200Response.Model; + return responseModel; + } + + /** + * @summary Rollback + * @description Config Log + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @param log Unique identifier for the log object. + * @returns {Promise} - The promise with the result + */ + async rollback( + project: string, + config: string, + log: string, + ): Promise { + if (project === undefined || config === undefined || log === undefined) { + throw new Error( + 'The following are required parameters: project,config,log, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (log) { + queryParams.push(`log=${log}`); + } + const urlEndpoint = '/v3/configs/config/logs/log/rollback'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.post( + finalUrl, + { project, config, log }, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigLogsRollback200Response.Model; + return responseModel; + } +} diff --git a/src/services/Configs.ts b/src/services/Configs.ts new file mode 100644 index 0000000..98d45f0 --- /dev/null +++ b/src/services/Configs.ts @@ -0,0 +1,238 @@ +import BaseService from './base'; + +import { ConfigsList200Response } from '../models/ConfigsList200Response'; +import { ConfigsCreateRequest } from '../models/ConfigsCreateRequest'; +import { ConfigsCreate200Response } from '../models/ConfigsCreate200Response'; +import { ConfigsGet200Response } from '../models/ConfigsGet200Response'; +import { ConfigsUpdateRequest } from '../models/ConfigsUpdateRequest'; +import { ConfigsUpdate200Response } from '../models/ConfigsUpdate200Response'; +import { ConfigsDeleteRequest } from '../models/ConfigsDeleteRequest'; +import { ConfigsDelete200Response } from '../models/ConfigsDelete200Response'; +import { ConfigsCloneRequest } from '../models/ConfigsCloneRequest'; +import { ConfigsClone200Response } from '../models/ConfigsClone200Response'; +import { ConfigsLockRequest } from '../models/ConfigsLockRequest'; +import { ConfigsLock200Response } from '../models/ConfigsLock200Response'; +import { ConfigsUnlockRequest } from '../models/ConfigsUnlockRequest'; +import { ConfigsUnlock200Response } from '../models/ConfigsUnlock200Response'; + +export default class ConfigsService extends BaseService { + /** + * @summary List + * @description Fetch all configs. + + * @param project The project's name + * @param optionalParams - Optional parameters + * @param optionalParams.environment - (optional) the environment from which to list configs + * @param optionalParams.page - Page number + * @param optionalParams.perPage - Items per page + * @returns {Promise} - The promise with the result + */ + async list( + project: string, + optionalParams: { environment?: string; page?: number; perPage?: number } = {}, + ): Promise { + const { environment, page, perPage } = optionalParams; + if (project === undefined) { + throw new Error('The following parameter is required: project, cannot be empty or blank'); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (environment) { + queryParams.push(`environment=${environment}`); + } + if (page) { + queryParams.push(`page=${page}`); + } + if (perPage) { + queryParams.push(`per_page=${perPage}`); + } + const urlEndpoint = '/v3/configs'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsList200Response.Model; + return responseModel; + } + + /** + * @summary Create + * @description Create a new branch config. + + * @returns {Promise} - The promise with the result + */ + async create(input: ConfigsCreateRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsCreate200Response.Model; + return responseModel; + } + + /** + * @summary Retrieve + * @description Fetch a config's details. + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @returns {Promise} - The promise with the result + */ + async get(project: string, config: string): Promise { + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + const urlEndpoint = '/v3/configs/config'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsGet200Response.Model; + return responseModel; + } + + /** + * @summary Update + * @description Modify an existing config. + + * @returns {Promise} - The promise with the result + */ + async update(input: ConfigsUpdateRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsUpdate200Response.Model; + return responseModel; + } + + /** + * @summary Delete + * @description Permanently delete the config. + + * @returns {Promise} - The promise with the result + */ + async delete(input: ConfigsDeleteRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.delete( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsDelete200Response.Model; + return responseModel; + } + + /** + * @summary Clone + * @description Create a new branch config by cloning another. This duplicates a branch config and all its secrets. + + * @returns {Promise} - The promise with the result + */ + async clone(input: ConfigsCloneRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/clone'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsClone200Response.Model; + return responseModel; + } + + /** + * @summary Lock + * @description Prevent the config from being renamed or deleted. + + * @returns {Promise} - The promise with the result + */ + async lock(input: ConfigsLockRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/lock'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsLock200Response.Model; + return responseModel; + } + + /** + * @summary Unlock + * @description Allow the config to be renamed and/or deleted. + + * @returns {Promise} - The promise with the result + */ + async unlock(input: ConfigsUnlockRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/unlock'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ConfigsUnlock200Response.Model; + return responseModel; + } +} diff --git a/src/services/DynamicSecrets.ts b/src/services/DynamicSecrets.ts new file mode 100644 index 0000000..c9e5606 --- /dev/null +++ b/src/services/DynamicSecrets.ts @@ -0,0 +1,54 @@ +import BaseService from './base'; + +import { DynamicSecretsIssueLeaseRequest } from '../models/DynamicSecretsIssueLeaseRequest'; +import { DynamicSecretsRevokeLeaseRequest } from '../models/DynamicSecretsRevokeLeaseRequest'; +import { DynamicSecretsRevokeLease200Response } from '../models/DynamicSecretsRevokeLease200Response'; + +export default class DynamicSecretsService extends BaseService { + /** + * @summary Issue Lease + * @description Issue a lease for a dynamic secret + + * @returns {Promise} - The promise with the result + */ + async issueLease(input: DynamicSecretsIssueLeaseRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/dynamic_secrets/dynamic_secret/leases'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } + + /** + * @summary Revoke Lease + + * @returns {Promise} - The promise with the result + */ + async revokeLease( + input: DynamicSecretsRevokeLeaseRequest.Model, + ): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/dynamic_secrets/dynamic_secret/leases/lease'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.delete( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as DynamicSecretsRevokeLease200Response.Model; + return responseModel; + } +} diff --git a/src/services/Environments.ts b/src/services/Environments.ts new file mode 100644 index 0000000..4e1683d --- /dev/null +++ b/src/services/Environments.ts @@ -0,0 +1,184 @@ +import BaseService from './base'; + +import { EnvironmentsGet200Response } from '../models/EnvironmentsGet200Response'; +import { EnvironmentsRenameRequest } from '../models/EnvironmentsRenameRequest'; +import { EnvironmentsRename200Response } from '../models/EnvironmentsRename200Response'; +import { EnvironmentsList200Response } from '../models/EnvironmentsList200Response'; +import { EnvironmentsCreateRequest } from '../models/EnvironmentsCreateRequest'; +import { EnvironmentsCreate200Response } from '../models/EnvironmentsCreate200Response'; + +export default class EnvironmentsService extends BaseService { + /** + * @summary Retrieve + * @description Environment + + * @param project The project's name + * @param environment The environment's slug + * @returns {Promise} - The promise with the result + */ + async get(project: string, environment: string): Promise { + if (project === undefined || environment === undefined) { + throw new Error( + 'The following are required parameters: project,environment, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (environment) { + queryParams.push(`environment=${environment}`); + } + const urlEndpoint = '/v3/environments/environment'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as EnvironmentsGet200Response.Model; + return responseModel; + } + + /** + * @summary Rename + * @description Environment + + * @param project The project's name + * @param environment The environment's slug + * @returns {Promise} - The promise with the result + */ + async rename( + input: EnvironmentsRenameRequest.Model, + project: string, + environment: string, + ): Promise { + if (project === undefined || environment === undefined) { + throw new Error( + 'The following are required parameters: project,environment, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + if (project) { + queryParams.push(`project=${project}`); + } + if (environment) { + queryParams.push(`environment=${environment}`); + } + const urlEndpoint = '/v3/environments/environment'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.put( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as EnvironmentsRename200Response.Model; + return responseModel; + } + + /** + * @summary Delete + * @description Environment + + * @param project The project's name + * @param environment The environment's slug + * @returns {Promise} - The promise with the result + */ + async delete(project: string, environment: string): Promise { + if (project === undefined || environment === undefined) { + throw new Error( + 'The following are required parameters: project,environment, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (environment) { + queryParams.push(`environment=${environment}`); + } + const urlEndpoint = '/v3/environments/environment'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.delete( + finalUrl, + { project, environment }, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } + + /** + * @summary List + * @description Environments + + * @param project The project's name + * @returns {Promise} - The promise with the result + */ + async list(project: string): Promise { + if (project === undefined) { + throw new Error('The following parameter is required: project, cannot be empty or blank'); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + const urlEndpoint = '/v3/environments'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as EnvironmentsList200Response.Model; + return responseModel; + } + + /** + * @summary Create + * @description Environment + + * @param project The project's name + * @returns {Promise} - The promise with the result + */ + async create( + input: EnvironmentsCreateRequest.Model, + project: string, + ): Promise { + if (project === undefined) { + throw new Error('The following parameter is required: project, cannot be empty or blank'); + } + const queryParams: string[] = []; + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + if (project) { + queryParams.push(`project=${project}`); + } + const urlEndpoint = '/v3/environments'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as EnvironmentsCreate200Response.Model; + return responseModel; + } +} diff --git a/src/services/Integrations.ts b/src/services/Integrations.ts new file mode 100644 index 0000000..037b0fa --- /dev/null +++ b/src/services/Integrations.ts @@ -0,0 +1,148 @@ +import BaseService from './base'; + +import { IntegrationsCreateRequest } from '../models/IntegrationsCreateRequest'; +import { IntegrationsCreate200Response } from '../models/IntegrationsCreate200Response'; +import { IntegrationsGet200Response } from '../models/IntegrationsGet200Response'; +import { IntegrationsUpdateRequest } from '../models/IntegrationsUpdateRequest'; +import { IntegrationsUpdate200Response } from '../models/IntegrationsUpdate200Response'; +import { IntegrationsDelete200Response } from '../models/IntegrationsDelete200Response'; + +export default class IntegrationsService extends BaseService { + /** + * @summary List + * @description List all existing integrations + + * @returns {Promise} - The promise with the result + */ + async list(): Promise { + const urlEndpoint = '/v3/integrations'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } + + /** + * @summary Create + * @description Create a new external integration. + + * @returns {Promise} - The promise with the result + */ + async create( + input: IntegrationsCreateRequest.Model, + ): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/integrations'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as IntegrationsCreate200Response.Model; + return responseModel; + } + + /** + * @summary Retrieve + * @description Retrieve an existing integration + + * @param integration The integration slug + * @returns {Promise} - The promise with the result + */ + async get(integration: string): Promise { + if (integration === undefined) { + throw new Error('The following parameter is required: integration, cannot be empty or blank'); + } + const queryParams: string[] = []; + if (integration) { + queryParams.push(`integration=${integration}`); + } + const urlEndpoint = '/v3/integrations/integration'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as IntegrationsGet200Response.Model; + return responseModel; + } + + /** + * @summary Update + * @description Update an existing integration. + + * @param integration The slug of the integration to update + * @returns {Promise} - The promise with the result + */ + async update( + input: IntegrationsUpdateRequest.Model, + integration: string, + ): Promise { + if (integration === undefined) { + throw new Error('The following parameter is required: integration, cannot be empty or blank'); + } + const queryParams: string[] = []; + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + if (integration) { + queryParams.push(`integration=${integration}`); + } + const urlEndpoint = '/v3/integrations/integration'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.put( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as IntegrationsUpdate200Response.Model; + return responseModel; + } + + /** + * @summary Delete + * @description Delete an existing integration. + + * @param integration The slug of the integration to delete + * @returns {Promise} - The promise with the result + */ + async delete(integration: string): Promise { + if (integration === undefined) { + throw new Error('The following parameter is required: integration, cannot be empty or blank'); + } + const queryParams: string[] = []; + if (integration) { + queryParams.push(`integration=${integration}`); + } + const urlEndpoint = '/v3/integrations/integration'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.delete( + finalUrl, + { integration }, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as IntegrationsDelete200Response.Model; + return responseModel; + } +} diff --git a/src/services/Projects.ts b/src/services/Projects.ts new file mode 100644 index 0000000..d490931 --- /dev/null +++ b/src/services/Projects.ts @@ -0,0 +1,145 @@ +import BaseService from './base'; + +import { ProjectsList200Response } from '../models/ProjectsList200Response'; +import { ProjectsCreateRequest } from '../models/ProjectsCreateRequest'; +import { ProjectsCreate200Response } from '../models/ProjectsCreate200Response'; +import { ProjectsGet200Response } from '../models/ProjectsGet200Response'; +import { ProjectsUpdateRequest } from '../models/ProjectsUpdateRequest'; +import { ProjectsUpdate200Response } from '../models/ProjectsUpdate200Response'; +import { ProjectsDeleteRequest } from '../models/ProjectsDeleteRequest'; + +export default class ProjectsService extends BaseService { + /** + * @summary List + * @description Projects + + * @param optionalParams - Optional parameters + * @param optionalParams.page - Page number + * @param optionalParams.perPage - Items per page + * @returns {Promise} - The promise with the result + */ + async list( + optionalParams: { page?: number; perPage?: number } = {}, + ): Promise { + const { page, perPage } = optionalParams; + + const queryParams: string[] = []; + if (page) { + queryParams.push(`page=${page}`); + } + if (perPage) { + queryParams.push(`per_page=${perPage}`); + } + const urlEndpoint = '/v3/projects'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ProjectsList200Response.Model; + return responseModel; + } + + /** + * @summary Create + * @description Project + + * @returns {Promise} - The promise with the result + */ + async create(input: ProjectsCreateRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/projects'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ProjectsCreate200Response.Model; + return responseModel; + } + + /** + * @summary Retrieve + * @description Project + + * @param project Unique identifier for the project object. + * @returns {Promise} - The promise with the result + */ + async get(project: string): Promise { + if (project === undefined) { + throw new Error('The following parameter is required: project, cannot be empty or blank'); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + const urlEndpoint = '/v3/projects/project'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ProjectsGet200Response.Model; + return responseModel; + } + + /** + * @summary Update + * @description Project + + * @returns {Promise} - The promise with the result + */ + async update(input: ProjectsUpdateRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/projects/project'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ProjectsUpdate200Response.Model; + return responseModel; + } + + /** + * @summary Delete + * @description Project + + * @returns {Promise} - The promise with the result + */ + async delete(input: ProjectsDeleteRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/projects/project'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.delete( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } +} diff --git a/src/services/README.MD b/src/services/README.MD new file mode 100644 index 0000000..c78fa5b --- /dev/null +++ b/src/services/README.MD @@ -0,0 +1,1762 @@ +# DopplerSDK Services +A list of all services and services methods. +- Services + + - [Projects](#projects) + + - [Secrets](#secrets) + + - [ConfigLogs](#configlogs) + + - [Environments](#environments) + + - [Configs](#configs) + + - [ActivityLogs](#activitylogs) + + - [V3](#v3) + + - [ServiceTokens](#servicetokens) + + - [DynamicSecrets](#dynamicsecrets) + + - [Integrations](#integrations) + + - [Syncs](#syncs) +- [All Methods](#all-methods) + + +## Projects + +| Method | Description| +| :-------- | :----------| +| [create](#create) | Create | +| [list](#list) | List | +| [update](#update) | Update | +| [get](#get) | Retrieve | +| [delete](#delete) | Delete | + + +## Secrets + +| Method | Description| +| :-------- | :----------| +| [update](#update) | Update | +| [list](#list) | List | +| [get](#get) | Retrieve | +| [download](#download) | Download | +| [listNames](#listnames) | List | +| [updateNote](#updatenote) | Note | + + +## ConfigLogs + +| Method | Description| +| :-------- | :----------| +| [list](#list) | List | +| [get](#get) | Retrieve | +| [rollback](#rollback) | Rollback | + + +## Environments + +| Method | Description| +| :-------- | :----------| +| [get](#get) | Retrieve | +| [delete](#delete) | Delete | +| [rename](#rename) | Rename | +| [create](#create) | Create | +| [list](#list) | List | + + +## Configs + +| Method | Description| +| :-------- | :----------| +| [create](#create) | Create | +| [list](#list) | List | +| [update](#update) | Update | +| [get](#get) | Retrieve | +| [delete](#delete) | Delete | +| [clone](#clone) | Clone | +| [lock](#lock) | Lock | +| [unlock](#unlock) | Unlock | + + +## ActivityLogs + +| Method | Description| +| :-------- | :----------| +| [retrieve](#retrieve) | Retrieve | +| [list](#list) | List | + + +## V3 + +| Method | Description| +| :-------- | :----------| +| [me](#me) | Me | + + +## ServiceTokens + +| Method | Description| +| :-------- | :----------| +| [create](#create) | Create | +| [list](#list) | List | +| [delete](#delete) | Delete | + + +## DynamicSecrets + +| Method | Description| +| :-------- | :----------| +| [issueLease](#issuelease) | Issue Lease | +| [revokeLease](#revokelease) | Revoke Lease | + + +## Integrations + +| Method | Description| +| :-------- | :----------| +| [create](#create) | Create | +| [list](#list) | List | +| [get](#get) | Retrieve | +| [delete](#delete) | Delete | +| [update](#update) | Update | + + +## Syncs + +| Method | Description| +| :-------- | :----------| +| [create](#create) | Create | +| [get](#get) | Retrieve | +| [delete](#delete) | Delete | + + + + +## All Methods + + +### **create** +Create +- HTTP Method: POST +- Endpoint: /v3/projects + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ProjectsCreate200Response](../models/README.MD#projectscreate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { description: 'PROJECT_DESCRIPTION', name: 'PROJECT_NAME' }; + const result = await sdk.projects.create(input); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/projects + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| page | number | Page number | +| perPage | number | Items per page | + + +**Return Type** + +[ProjectsList200Response](../models/README.MD#projectslist200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.projects.list({ page: 1, perPage: 20 }); + console.log(result); +})(); + +``` + +### **update** +Update +- HTTP Method: POST +- Endpoint: /v3/projects/project + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ProjectsUpdate200Response](../models/README.MD#projectsupdate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + description: 'PROJECT_DESCRIPTION', + name: 'PROJECT_NEW_NAME', + project: 'PROJECT_NAME', + }; + const result = await sdk.projects.update(input); + console.log(result); +})(); + +``` + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/projects/project + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[ProjectsGet200Response](../models/README.MD#projectsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.projects.get('PROJECT_NAME'); + console.log(result); +})(); + +``` + +### **delete** +Delete +- HTTP Method: DELETE +- Endpoint: /v3/projects/project + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { project: 'PROJECT_NAME' }; + const result = await sdk.projects.delete(input); + console.log(result); +})(); + +``` + + +### **update** +Update +- HTTP Method: POST +- Endpoint: /v3/configs/config/secrets + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[SecretsUpdate200Response](../models/README.MD#secretsupdate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + config: 'CONFIG_NAME', + project: 'PROJECT_NAME', + secrets: { + ALGOLIA: 'N9TOPUCTO', + DATABASE: '${USER}@aws.dynamodb.com:9876', + STRIPE: 'sk_test_9YxLnoLDdvOPn2dfjBVPB', + }, + }; + const result = await sdk.secrets.update(input); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/configs/config/secrets + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| accepts | string | Available options are: **application/json**, **text/plain** | +| includeDynamicSecrets | boolean | Whether or not to issue leases and include dynamic secret values for the config | +| dynamicSecretsTtlSec | number | The number of seconds until dynamic leases expire. Must be used with `include_dynamic_secrets`. Defaults to 1800 (30 minutes). | +| secrets | string | A comma-separated list of secrets to include in the response | +| includeManagedSecrets | boolean | Whether to include Doppler's auto-generated (managed) secrets | + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.secrets.list('PROJECT_NAME', 'CONFIG_NAME', { + accepts: 'application/json', + includeDynamicSecrets: true, + dynamicSecretsTtlSec: 58532169, + secrets: 'dolore exercitation nostrud', + includeManagedSecrets: true, + }); + console.log(result); +})(); + +``` + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/configs/config/secret + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | +| name | string | Name of the secret. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[SecretsGet200Response](../models/README.MD#secretsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.secrets.get('PROJECT_NAME', 'CONFIG_NAME', 'SECRET_NAME'); + console.log(result); +})(); + +``` + +### **download** +Download +- HTTP Method: GET +- Endpoint: /v3/configs/config/secrets/download + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. Not required if using a Service Token. | +| config | string | Name of the config object. Not required if using a Service Token. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| format | string | | +| nameTransformer | string | Transform secret names to a different case | +| includeDynamicSecrets | boolean | Whether or not to issue leases and include dynamic secret values for the config | +| dynamicSecretsTtlSec | number | The number of seconds until dynamic leases expire. Must be used with `include_dynamic_secrets`. Defaults to 1800 (30 minutes). | + + +**Return Type** + +[SecretsDownload200Response](../models/README.MD#secretsdownload200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.secrets.download('eiusmod', 'reprehenderit', { + format: 'json', + nameTransformer: 'dotnet-env', + includeDynamicSecrets: true, + dynamicSecretsTtlSec: 1800, + }); + console.log(result); +})(); + +``` + +### **listNames** +List +- HTTP Method: GET +- Endpoint: /v3/configs/config/secrets/names + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| includeDynamicSecrets | boolean | Whether or not to issue leases and include dynamic secret values for the config | +| includeManagedSecrets | boolean | Whether to include Doppler's auto-generated (managed) secrets | + + +**Return Type** + +[SecretsListNames200Response](../models/README.MD#secretslistnames200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.secrets.listNames('PROJECT_NAME', 'CONFIG_NAME', { + includeDynamicSecrets: true, + includeManagedSecrets: true, + }); + console.log(result); +})(); + +``` + +### **updateNote** +Note +- HTTP Method: POST +- Endpoint: /v3/configs/config/secrets/note + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[SecretsUpdateNote200Response](../models/README.MD#secretsupdatenote200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + config: 'CONFIG_NAME', + note: 'amet enim', + project: 'PROJECT_NAME', + secret: 'proident', + }; + const result = await sdk.secrets.updateNote(input); + console.log(result); +})(); + +``` + + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/configs/config/logs + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| page | number | Page number | +| perPage | number | Items per page | + + +**Return Type** + +[ConfigLogsList200Response](../models/README.MD#configlogslist200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.configLogs.list('PROJECT_NAME', 'CONFIG_NAME', { page: 1, perPage: 20 }); + console.log(result); +})(); + +``` + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/configs/config/logs/log + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | +| log | string | Unique identifier for the log object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[ConfigLogsGet200Response](../models/README.MD#configlogsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.configLogs.get('PROJECT_NAME', 'CONFIG_NAME', 'LOG_ID'); + console.log(result); +})(); + +``` + +### **rollback** +Rollback +- HTTP Method: POST +- Endpoint: /v3/configs/config/logs/log/rollback + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | +| log | string | Unique identifier for the log object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[ConfigLogsRollback200Response](../models/README.MD#configlogsrollback200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.configLogs.rollback('PROJECT_NAME', 'CONFIG_NAME', 'LOG_ID'); + console.log(result); +})(); + +``` + + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/environments/environment + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project's name | +| environment | string | The environment's slug | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[EnvironmentsGet200Response](../models/README.MD#environmentsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.environments.get('dolor', 'do deserunt quis Lorem'); + console.log(result); +})(); + +``` + +### **delete** +Delete +- HTTP Method: DELETE +- Endpoint: /v3/environments/environment + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project's name | +| environment | string | The environment's slug | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.environments.delete('tempor dolor aliquip in', 'eiusmod ut'); + console.log(result); +})(); + +``` + +### **rename** +Rename +- HTTP Method: PUT +- Endpoint: /v3/environments/environment + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project's name | +| environment | string | The environment's slug | +| input | object | Request body. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[EnvironmentsRename200Response](../models/README.MD#environmentsrename200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { name: 'nulla minim', slug: 'consectetur sed in' }; + const result = await sdk.environments.rename(input, 'occaecat', 'culpa fugiat nisi'); + console.log(result); +})(); + +``` + +### **create** +Create +- HTTP Method: POST +- Endpoint: /v3/environments + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project's name | +| input | object | Request body. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[EnvironmentsCreate200Response](../models/README.MD#environmentscreate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { name: 'in consequat in', slug: 'commodo est elit laboris aliqua' }; + const result = await sdk.environments.create(input, 'aute dolore eu'); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/environments + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project's name | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[EnvironmentsList200Response](../models/README.MD#environmentslist200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.environments.list('sint'); + console.log(result); +})(); + +``` + + +### **create** +Create +- HTTP Method: POST +- Endpoint: /v3/configs + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ConfigsCreate200Response](../models/README.MD#configscreate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { environment: 'ENVIRONMENT_ID', name: 'CONFIG_NAME', project: 'PROJECT_NAME' }; + const result = await sdk.configs.create(input); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/configs + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project's name | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| environment | string | (optional) the environment from which to list configs | +| page | number | Page number | +| perPage | number | Items per page | + + +**Return Type** + +[ConfigsList200Response](../models/README.MD#configslist200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.configs.list('commodo sunt esse quis', { + environment: 'Environment slug', + page: 1, + perPage: 20, + }); + console.log(result); +})(); + +``` + +### **update** +Update +- HTTP Method: POST +- Endpoint: /v3/configs/config + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ConfigsUpdate200Response](../models/README.MD#configsupdate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { config: 'CONFIG_NAME', name: 'CONFIG_NEW_NAME', project: 'PROJECT_NAME' }; + const result = await sdk.configs.update(input); + console.log(result); +})(); + +``` + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/configs/config + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[ConfigsGet200Response](../models/README.MD#configsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.configs.get('PROJECT_NAME', 'CONFIG_NAME'); + console.log(result); +})(); + +``` + +### **delete** +Delete +- HTTP Method: DELETE +- Endpoint: /v3/configs/config + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ConfigsDelete200Response](../models/README.MD#configsdelete200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { config: 'CONFIG_NAME', project: 'PROJECT_NAME' }; + const result = await sdk.configs.delete(input); + console.log(result); +})(); + +``` + +### **clone** +Clone +- HTTP Method: POST +- Endpoint: /v3/configs/config/clone + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ConfigsClone200Response](../models/README.MD#configsclone200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { config: 'CONFIG_NAME', name: 'NEW_CONFIG_NAME', project: 'PROJECT_NAME' }; + const result = await sdk.configs.clone(input); + console.log(result); +})(); + +``` + +### **lock** +Lock +- HTTP Method: POST +- Endpoint: /v3/configs/config/lock + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ConfigsLock200Response](../models/README.MD#configslock200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { config: 'CONFIG_NAME', project: 'PROJECT_NAME' }; + const result = await sdk.configs.lock(input); + console.log(result); +})(); + +``` + +### **unlock** +Unlock +- HTTP Method: POST +- Endpoint: /v3/configs/config/unlock + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ConfigsUnlock200Response](../models/README.MD#configsunlock200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { config: 'CONFIG_NAME', project: 'PROJECT_NAME' }; + const result = await sdk.configs.unlock(input); + console.log(result); +})(); + +``` + + +### **retrieve** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/logs/log + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| log | string | Unique identifier for the log object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[ActivityLogsRetrieve200Response](../models/README.MD#activitylogsretrieve200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.activityLogs.retrieve('LOG_ID'); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/logs + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| +| page | string | Page number | +| perPage | number | Items per page | + + +**Return Type** + +[ActivityLogsList200Response](../models/README.MD#activitylogslist200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.activityLogs.list({ page: '1', perPage: 20 }); + console.log(result); +})(); + +``` + + +### **me** +Me +- HTTP Method: GET +- Endpoint: /v3/me + + +**Return Type** + +[V3Me200Response](../models/README.MD#v3me200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.v3.me(); + console.log(result); +})(); + +``` + + +### **create** +Create +- HTTP Method: POST +- Endpoint: /v3/configs/config/tokens + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + access: 'read', + config: 'CONFIG_NAME', + expire_at: '1919-10-16T02:51:47.0Z', + name: 'TOKEN_NAME', + project: 'PROJECT_NAME', + }; + const result = await sdk.serviceTokens.create(input); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/configs/config/tokens + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | Unique identifier for the project object. | +| config | string | Name of the config object. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.serviceTokens.list('PROJECT_NAME', 'CONFIG_NAME'); + console.log(result); +})(); + +``` + +### **delete** +Delete +- HTTP Method: DELETE +- Endpoint: /v3/configs/config/tokens/token + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[ServiceTokensDelete200Response](../models/README.MD#servicetokensdelete200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + config: 'CONFIG_NAME', + project: 'PROJECT_NAME', + slug: 'TOKEN_SLUG', + token: 'TOKEN_VALUE', + }; + const result = await sdk.serviceTokens.delete(input); + console.log(result); +})(); + +``` + + +### **issueLease** +Issue Lease +- HTTP Method: POST +- Endpoint: /v3/configs/config/dynamic_secrets/dynamic_secret/leases + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + config: 'aliqua ut', + dynamic_secret: 'velit in', + project: 'amet enim sint sunt fugiat', + ttl_sec: 61886594, + }; + const result = await sdk.dynamicSecrets.issueLease(input); + console.log(result); +})(); + +``` + +### **revokeLease** +Revoke Lease +- HTTP Method: DELETE +- Endpoint: /v3/configs/config/dynamic_secrets/dynamic_secret/leases/lease + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[DynamicSecretsRevokeLease200Response](../models/README.MD#dynamicsecretsrevokelease200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { + config: 'nostrud minim ad sint nulla', + dynamic_secret: 'aliquip', + project: 'sint veniam', + slug: 'Ut minim sit', + }; + const result = await sdk.dynamicSecrets.revokeLease(input); + console.log(result); +})(); + +``` + + +### **create** +Create +- HTTP Method: POST +- Endpoint: /v3/integrations + +**Required Parameters** + +| input | object | Request body. | + + + +**Return Type** + +[IntegrationsCreate200Response](../models/README.MD#integrationscreate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { data: {}, name: 'enim', type_: 'in in' }; + const result = await sdk.integrations.create(input); + console.log(result); +})(); + +``` + +### **list** +List +- HTTP Method: GET +- Endpoint: /v3/integrations + + +**Return Type** + +Returns a dict object. + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.integrations.list(); + console.log(result); +})(); + +``` + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/integrations/integration + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| integration | string | The integration slug | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[IntegrationsGet200Response](../models/README.MD#integrationsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.integrations.get('eu commodo sint est consequat'); + console.log(result); +})(); + +``` + +### **delete** +Delete +- HTTP Method: DELETE +- Endpoint: /v3/integrations/integration + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| integration | string | The slug of the integration to delete | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[IntegrationsDelete200Response](../models/README.MD#integrationsdelete200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.integrations.delete('occaecat exercitation ad minim'); + console.log(result); +})(); + +``` + +### **update** +Update +- HTTP Method: PUT +- Endpoint: /v3/integrations/integration + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| integration | string | The slug of the integration to update | +| input | object | Request body. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[IntegrationsUpdate200Response](../models/README.MD#integrationsupdate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { data: 'est Duis cupidatat occaecat labore', name: 'fugiat ex Ut' }; + const result = await sdk.integrations.update(input, 'consectetur culpa'); + console.log(result); +})(); + +``` + + +### **create** +Create +- HTTP Method: POST +- Endpoint: /v3/configs/config/syncs + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project slug | +| config | string | The config slug | +| input | object | Request body. | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[SyncsCreate200Response](../models/README.MD#syncscreate200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const input = { data: {}, import_option: 'none', integration: 'in dolore' }; + const result = await sdk.syncs.create( + input, + 'esse Ut Duis aliquip commodo', + 'ex Duis est reprehenderit dolore', + ); + console.log(result); +})(); + +``` + +### **get** +Retrieve +- HTTP Method: GET +- Endpoint: /v3/configs/config/syncs/sync + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project slug | +| config | string | The config slug | +| sync | string | The sync slug | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[SyncsGet200Response](../models/README.MD#syncsget200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.syncs.get( + 'adipisicing laboris est exercitation', + 'pariatur cupidatat laboris', + 'cillum mollit veniam cupidatat aute', + ); + console.log(result); +})(); + +``` + +### **delete** +Delete +- HTTP Method: DELETE +- Endpoint: /v3/configs/config/syncs/sync + +**Required Parameters** + +| Name | Type| Description | +| :-------- | :----------| :----------| +| project | string | The project slug | +| config | string | The config slug | +| sync | string | The sync slug | +| deleteFromTarget | boolean | Whether or not to delete the synced data from the target integration | + +**Optional Parameters** + +Optional parameters are passed as part of the last parameter to the method. Ex. {optionalParam1 : 'value1', optionalParam2: 'value2'} + +| Name | Type| Description | +| :-------- | :----------| :----------| + + +**Return Type** + +[SyncsDelete200Response](../models/README.MD#syncsdelete200response) + +**Example Usage Code Snippet** +```Typescript +import { DopplerSDK } from './src'; + +const DOPPLERSDK_BEARER_TOKEN = ''; + +const sdk = new DopplerSDK(DOPPLERSDK_BEARER_TOKEN); + +(async () => { + const result = await sdk.syncs.delete('ad', 'ex ea', 'ea ut amet', true); + console.log(result); +})(); + +``` + + + + diff --git a/src/services/Secrets.ts b/src/services/Secrets.ts new file mode 100644 index 0000000..6920316 --- /dev/null +++ b/src/services/Secrets.ts @@ -0,0 +1,282 @@ +import BaseService from './base'; + +import { SecretsUpdateRequest } from '../models/SecretsUpdateRequest'; +import { SecretsUpdate200Response } from '../models/SecretsUpdate200Response'; +import { SecretsGet200Response } from '../models/SecretsGet200Response'; +import { SecretsDownload200Response } from '../models/SecretsDownload200Response'; +import { SecretsListNames200Response } from '../models/SecretsListNames200Response'; +import { SecretsUpdateNoteRequest } from '../models/SecretsUpdateNoteRequest'; +import { SecretsUpdateNote200Response } from '../models/SecretsUpdateNote200Response'; + +export default class SecretsService extends BaseService { + /** + * @summary List + * @description Secrets + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @param optionalParams - Optional parameters + * @param optionalParams.accepts - Available options are: **application/json**, **text/plain** + * @param optionalParams.includeDynamicSecrets - Whether or not to issue leases and include dynamic secret values for the config + * @param optionalParams.dynamicSecretsTtlSec - The number of seconds until dynamic leases expire. Must be used with `include_dynamic_secrets`. Defaults to 1800 (30 minutes). + * @param optionalParams.secrets - A comma-separated list of secrets to include in the response + * @param optionalParams.includeManagedSecrets - Whether to include Doppler's auto-generated (managed) secrets + * @returns {Promise} - The promise with the result + */ + async list( + project: string, + config: string, + optionalParams: { + accepts?: string; + includeDynamicSecrets?: boolean; + dynamicSecretsTtlSec?: number; + secrets?: string; + includeManagedSecrets?: boolean; + } = {}, + ): Promise { + const { accepts, includeDynamicSecrets, dynamicSecretsTtlSec, secrets, includeManagedSecrets } = + optionalParams; + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + const headers: { [key: string]: string } = {}; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (accepts) { + headers['accepts'] = accepts; + } + if (includeDynamicSecrets) { + queryParams.push(`include_dynamic_secrets=${includeDynamicSecrets}`); + } + if (dynamicSecretsTtlSec) { + queryParams.push(`dynamic_secrets_ttl_sec=${dynamicSecretsTtlSec}`); + } + if (secrets) { + queryParams.push(`secrets=${secrets}`); + } + if (includeManagedSecrets) { + queryParams.push(`include_managed_secrets=${includeManagedSecrets}`); + } + const urlEndpoint = '/v3/configs/config/secrets'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } + + /** + * @summary Update + * @description Secrets + + * @returns {Promise} - The promise with the result + */ + async update(input: SecretsUpdateRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/secrets'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SecretsUpdate200Response.Model; + return responseModel; + } + + /** + * @summary Retrieve + * @description Secret + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @param name Name of the secret. + * @returns {Promise} - The promise with the result + */ + async get(project: string, config: string, name: string): Promise { + if (project === undefined || config === undefined || name === undefined) { + throw new Error( + 'The following are required parameters: project,config,name, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (name) { + queryParams.push(`name=${name}`); + } + const urlEndpoint = '/v3/configs/config/secret'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SecretsGet200Response.Model; + return responseModel; + } + + /** + * @summary Download + * @description Download Secrets + + * @param project Unique identifier for the project object. Not required if using a Service Token. + * @param config Name of the config object. Not required if using a Service Token. + * @param optionalParams - Optional parameters + * @param optionalParams.format - Needed input variable + * @param optionalParams.nameTransformer - Transform secret names to a different case + * @param optionalParams.includeDynamicSecrets - Whether or not to issue leases and include dynamic secret values for the config + * @param optionalParams.dynamicSecretsTtlSec - The number of seconds until dynamic leases expire. Must be used with `include_dynamic_secrets`. Defaults to 1800 (30 minutes). + * @returns {Promise} - The promise with the result + */ + async download( + project: string, + config: string, + optionalParams: { + format?: string; + nameTransformer?: string; + includeDynamicSecrets?: boolean; + dynamicSecretsTtlSec?: number; + } = {}, + ): Promise { + const { format, nameTransformer, includeDynamicSecrets, dynamicSecretsTtlSec } = optionalParams; + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (format) { + queryParams.push(`format=${format}`); + } + if (nameTransformer) { + queryParams.push(`name_transformer=${nameTransformer}`); + } + if (includeDynamicSecrets) { + queryParams.push(`include_dynamic_secrets=${includeDynamicSecrets}`); + } + if (dynamicSecretsTtlSec) { + queryParams.push(`dynamic_secrets_ttl_sec=${dynamicSecretsTtlSec}`); + } + const urlEndpoint = '/v3/configs/config/secrets/download'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SecretsDownload200Response.Model; + return responseModel; + } + + /** + * @summary List + * @description Secret Names + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @param optionalParams - Optional parameters + * @param optionalParams.includeDynamicSecrets - Whether or not to issue leases and include dynamic secret values for the config + * @param optionalParams.includeManagedSecrets - Whether to include Doppler's auto-generated (managed) secrets + * @returns {Promise} - The promise with the result + */ + async listNames( + project: string, + config: string, + optionalParams: { includeDynamicSecrets?: boolean; includeManagedSecrets?: boolean } = {}, + ): Promise { + const { includeDynamicSecrets, includeManagedSecrets } = optionalParams; + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (includeDynamicSecrets) { + queryParams.push(`include_dynamic_secrets=${includeDynamicSecrets}`); + } + if (includeManagedSecrets) { + queryParams.push(`include_managed_secrets=${includeManagedSecrets}`); + } + const urlEndpoint = '/v3/configs/config/secrets/names'; + const urlParams = queryParams.length > 0 ? `?${encodeURI(queryParams.join('&'))}` : ''; + const finalUrl = `${this.baseUrl + urlEndpoint}${urlParams}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SecretsListNames200Response.Model; + return responseModel; + } + + /** + * @summary Note + * @description Set a note on a secret + + * @returns {Promise} - The promise with the result + */ + async updateNote( + input: SecretsUpdateNoteRequest.Model, + ): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/secrets/note'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SecretsUpdateNote200Response.Model; + return responseModel; + } +} diff --git a/src/services/ServiceTokens.ts b/src/services/ServiceTokens.ts new file mode 100644 index 0000000..b7df189 --- /dev/null +++ b/src/services/ServiceTokens.ts @@ -0,0 +1,90 @@ +import BaseService from './base'; + +import { ServiceTokensCreateRequest } from '../models/ServiceTokensCreateRequest'; +import { ServiceTokensDeleteRequest } from '../models/ServiceTokensDeleteRequest'; +import { ServiceTokensDelete200Response } from '../models/ServiceTokensDelete200Response'; + +export default class ServiceTokensService extends BaseService { + /** + * @summary List + * @description Service Tokens + + * @param project Unique identifier for the project object. + * @param config Name of the config object. + * @returns {Promise} - The promise with the result + */ + async list(project: string, config: string): Promise { + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + const urlEndpoint = '/v3/configs/config/tokens'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } + + /** + * @summary Create + * @description Service Token + + * @returns {Promise} - The promise with the result + */ + async create(input: ServiceTokensCreateRequest.Model): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/tokens'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data; + return responseModel; + } + + /** + * @summary Delete + * @description Service Token + + * @returns {Promise} - The promise with the result + */ + async delete( + input: ServiceTokensDeleteRequest.Model, + ): Promise { + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + const urlEndpoint = '/v3/configs/config/tokens/token'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.delete( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as ServiceTokensDelete200Response.Model; + return responseModel; + } +} diff --git a/src/services/Syncs.ts b/src/services/Syncs.ts new file mode 100644 index 0000000..c8a0f04 --- /dev/null +++ b/src/services/Syncs.ts @@ -0,0 +1,141 @@ +import BaseService from './base'; + +import { SyncsCreateRequest } from '../models/SyncsCreateRequest'; +import { SyncsCreate200Response } from '../models/SyncsCreate200Response'; +import { SyncsGet200Response } from '../models/SyncsGet200Response'; +import { SyncsDelete200Response } from '../models/SyncsDelete200Response'; + +export default class SyncsService extends BaseService { + /** + * @summary Create + * @description Create a new secrets sync. + + * @param project The project slug + * @param config The config slug + * @returns {Promise} - The promise with the result + */ + async create( + input: SyncsCreateRequest.Model, + project: string, + config: string, + ): Promise { + if (project === undefined || config === undefined) { + throw new Error( + 'The following are required parameters: project,config, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + const headers: { [key: string]: string } = { 'Content-type': 'application/json' }; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + const urlEndpoint = '/v3/configs/config/syncs'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.post( + finalUrl, + input, + { + ...headers, + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SyncsCreate200Response.Model; + return responseModel; + } + + /** + * @summary Retrieve + * @description Retrieve an existing secrets sync. + + * @param project The project slug + * @param config The config slug + * @param sync The sync slug + * @returns {Promise} - The promise with the result + */ + async get(project: string, config: string, sync: string): Promise { + if (project === undefined || config === undefined || sync === undefined) { + throw new Error( + 'The following are required parameters: project,config,sync, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (sync) { + queryParams.push(`sync=${sync}`); + } + const urlEndpoint = '/v3/configs/config/syncs/sync'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SyncsGet200Response.Model; + return responseModel; + } + + /** + * @summary Delete + * @description Delete an existing sync. + + * @param project The project slug + * @param config The config slug + * @param sync The sync slug + * @param deleteFromTarget Whether or not to delete the synced data from the target integration + * @returns {Promise} - The promise with the result + */ + async delete( + project: string, + config: string, + sync: string, + deleteFromTarget: boolean, + ): Promise { + if ( + project === undefined || + config === undefined || + sync === undefined || + deleteFromTarget === undefined + ) { + throw new Error( + 'The following are required parameters: project,config,sync,deleteFromTarget, cannot be empty or blank', + ); + } + const queryParams: string[] = []; + if (project) { + queryParams.push(`project=${project}`); + } + if (config) { + queryParams.push(`config=${config}`); + } + if (sync) { + queryParams.push(`sync=${sync}`); + } + if (deleteFromTarget) { + queryParams.push(`delete_from_target=${deleteFromTarget}`); + } + const urlEndpoint = '/v3/configs/config/syncs/sync'; + const finalUrl = `${this.baseUrl + urlEndpoint}?${encodeURI(queryParams.join('&'))}`; + const response: any = await this.http.delete( + finalUrl, + { project, config, sync, delete_from_target: deleteFromTarget }, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as SyncsDelete200Response.Model; + return responseModel; + } +} diff --git a/src/services/V3.ts b/src/services/V3.ts new file mode 100644 index 0000000..62d7240 --- /dev/null +++ b/src/services/V3.ts @@ -0,0 +1,26 @@ +import BaseService from './base'; + +import { V3Me200Response } from '../models/V3Me200Response'; + +export default class V3Service extends BaseService { + /** + * @summary Me + * @description Get information about a token + + * @returns {Promise} - The promise with the result + */ + async me(): Promise { + const urlEndpoint = '/v3/me'; + const finalUrl = `${this.baseUrl + urlEndpoint}`; + const response: any = await this.http.get( + finalUrl, + {}, + { + ...this.getAuthorizationHeader(), + }, + true, + ); + const responseModel = response.data as V3Me200Response.Model; + return responseModel; + } +} diff --git a/src/services/base.ts b/src/services/base.ts new file mode 100644 index 0000000..9dcff76 --- /dev/null +++ b/src/services/base.ts @@ -0,0 +1,46 @@ +import HTTPClient from '../http/HTTPClient'; +import { Environment } from '../http/Environment'; +import HTTPLibrary from '../http/HTTPLibrary'; + +export default class BaseService { + private userAgent: string = 'liblab/0.1.11 DopplerSDK/1.0.0 typescript/5.1.6'; + + public baseUrl: string = Environment.DEFAULT; + + public http = new HTTPLibrary(this.userAgent) as HTTPClient; + + private bearer: string = ''; + + setToken(bearer: string): void { + this.bearer = bearer; + } + + getAuthorizationHeader(): object { + const auth = { Authorization: `Bearer ${this.bearer}` }; + + return { ...auth }; + } + + setBaseUrl(url: string): void { + this.baseUrl = url; + } + + constructor(bearerToken: string = '') { + this.setToken(bearerToken); + } + + static patternMatching(value: string, pattern: string, variableName: string): string { + if (!value) { + throw new Error(`${variableName} cannot be null or undefined`); + } + if (!value.match(new RegExp(pattern))) { + throw new Error(`Invalid value for ${variableName}: must match ${pattern}`); + } + return value; + } + + static urlEncode = (input: { [key: string]: any }): string => + Object.keys(input) + .map((key) => `${key}=${encodeURIComponent(input[key])}`) + .join('&'); +} diff --git a/test/services/ActivityLogs.test.ts b/test/services/ActivityLogs.test.ts new file mode 100644 index 0000000..006df90 --- /dev/null +++ b/test/services/ActivityLogs.test.ts @@ -0,0 +1,55 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import ActivityLogsService from '../../src/services/ActivityLogs'; + +describe('test ActivityLogsService object', () => { + it('should be an object', () => { + expect(typeof ActivityLogsService).toBe('function'); + }); +}); + +describe('test ActivityLogsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test retrieve', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/logs/log?log=ea') + .reply(200, { data: {} }); + return sdk.activityLogs.retrieve('ea').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/logs/log?log=minima') + .reply(200, { data: {} }); + return expect(async () => await sdk.activityLogs.retrieve()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/logs/log?log=quae') + .reply(404, { data: {} }); + return expect(async () => await sdk.activityLogs.retrieve('quae')).rejects.toThrow(); + }); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/logs?page=illum&per_page=5') + .reply(200, { data: {} }); + return sdk.activityLogs + .list({ page: 'illum', perPage: 5 }) + .then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/test/services/ConfigLogs.test.ts b/test/services/ConfigLogs.test.ts new file mode 100644 index 0000000..f7aec70 --- /dev/null +++ b/test/services/ConfigLogs.test.ts @@ -0,0 +1,102 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import ConfigLogsService from '../../src/services/ConfigLogs'; + +describe('test ConfigLogsService object', () => { + it('should be an object', () => { + expect(typeof ConfigLogsService).toBe('function'); + }); +}); + +describe('test ConfigLogsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/logs?project=quasi&config=quia&page=3&per_page=1') + .reply(200, { data: {} }); + return sdk.configLogs + .list('quasi', 'quia', { page: 3, perPage: 1 }) + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/logs?project=adipisci&config=blanditiis&page=1&per_page=3') + .reply(200, { data: {} }); + return expect(async () => await sdk.configLogs.list()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/logs?project=quae&config=vero&page=9&per_page=6') + .reply(404, { data: {} }); + return expect( + async () => await sdk.configLogs.list('quae', 'vero', { page: 9, perPage: 6 }), + ).rejects.toThrow(); + }); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/logs/log?project=repudiandae&config=nemo&log=quas') + .reply(200, { data: {} }); + return sdk.configLogs + .get('repudiandae', 'nemo', 'quas') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/logs/log?project=quae&config=ex&log=praesentium') + .reply(200, { data: {} }); + return expect(async () => await sdk.configLogs.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/logs/log?project=laboriosam&config=mollitia&log=quis') + .reply(404, { data: {} }); + return expect( + async () => await sdk.configLogs.get('laboriosam', 'mollitia', 'quis'), + ).rejects.toThrow(); + }); + }); + + describe('test rollback', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/logs/log/rollback?project=ratione&config=corporis&log=minus') + .reply(200, { data: {} }); + return sdk.configLogs + .rollback('ratione', 'corporis', 'minus') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/logs/log/rollback?project=repellendus&config=adipisci&log=ex') + .reply(200, { data: {} }); + return expect(async () => await sdk.configLogs.rollback()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/logs/log/rollback?project=doloribus&config=occaecati&log=quod') + .reply(404, { data: {} }); + return expect( + async () => await sdk.configLogs.rollback('doloribus', 'occaecati', 'quod'), + ).rejects.toThrow(); + }); + }); +}); diff --git a/test/services/Configs.test.ts b/test/services/Configs.test.ts new file mode 100644 index 0000000..770b1d6 --- /dev/null +++ b/test/services/Configs.test.ts @@ -0,0 +1,123 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import ConfigsService from '../../src/services/Configs'; + +describe('test ConfigsService object', () => { + it('should be an object', () => { + expect(typeof ConfigsService).toBe('function'); + }); +}); + +describe('test ConfigsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs?project=quasi&environment=animi&page=5&per_page=1') + .reply(200, { data: {} }); + return sdk.configs + .list('quasi', { environment: 'animi', page: 5, perPage: 1 }) + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs?project=impedit&environment=quisquam&page=8&per_page=5') + .reply(200, { data: {} }); + return expect(async () => await sdk.configs.list()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs?project=facere&environment=velit&page=4&per_page=3') + .reply(404, { data: {} }); + return expect( + async () => await sdk.configs.list('facere', { environment: 'velit', page: 4, perPage: 3 }), + ).rejects.toThrow(); + }); + }); + + describe('test create', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com').post('/v3/configs').reply(200, { data: {} }); + return sdk.configs.create({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config?project=eligendi&config=omnis') + .reply(200, { data: {} }); + return sdk.configs.get('eligendi', 'omnis').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config?project=repudiandae&config=nostrum') + .reply(200, { data: {} }); + return expect(async () => await sdk.configs.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config?project=alias&config=veniam') + .reply(404, { data: {} }); + return expect(async () => await sdk.configs.get('alias', 'veniam')).rejects.toThrow(); + }); + }); + + describe('test update', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config') + .reply(200, { data: {} }); + return sdk.configs.update({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test delete', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/configs/config') + .reply(200, { data: {} }); + return sdk.configs.delete({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test clone', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/clone') + .reply(200, { data: {} }); + return sdk.configs.clone({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test lock', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/lock') + .reply(200, { data: {} }); + return sdk.configs.lock({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test unlock', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/unlock') + .reply(200, { data: {} }); + return sdk.configs.unlock({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/test/services/DynamicSecrets.test.ts b/test/services/DynamicSecrets.test.ts new file mode 100644 index 0000000..f35c35b --- /dev/null +++ b/test/services/DynamicSecrets.test.ts @@ -0,0 +1,39 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import DynamicSecretsService from '../../src/services/DynamicSecrets'; + +describe('test DynamicSecretsService object', () => { + it('should be an object', () => { + expect(typeof DynamicSecretsService).toBe('function'); + }); +}); + +describe('test DynamicSecretsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test issueLease', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/dynamic_secrets/dynamic_secret/leases') + .reply(200, { data: {} }); + return sdk.dynamicSecrets.issueLease({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test revokeLease', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/configs/config/dynamic_secrets/dynamic_secret/leases/lease') + .reply(200, { data: {} }); + return sdk.dynamicSecrets.revokeLease({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/test/services/Environments.test.ts b/test/services/Environments.test.ts new file mode 100644 index 0000000..18e318c --- /dev/null +++ b/test/services/Environments.test.ts @@ -0,0 +1,146 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import EnvironmentsService from '../../src/services/Environments'; + +describe('test EnvironmentsService object', () => { + it('should be an object', () => { + expect(typeof EnvironmentsService).toBe('function'); + }); +}); + +describe('test EnvironmentsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/environments/environment?project=consequuntur&environment=voluptate') + .reply(200, { data: {} }); + return sdk.environments + .get('consequuntur', 'voluptate') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/environments/environment?project=repellat&environment=totam') + .reply(200, { data: {} }); + return expect(async () => await sdk.environments.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/environments/environment?project=maxime&environment=rem') + .reply(404, { data: {} }); + return expect(async () => await sdk.environments.get('maxime', 'rem')).rejects.toThrow(); + }); + }); + + describe('test rename', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .put('/v3/environments/environment?project=veritatis&environment=aut') + .reply(200, { data: {} }); + return sdk.environments + .rename({}, 'veritatis', 'aut') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .put('/v3/environments/environment?project=repudiandae&environment=debitis') + .reply(200, { data: {} }); + return expect(async () => await sdk.environments.rename()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .put('/v3/environments/environment?project=ratione&environment=ducimus') + .reply(404, { data: {} }); + return expect( + async () => await sdk.environments.rename({}, 'ratione', 'ducimus'), + ).rejects.toThrow(); + }); + }); + + describe('test delete', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/environments/environment?project=quas&environment=quibusdam') + .reply(200, { data: {} }); + return sdk.environments + .delete('quas', 'quibusdam') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/environments/environment?project=ut&environment=magnam') + .reply(200, { data: {} }); + return expect(async () => await sdk.environments.delete()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/environments/environment?project=cupiditate&environment=sunt') + .reply(404, { data: {} }); + return expect( + async () => await sdk.environments.delete('cupiditate', 'sunt'), + ).rejects.toThrow(); + }); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/environments?project=minus') + .reply(200, { data: {} }); + return sdk.environments.list('minus').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/environments?project=et') + .reply(200, { data: {} }); + return expect(async () => await sdk.environments.list()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/environments?project=voluptatibus') + .reply(404, { data: {} }); + return expect(async () => await sdk.environments.list('voluptatibus')).rejects.toThrow(); + }); + }); + + describe('test create', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/environments?project=occaecati') + .reply(200, { data: {} }); + return sdk.environments.create({}, 'occaecati').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/environments?project=nobis') + .reply(200, { data: {} }); + return expect(async () => await sdk.environments.create()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/environments?project=pariatur') + .reply(404, { data: {} }); + return expect(async () => await sdk.environments.create({}, 'pariatur')).rejects.toThrow(); + }); + }); +}); diff --git a/test/services/Integrations.test.ts b/test/services/Integrations.test.ts new file mode 100644 index 0000000..cf46a9d --- /dev/null +++ b/test/services/Integrations.test.ts @@ -0,0 +1,108 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import IntegrationsService from '../../src/services/Integrations'; + +describe('test IntegrationsService object', () => { + it('should be an object', () => { + expect(typeof IntegrationsService).toBe('function'); + }); +}); + +describe('test IntegrationsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/integrations') + .reply(200, { data: {} }); + return sdk.integrations.list().then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test create', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/integrations') + .reply(200, { data: {} }); + return sdk.integrations.create({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/integrations/integration?integration=necessitatibus') + .reply(200, { data: {} }); + return sdk.integrations.get('necessitatibus').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/integrations/integration?integration=ab') + .reply(200, { data: {} }); + return expect(async () => await sdk.integrations.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/integrations/integration?integration=suscipit') + .reply(404, { data: {} }); + return expect(async () => await sdk.integrations.get('suscipit')).rejects.toThrow(); + }); + }); + + describe('test update', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .put('/v3/integrations/integration?integration=dolor') + .reply(200, { data: {} }); + return sdk.integrations.update({}, 'dolor').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .put('/v3/integrations/integration?integration=voluptate') + .reply(200, { data: {} }); + return expect(async () => await sdk.integrations.update()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .put('/v3/integrations/integration?integration=cumque') + .reply(404, { data: {} }); + return expect(async () => await sdk.integrations.update({}, 'cumque')).rejects.toThrow(); + }); + }); + + describe('test delete', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/integrations/integration?integration=dolor') + .reply(200, { data: {} }); + return sdk.integrations.delete('dolor').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/integrations/integration?integration=amet') + .reply(200, { data: {} }); + return expect(async () => await sdk.integrations.delete()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/integrations/integration?integration=ducimus') + .reply(404, { data: {} }); + return expect(async () => await sdk.integrations.delete('ducimus')).rejects.toThrow(); + }); + }); +}); diff --git a/test/services/Projects.test.ts b/test/services/Projects.test.ts new file mode 100644 index 0000000..b9af316 --- /dev/null +++ b/test/services/Projects.test.ts @@ -0,0 +1,80 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import ProjectsService from '../../src/services/Projects'; + +describe('test ProjectsService object', () => { + it('should be an object', () => { + expect(typeof ProjectsService).toBe('function'); + }); +}); + +describe('test ProjectsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/projects?page=7&per_page=7') + .reply(200, { data: {} }); + return sdk.projects + .list({ page: 7, perPage: 7 }) + .then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test create', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com').post('/v3/projects').reply(200, { data: {} }); + return sdk.projects.create({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/projects/project?project=perspiciatis') + .reply(200, { data: {} }); + return sdk.projects.get('perspiciatis').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/projects/project?project=eos') + .reply(200, { data: {} }); + return expect(async () => await sdk.projects.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/projects/project?project=similique') + .reply(404, { data: {} }); + return expect(async () => await sdk.projects.get('similique')).rejects.toThrow(); + }); + }); + + describe('test update', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/projects/project') + .reply(200, { data: {} }); + return sdk.projects.update({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test delete', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/projects/project') + .reply(200, { data: {} }); + return sdk.projects.delete({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/test/services/Secrets.test.ts b/test/services/Secrets.test.ts new file mode 100644 index 0000000..a1e51b2 --- /dev/null +++ b/test/services/Secrets.test.ts @@ -0,0 +1,191 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import SecretsService from '../../src/services/Secrets'; + +describe('test SecretsService object', () => { + it('should be an object', () => { + expect(typeof SecretsService).toBe('function'); + }); +}); + +describe('test SecretsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets?project=placeat&config=at&include_dynamic_secrets=true&dynamic_secrets_ttl_sec=9&secrets=in&include_managed_secrets=true', + ) + .reply(200, { data: {} }); + return sdk.secrets + .list('placeat', 'at', { + accepts: 'ut', + includeDynamicSecrets: true, + dynamicSecretsTtlSec: 9, + secrets: 'in', + includeManagedSecrets: true, + }) + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets?project=officiis&config=repudiandae&include_dynamic_secrets=true&dynamic_secrets_ttl_sec=2&secrets=exercitationem&include_managed_secrets=true', + ) + .reply(200, { data: {} }); + return expect(async () => await sdk.secrets.list()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets?project=est&config=voluptatem&include_dynamic_secrets=true&dynamic_secrets_ttl_sec=4&secrets=sint&include_managed_secrets=true', + ) + .reply(404, { data: {} }); + return expect( + async () => + await sdk.secrets.list('est', 'voluptatem', { + accepts: 'illum', + includeDynamicSecrets: true, + dynamicSecretsTtlSec: 4, + secrets: 'sint', + includeManagedSecrets: true, + }), + ).rejects.toThrow(); + }); + }); + + describe('test update', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/secrets') + .reply(200, { data: {} }); + return sdk.secrets.update({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/secret?project=temporibus&config=necessitatibus&name=Annabell') + .reply(200, { data: {} }); + return sdk.secrets + .get('temporibus', 'necessitatibus', 'Annabell') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/secret?project=suscipit&config=saepe&name=Misael') + .reply(200, { data: {} }); + return expect(async () => await sdk.secrets.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/secret?project=iste&config=optio&name=Naomi') + .reply(404, { data: {} }); + return expect(async () => await sdk.secrets.get('iste', 'optio', 'Naomi')).rejects.toThrow(); + }); + }); + + describe('test download', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets/download?project=blanditiis&config=magni&format=json&name_transformer=camel&include_dynamic_secrets=true&dynamic_secrets_ttl_sec=4', + ) + .reply(200, { data: {} }); + return sdk.secrets + .download('blanditiis', 'magni', { + format: 'json', + nameTransformer: 'camel', + includeDynamicSecrets: true, + dynamicSecretsTtlSec: 4, + }) + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets/download?project=non&config=repellendus&format=json&name_transformer=camel&include_dynamic_secrets=true&dynamic_secrets_ttl_sec=1', + ) + .reply(200, { data: {} }); + return expect(async () => await sdk.secrets.download()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets/download?project=officiis&config=dolore&format=json&name_transformer=camel&include_dynamic_secrets=true&dynamic_secrets_ttl_sec=5', + ) + .reply(404, { data: {} }); + return expect( + async () => + await sdk.secrets.download('officiis', 'dolore', { + format: 'json', + nameTransformer: 'camel', + includeDynamicSecrets: true, + dynamicSecretsTtlSec: 5, + }), + ).rejects.toThrow(); + }); + }); + + describe('test listNames', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets/names?project=quam&config=ipsum&include_dynamic_secrets=true&include_managed_secrets=true', + ) + .reply(200, { data: {} }); + return sdk.secrets + .listNames('quam', 'ipsum', { includeDynamicSecrets: true, includeManagedSecrets: true }) + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets/names?project=ipsum&config=sit&include_dynamic_secrets=true&include_managed_secrets=true', + ) + .reply(200, { data: {} }); + return expect(async () => await sdk.secrets.listNames()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get( + '/v3/configs/config/secrets/names?project=molestias&config=aut&include_dynamic_secrets=true&include_managed_secrets=true', + ) + .reply(404, { data: {} }); + return expect( + async () => + await sdk.secrets.listNames('molestias', 'aut', { + includeDynamicSecrets: true, + includeManagedSecrets: true, + }), + ).rejects.toThrow(); + }); + }); + + describe('test updateNote', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/secrets/note') + .reply(200, { data: {} }); + return sdk.secrets.updateNote({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/test/services/ServiceTokens.test.ts b/test/services/ServiceTokens.test.ts new file mode 100644 index 0000000..5e27831 --- /dev/null +++ b/test/services/ServiceTokens.test.ts @@ -0,0 +1,64 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import ServiceTokensService from '../../src/services/ServiceTokens'; + +describe('test ServiceTokensService object', () => { + it('should be an object', () => { + expect(typeof ServiceTokensService).toBe('function'); + }); +}); + +describe('test ServiceTokensService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test list', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/tokens?project=quas&config=quas') + .reply(200, { data: {} }); + return sdk.serviceTokens.list('quas', 'quas').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/tokens?project=temporibus&config=itaque') + .reply(200, { data: {} }); + return expect(async () => await sdk.serviceTokens.list()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/tokens?project=quos&config=aspernatur') + .reply(404, { data: {} }); + return expect( + async () => await sdk.serviceTokens.list('quos', 'aspernatur'), + ).rejects.toThrow(); + }); + }); + + describe('test create', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/tokens') + .reply(200, { data: {} }); + return sdk.serviceTokens.create({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); + + describe('test delete', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete('/v3/configs/config/tokens/token') + .reply(200, { data: {} }); + return sdk.serviceTokens.delete({}).then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/test/services/Syncs.test.ts b/test/services/Syncs.test.ts new file mode 100644 index 0000000..2b483ec --- /dev/null +++ b/test/services/Syncs.test.ts @@ -0,0 +1,104 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import SyncsService from '../../src/services/Syncs'; + +describe('test SyncsService object', () => { + it('should be an object', () => { + expect(typeof SyncsService).toBe('function'); + }); +}); + +describe('test SyncsService', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test create', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/syncs?project=veniam&config=excepturi') + .reply(200, { data: {} }); + return sdk.syncs + .create({}, 'veniam', 'excepturi') + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/syncs?project=assumenda&config=reprehenderit') + .reply(200, { data: {} }); + return expect(async () => await sdk.syncs.create()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .post('/v3/configs/config/syncs?project=mollitia&config=quam') + .reply(404, { data: {} }); + return expect(async () => await sdk.syncs.create({}, 'mollitia', 'quam')).rejects.toThrow(); + }); + }); + + describe('test get', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/syncs/sync?project=libero&config=omnis&sync=esse') + .reply(200, { data: {} }); + return sdk.syncs.get('libero', 'omnis', 'esse').then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/syncs/sync?project=quod&config=ullam&sync=ipsa') + .reply(200, { data: {} }); + return expect(async () => await sdk.syncs.get()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .get('/v3/configs/config/syncs/sync?project=veritatis&config=consequatur&sync=iure') + .reply(404, { data: {} }); + return expect( + async () => await sdk.syncs.get('veritatis', 'consequatur', 'iure'), + ).rejects.toThrow(); + }); + }); + + describe('test delete', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com') + .delete( + '/v3/configs/config/syncs/sync?project=eius&config=voluptate&sync=ipsum&delete_from_target=true', + ) + .reply(200, { data: {} }); + return sdk.syncs + .delete('eius', 'voluptate', 'ipsum', true) + .then((r: any) => expect(r.data).toEqual({})); + }); + + test('test will throw error if required fields missing', () => { + const scope = nock('https://api.doppler.com') + .delete( + '/v3/configs/config/syncs/sync?project=id&config=doloremque&sync=sunt&delete_from_target=true', + ) + .reply(200, { data: {} }); + return expect(async () => await sdk.syncs.delete()).rejects.toThrow(); + }); + + test('test will throw error on a non-200 response', () => { + const scope = nock('https://api.doppler.com') + .delete( + '/v3/configs/config/syncs/sync?project=enim&config=earum&sync=laudantium&delete_from_target=true', + ) + .reply(404, { data: {} }); + return expect( + async () => await sdk.syncs.delete('enim', 'earum', 'laudantium', true), + ).rejects.toThrow(); + }); + }); +}); diff --git a/test/services/V3.test.ts b/test/services/V3.test.ts new file mode 100644 index 0000000..5f78c29 --- /dev/null +++ b/test/services/V3.test.ts @@ -0,0 +1,28 @@ +import nock from 'nock'; + +import { DopplerSDK } from '../../src/'; + +import V3Service from '../../src/services/V3'; + +describe('test V3Service object', () => { + it('should be an object', () => { + expect(typeof V3Service).toBe('function'); + }); +}); + +describe('test V3Service', () => { + let sdk: any; + + beforeEach(() => { + sdk = new DopplerSDK(); + + nock.cleanAll(); + }); + + describe('test me', () => { + test('test api call', () => { + const scope = nock('https://api.doppler.com').get('/v3/me').reply(200, { data: {} }); + return sdk.v3.me().then((r: any) => expect(r.data).toEqual({})); + }); + }); +}); diff --git a/tsconfig.eslint.json b/tsconfig.eslint.json new file mode 100644 index 0000000..7b398aa --- /dev/null +++ b/tsconfig.eslint.json @@ -0,0 +1,6 @@ +{ + "extends": "./tsconfig.json", + "include": [ + "./src", "./test" + ] +} diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..651d48f --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,27 @@ +{ + "compilerOptions": { + "target": "es2018", + "module": "commonjs", + "esModuleInterop": true, + "forceConsistentCasingInFileNames": true, + "strict": true, + "skipLibCheck": true, + "outDir": "./dist", + "rootDir": "./src", + "noImplicitAny": true, + "baseUrl": "./", + "declaration": true, + "moduleResolution": "node", + "isolatedModules": true, + "allowSyntheticDefaultImports": true, + "declarationMap": true, + "lib": ["ES2021.String", "dom", "esnext"], + "sourceMap": true + }, + "include": [ + "./src/" + ], + "exclude": [ + "src/client/@custom_types" + ] +}