├── .editorconfig ├── .eslintrc.js ├── .gitignore ├── .npmignore ├── README.md ├── example ├── .eslintrc.js ├── index.js ├── package.json ├── serverless.yml └── template.yaml ├── img └── circuitbreaker-lambda-diagram.png ├── lib └── circuitbreaker.js ├── package-lock.json └── package.json /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | charset = utf-8 5 | indent_style = space 6 | indent_size = 2 7 | insert_final_newline = true 8 | trim_trailing_whitespace = true 9 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { "extends": "standard" }; -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .vs/ 2 | .vscode/ 3 | .serverless/ 4 | .aws-sam/ 5 | node_modules/ 6 | /samconfig.toml 7 | /index.js 8 | /serverless.yml 9 | /template.yaml 10 | example/.vscode/ 11 | example/.serverless/ 12 | example/.aws-sam/ 13 | example/node_modules/ 14 | example/samconfig.toml 15 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .vscode/ 2 | .serverless 3 | .aws-sam 4 | node_modules/ 5 | example/ 6 | img/ 7 | .editorconfig 8 | .eslintrc.js 9 | samconfig.toml 10 | index.js 11 | serverless.yml 12 | template.yaml -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Circuit breaker for AWS Lambda - circuitbreaker-lambda 2 | 3 | ## Description 4 | 5 | `circuitbreaker-lambda` is a basic Node module for using the circuit breaker pattern in AWS Lambda (https://aws.amazon.com/lambda) and general async functions. It relies on a pass/fail assumption. Thresholds and timeout values are configurable and there is support for using a fallback function for graceful degradation. State and counters for the circuit breaker is stored in an Amazon DynamoDB table. 6 | 7 | ![circuitbreaker-lambda diagram](img/circuitbreaker-lambda-diagram.png) 8 | 9 | ## How to install and configure 10 | 11 | 1. Install `circuitbreaker-lambda` module using NPM. 12 | ```bash 13 | npm install circuitbreaker-lambda 14 | ``` 15 | 2. Import the `circuitbreaker-lambda` module in your Lambda function code. 16 | ```js 17 | const CircuitBreaker = require('circuitbreaker-lambda') 18 | ``` 19 | 3. Add options for the circuit breaker. This is optional and if all or single options are missing the circuit breaker will revert to defaults. 20 | ```js 21 | const options = { 22 | fallback: fallbackFunction, 23 | failureThreshold: 5, 24 | successThreshold: 2, 25 | timeout: 10000 26 | } 27 | ``` 28 | 4. Instantiate the circuit breaker with the function and optional options. 29 | ```js 30 | const circuitBreaker = new CircuitBreaker(unreliableFunction, options) 31 | ``` 32 | 5. Add the fire function for the circuit breaker. 33 | ```js 34 | await circuitBreaker.fire() 35 | ``` 36 | 6. Create an Amazon DynamoDB table with a single attribute primary key. The primary key should be a String with a value of id. 37 | ```bash 38 | aws dynamodb create-table \ 39 | --table-name circuitbreakerLambdaTable \ 40 | --attribute-definitions AttributeName=id,AttributeType=S \ 41 | --key-schema AttributeName=id,KeyType=HASH \ 42 | --billing-mode PAY_PER_REQUEST 43 | ``` 44 | 7. Give the Lambda function GetItem and UpdateItem permissions to the Lambda table. 45 | ```json 46 | { 47 | "Action": [ 48 | "dynamodb:GetItem", 49 | "dynamodb:UpdateItem" 50 | ], 51 | "Resource": "arn:aws:dynamodb:eu-west-1:*:table/circuitbreakerLambdaTable", 52 | "Effect": "Allow" 53 | } 54 | ``` 55 | 8. Add an environment variable to your Lambda function with the key CIRCUITBREAKER_TABLE and the value set to the name of your table in Amazon DynamoDB. 56 | 6. Try it out! 57 | 58 | ## Circuit breaker states 59 | 60 | These are the different states for `circuitbreaker-lambda`. 61 | 62 | * `CLOSED`: Everything is working normally and all calls pass through to the circuit breaker 63 | * `OPEN`: Requests fail for a set amount of time. Fallback is used if configured. 64 | * `HALF`: Requests are let through to test the stability of the call. Fallback is used if configured. 65 | 66 | ## State transitions 67 | 68 | These are the ways `circuitbreaker-lambda` transitions between states. 69 | 70 | * `CLOSED` to `OPEN`: When `failureCount` greater than or equal to `failureThreshold`. 71 | * `OPEN` to `HALF`: When `Date.now()` greater than or equal to `nextAttempt`. 72 | * `HALF` to `OPEN`: When failure occurs in `HALF` state. 73 | * `HALF` to `CLOSED`: When `successCount` greater than or equal to `successThreshold`. 74 | 75 | ## Options 76 | 77 | You can optionally add options and control the behavior of `circuitbreaker-lambda`. 78 | ```js 79 | const options = { 80 | fallback: fallbackFunction, 81 | failureThreshold: 5, 82 | successThreshold: 2, 83 | timeout: 10000 84 | } 85 | ``` 86 | 87 | * `fallback:` Add this option if you wish to use a fallback function in case of failure. Use the name of your function. 88 | * `failureThreshold:` The number of failed attempts before the circuit breaker changes state to `OPEN`. 89 | * `successThreshold` The number of successful attempts while the state is `HALF` before the circuit breaker changes state to `CLOSED`. 90 | * `timeout` The timeout after the circuit breaker changed state to `OPEN` before it will attempt the regular function call again. 91 | 92 | These are the default values used if options aren't defined. 93 | ```js 94 | const defaults = { 95 | fallback: null, 96 | failureThreshold: 5, 97 | successThreshold: 2, 98 | timeout: 10000 99 | } 100 | ``` 101 | 102 | ## Example 103 | 104 | In the subfolder `example` is a simple Serverless Framework template and an AWS SAM template which will install an example application with a Lambda function and a DynamoDB table. The example Lambda function has `circuitbreaker-lambda` installed, an example unreliableFunction which fails about 60 percent of the time (`Math.random() < 0.6`), and an example fallbackFunction. 105 | 106 | ### Serverless Framework Example 107 | ```bash 108 | npm install 109 | sls deploy 110 | ``` 111 | 112 | ### AWS SAM Example 113 | ```bash 114 | npm install 115 | sam build 116 | sam deploy --guided 117 | ``` 118 | 119 | ## Notes 120 | 121 | Inspired by Michael Nygard's book Release it! (https://www.amazon.com/gp/product/0978739213), Martin Fowler's article on the circuit breaker (https://martinfowler.com/bliki/CircuitBreaker.html), and Mark Michon's post on building a Node.js circuit breaker (https://blog.bearer.sh/build-a-circuit-breaker-in-node-js/). 122 | 123 | ## Changelog 124 | 125 | ### 2020-10-10 v0.0.1 126 | 127 | * Initial release 128 | 129 | ## Contributors 130 | 131 | **Gunnar Grosch** - [GitHub](https://github.com/gunnargrosch) | [Twitter](https://twitter.com/gunnargrosch) | [LinkedIn](https://www.linkedin.com/in/gunnargrosch/) 132 | -------------------------------------------------------------------------------- /example/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { "extends": "standard" }; -------------------------------------------------------------------------------- /example/index.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | const CircuitBreaker = require('circuitbreaker-lambda') 3 | let message 4 | 5 | const options = { 6 | fallback: fallbackFunction, 7 | failureThreshold: 3, 8 | successThreshold: 2, 9 | timeout: 10000 10 | } 11 | 12 | function unreliableFunction () { 13 | return new Promise((resolve, reject) => { 14 | if (Math.random() < 0.6) { 15 | resolve({ data: 'Success' }) 16 | message = 'Success' 17 | } else { 18 | reject({ data: 'Failed' }) 19 | message = 'Failed' 20 | } 21 | }) 22 | } 23 | function fallbackFunction () { 24 | return new Promise((resolve, reject) => { 25 | resolve({ data: 'Expensive Fallback Successful' }) 26 | message = 'Fallback' 27 | }) 28 | } 29 | 30 | exports.handler = async (event) => { 31 | const circuitBreaker = new CircuitBreaker(unreliableFunction, options) 32 | await circuitBreaker.fire() 33 | const response = { 34 | statusCode: 200, 35 | body: JSON.stringify({ 36 | message: message 37 | }) 38 | } 39 | return response 40 | } 41 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "circuitbreaker-lambda-example", 3 | "version": "0.0.0", 4 | "description": "", 5 | "dependencies": { 6 | "circuitbreaker-lambda": "" 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /example/serverless.yml: -------------------------------------------------------------------------------- 1 | service: circuitbreaker-lambda-example 2 | frameworkVersion: ">=1.65.0" 3 | provider: 4 | name: aws 5 | runtime: nodejs12.x 6 | memorySize: 128 7 | iamRoleStatements: 8 | - Effect: Allow 9 | Action: 10 | - dynamodb:GetItem 11 | - dynamodb:UpdateItem 12 | Resource: 13 | Fn::Join: 14 | - '' 15 | - - 'arn:aws:dynamodb:${opt:region, self:provider.region}:*:table/' 16 | - Ref: circuitbreakerLambdaTable 17 | 18 | functions: 19 | circuitbreakerLambdaFunction: 20 | handler: index.handler 21 | timeout: 3 22 | environment: 23 | CIRCUITBREAKER_TABLE: 24 | Ref: circuitbreakerLambdaTable 25 | events: 26 | - httpApi: 27 | method: GET 28 | path: /circuitbreakerLambda 29 | 30 | resources: 31 | Resources: 32 | circuitbreakerLambdaTable: 33 | Type: 'AWS::DynamoDB::Table' 34 | DeletionPolicy: Delete 35 | Properties: 36 | AttributeDefinitions: 37 | - 38 | AttributeName: id 39 | AttributeType: S 40 | KeySchema: 41 | - 42 | AttributeName: id 43 | KeyType: HASH 44 | BillingMode: PAY_PER_REQUEST 45 | 46 | package: 47 | exclude: 48 | - ./client/** 49 | - .vscode 50 | - .serverless 51 | -------------------------------------------------------------------------------- /example/template.yaml: -------------------------------------------------------------------------------- 1 | AWSTemplateFormatVersion: '2010-09-09' 2 | Transform: AWS::Serverless-2016-10-31 3 | Description: > 4 | circuitbreaker-lambda-example 5 | 6 | SAM Template for circuitbreaker-lambda-example 7 | 8 | Globals: 9 | Function: 10 | Timeout: 3 11 | Environment: 12 | Variables: 13 | CIRCUITBREAKER_TABLE: 14 | !Select [1, !Split ['/', !GetAtt circuitbreakerLambdaTable.Arn]] 15 | 16 | Resources: 17 | circuitbreakerLambdaFunction: 18 | Type: AWS::Serverless::Function 19 | Properties: 20 | CodeUri: 21 | Handler: index.handler 22 | Runtime: nodejs12.x 23 | Policies: 24 | - DynamoDBCrudPolicy: 25 | TableName: 26 | !Select [1, !Split ['/', !GetAtt circuitbreakerLambdaTable.Arn]] 27 | Events: 28 | circuitbreakerLambda: 29 | Type: HttpApi 30 | Properties: 31 | Path: /circuitbreakerLambda 32 | Method: get 33 | circuitbreakerLambdaTable: 34 | Type: 'AWS::Serverless::SimpleTable' 35 | DeletionPolicy: Delete 36 | Properties: 37 | PrimaryKey: 38 | Name: id 39 | Type: String 40 | 41 | Outputs: 42 | circuitbreakerLambdaFunction: 43 | Description: "circuitbreakerLambdaFunction ARN" 44 | Value: !GetAtt circuitbreakerLambdaFunction.Arn 45 | -------------------------------------------------------------------------------- /img/circuitbreaker-lambda-diagram.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/gunnargrosch/circuitbreaker-lambda/129d8ef478a12286b050f676063a7ebd3757ca88/img/circuitbreaker-lambda-diagram.png -------------------------------------------------------------------------------- /lib/circuitbreaker.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | const AWS = require('aws-sdk') 3 | const circuitBreakerTable = process.env.CIRCUITBREAKER_TABLE 4 | const lambdaFunctionName = process.env.AWS_LAMBDA_FUNCTION_NAME 5 | const dynamoDb = new AWS.DynamoDB.DocumentClient() 6 | 7 | var CircuitBreaker = (function () { 8 | function CircuitBreaker (request, options) { 9 | if (options === undefined) { 10 | options = {} 11 | } 12 | const defaults = { 13 | failureThreshold: 5, 14 | successThreshold: 2, 15 | timeout: 10000, 16 | fallback: null 17 | } 18 | Object.assign(this, defaults, options, { 19 | request: request, 20 | state: 'CLOSED', 21 | failureCount: 0, 22 | successCount: 0, 23 | nextAttempt: Date.now() 24 | }) 25 | } 26 | 27 | var _proto = CircuitBreaker.prototype 28 | 29 | _proto.fire = async function fire () { 30 | const data = await this.getState() 31 | const itemData = data.Item 32 | if (itemData !== undefined) { 33 | this.state = itemData.circuitState 34 | this.failureCount = itemData.failureCount 35 | this.successCount = itemData.successCount 36 | this.nextAttempt = itemData.nextAttempt 37 | } 38 | if (this.state === 'OPEN') { 39 | if (this.nextAttempt <= Date.now()) { 40 | this.half() 41 | } else { 42 | if (this.fallback) { 43 | return this.tryFallback() 44 | } 45 | throw new Error('CircuitBreaker state: OPEN') 46 | } 47 | } 48 | try { 49 | const response = await this.request() 50 | return this.success(response) 51 | } catch (err) { 52 | return this.fail(err) 53 | } 54 | } 55 | 56 | _proto.success = async function success (response) { 57 | if (this.state === 'HALF') { 58 | this.successCount++ 59 | if (this.successCount > this.successThreshold) { 60 | this.close() 61 | } 62 | } 63 | this.failureCount = 0 64 | await this.updateState('Success') 65 | return response 66 | } 67 | 68 | _proto.fail = async function fail (err) { 69 | this.failureCount++ 70 | if (this.failureCount >= this.failureThreshold) { 71 | this.open() 72 | } 73 | await this.updateState('Failure') 74 | if (this.fallback) return this.tryFallback() 75 | return err 76 | } 77 | 78 | _proto.open = function open () { 79 | console.log('CircuitBreaker state: OPEN') 80 | this.state = 'OPEN' 81 | this.nextAttempt = Date.now() + this.timeout 82 | } 83 | 84 | _proto.close = function close () { 85 | console.log('CircuitBreaker state: CLOSED') 86 | this.successCount = 0 87 | this.failureCount = 0 88 | this.state = 'CLOSED' 89 | } 90 | 91 | _proto.half = function half () { 92 | console.log('CircuitBreaker state: HALF') 93 | this.state = 'HALF' 94 | } 95 | 96 | _proto.tryFallback = async function tryFallback () { 97 | console.log('CircuitBreaker Fallback request') 98 | try { 99 | const response = await this.fallback() 100 | return response 101 | } catch (err) { 102 | return err 103 | } 104 | } 105 | 106 | _proto.getState = async function getState () { 107 | try { 108 | const ddbParams = { 109 | TableName: circuitBreakerTable, 110 | Key: { 111 | id: lambdaFunctionName 112 | } 113 | } 114 | const data = await dynamoDb.get(ddbParams).promise() 115 | return data 116 | } catch (err) { 117 | console.error(err) 118 | throw err 119 | } 120 | } 121 | 122 | _proto.updateState = async function updateState (action) { 123 | try { 124 | const ddbParams = { 125 | TableName: circuitBreakerTable, 126 | Key: { 127 | id: lambdaFunctionName 128 | }, 129 | UpdateExpression: 130 | 'set circuitState=:st, failureCount=:fc, successCount=:sc, nextAttempt=:na, stateTimestamp=:ts', 131 | ExpressionAttributeValues: { 132 | ':st': this.state, 133 | ':fc': this.failureCount, 134 | ':sc': this.successCount, 135 | ':na': this.nextAttempt, 136 | ':ts': Date.now() 137 | }, 138 | ReturnValues: 'UPDATED_NEW' 139 | } 140 | const data = await dynamoDb.update(ddbParams).promise() 141 | return data 142 | } catch (err) { 143 | console.log(err) 144 | return err 145 | } 146 | } 147 | return CircuitBreaker 148 | })() 149 | 150 | module.exports = CircuitBreaker 151 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "circuitbreaker-lambda", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.10.4", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 10 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.10.4" 14 | } 15 | }, 16 | "@babel/helper-validator-identifier": { 17 | "version": "7.10.4", 18 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 19 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 20 | "dev": true 21 | }, 22 | "@babel/highlight": { 23 | "version": "7.10.4", 24 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 25 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/helper-validator-identifier": "^7.10.4", 29 | "chalk": "^2.0.0", 30 | "js-tokens": "^4.0.0" 31 | }, 32 | "dependencies": { 33 | "chalk": { 34 | "version": "2.4.2", 35 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 36 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 37 | "dev": true, 38 | "requires": { 39 | "ansi-styles": "^3.2.1", 40 | "escape-string-regexp": "^1.0.5", 41 | "supports-color": "^5.3.0" 42 | } 43 | } 44 | } 45 | }, 46 | "@eslint/eslintrc": { 47 | "version": "0.1.3", 48 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.1.3.tgz", 49 | "integrity": "sha512-4YVwPkANLeNtRjMekzux1ci8hIaH5eGKktGqR0d3LWsKNn5B2X/1Z6Trxy7jQXl9EBGE6Yj02O+t09FMeRllaA==", 50 | "dev": true, 51 | "requires": { 52 | "ajv": "^6.12.4", 53 | "debug": "^4.1.1", 54 | "espree": "^7.3.0", 55 | "globals": "^12.1.0", 56 | "ignore": "^4.0.6", 57 | "import-fresh": "^3.2.1", 58 | "js-yaml": "^3.13.1", 59 | "lodash": "^4.17.19", 60 | "minimatch": "^3.0.4", 61 | "strip-json-comments": "^3.1.1" 62 | } 63 | }, 64 | "@types/json5": { 65 | "version": "0.0.29", 66 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 67 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", 68 | "dev": true 69 | }, 70 | "acorn": { 71 | "version": "7.4.1", 72 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 73 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 74 | "dev": true 75 | }, 76 | "acorn-jsx": { 77 | "version": "5.3.1", 78 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 79 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 80 | "dev": true 81 | }, 82 | "ajv": { 83 | "version": "6.12.5", 84 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.5.tgz", 85 | "integrity": "sha512-lRF8RORchjpKG50/WFf8xmg7sgCLFiYNNnqdKflk63whMQcWR5ngGjiSXkL9bjxy6B2npOK2HSMN49jEBMSkag==", 86 | "dev": true, 87 | "requires": { 88 | "fast-deep-equal": "^3.1.1", 89 | "fast-json-stable-stringify": "^2.0.0", 90 | "json-schema-traverse": "^0.4.1", 91 | "uri-js": "^4.2.2" 92 | } 93 | }, 94 | "ansi-colors": { 95 | "version": "4.1.1", 96 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 97 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 98 | "dev": true 99 | }, 100 | "ansi-regex": { 101 | "version": "5.0.0", 102 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 103 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 104 | "dev": true 105 | }, 106 | "ansi-styles": { 107 | "version": "3.2.1", 108 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 109 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 110 | "dev": true, 111 | "requires": { 112 | "color-convert": "^1.9.0" 113 | } 114 | }, 115 | "argparse": { 116 | "version": "1.0.10", 117 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 118 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 119 | "dev": true, 120 | "requires": { 121 | "sprintf-js": "~1.0.2" 122 | } 123 | }, 124 | "array-includes": { 125 | "version": "3.1.1", 126 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.1.tgz", 127 | "integrity": "sha512-c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ==", 128 | "dev": true, 129 | "requires": { 130 | "define-properties": "^1.1.3", 131 | "es-abstract": "^1.17.0", 132 | "is-string": "^1.0.5" 133 | } 134 | }, 135 | "array.prototype.flat": { 136 | "version": "1.2.3", 137 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.3.tgz", 138 | "integrity": "sha512-gBlRZV0VSmfPIeWfuuy56XZMvbVfbEUnOXUvt3F/eUUUSyzlgLxhEX4YAEpxNAogRGehPSnfXyPtYyKAhkzQhQ==", 139 | "dev": true, 140 | "requires": { 141 | "define-properties": "^1.1.3", 142 | "es-abstract": "^1.17.0-next.1" 143 | } 144 | }, 145 | "astral-regex": { 146 | "version": "1.0.0", 147 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 148 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 149 | "dev": true 150 | }, 151 | "aws-sdk": { 152 | "version": "2.767.0", 153 | "resolved": "https://registry.npmjs.org/aws-sdk/-/aws-sdk-2.767.0.tgz", 154 | "integrity": "sha512-soPZxjNpat0CtuIqm54GO/FDT4SZTlQG0icSptWYfMFYdkXe8b0tJqaPssNn9TzlgoWDCNTdaoepM6TN0rNHkQ==", 155 | "dev": true, 156 | "requires": { 157 | "buffer": "4.9.2", 158 | "events": "1.1.1", 159 | "ieee754": "1.1.13", 160 | "jmespath": "0.15.0", 161 | "querystring": "0.2.0", 162 | "sax": "1.2.1", 163 | "url": "0.10.3", 164 | "uuid": "3.3.2", 165 | "xml2js": "0.4.19" 166 | } 167 | }, 168 | "balanced-match": { 169 | "version": "1.0.0", 170 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 171 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 172 | "dev": true 173 | }, 174 | "base64-js": { 175 | "version": "1.3.1", 176 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", 177 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==", 178 | "dev": true 179 | }, 180 | "brace-expansion": { 181 | "version": "1.1.11", 182 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 183 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 184 | "dev": true, 185 | "requires": { 186 | "balanced-match": "^1.0.0", 187 | "concat-map": "0.0.1" 188 | } 189 | }, 190 | "buffer": { 191 | "version": "4.9.2", 192 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", 193 | "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", 194 | "dev": true, 195 | "requires": { 196 | "base64-js": "^1.0.2", 197 | "ieee754": "^1.1.4", 198 | "isarray": "^1.0.0" 199 | } 200 | }, 201 | "callsites": { 202 | "version": "3.1.0", 203 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 204 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 205 | "dev": true 206 | }, 207 | "chalk": { 208 | "version": "4.1.0", 209 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 210 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 211 | "dev": true, 212 | "requires": { 213 | "ansi-styles": "^4.1.0", 214 | "supports-color": "^7.1.0" 215 | }, 216 | "dependencies": { 217 | "ansi-styles": { 218 | "version": "4.3.0", 219 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 220 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 221 | "dev": true, 222 | "requires": { 223 | "color-convert": "^2.0.1" 224 | } 225 | }, 226 | "color-convert": { 227 | "version": "2.0.1", 228 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 229 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 230 | "dev": true, 231 | "requires": { 232 | "color-name": "~1.1.4" 233 | } 234 | }, 235 | "color-name": { 236 | "version": "1.1.4", 237 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 238 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 239 | "dev": true 240 | }, 241 | "has-flag": { 242 | "version": "4.0.0", 243 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 244 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 245 | "dev": true 246 | }, 247 | "supports-color": { 248 | "version": "7.2.0", 249 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 250 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 251 | "dev": true, 252 | "requires": { 253 | "has-flag": "^4.0.0" 254 | } 255 | } 256 | } 257 | }, 258 | "color-convert": { 259 | "version": "1.9.3", 260 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 261 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 262 | "dev": true, 263 | "requires": { 264 | "color-name": "1.1.3" 265 | } 266 | }, 267 | "color-name": { 268 | "version": "1.1.3", 269 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 270 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 271 | "dev": true 272 | }, 273 | "concat-map": { 274 | "version": "0.0.1", 275 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 276 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 277 | "dev": true 278 | }, 279 | "contains-path": { 280 | "version": "0.1.0", 281 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 282 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 283 | "dev": true 284 | }, 285 | "cross-spawn": { 286 | "version": "7.0.3", 287 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 288 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 289 | "dev": true, 290 | "requires": { 291 | "path-key": "^3.1.0", 292 | "shebang-command": "^2.0.0", 293 | "which": "^2.0.1" 294 | } 295 | }, 296 | "debug": { 297 | "version": "4.2.0", 298 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", 299 | "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", 300 | "dev": true, 301 | "requires": { 302 | "ms": "2.1.2" 303 | } 304 | }, 305 | "deep-is": { 306 | "version": "0.1.3", 307 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 308 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 309 | "dev": true 310 | }, 311 | "define-properties": { 312 | "version": "1.1.3", 313 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 314 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 315 | "dev": true, 316 | "requires": { 317 | "object-keys": "^1.0.12" 318 | } 319 | }, 320 | "doctrine": { 321 | "version": "3.0.0", 322 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 323 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 324 | "dev": true, 325 | "requires": { 326 | "esutils": "^2.0.2" 327 | } 328 | }, 329 | "emoji-regex": { 330 | "version": "7.0.3", 331 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 332 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 333 | "dev": true 334 | }, 335 | "enquirer": { 336 | "version": "2.3.6", 337 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 338 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 339 | "dev": true, 340 | "requires": { 341 | "ansi-colors": "^4.1.1" 342 | } 343 | }, 344 | "error-ex": { 345 | "version": "1.3.2", 346 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 347 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 348 | "dev": true, 349 | "requires": { 350 | "is-arrayish": "^0.2.1" 351 | } 352 | }, 353 | "es-abstract": { 354 | "version": "1.17.7", 355 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.7.tgz", 356 | "integrity": "sha512-VBl/gnfcJ7OercKA9MVaegWsBHFjV492syMudcnQZvt/Dw8ezpcOHYZXa/J96O8vx+g4x65YKhxOwDUh63aS5g==", 357 | "dev": true, 358 | "requires": { 359 | "es-to-primitive": "^1.2.1", 360 | "function-bind": "^1.1.1", 361 | "has": "^1.0.3", 362 | "has-symbols": "^1.0.1", 363 | "is-callable": "^1.2.2", 364 | "is-regex": "^1.1.1", 365 | "object-inspect": "^1.8.0", 366 | "object-keys": "^1.1.1", 367 | "object.assign": "^4.1.1", 368 | "string.prototype.trimend": "^1.0.1", 369 | "string.prototype.trimstart": "^1.0.1" 370 | } 371 | }, 372 | "es-to-primitive": { 373 | "version": "1.2.1", 374 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 375 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 376 | "dev": true, 377 | "requires": { 378 | "is-callable": "^1.1.4", 379 | "is-date-object": "^1.0.1", 380 | "is-symbol": "^1.0.2" 381 | } 382 | }, 383 | "escape-string-regexp": { 384 | "version": "1.0.5", 385 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 386 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 387 | "dev": true 388 | }, 389 | "eslint": { 390 | "version": "7.10.0", 391 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.10.0.tgz", 392 | "integrity": "sha512-BDVffmqWl7JJXqCjAK6lWtcQThZB/aP1HXSH1JKwGwv0LQEdvpR7qzNrUT487RM39B5goWuboFad5ovMBmD8yA==", 393 | "dev": true, 394 | "requires": { 395 | "@babel/code-frame": "^7.0.0", 396 | "@eslint/eslintrc": "^0.1.3", 397 | "ajv": "^6.10.0", 398 | "chalk": "^4.0.0", 399 | "cross-spawn": "^7.0.2", 400 | "debug": "^4.0.1", 401 | "doctrine": "^3.0.0", 402 | "enquirer": "^2.3.5", 403 | "eslint-scope": "^5.1.1", 404 | "eslint-utils": "^2.1.0", 405 | "eslint-visitor-keys": "^1.3.0", 406 | "espree": "^7.3.0", 407 | "esquery": "^1.2.0", 408 | "esutils": "^2.0.2", 409 | "file-entry-cache": "^5.0.1", 410 | "functional-red-black-tree": "^1.0.1", 411 | "glob-parent": "^5.0.0", 412 | "globals": "^12.1.0", 413 | "ignore": "^4.0.6", 414 | "import-fresh": "^3.0.0", 415 | "imurmurhash": "^0.1.4", 416 | "is-glob": "^4.0.0", 417 | "js-yaml": "^3.13.1", 418 | "json-stable-stringify-without-jsonify": "^1.0.1", 419 | "levn": "^0.4.1", 420 | "lodash": "^4.17.19", 421 | "minimatch": "^3.0.4", 422 | "natural-compare": "^1.4.0", 423 | "optionator": "^0.9.1", 424 | "progress": "^2.0.0", 425 | "regexpp": "^3.1.0", 426 | "semver": "^7.2.1", 427 | "strip-ansi": "^6.0.0", 428 | "strip-json-comments": "^3.1.0", 429 | "table": "^5.2.3", 430 | "text-table": "^0.2.0", 431 | "v8-compile-cache": "^2.0.3" 432 | } 433 | }, 434 | "eslint-config-standard": { 435 | "version": "14.1.1", 436 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-14.1.1.tgz", 437 | "integrity": "sha512-Z9B+VR+JIXRxz21udPTL9HpFMyoMUEeX1G251EQ6e05WD9aPVtVBn09XUmZ259wCMlCDmYDSZG62Hhm+ZTJcUg==", 438 | "dev": true 439 | }, 440 | "eslint-import-resolver-node": { 441 | "version": "0.3.4", 442 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.4.tgz", 443 | "integrity": "sha512-ogtf+5AB/O+nM6DIeBUNr2fuT7ot9Qg/1harBfBtaP13ekEWFQEEMP94BCB7zaNW3gyY+8SHYF00rnqYwXKWOA==", 444 | "dev": true, 445 | "requires": { 446 | "debug": "^2.6.9", 447 | "resolve": "^1.13.1" 448 | }, 449 | "dependencies": { 450 | "debug": { 451 | "version": "2.6.9", 452 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 453 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 454 | "dev": true, 455 | "requires": { 456 | "ms": "2.0.0" 457 | } 458 | }, 459 | "ms": { 460 | "version": "2.0.0", 461 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 462 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 463 | "dev": true 464 | } 465 | } 466 | }, 467 | "eslint-module-utils": { 468 | "version": "2.6.0", 469 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz", 470 | "integrity": "sha512-6j9xxegbqe8/kZY8cYpcp0xhbK0EgJlg3g9mib3/miLaExuuwc3n5UEfSnU6hWMbT0FAYVvDbL9RrRgpUeQIvA==", 471 | "dev": true, 472 | "requires": { 473 | "debug": "^2.6.9", 474 | "pkg-dir": "^2.0.0" 475 | }, 476 | "dependencies": { 477 | "debug": { 478 | "version": "2.6.9", 479 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 480 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 481 | "dev": true, 482 | "requires": { 483 | "ms": "2.0.0" 484 | } 485 | }, 486 | "ms": { 487 | "version": "2.0.0", 488 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 489 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 490 | "dev": true 491 | } 492 | } 493 | }, 494 | "eslint-plugin-es": { 495 | "version": "3.0.1", 496 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-3.0.1.tgz", 497 | "integrity": "sha512-GUmAsJaN4Fc7Gbtl8uOBlayo2DqhwWvEzykMHSCZHU3XdJ+NSzzZcVhXh3VxX5icqQ+oQdIEawXX8xkR3mIFmQ==", 498 | "dev": true, 499 | "requires": { 500 | "eslint-utils": "^2.0.0", 501 | "regexpp": "^3.0.0" 502 | } 503 | }, 504 | "eslint-plugin-import": { 505 | "version": "2.22.1", 506 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.22.1.tgz", 507 | "integrity": "sha512-8K7JjINHOpH64ozkAhpT3sd+FswIZTfMZTjdx052pnWrgRCVfp8op9tbjpAk3DdUeI/Ba4C8OjdC0r90erHEOw==", 508 | "dev": true, 509 | "requires": { 510 | "array-includes": "^3.1.1", 511 | "array.prototype.flat": "^1.2.3", 512 | "contains-path": "^0.1.0", 513 | "debug": "^2.6.9", 514 | "doctrine": "1.5.0", 515 | "eslint-import-resolver-node": "^0.3.4", 516 | "eslint-module-utils": "^2.6.0", 517 | "has": "^1.0.3", 518 | "minimatch": "^3.0.4", 519 | "object.values": "^1.1.1", 520 | "read-pkg-up": "^2.0.0", 521 | "resolve": "^1.17.0", 522 | "tsconfig-paths": "^3.9.0" 523 | }, 524 | "dependencies": { 525 | "debug": { 526 | "version": "2.6.9", 527 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 528 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 529 | "dev": true, 530 | "requires": { 531 | "ms": "2.0.0" 532 | } 533 | }, 534 | "doctrine": { 535 | "version": "1.5.0", 536 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 537 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 538 | "dev": true, 539 | "requires": { 540 | "esutils": "^2.0.2", 541 | "isarray": "^1.0.0" 542 | } 543 | }, 544 | "ms": { 545 | "version": "2.0.0", 546 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 547 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 548 | "dev": true 549 | } 550 | } 551 | }, 552 | "eslint-plugin-node": { 553 | "version": "11.1.0", 554 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-11.1.0.tgz", 555 | "integrity": "sha512-oUwtPJ1W0SKD0Tr+wqu92c5xuCeQqB3hSCHasn/ZgjFdA9iDGNkNf2Zi9ztY7X+hNuMib23LNGRm6+uN+KLE3g==", 556 | "dev": true, 557 | "requires": { 558 | "eslint-plugin-es": "^3.0.0", 559 | "eslint-utils": "^2.0.0", 560 | "ignore": "^5.1.1", 561 | "minimatch": "^3.0.4", 562 | "resolve": "^1.10.1", 563 | "semver": "^6.1.0" 564 | }, 565 | "dependencies": { 566 | "ignore": { 567 | "version": "5.1.8", 568 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 569 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 570 | "dev": true 571 | }, 572 | "semver": { 573 | "version": "6.3.0", 574 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 575 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 576 | "dev": true 577 | } 578 | } 579 | }, 580 | "eslint-plugin-promise": { 581 | "version": "4.2.1", 582 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-4.2.1.tgz", 583 | "integrity": "sha512-VoM09vT7bfA7D+upt+FjeBO5eHIJQBUWki1aPvB+vbNiHS3+oGIJGIeyBtKQTME6UPXXy3vV07OL1tHd3ANuDw==", 584 | "dev": true 585 | }, 586 | "eslint-plugin-standard": { 587 | "version": "4.0.1", 588 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-4.0.1.tgz", 589 | "integrity": "sha512-v/KBnfyaOMPmZc/dmc6ozOdWqekGp7bBGq4jLAecEfPGmfKiWS4sA8sC0LqiV9w5qmXAtXVn4M3p1jSyhY85SQ==", 590 | "dev": true 591 | }, 592 | "eslint-scope": { 593 | "version": "5.1.1", 594 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 595 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 596 | "dev": true, 597 | "requires": { 598 | "esrecurse": "^4.3.0", 599 | "estraverse": "^4.1.1" 600 | } 601 | }, 602 | "eslint-utils": { 603 | "version": "2.1.0", 604 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 605 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 606 | "dev": true, 607 | "requires": { 608 | "eslint-visitor-keys": "^1.1.0" 609 | } 610 | }, 611 | "eslint-visitor-keys": { 612 | "version": "1.3.0", 613 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 614 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 615 | "dev": true 616 | }, 617 | "espree": { 618 | "version": "7.3.0", 619 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.0.tgz", 620 | "integrity": "sha512-dksIWsvKCixn1yrEXO8UosNSxaDoSYpq9reEjZSbHLpT5hpaCAKTLBwq0RHtLrIr+c0ByiYzWT8KTMRzoRCNlw==", 621 | "dev": true, 622 | "requires": { 623 | "acorn": "^7.4.0", 624 | "acorn-jsx": "^5.2.0", 625 | "eslint-visitor-keys": "^1.3.0" 626 | } 627 | }, 628 | "esprima": { 629 | "version": "4.0.1", 630 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 631 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 632 | "dev": true 633 | }, 634 | "esquery": { 635 | "version": "1.3.1", 636 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 637 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 638 | "dev": true, 639 | "requires": { 640 | "estraverse": "^5.1.0" 641 | }, 642 | "dependencies": { 643 | "estraverse": { 644 | "version": "5.2.0", 645 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 646 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 647 | "dev": true 648 | } 649 | } 650 | }, 651 | "esrecurse": { 652 | "version": "4.3.0", 653 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 654 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 655 | "dev": true, 656 | "requires": { 657 | "estraverse": "^5.2.0" 658 | }, 659 | "dependencies": { 660 | "estraverse": { 661 | "version": "5.2.0", 662 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 663 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 664 | "dev": true 665 | } 666 | } 667 | }, 668 | "estraverse": { 669 | "version": "4.3.0", 670 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 671 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 672 | "dev": true 673 | }, 674 | "esutils": { 675 | "version": "2.0.3", 676 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 677 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 678 | "dev": true 679 | }, 680 | "events": { 681 | "version": "1.1.1", 682 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", 683 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", 684 | "dev": true 685 | }, 686 | "fast-deep-equal": { 687 | "version": "3.1.3", 688 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 689 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 690 | "dev": true 691 | }, 692 | "fast-json-stable-stringify": { 693 | "version": "2.1.0", 694 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 695 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 696 | "dev": true 697 | }, 698 | "fast-levenshtein": { 699 | "version": "2.0.6", 700 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 701 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 702 | "dev": true 703 | }, 704 | "file-entry-cache": { 705 | "version": "5.0.1", 706 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 707 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 708 | "dev": true, 709 | "requires": { 710 | "flat-cache": "^2.0.1" 711 | } 712 | }, 713 | "find-up": { 714 | "version": "2.1.0", 715 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 716 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 717 | "dev": true, 718 | "requires": { 719 | "locate-path": "^2.0.0" 720 | } 721 | }, 722 | "flat-cache": { 723 | "version": "2.0.1", 724 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 725 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 726 | "dev": true, 727 | "requires": { 728 | "flatted": "^2.0.0", 729 | "rimraf": "2.6.3", 730 | "write": "1.0.3" 731 | } 732 | }, 733 | "flatted": { 734 | "version": "2.0.2", 735 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 736 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 737 | "dev": true 738 | }, 739 | "fs.realpath": { 740 | "version": "1.0.0", 741 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 742 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 743 | "dev": true 744 | }, 745 | "function-bind": { 746 | "version": "1.1.1", 747 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 748 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 749 | "dev": true 750 | }, 751 | "functional-red-black-tree": { 752 | "version": "1.0.1", 753 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 754 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 755 | "dev": true 756 | }, 757 | "glob": { 758 | "version": "7.1.6", 759 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 760 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 761 | "dev": true, 762 | "requires": { 763 | "fs.realpath": "^1.0.0", 764 | "inflight": "^1.0.4", 765 | "inherits": "2", 766 | "minimatch": "^3.0.4", 767 | "once": "^1.3.0", 768 | "path-is-absolute": "^1.0.0" 769 | } 770 | }, 771 | "glob-parent": { 772 | "version": "5.1.1", 773 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 774 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 775 | "dev": true, 776 | "requires": { 777 | "is-glob": "^4.0.1" 778 | } 779 | }, 780 | "globals": { 781 | "version": "12.4.0", 782 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 783 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 784 | "dev": true, 785 | "requires": { 786 | "type-fest": "^0.8.1" 787 | } 788 | }, 789 | "graceful-fs": { 790 | "version": "4.2.4", 791 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 792 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 793 | "dev": true 794 | }, 795 | "has": { 796 | "version": "1.0.3", 797 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 798 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 799 | "dev": true, 800 | "requires": { 801 | "function-bind": "^1.1.1" 802 | } 803 | }, 804 | "has-flag": { 805 | "version": "3.0.0", 806 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 807 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 808 | "dev": true 809 | }, 810 | "has-symbols": { 811 | "version": "1.0.1", 812 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 813 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 814 | "dev": true 815 | }, 816 | "hosted-git-info": { 817 | "version": "2.8.8", 818 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz", 819 | "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==", 820 | "dev": true 821 | }, 822 | "ieee754": { 823 | "version": "1.1.13", 824 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 825 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==", 826 | "dev": true 827 | }, 828 | "ignore": { 829 | "version": "4.0.6", 830 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 831 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 832 | "dev": true 833 | }, 834 | "import-fresh": { 835 | "version": "3.2.1", 836 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 837 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 838 | "dev": true, 839 | "requires": { 840 | "parent-module": "^1.0.0", 841 | "resolve-from": "^4.0.0" 842 | } 843 | }, 844 | "imurmurhash": { 845 | "version": "0.1.4", 846 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 847 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 848 | "dev": true 849 | }, 850 | "inflight": { 851 | "version": "1.0.6", 852 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 853 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 854 | "dev": true, 855 | "requires": { 856 | "once": "^1.3.0", 857 | "wrappy": "1" 858 | } 859 | }, 860 | "inherits": { 861 | "version": "2.0.4", 862 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 863 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 864 | "dev": true 865 | }, 866 | "is-arrayish": { 867 | "version": "0.2.1", 868 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 869 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 870 | "dev": true 871 | }, 872 | "is-callable": { 873 | "version": "1.2.2", 874 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.2.tgz", 875 | "integrity": "sha512-dnMqspv5nU3LoewK2N/y7KLtxtakvTuaCsU9FU50/QDmdbHNy/4/JuRtMHqRU22o3q+W89YQndQEeCVwK+3qrA==", 876 | "dev": true 877 | }, 878 | "is-date-object": { 879 | "version": "1.0.2", 880 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 881 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 882 | "dev": true 883 | }, 884 | "is-extglob": { 885 | "version": "2.1.1", 886 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 887 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 888 | "dev": true 889 | }, 890 | "is-fullwidth-code-point": { 891 | "version": "2.0.0", 892 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 893 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 894 | "dev": true 895 | }, 896 | "is-glob": { 897 | "version": "4.0.1", 898 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 899 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 900 | "dev": true, 901 | "requires": { 902 | "is-extglob": "^2.1.1" 903 | } 904 | }, 905 | "is-negative-zero": { 906 | "version": "2.0.0", 907 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.0.tgz", 908 | "integrity": "sha1-lVOxIbD6wohp2p7UWeIMdUN4hGE=", 909 | "dev": true 910 | }, 911 | "is-regex": { 912 | "version": "1.1.1", 913 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz", 914 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==", 915 | "dev": true, 916 | "requires": { 917 | "has-symbols": "^1.0.1" 918 | } 919 | }, 920 | "is-string": { 921 | "version": "1.0.5", 922 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 923 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 924 | "dev": true 925 | }, 926 | "is-symbol": { 927 | "version": "1.0.3", 928 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 929 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 930 | "dev": true, 931 | "requires": { 932 | "has-symbols": "^1.0.1" 933 | } 934 | }, 935 | "isarray": { 936 | "version": "1.0.0", 937 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 938 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 939 | "dev": true 940 | }, 941 | "isexe": { 942 | "version": "2.0.0", 943 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 944 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 945 | "dev": true 946 | }, 947 | "jmespath": { 948 | "version": "0.15.0", 949 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 950 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=", 951 | "dev": true 952 | }, 953 | "js-tokens": { 954 | "version": "4.0.0", 955 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 956 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 957 | "dev": true 958 | }, 959 | "js-yaml": { 960 | "version": "3.14.0", 961 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 962 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 963 | "dev": true, 964 | "requires": { 965 | "argparse": "^1.0.7", 966 | "esprima": "^4.0.0" 967 | } 968 | }, 969 | "json-schema-traverse": { 970 | "version": "0.4.1", 971 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 972 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 973 | "dev": true 974 | }, 975 | "json-stable-stringify-without-jsonify": { 976 | "version": "1.0.1", 977 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 978 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 979 | "dev": true 980 | }, 981 | "json5": { 982 | "version": "1.0.1", 983 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 984 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 985 | "dev": true, 986 | "requires": { 987 | "minimist": "^1.2.0" 988 | } 989 | }, 990 | "levn": { 991 | "version": "0.4.1", 992 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 993 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 994 | "dev": true, 995 | "requires": { 996 | "prelude-ls": "^1.2.1", 997 | "type-check": "~0.4.0" 998 | } 999 | }, 1000 | "load-json-file": { 1001 | "version": "2.0.0", 1002 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1003 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1004 | "dev": true, 1005 | "requires": { 1006 | "graceful-fs": "^4.1.2", 1007 | "parse-json": "^2.2.0", 1008 | "pify": "^2.0.0", 1009 | "strip-bom": "^3.0.0" 1010 | } 1011 | }, 1012 | "locate-path": { 1013 | "version": "2.0.0", 1014 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1015 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1016 | "dev": true, 1017 | "requires": { 1018 | "p-locate": "^2.0.0", 1019 | "path-exists": "^3.0.0" 1020 | } 1021 | }, 1022 | "lodash": { 1023 | "version": "4.17.20", 1024 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", 1025 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", 1026 | "dev": true 1027 | }, 1028 | "minimatch": { 1029 | "version": "3.0.4", 1030 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1031 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1032 | "dev": true, 1033 | "requires": { 1034 | "brace-expansion": "^1.1.7" 1035 | } 1036 | }, 1037 | "minimist": { 1038 | "version": "1.2.5", 1039 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1040 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1041 | "dev": true 1042 | }, 1043 | "mkdirp": { 1044 | "version": "0.5.5", 1045 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1046 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1047 | "dev": true, 1048 | "requires": { 1049 | "minimist": "^1.2.5" 1050 | } 1051 | }, 1052 | "ms": { 1053 | "version": "2.1.2", 1054 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1055 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1056 | "dev": true 1057 | }, 1058 | "natural-compare": { 1059 | "version": "1.4.0", 1060 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1061 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1062 | "dev": true 1063 | }, 1064 | "normalize-package-data": { 1065 | "version": "2.5.0", 1066 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1067 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1068 | "dev": true, 1069 | "requires": { 1070 | "hosted-git-info": "^2.1.4", 1071 | "resolve": "^1.10.0", 1072 | "semver": "2 || 3 || 4 || 5", 1073 | "validate-npm-package-license": "^3.0.1" 1074 | }, 1075 | "dependencies": { 1076 | "semver": { 1077 | "version": "5.7.1", 1078 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1079 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1080 | "dev": true 1081 | } 1082 | } 1083 | }, 1084 | "object-inspect": { 1085 | "version": "1.8.0", 1086 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1087 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 1088 | "dev": true 1089 | }, 1090 | "object-keys": { 1091 | "version": "1.1.1", 1092 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1093 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1094 | "dev": true 1095 | }, 1096 | "object.assign": { 1097 | "version": "4.1.1", 1098 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.1.tgz", 1099 | "integrity": "sha512-VT/cxmx5yaoHSOTSyrCygIDFco+RsibY2NM0a4RdEeY/4KgqezwFtK1yr3U67xYhqJSlASm2pKhLVzPj2lr4bA==", 1100 | "dev": true, 1101 | "requires": { 1102 | "define-properties": "^1.1.3", 1103 | "es-abstract": "^1.18.0-next.0", 1104 | "has-symbols": "^1.0.1", 1105 | "object-keys": "^1.1.1" 1106 | }, 1107 | "dependencies": { 1108 | "es-abstract": { 1109 | "version": "1.18.0-next.1", 1110 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", 1111 | "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", 1112 | "dev": true, 1113 | "requires": { 1114 | "es-to-primitive": "^1.2.1", 1115 | "function-bind": "^1.1.1", 1116 | "has": "^1.0.3", 1117 | "has-symbols": "^1.0.1", 1118 | "is-callable": "^1.2.2", 1119 | "is-negative-zero": "^2.0.0", 1120 | "is-regex": "^1.1.1", 1121 | "object-inspect": "^1.8.0", 1122 | "object-keys": "^1.1.1", 1123 | "object.assign": "^4.1.1", 1124 | "string.prototype.trimend": "^1.0.1", 1125 | "string.prototype.trimstart": "^1.0.1" 1126 | } 1127 | } 1128 | } 1129 | }, 1130 | "object.values": { 1131 | "version": "1.1.1", 1132 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.1.tgz", 1133 | "integrity": "sha512-WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA==", 1134 | "dev": true, 1135 | "requires": { 1136 | "define-properties": "^1.1.3", 1137 | "es-abstract": "^1.17.0-next.1", 1138 | "function-bind": "^1.1.1", 1139 | "has": "^1.0.3" 1140 | } 1141 | }, 1142 | "once": { 1143 | "version": "1.4.0", 1144 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1145 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1146 | "dev": true, 1147 | "requires": { 1148 | "wrappy": "1" 1149 | } 1150 | }, 1151 | "optionator": { 1152 | "version": "0.9.1", 1153 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1154 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1155 | "dev": true, 1156 | "requires": { 1157 | "deep-is": "^0.1.3", 1158 | "fast-levenshtein": "^2.0.6", 1159 | "levn": "^0.4.1", 1160 | "prelude-ls": "^1.2.1", 1161 | "type-check": "^0.4.0", 1162 | "word-wrap": "^1.2.3" 1163 | } 1164 | }, 1165 | "p-limit": { 1166 | "version": "1.3.0", 1167 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1168 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1169 | "dev": true, 1170 | "requires": { 1171 | "p-try": "^1.0.0" 1172 | } 1173 | }, 1174 | "p-locate": { 1175 | "version": "2.0.0", 1176 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1177 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1178 | "dev": true, 1179 | "requires": { 1180 | "p-limit": "^1.1.0" 1181 | } 1182 | }, 1183 | "p-try": { 1184 | "version": "1.0.0", 1185 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1186 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1187 | "dev": true 1188 | }, 1189 | "parent-module": { 1190 | "version": "1.0.1", 1191 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1192 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1193 | "dev": true, 1194 | "requires": { 1195 | "callsites": "^3.0.0" 1196 | } 1197 | }, 1198 | "parse-json": { 1199 | "version": "2.2.0", 1200 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1201 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1202 | "dev": true, 1203 | "requires": { 1204 | "error-ex": "^1.2.0" 1205 | } 1206 | }, 1207 | "path-exists": { 1208 | "version": "3.0.0", 1209 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1210 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1211 | "dev": true 1212 | }, 1213 | "path-is-absolute": { 1214 | "version": "1.0.1", 1215 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1216 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1217 | "dev": true 1218 | }, 1219 | "path-key": { 1220 | "version": "3.1.1", 1221 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1222 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1223 | "dev": true 1224 | }, 1225 | "path-parse": { 1226 | "version": "1.0.6", 1227 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1228 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1229 | "dev": true 1230 | }, 1231 | "path-type": { 1232 | "version": "2.0.0", 1233 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1234 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1235 | "dev": true, 1236 | "requires": { 1237 | "pify": "^2.0.0" 1238 | } 1239 | }, 1240 | "pify": { 1241 | "version": "2.3.0", 1242 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1243 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1244 | "dev": true 1245 | }, 1246 | "pkg-dir": { 1247 | "version": "2.0.0", 1248 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1249 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1250 | "dev": true, 1251 | "requires": { 1252 | "find-up": "^2.1.0" 1253 | } 1254 | }, 1255 | "prelude-ls": { 1256 | "version": "1.2.1", 1257 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1258 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1259 | "dev": true 1260 | }, 1261 | "progress": { 1262 | "version": "2.0.3", 1263 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1264 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1265 | "dev": true 1266 | }, 1267 | "punycode": { 1268 | "version": "1.3.2", 1269 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 1270 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", 1271 | "dev": true 1272 | }, 1273 | "querystring": { 1274 | "version": "0.2.0", 1275 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 1276 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 1277 | "dev": true 1278 | }, 1279 | "read-pkg": { 1280 | "version": "2.0.0", 1281 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1282 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1283 | "dev": true, 1284 | "requires": { 1285 | "load-json-file": "^2.0.0", 1286 | "normalize-package-data": "^2.3.2", 1287 | "path-type": "^2.0.0" 1288 | } 1289 | }, 1290 | "read-pkg-up": { 1291 | "version": "2.0.0", 1292 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1293 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1294 | "dev": true, 1295 | "requires": { 1296 | "find-up": "^2.0.0", 1297 | "read-pkg": "^2.0.0" 1298 | } 1299 | }, 1300 | "regexpp": { 1301 | "version": "3.1.0", 1302 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1303 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1304 | "dev": true 1305 | }, 1306 | "resolve": { 1307 | "version": "1.17.0", 1308 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 1309 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 1310 | "dev": true, 1311 | "requires": { 1312 | "path-parse": "^1.0.6" 1313 | } 1314 | }, 1315 | "resolve-from": { 1316 | "version": "4.0.0", 1317 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1318 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1319 | "dev": true 1320 | }, 1321 | "rimraf": { 1322 | "version": "2.6.3", 1323 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1324 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1325 | "dev": true, 1326 | "requires": { 1327 | "glob": "^7.1.3" 1328 | } 1329 | }, 1330 | "sax": { 1331 | "version": "1.2.1", 1332 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.1.tgz", 1333 | "integrity": "sha1-e45lYZCyKOgaZq6nSEgNgozS03o=", 1334 | "dev": true 1335 | }, 1336 | "semver": { 1337 | "version": "7.3.2", 1338 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 1339 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 1340 | "dev": true 1341 | }, 1342 | "shebang-command": { 1343 | "version": "2.0.0", 1344 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1345 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1346 | "dev": true, 1347 | "requires": { 1348 | "shebang-regex": "^3.0.0" 1349 | } 1350 | }, 1351 | "shebang-regex": { 1352 | "version": "3.0.0", 1353 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1354 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1355 | "dev": true 1356 | }, 1357 | "slice-ansi": { 1358 | "version": "2.1.0", 1359 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1360 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1361 | "dev": true, 1362 | "requires": { 1363 | "ansi-styles": "^3.2.0", 1364 | "astral-regex": "^1.0.0", 1365 | "is-fullwidth-code-point": "^2.0.0" 1366 | } 1367 | }, 1368 | "spdx-correct": { 1369 | "version": "3.1.1", 1370 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 1371 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 1372 | "dev": true, 1373 | "requires": { 1374 | "spdx-expression-parse": "^3.0.0", 1375 | "spdx-license-ids": "^3.0.0" 1376 | } 1377 | }, 1378 | "spdx-exceptions": { 1379 | "version": "2.3.0", 1380 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1381 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 1382 | "dev": true 1383 | }, 1384 | "spdx-expression-parse": { 1385 | "version": "3.0.1", 1386 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1387 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1388 | "dev": true, 1389 | "requires": { 1390 | "spdx-exceptions": "^2.1.0", 1391 | "spdx-license-ids": "^3.0.0" 1392 | } 1393 | }, 1394 | "spdx-license-ids": { 1395 | "version": "3.0.6", 1396 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.6.tgz", 1397 | "integrity": "sha512-+orQK83kyMva3WyPf59k1+Y525csj5JejicWut55zeTWANuN17qSiSLUXWtzHeNWORSvT7GLDJ/E/XiIWoXBTw==", 1398 | "dev": true 1399 | }, 1400 | "sprintf-js": { 1401 | "version": "1.0.3", 1402 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1403 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1404 | "dev": true 1405 | }, 1406 | "string-width": { 1407 | "version": "3.1.0", 1408 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1409 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1410 | "dev": true, 1411 | "requires": { 1412 | "emoji-regex": "^7.0.1", 1413 | "is-fullwidth-code-point": "^2.0.0", 1414 | "strip-ansi": "^5.1.0" 1415 | }, 1416 | "dependencies": { 1417 | "ansi-regex": { 1418 | "version": "4.1.0", 1419 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1420 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1421 | "dev": true 1422 | }, 1423 | "strip-ansi": { 1424 | "version": "5.2.0", 1425 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1426 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1427 | "dev": true, 1428 | "requires": { 1429 | "ansi-regex": "^4.1.0" 1430 | } 1431 | } 1432 | } 1433 | }, 1434 | "string.prototype.trimend": { 1435 | "version": "1.0.1", 1436 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 1437 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 1438 | "dev": true, 1439 | "requires": { 1440 | "define-properties": "^1.1.3", 1441 | "es-abstract": "^1.17.5" 1442 | } 1443 | }, 1444 | "string.prototype.trimstart": { 1445 | "version": "1.0.1", 1446 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 1447 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 1448 | "dev": true, 1449 | "requires": { 1450 | "define-properties": "^1.1.3", 1451 | "es-abstract": "^1.17.5" 1452 | } 1453 | }, 1454 | "strip-ansi": { 1455 | "version": "6.0.0", 1456 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1457 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1458 | "dev": true, 1459 | "requires": { 1460 | "ansi-regex": "^5.0.0" 1461 | } 1462 | }, 1463 | "strip-bom": { 1464 | "version": "3.0.0", 1465 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1466 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1467 | "dev": true 1468 | }, 1469 | "strip-json-comments": { 1470 | "version": "3.1.1", 1471 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1472 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1473 | "dev": true 1474 | }, 1475 | "supports-color": { 1476 | "version": "5.5.0", 1477 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1478 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1479 | "dev": true, 1480 | "requires": { 1481 | "has-flag": "^3.0.0" 1482 | } 1483 | }, 1484 | "table": { 1485 | "version": "5.4.6", 1486 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1487 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1488 | "dev": true, 1489 | "requires": { 1490 | "ajv": "^6.10.2", 1491 | "lodash": "^4.17.14", 1492 | "slice-ansi": "^2.1.0", 1493 | "string-width": "^3.0.0" 1494 | } 1495 | }, 1496 | "text-table": { 1497 | "version": "0.2.0", 1498 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1499 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1500 | "dev": true 1501 | }, 1502 | "tsconfig-paths": { 1503 | "version": "3.9.0", 1504 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz", 1505 | "integrity": "sha512-dRcuzokWhajtZWkQsDVKbWyY+jgcLC5sqJhg2PSgf4ZkH2aHPvaOY8YWGhmjb68b5qqTfasSsDO9k7RUiEmZAw==", 1506 | "dev": true, 1507 | "requires": { 1508 | "@types/json5": "^0.0.29", 1509 | "json5": "^1.0.1", 1510 | "minimist": "^1.2.0", 1511 | "strip-bom": "^3.0.0" 1512 | } 1513 | }, 1514 | "type-check": { 1515 | "version": "0.4.0", 1516 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1517 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1518 | "dev": true, 1519 | "requires": { 1520 | "prelude-ls": "^1.2.1" 1521 | } 1522 | }, 1523 | "type-fest": { 1524 | "version": "0.8.1", 1525 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1526 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1527 | "dev": true 1528 | }, 1529 | "uri-js": { 1530 | "version": "4.4.0", 1531 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.0.tgz", 1532 | "integrity": "sha512-B0yRTzYdUCCn9n+F4+Gh4yIDtMQcaJsmYBDsTSG8g/OejKBodLQ2IHfN3bM7jUsRXndopT7OIXWdYqc1fjmV6g==", 1533 | "dev": true, 1534 | "requires": { 1535 | "punycode": "^2.1.0" 1536 | }, 1537 | "dependencies": { 1538 | "punycode": { 1539 | "version": "2.1.1", 1540 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1541 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1542 | "dev": true 1543 | } 1544 | } 1545 | }, 1546 | "url": { 1547 | "version": "0.10.3", 1548 | "resolved": "https://registry.npmjs.org/url/-/url-0.10.3.tgz", 1549 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 1550 | "dev": true, 1551 | "requires": { 1552 | "punycode": "1.3.2", 1553 | "querystring": "0.2.0" 1554 | } 1555 | }, 1556 | "uuid": { 1557 | "version": "3.3.2", 1558 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1559 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 1560 | "dev": true 1561 | }, 1562 | "v8-compile-cache": { 1563 | "version": "2.1.1", 1564 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 1565 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 1566 | "dev": true 1567 | }, 1568 | "validate-npm-package-license": { 1569 | "version": "3.0.4", 1570 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1571 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1572 | "dev": true, 1573 | "requires": { 1574 | "spdx-correct": "^3.0.0", 1575 | "spdx-expression-parse": "^3.0.0" 1576 | } 1577 | }, 1578 | "which": { 1579 | "version": "2.0.2", 1580 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1581 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1582 | "dev": true, 1583 | "requires": { 1584 | "isexe": "^2.0.0" 1585 | } 1586 | }, 1587 | "word-wrap": { 1588 | "version": "1.2.3", 1589 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1590 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1591 | "dev": true 1592 | }, 1593 | "wrappy": { 1594 | "version": "1.0.2", 1595 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1596 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1597 | "dev": true 1598 | }, 1599 | "write": { 1600 | "version": "1.0.3", 1601 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1602 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1603 | "dev": true, 1604 | "requires": { 1605 | "mkdirp": "^0.5.1" 1606 | } 1607 | }, 1608 | "xml2js": { 1609 | "version": "0.4.19", 1610 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.19.tgz", 1611 | "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", 1612 | "dev": true, 1613 | "requires": { 1614 | "sax": ">=0.6.0", 1615 | "xmlbuilder": "~9.0.1" 1616 | } 1617 | }, 1618 | "xmlbuilder": { 1619 | "version": "9.0.7", 1620 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", 1621 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=", 1622 | "dev": true 1623 | } 1624 | } 1625 | } 1626 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "circuitbreaker-lambda", 3 | "version": "0.0.1", 4 | "description": "Module for circuit breaker pattern in AWS Lambda", 5 | "main": "./lib/circuitbreaker.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "repository": { 10 | "type": "git", 11 | "url": "git+https://github.com/gunnargrosch/circuitbreaker-lambda.git" 12 | }, 13 | "keywords": [ 14 | "aws", 15 | "lambda", 16 | "circuitbreaker", 17 | "fallback" 18 | ], 19 | "author": "Gunnar Grosch", 20 | "license": "MIT", 21 | "bugs": { 22 | "url": "https://github.com/gunnargrosch/circuitbreaker-lambda/issues" 23 | }, 24 | "homepage": "https://github.com/gunnargrosch/circuitbreaker-lambda#readme", 25 | "devDependencies": { 26 | "aws-sdk": "^2.761.0", 27 | "eslint": "^7.10.0", 28 | "eslint-config-standard": "^14.1.1", 29 | "eslint-plugin-import": "^2.22.1", 30 | "eslint-plugin-node": "^11.1.0", 31 | "eslint-plugin-promise": "^4.2.1", 32 | "eslint-plugin-standard": "^4.0.1" 33 | }, 34 | "dependencies": {} 35 | } 36 | --------------------------------------------------------------------------------