├── .eslintrc.json ├── .gitignore ├── .travis.yml ├── LICENSE ├── README.md ├── bin └── pino-cloudwatch.js ├── index.js ├── lib ├── cloudwatch-stream.js ├── max-length.js ├── max-size.js ├── max-span.js ├── stdout-stream.js └── throttle-stream.js ├── package-lock.json ├── package.json └── test ├── mocks ├── aws-sdk.js ├── cloudwatch-logs.js ├── log_empty.txt ├── log_single.txt └── logs.txt └── specs ├── cloudwatch-stream.spec.js ├── index.spec.js ├── max-length.spec.js ├── max-size.spec.js └── stdout-stream.spec.js /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "es6": true, 4 | "node": true 5 | }, 6 | "extends": "eslint:recommended", 7 | "overrides": [ 8 | { 9 | "files": ["**/*.spec.js"], 10 | "env": { 11 | "mocha": true 12 | } 13 | } 14 | ] 15 | } 16 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | 8 | # Runtime data 9 | pids 10 | *.pid 11 | *.seed 12 | *.pid.lock 13 | 14 | # Directory for instrumented libs generated by jscoverage/JSCover 15 | lib-cov 16 | 17 | # Coverage directory used by tools like istanbul 18 | coverage 19 | 20 | # nyc test coverage 21 | .nyc_output 22 | 23 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 24 | .grunt 25 | 26 | # Bower dependency directory (https://bower.io/) 27 | bower_components 28 | 29 | # node-waf configuration 30 | .lock-wscript 31 | 32 | # Compiled binary addons (http://nodejs.org/api/addons.html) 33 | build/Release 34 | 35 | # Dependency directories 36 | node_modules/ 37 | jspm_packages/ 38 | 39 | # Typescript v1 declaration files 40 | typings/ 41 | 42 | # Optional npm cache directory 43 | .npm 44 | 45 | # Optional eslint cache 46 | .eslintcache 47 | 48 | # Optional REPL history 49 | .node_repl_history 50 | 51 | # Output of 'npm pack' 52 | *.tgz 53 | 54 | # Yarn Integrity file 55 | .yarn-integrity 56 | 57 | # dotenv environment variables file 58 | .env 59 | 60 | .idea 61 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | --- 2 | 3 | language: node_js 4 | 5 | node_js: 6 | - lts/* 7 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 David Howell 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # pino-cloudwatch 2 | 3 | #### Send pino logs to AWS CloudWatch Logs. 4 | 5 | ## About 6 | 7 | `pino-cloudwatch` is a simple [pino](https://getpino.io/#/) transport that buffers and holds [pino](https://getpino.io/#/) logs until one of the following conditions are met: 8 | * the number of logs reaches 10,000 9 | * the 'size' of the logs reaches 1,048,576 bytes OR 10 | * there is at least 1 log buffered and 1,000ms (default) has passed without another log item being buffered 11 | This is to minimise the number of calls to CloudWatch Logs. 12 | 13 | The log group name is specified via the CLI (`--prefix`) and the log stream name is built based on the following information: 14 | * An optional `prefix`, 15 | * the hostname (via `os.hostname()`), 16 | * the process ID (via `process.id`), 17 | * the epoch when the first log are sent to CloudWatch Logs 18 | 19 | ## Usage 20 | ``` 21 | # ./bin/pino-cloudwatch.js 22 | Sends pino logs to AWS CloudWatch Logs. 23 | Usage: node index.js | pino-cloudwatch [options] 24 | 25 | Options: 26 | --help Show help [boolean] 27 | --version Show version number [boolean] 28 | --aws_access_key_id AWS Access Key ID 29 | --aws_secret_access_key AWS Secret Access Key 30 | --aws_region AWS Region 31 | --group AWS CloudWatch log group name [required] 32 | --prefix AWS CloudWatch log stream name prefix 33 | --stream AWS CloudWatch log stream name, overrides --prefix option. 34 | --interval The maxmimum interval (in ms) before flushing the log 35 | queue. [default: 1000] 36 | ``` 37 | ## Options 38 | 39 | ### `group`: `String` (required) 40 | 41 | ### `prefix`: `String` 42 | 43 | ### `interval`: `Integer` (default `1000`ms, `0` to disable) 44 | 45 | The `interval` is the amount of time in ms that must elapse before attempting to send logs to CloudWatch Logs. Increase this to reduce the number of calls to CloudWatch Logs. 46 | 47 | If you set this to `0` then it will only send logs when: 48 | * It reaches the maxiumum number of logs 49 | * It reaches the maximum size of the logs 50 | 51 | __note__: Disabling the interval could mean that logs will *never* be sent to CloudWatch Logs. 52 | 53 | ### `aws_access_key_id`: `String` 54 | 55 | ### `aws_secret_access_key`: `String` 56 | 57 | ### `aws_region`: `String` 58 | 59 | ## Other uses 60 | 61 | ### Writable Stream 62 | 63 | This module can be required and used as a writable stream: 64 | ```javascript 65 | var pump = require('pump'); 66 | var split = require('split2'); 67 | var pinoCloudWatch = require('pino-cloudwatch'); 68 | 69 | pump(process.stdin, split(), pinoCloudWatch({ group: 'test' })); 70 | 71 | ``` 72 | 73 | #### Writeable Stream Events 74 | 75 | Since pino-cloudwatch returns a writable stream, you can attach event handlers like any other writeable stream (see https://nodejs.org/dist/v10.19.0/docs/api/stream.html#stream_writable_streams). 76 | 77 | In addition, a `flushed` event is emitted once the logs are successfully pushed / saved in AWS CloudWatch Logs. 78 | 79 | ```javascript 80 | var pump = require('pump'); 81 | var split = require('split2'); 82 | var pinoCloudWatch = require('pino-cloudwatch'); 83 | var streamToCloudWatch = pinoCloudWatch({ group: 'test' }); 84 | 85 | streamToCloudWatch.on('flushed', function () { 86 | console.log('Logs were successfully sent to AWS CloudWatch'); 87 | }); 88 | 89 | pump(process.stdin, split(), pinoCloudWatch({ group: 'test' })); 90 | ``` 91 | 92 | ### Arbitrary logs 93 | 94 | Technically `pino-cloudwatch` can send any object mode stream to CloudWatch Logs. This includes *any* text-based log file. For example: tailing a standard log file like nginx access.log. 95 | 96 | ## Test 97 | ``` 98 | # npm test 99 | ``` 100 | -------------------------------------------------------------------------------- /bin/pino-cloudwatch.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | var yargs = require('yargs'); 3 | var pump = require('pump'); 4 | var split = require('split2'); 5 | 6 | var argv = yargs 7 | .usage('Sends pino logs to AWS CloudWatch Logs.\nUsage: node index.js | pino-cloudwatch [options]') 8 | .describe('aws_access_key_id', 'AWS Access Key ID') 9 | .describe('aws_secret_access_key', 'AWS Secret Access Key') 10 | .describe('aws_region', 'AWS Region') 11 | .describe('group', 'AWS CloudWatch log group name') 12 | .describe('prefix', 'AWS CloudWatch log stream name prefix') 13 | .describe('stream', 'AWS CloudWatch log stream name, overrides --prefix option') 14 | .describe('interval', 'The maxmimum interval (in ms) before flushing the log queue.') 15 | .describe('stdout', 'Copy stdin to stdout') 16 | .demand('group') 17 | .default('interval', 1000) 18 | .default('stdout', false) 19 | .argv; 20 | 21 | module.exports = pump(process.stdin, split(), require('../index')(argv)); 22 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | var ChunkyStream = require('chunky-stream'); 2 | var StdoutStream = require('./lib/stdout-stream'); 3 | var ThrottleStream = require('./lib/throttle-stream'); 4 | var CloudWatchStream = require('./lib/cloudwatch-stream'); 5 | 6 | module.exports = function (options, errorHandler) { 7 | options = options || {}; 8 | options.ignoreEmpty = true; 9 | 10 | var log = new CloudWatchStream(options); 11 | var chunk = new ChunkyStream(options); 12 | var throttle = new ThrottleStream(); 13 | var stdout = new StdoutStream(options); 14 | 15 | chunk.use(require('./lib/max-length')); 16 | chunk.use(require('./lib/max-size')); 17 | 18 | if (typeof errorHandler === 'function') { 19 | log.on('error', errorHandler); 20 | } 21 | 22 | log.on('flushed', function () { 23 | stdout.emit('flushed') 24 | }); 25 | 26 | stdout.pipe(chunk).pipe(throttle).pipe(log); 27 | 28 | return stdout; 29 | }; 30 | -------------------------------------------------------------------------------- /lib/cloudwatch-stream.js: -------------------------------------------------------------------------------- 1 | var os = require('os'); 2 | var util = require('util'); 3 | var async = require('async'); 4 | var AWS = require('aws-sdk'); 5 | var Writable = require('readable-stream/writable'); 6 | 7 | function CloudWatchStream (options) { 8 | if (!(this instanceof CloudWatchStream)) { 9 | return new CloudWatchStream(options); 10 | } 11 | 12 | if (!options.group) { 13 | throw new Error('options.group is required.'); 14 | } 15 | 16 | options.objectMode = true; 17 | 18 | this.logStreamNamePrefix = options.prefix; 19 | this.logGroupName = options.group; 20 | this.logStreamName = options.stream || (options.prefix ? options.prefix + '-' : '') + os.hostname() + '-' + process.pid + '-' + new Date().getTime(); 21 | this.nextSequenceToken = null; 22 | 23 | var awsOptions = {}; 24 | 25 | if (options.aws_region || options.aws_access_key_id || options.aws_secret_access_key) { 26 | awsOptions = { 27 | region: options.aws_region, 28 | accessKeyId: options.aws_access_key_id, 29 | secretAccessKey: options.aws_secret_access_key 30 | }; 31 | } 32 | 33 | this.cloudWatchLogs = new AWS.CloudWatchLogs(awsOptions); 34 | 35 | Writable.call(this, options); 36 | } 37 | 38 | util.inherits(CloudWatchStream, Writable); 39 | 40 | CloudWatchStream.prototype.createLogGroup = function (options, callback) { 41 | if (options.nextSequenceToken) { 42 | return callback(null, options); 43 | } 44 | 45 | this.cloudWatchLogs.createLogGroup({ 46 | logGroupName: options.logGroupName 47 | }, function (err/*, data*/) { 48 | if (err && err.code === 'ResourceAlreadyExistsException') { 49 | err = null; 50 | } 51 | 52 | callback(err, options); 53 | }); 54 | }; 55 | 56 | CloudWatchStream.prototype.createLogStream = function (options, callback) { 57 | if (options.nextSequenceToken) { 58 | return callback(null, options); 59 | } 60 | 61 | this.cloudWatchLogs.createLogStream({ 62 | logGroupName: options.logGroupName, 63 | logStreamName: options.logStreamName 64 | }, function (err/*, data*/) { 65 | if (err && err.code === 'ResourceAlreadyExistsException') { 66 | err = null; 67 | } 68 | 69 | callback(err, options); 70 | }); 71 | }; 72 | 73 | CloudWatchStream.prototype.nextToken = function (options, callback) { 74 | if (options.nextSequenceToken) { 75 | return callback(null, options); 76 | } 77 | 78 | this.cloudWatchLogs.describeLogStreams({ 79 | logGroupName: options.logGroupName, 80 | logStreamNamePrefix: options.logStreamName 81 | }, function (err, data) { 82 | if (err) { 83 | return callback(err); 84 | } 85 | 86 | if (data.logStreams.length === 0) { 87 | return callback(new Error('LogStream not found.')); 88 | } 89 | 90 | options.nextSequenceToken = data.logStreams[0].uploadSequenceToken; 91 | callback(err, options); 92 | }); 93 | }; 94 | 95 | CloudWatchStream.prototype.putLogEvents = function (options, callback) { 96 | var self = this; 97 | 98 | this.cloudWatchLogs.putLogEvents({ 99 | logEvents: options.logEvents, 100 | logGroupName: options.logGroupName, 101 | logStreamName: options.logStreamName, 102 | sequenceToken: options.nextSequenceToken 103 | }, function (err, data) { 104 | if (err && err.code === 'InvalidSequenceTokenException') { 105 | var body = JSON.parse(this.httpResponse.body.toString()); 106 | options.nextSequenceToken = body.expectedSequenceToken; 107 | 108 | return self.putLogEvents(options, callback); 109 | } 110 | 111 | options.nextSequenceToken = data && data.nextSequenceToken; 112 | callback(err, options); 113 | }); 114 | }; 115 | 116 | CloudWatchStream.prototype._write = function (chunks, encoding, callback) { 117 | if (!Array.isArray(chunks)) { 118 | chunks = [chunks]; 119 | } 120 | 121 | var complete = function (err, options) { 122 | if (err) { 123 | return callback(err); 124 | } 125 | 126 | this.nextSequenceToken = options.nextSequenceToken; 127 | this.emit('flushed'); 128 | 129 | return callback(); 130 | }; 131 | 132 | var options = { 133 | logGroupName: this.logGroupName, 134 | logStreamName: this.logStreamName, 135 | nextSequenceToken: this.nextSequenceToken, 136 | logEvents: chunks.map(function (c) { 137 | return { 138 | timestamp: new Date().getTime(), 139 | message: c.toString() 140 | }; 141 | }) 142 | }; 143 | 144 | async.waterfall([ 145 | this.createLogGroup.bind(this, options), 146 | this.createLogStream.bind(this), 147 | this.nextToken.bind(this), 148 | this.putLogEvents.bind(this) 149 | ], complete.bind(this)); 150 | }; 151 | 152 | module.exports = CloudWatchStream; 153 | -------------------------------------------------------------------------------- /lib/max-length.js: -------------------------------------------------------------------------------- 1 | var MAX_LENGTH = 10000; 2 | 3 | module.exports = function (chunks/*, nextChunk*/) { 4 | return chunks.length === MAX_LENGTH; 5 | }; 6 | -------------------------------------------------------------------------------- /lib/max-size.js: -------------------------------------------------------------------------------- 1 | // max event size is 256kb see https://docs.aws.amazon.com/AmazonCloudWatch/latest/logs/cloudwatch_limits_cwl.html 2 | 3 | const MAX_SIZE = 262144; 4 | 5 | module.exports = function (chunks, nextChunk) { 6 | const size = chunks.reduce(function (v, c) { return v + c.length + 26; }, 0); 7 | 8 | return (size + nextChunk.length + 26) >=MAX_SIZE; 9 | }; 10 | -------------------------------------------------------------------------------- /lib/max-span.js: -------------------------------------------------------------------------------- 1 | var MAX_DURATION = 24 * 60 * 60 * 1000; 2 | var startTime = null; 3 | 4 | module.exports = function (chunks/*, nextChunk*/) { 5 | if (!startTime) { 6 | startTime = new Date().getTime(); 7 | } 8 | 9 | if (chunks.length === 0) { 10 | return false; 11 | } 12 | 13 | var endTime = new Date().getTime(); 14 | var flush = (endTime - startTime) > MAX_DURATION; 15 | 16 | if (flush) { 17 | startTime = endTime; 18 | } 19 | 20 | return flush; 21 | }; 22 | -------------------------------------------------------------------------------- /lib/stdout-stream.js: -------------------------------------------------------------------------------- 1 | var Transform = require('readable-stream/transform'); 2 | var util = require('util'); 3 | 4 | function StdoutStream (options) { 5 | if (!(this instanceof StdoutStream)) { 6 | return new StdoutStream(options); 7 | } 8 | 9 | options = options || {}; 10 | options.objectMode = true; 11 | options.writeableObjectMode = true; 12 | options.readableObjectMode = true; 13 | 14 | this.console = options.console || console; 15 | this.stdout = options.stdout || false; 16 | 17 | Transform.call(this, options); 18 | } 19 | 20 | util.inherits(StdoutStream, Transform); 21 | 22 | StdoutStream.prototype.flush = function (callback) { 23 | if (callback) { 24 | return callback(); 25 | } 26 | }; 27 | 28 | StdoutStream.prototype._transform = function (chunk, encoding, callback) { 29 | if (this.stdout) this.console.log(chunk); 30 | 31 | callback(null, chunk); 32 | }; 33 | 34 | StdoutStream.prototype._flush = function (callback) { 35 | this.flush(callback); 36 | }; 37 | 38 | module.exports = StdoutStream; 39 | -------------------------------------------------------------------------------- /lib/throttle-stream.js: -------------------------------------------------------------------------------- 1 | var Transform = require('readable-stream/transform'); 2 | var util = require('util'); 3 | 4 | function ThrottleStream (options) { 5 | if (!(this instanceof ThrottleStream)) { 6 | return new ThrottleStream(options); 7 | } 8 | 9 | options = options || {}; 10 | options.objectMode = true; 11 | options.writeableObjectMode = true; 12 | options.readableObjectMode = true; 13 | 14 | this.lastTime = 0; 15 | this.interval = (1000 / 5); 16 | this.timeoutId = null; 17 | this.buffer = []; 18 | 19 | Transform.call(this, options); 20 | } 21 | 22 | util.inherits(ThrottleStream, Transform); 23 | 24 | ThrottleStream.prototype.flush = function (callback) { 25 | if (this.buffer.length > 0) { 26 | var chunk = this.buffer.shift(); 27 | this.push(chunk); 28 | 29 | if (this.buffer.length > 0) { 30 | this.timeoutId = setTimeout(this.flush.bind(this, callback), this.interval); 31 | } else { 32 | if (callback) { 33 | return callback(); 34 | } 35 | } 36 | } 37 | }; 38 | 39 | ThrottleStream.prototype._transform = function (chunk, encoding, callback) { 40 | var duration = new Date().getTime() - this.lastTime; 41 | this.lastTime = new Date().getTime(); 42 | 43 | if (duration > this.interval) { 44 | callback(null, chunk); 45 | return; 46 | } 47 | 48 | this.buffer.push(chunk); 49 | this.timeoutId = setTimeout(this.flush.bind(this, callback), duration); 50 | }; 51 | 52 | ThrottleStream.prototype._flush = function (callback) { 53 | this.flush(callback); 54 | }; 55 | 56 | module.exports = ThrottleStream; 57 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pino-cloudwatch", 3 | "version": "0.7.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.8.3", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz", 10 | "integrity": "sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.8.3" 14 | } 15 | }, 16 | "@babel/helper-validator-identifier": { 17 | "version": "7.9.5", 18 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz", 19 | "integrity": "sha512-/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g==", 20 | "dev": true 21 | }, 22 | "@babel/highlight": { 23 | "version": "7.9.0", 24 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.9.0.tgz", 25 | "integrity": "sha512-lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/helper-validator-identifier": "^7.9.0", 29 | "chalk": "^2.0.0", 30 | "js-tokens": "^4.0.0" 31 | } 32 | }, 33 | "@types/color-name": { 34 | "version": "1.1.1", 35 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 36 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 37 | "dev": true 38 | }, 39 | "acorn": { 40 | "version": "7.1.1", 41 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.1.tgz", 42 | "integrity": "sha512-add7dgA5ppRPxCFJoAGfMDi7PIBXq1RtGo7BhbLaxwrXPOmw8gq48Y9ozT01hUKy9byMjlR20EJhu5zlkErEkg==", 43 | "dev": true 44 | }, 45 | "acorn-jsx": { 46 | "version": "5.2.0", 47 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 48 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 49 | "dev": true 50 | }, 51 | "ajv": { 52 | "version": "6.12.2", 53 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.2.tgz", 54 | "integrity": "sha512-k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ==", 55 | "dev": true, 56 | "requires": { 57 | "fast-deep-equal": "^3.1.1", 58 | "fast-json-stable-stringify": "^2.0.0", 59 | "json-schema-traverse": "^0.4.1", 60 | "uri-js": "^4.2.2" 61 | } 62 | }, 63 | "ansi-colors": { 64 | "version": "3.2.3", 65 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 66 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 67 | "dev": true 68 | }, 69 | "ansi-escapes": { 70 | "version": "4.3.1", 71 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 72 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 73 | "dev": true, 74 | "requires": { 75 | "type-fest": "^0.11.0" 76 | }, 77 | "dependencies": { 78 | "type-fest": { 79 | "version": "0.11.0", 80 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 81 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 82 | "dev": true 83 | } 84 | } 85 | }, 86 | "ansi-regex": { 87 | "version": "4.1.0", 88 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 89 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 90 | }, 91 | "ansi-styles": { 92 | "version": "3.2.0", 93 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 94 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 95 | "requires": { 96 | "color-convert": "^1.9.0" 97 | } 98 | }, 99 | "argparse": { 100 | "version": "1.0.10", 101 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 102 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 103 | "dev": true, 104 | "requires": { 105 | "sprintf-js": "~1.0.2" 106 | } 107 | }, 108 | "assertion-error": { 109 | "version": "1.1.0", 110 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 111 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 112 | "dev": true 113 | }, 114 | "astral-regex": { 115 | "version": "1.0.0", 116 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 117 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 118 | "dev": true 119 | }, 120 | "async": { 121 | "version": "3.2.0", 122 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.0.tgz", 123 | "integrity": "sha512-TR2mEZFVOj2pLStYxLht7TyfuRzaydfpxr3k9RpHIzMgw7A64dzsdqCxH1WJyQdoe8T10nDXd9wnEigmiuHIZw==" 124 | }, 125 | "aws-sdk": { 126 | "version": "2.668.0", 127 | "resolved": "https://registry.npmjs.org/aws-sdk/-/aws-sdk-2.668.0.tgz", 128 | "integrity": "sha512-mmZJmeenNM9hRR4k+JAStBhYFym2+VCPTRWv0Vn2oqqXIaIaNVdNf9xag/WMG8b8M80R3XXfVHKmDPST0/EfHA==", 129 | "requires": { 130 | "buffer": "4.9.1", 131 | "events": "1.1.1", 132 | "ieee754": "1.1.13", 133 | "jmespath": "0.15.0", 134 | "querystring": "0.2.0", 135 | "sax": "1.2.1", 136 | "url": "0.10.3", 137 | "uuid": "3.3.2", 138 | "xml2js": "0.4.19" 139 | } 140 | }, 141 | "balanced-match": { 142 | "version": "1.0.0", 143 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 144 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 145 | "dev": true 146 | }, 147 | "base64-js": { 148 | "version": "1.3.1", 149 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", 150 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==" 151 | }, 152 | "brace-expansion": { 153 | "version": "1.1.11", 154 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 155 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 156 | "dev": true, 157 | "requires": { 158 | "balanced-match": "^1.0.0", 159 | "concat-map": "0.0.1" 160 | } 161 | }, 162 | "browser-stdout": { 163 | "version": "1.3.1", 164 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 165 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 166 | "dev": true 167 | }, 168 | "buffer": { 169 | "version": "4.9.1", 170 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.1.tgz", 171 | "integrity": "sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg=", 172 | "requires": { 173 | "base64-js": "^1.0.2", 174 | "ieee754": "^1.1.4", 175 | "isarray": "^1.0.0" 176 | } 177 | }, 178 | "caller-id": { 179 | "version": "0.1.0", 180 | "resolved": "https://registry.npmjs.org/caller-id/-/caller-id-0.1.0.tgz", 181 | "integrity": "sha1-Wb2sCJPRLDhxQIJ5Ix+XRYNk8Hs=", 182 | "dev": true, 183 | "requires": { 184 | "stack-trace": "~0.0.7" 185 | } 186 | }, 187 | "callsites": { 188 | "version": "3.1.0", 189 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 190 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 191 | "dev": true 192 | }, 193 | "camelcase": { 194 | "version": "5.3.1", 195 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 196 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" 197 | }, 198 | "chai": { 199 | "version": "4.2.0", 200 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 201 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 202 | "dev": true, 203 | "requires": { 204 | "assertion-error": "^1.1.0", 205 | "check-error": "^1.0.2", 206 | "deep-eql": "^3.0.1", 207 | "get-func-name": "^2.0.0", 208 | "pathval": "^1.1.0", 209 | "type-detect": "^4.0.5" 210 | } 211 | }, 212 | "chalk": { 213 | "version": "2.1.0", 214 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.1.0.tgz", 215 | "integrity": "sha512-LUHGS/dge4ujbXMJrnihYMcL4AoOweGnw9Tp3kQuqy1Kx5c1qKjqvMJZ6nVJPMWJtKCTN72ZogH3oeSO9g9rXQ==", 216 | "dev": true, 217 | "requires": { 218 | "ansi-styles": "^3.1.0", 219 | "escape-string-regexp": "^1.0.5", 220 | "supports-color": "^4.0.0" 221 | } 222 | }, 223 | "chardet": { 224 | "version": "0.7.0", 225 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 226 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 227 | "dev": true 228 | }, 229 | "check-error": { 230 | "version": "1.0.2", 231 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 232 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 233 | "dev": true 234 | }, 235 | "chunky-stream": { 236 | "version": "0.3.0", 237 | "resolved": "https://registry.npmjs.org/chunky-stream/-/chunky-stream-0.3.0.tgz", 238 | "integrity": "sha512-HxaNe+G5531t45LDnUb5ejIviwjqu8VWNDTfJvlItCeQVNiL7+bF/mxrZhyoQ+Po3MfDCrfI5bXVcUUHm3g2hQ==", 239 | "requires": { 240 | "lodash.reduce": "^4.6.0", 241 | "readable-stream": "^2.3.3" 242 | } 243 | }, 244 | "cli-cursor": { 245 | "version": "3.1.0", 246 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 247 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 248 | "dev": true, 249 | "requires": { 250 | "restore-cursor": "^3.1.0" 251 | } 252 | }, 253 | "cli-width": { 254 | "version": "2.2.1", 255 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.1.tgz", 256 | "integrity": "sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw==", 257 | "dev": true 258 | }, 259 | "cliui": { 260 | "version": "5.0.0", 261 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 262 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 263 | "requires": { 264 | "string-width": "^3.1.0", 265 | "strip-ansi": "^5.2.0", 266 | "wrap-ansi": "^5.1.0" 267 | }, 268 | "dependencies": { 269 | "string-width": { 270 | "version": "3.1.0", 271 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 272 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 273 | "requires": { 274 | "emoji-regex": "^7.0.1", 275 | "is-fullwidth-code-point": "^2.0.0", 276 | "strip-ansi": "^5.1.0" 277 | } 278 | } 279 | } 280 | }, 281 | "color-convert": { 282 | "version": "1.9.0", 283 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.0.tgz", 284 | "integrity": "sha1-Gsz5fdc5uYO/mU1W/sj5WFNkG3o=", 285 | "requires": { 286 | "color-name": "^1.1.1" 287 | } 288 | }, 289 | "color-name": { 290 | "version": "1.1.3", 291 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 292 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 293 | }, 294 | "concat-map": { 295 | "version": "0.0.1", 296 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 297 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 298 | "dev": true 299 | }, 300 | "core-util-is": { 301 | "version": "1.0.2", 302 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 303 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 304 | }, 305 | "cross-spawn": { 306 | "version": "6.0.5", 307 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 308 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 309 | "dev": true, 310 | "requires": { 311 | "nice-try": "^1.0.4", 312 | "path-key": "^2.0.1", 313 | "semver": "^5.5.0", 314 | "shebang-command": "^1.2.0", 315 | "which": "^1.2.9" 316 | }, 317 | "dependencies": { 318 | "semver": { 319 | "version": "5.7.1", 320 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 321 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 322 | "dev": true 323 | } 324 | } 325 | }, 326 | "debug": { 327 | "version": "3.2.6", 328 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 329 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 330 | "dev": true, 331 | "requires": { 332 | "ms": "^2.1.1" 333 | } 334 | }, 335 | "decamelize": { 336 | "version": "1.2.0", 337 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 338 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 339 | }, 340 | "deep-eql": { 341 | "version": "3.0.1", 342 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 343 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 344 | "dev": true, 345 | "requires": { 346 | "type-detect": "^4.0.0" 347 | } 348 | }, 349 | "deep-is": { 350 | "version": "0.1.3", 351 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 352 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 353 | "dev": true 354 | }, 355 | "define-properties": { 356 | "version": "1.1.3", 357 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 358 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 359 | "dev": true, 360 | "requires": { 361 | "object-keys": "^1.0.12" 362 | } 363 | }, 364 | "diff": { 365 | "version": "3.5.0", 366 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 367 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 368 | "dev": true 369 | }, 370 | "doctrine": { 371 | "version": "3.0.0", 372 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 373 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 374 | "dev": true, 375 | "requires": { 376 | "esutils": "^2.0.2" 377 | } 378 | }, 379 | "emoji-regex": { 380 | "version": "7.0.3", 381 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 382 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 383 | }, 384 | "end-of-stream": { 385 | "version": "1.4.0", 386 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.0.tgz", 387 | "integrity": "sha1-epDYM+/abPpurA9JSduw+tOmMgY=", 388 | "requires": { 389 | "once": "^1.4.0" 390 | } 391 | }, 392 | "es-abstract": { 393 | "version": "1.16.0", 394 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.16.0.tgz", 395 | "integrity": "sha512-xdQnfykZ9JMEiasTAJZJdMWCQ1Vm00NBw79/AWi7ELfZuuPCSOMDZbT9mkOfSctVtfhb+sAAzrm+j//GjjLHLg==", 396 | "dev": true, 397 | "requires": { 398 | "es-to-primitive": "^1.2.0", 399 | "function-bind": "^1.1.1", 400 | "has": "^1.0.3", 401 | "has-symbols": "^1.0.0", 402 | "is-callable": "^1.1.4", 403 | "is-regex": "^1.0.4", 404 | "object-inspect": "^1.6.0", 405 | "object-keys": "^1.1.1", 406 | "string.prototype.trimleft": "^2.1.0", 407 | "string.prototype.trimright": "^2.1.0" 408 | } 409 | }, 410 | "es-to-primitive": { 411 | "version": "1.2.0", 412 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 413 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 414 | "dev": true, 415 | "requires": { 416 | "is-callable": "^1.1.4", 417 | "is-date-object": "^1.0.1", 418 | "is-symbol": "^1.0.2" 419 | } 420 | }, 421 | "escape-string-regexp": { 422 | "version": "1.0.5", 423 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 424 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 425 | "dev": true 426 | }, 427 | "eslint": { 428 | "version": "6.8.0", 429 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 430 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 431 | "dev": true, 432 | "requires": { 433 | "@babel/code-frame": "^7.0.0", 434 | "ajv": "^6.10.0", 435 | "chalk": "^2.1.0", 436 | "cross-spawn": "^6.0.5", 437 | "debug": "^4.0.1", 438 | "doctrine": "^3.0.0", 439 | "eslint-scope": "^5.0.0", 440 | "eslint-utils": "^1.4.3", 441 | "eslint-visitor-keys": "^1.1.0", 442 | "espree": "^6.1.2", 443 | "esquery": "^1.0.1", 444 | "esutils": "^2.0.2", 445 | "file-entry-cache": "^5.0.1", 446 | "functional-red-black-tree": "^1.0.1", 447 | "glob-parent": "^5.0.0", 448 | "globals": "^12.1.0", 449 | "ignore": "^4.0.6", 450 | "import-fresh": "^3.0.0", 451 | "imurmurhash": "^0.1.4", 452 | "inquirer": "^7.0.0", 453 | "is-glob": "^4.0.0", 454 | "js-yaml": "^3.13.1", 455 | "json-stable-stringify-without-jsonify": "^1.0.1", 456 | "levn": "^0.3.0", 457 | "lodash": "^4.17.14", 458 | "minimatch": "^3.0.4", 459 | "mkdirp": "^0.5.1", 460 | "natural-compare": "^1.4.0", 461 | "optionator": "^0.8.3", 462 | "progress": "^2.0.0", 463 | "regexpp": "^2.0.1", 464 | "semver": "^6.1.2", 465 | "strip-ansi": "^5.2.0", 466 | "strip-json-comments": "^3.0.1", 467 | "table": "^5.2.3", 468 | "text-table": "^0.2.0", 469 | "v8-compile-cache": "^2.0.3" 470 | }, 471 | "dependencies": { 472 | "debug": { 473 | "version": "4.1.1", 474 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 475 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 476 | "dev": true, 477 | "requires": { 478 | "ms": "^2.1.1" 479 | } 480 | }, 481 | "strip-json-comments": { 482 | "version": "3.1.0", 483 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.0.tgz", 484 | "integrity": "sha512-e6/d0eBu7gHtdCqFt0xJr642LdToM5/cN4Qb9DbHjVx1CP5RyeM+zH7pbecEmDv/lBqb0QH+6Uqq75rxFPkM0w==", 485 | "dev": true 486 | } 487 | } 488 | }, 489 | "eslint-scope": { 490 | "version": "5.0.0", 491 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 492 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 493 | "dev": true, 494 | "requires": { 495 | "esrecurse": "^4.1.0", 496 | "estraverse": "^4.1.1" 497 | } 498 | }, 499 | "eslint-utils": { 500 | "version": "1.4.3", 501 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 502 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 503 | "dev": true, 504 | "requires": { 505 | "eslint-visitor-keys": "^1.1.0" 506 | } 507 | }, 508 | "eslint-visitor-keys": { 509 | "version": "1.1.0", 510 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 511 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 512 | "dev": true 513 | }, 514 | "espree": { 515 | "version": "6.2.1", 516 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", 517 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", 518 | "dev": true, 519 | "requires": { 520 | "acorn": "^7.1.1", 521 | "acorn-jsx": "^5.2.0", 522 | "eslint-visitor-keys": "^1.1.0" 523 | } 524 | }, 525 | "esprima": { 526 | "version": "4.0.1", 527 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 528 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 529 | "dev": true 530 | }, 531 | "esquery": { 532 | "version": "1.3.1", 533 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 534 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 535 | "dev": true, 536 | "requires": { 537 | "estraverse": "^5.1.0" 538 | }, 539 | "dependencies": { 540 | "estraverse": { 541 | "version": "5.1.0", 542 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 543 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 544 | "dev": true 545 | } 546 | } 547 | }, 548 | "esrecurse": { 549 | "version": "4.2.1", 550 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 551 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 552 | "dev": true, 553 | "requires": { 554 | "estraverse": "^4.1.0" 555 | } 556 | }, 557 | "estraverse": { 558 | "version": "4.3.0", 559 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 560 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 561 | "dev": true 562 | }, 563 | "esutils": { 564 | "version": "2.0.3", 565 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 566 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 567 | "dev": true 568 | }, 569 | "events": { 570 | "version": "1.1.1", 571 | "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", 572 | "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=" 573 | }, 574 | "external-editor": { 575 | "version": "3.1.0", 576 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 577 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 578 | "dev": true, 579 | "requires": { 580 | "chardet": "^0.7.0", 581 | "iconv-lite": "^0.4.24", 582 | "tmp": "^0.0.33" 583 | } 584 | }, 585 | "fast-deep-equal": { 586 | "version": "3.1.1", 587 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", 588 | "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==", 589 | "dev": true 590 | }, 591 | "fast-json-parse": { 592 | "version": "1.0.3", 593 | "resolved": "https://registry.npmjs.org/fast-json-parse/-/fast-json-parse-1.0.3.tgz", 594 | "integrity": "sha512-FRWsaZRWEJ1ESVNbDWmsAlqDk96gPQezzLghafp5J4GUKjbCz3OkAHuZs5TuPEtkbVQERysLp9xv6c24fBm8Aw==", 595 | "dev": true 596 | }, 597 | "fast-json-stable-stringify": { 598 | "version": "2.1.0", 599 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 600 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 601 | "dev": true 602 | }, 603 | "fast-levenshtein": { 604 | "version": "2.0.6", 605 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 606 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 607 | "dev": true 608 | }, 609 | "fast-safe-stringify": { 610 | "version": "1.2.0", 611 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-1.2.0.tgz", 612 | "integrity": "sha1-69QmZv0Y/k8rpPDSlQZfP4XK3pY=", 613 | "dev": true 614 | }, 615 | "figures": { 616 | "version": "3.2.0", 617 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 618 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 619 | "dev": true, 620 | "requires": { 621 | "escape-string-regexp": "^1.0.5" 622 | } 623 | }, 624 | "file-entry-cache": { 625 | "version": "5.0.1", 626 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 627 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 628 | "dev": true, 629 | "requires": { 630 | "flat-cache": "^2.0.1" 631 | } 632 | }, 633 | "find-up": { 634 | "version": "3.0.0", 635 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 636 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 637 | "requires": { 638 | "locate-path": "^3.0.0" 639 | } 640 | }, 641 | "flat": { 642 | "version": "4.1.0", 643 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 644 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 645 | "dev": true, 646 | "requires": { 647 | "is-buffer": "~2.0.3" 648 | } 649 | }, 650 | "flat-cache": { 651 | "version": "2.0.1", 652 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 653 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 654 | "dev": true, 655 | "requires": { 656 | "flatted": "^2.0.0", 657 | "rimraf": "2.6.3", 658 | "write": "1.0.3" 659 | } 660 | }, 661 | "flatstr": { 662 | "version": "1.0.5", 663 | "resolved": "https://registry.npmjs.org/flatstr/-/flatstr-1.0.5.tgz", 664 | "integrity": "sha1-W0UbCMvUji6sVKK74L9GFlqhS+M=", 665 | "dev": true 666 | }, 667 | "flatted": { 668 | "version": "2.0.2", 669 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 670 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 671 | "dev": true 672 | }, 673 | "fs.realpath": { 674 | "version": "1.0.0", 675 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 676 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 677 | "dev": true 678 | }, 679 | "function-bind": { 680 | "version": "1.1.1", 681 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 682 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 683 | "dev": true 684 | }, 685 | "functional-red-black-tree": { 686 | "version": "1.0.1", 687 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 688 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 689 | "dev": true 690 | }, 691 | "get-caller-file": { 692 | "version": "2.0.5", 693 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 694 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" 695 | }, 696 | "get-func-name": { 697 | "version": "2.0.0", 698 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 699 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 700 | "dev": true 701 | }, 702 | "glob": { 703 | "version": "7.1.3", 704 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 705 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 706 | "dev": true, 707 | "requires": { 708 | "fs.realpath": "^1.0.0", 709 | "inflight": "^1.0.4", 710 | "inherits": "2", 711 | "minimatch": "^3.0.4", 712 | "once": "^1.3.0", 713 | "path-is-absolute": "^1.0.0" 714 | } 715 | }, 716 | "glob-parent": { 717 | "version": "5.1.1", 718 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 719 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 720 | "dev": true, 721 | "requires": { 722 | "is-glob": "^4.0.1" 723 | } 724 | }, 725 | "globals": { 726 | "version": "12.4.0", 727 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 728 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 729 | "dev": true, 730 | "requires": { 731 | "type-fest": "^0.8.1" 732 | } 733 | }, 734 | "growl": { 735 | "version": "1.10.5", 736 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 737 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 738 | "dev": true 739 | }, 740 | "has": { 741 | "version": "1.0.3", 742 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 743 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 744 | "dev": true, 745 | "requires": { 746 | "function-bind": "^1.1.1" 747 | } 748 | }, 749 | "has-flag": { 750 | "version": "2.0.0", 751 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 752 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 753 | "dev": true 754 | }, 755 | "has-symbols": { 756 | "version": "1.0.0", 757 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 758 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 759 | "dev": true 760 | }, 761 | "he": { 762 | "version": "1.2.0", 763 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 764 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 765 | "dev": true 766 | }, 767 | "iconv-lite": { 768 | "version": "0.4.24", 769 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 770 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 771 | "dev": true, 772 | "requires": { 773 | "safer-buffer": ">= 2.1.2 < 3" 774 | } 775 | }, 776 | "ieee754": { 777 | "version": "1.1.13", 778 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", 779 | "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==" 780 | }, 781 | "ignore": { 782 | "version": "4.0.6", 783 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 784 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 785 | "dev": true 786 | }, 787 | "import-fresh": { 788 | "version": "3.2.1", 789 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 790 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 791 | "dev": true, 792 | "requires": { 793 | "parent-module": "^1.0.0", 794 | "resolve-from": "^4.0.0" 795 | } 796 | }, 797 | "imurmurhash": { 798 | "version": "0.1.4", 799 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 800 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 801 | "dev": true 802 | }, 803 | "inflight": { 804 | "version": "1.0.6", 805 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 806 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 807 | "dev": true, 808 | "requires": { 809 | "once": "^1.3.0", 810 | "wrappy": "1" 811 | } 812 | }, 813 | "inherits": { 814 | "version": "2.0.3", 815 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 816 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 817 | }, 818 | "inquirer": { 819 | "version": "7.1.0", 820 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.1.0.tgz", 821 | "integrity": "sha512-5fJMWEmikSYu0nv/flMc475MhGbB7TSPd/2IpFV4I4rMklboCH2rQjYY5kKiYGHqUF9gvaambupcJFFG9dvReg==", 822 | "dev": true, 823 | "requires": { 824 | "ansi-escapes": "^4.2.1", 825 | "chalk": "^3.0.0", 826 | "cli-cursor": "^3.1.0", 827 | "cli-width": "^2.0.0", 828 | "external-editor": "^3.0.3", 829 | "figures": "^3.0.0", 830 | "lodash": "^4.17.15", 831 | "mute-stream": "0.0.8", 832 | "run-async": "^2.4.0", 833 | "rxjs": "^6.5.3", 834 | "string-width": "^4.1.0", 835 | "strip-ansi": "^6.0.0", 836 | "through": "^2.3.6" 837 | }, 838 | "dependencies": { 839 | "ansi-regex": { 840 | "version": "5.0.0", 841 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 842 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 843 | "dev": true 844 | }, 845 | "ansi-styles": { 846 | "version": "4.2.1", 847 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 848 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 849 | "dev": true, 850 | "requires": { 851 | "@types/color-name": "^1.1.1", 852 | "color-convert": "^2.0.1" 853 | } 854 | }, 855 | "chalk": { 856 | "version": "3.0.0", 857 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 858 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 859 | "dev": true, 860 | "requires": { 861 | "ansi-styles": "^4.1.0", 862 | "supports-color": "^7.1.0" 863 | } 864 | }, 865 | "color-convert": { 866 | "version": "2.0.1", 867 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 868 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 869 | "dev": true, 870 | "requires": { 871 | "color-name": "~1.1.4" 872 | } 873 | }, 874 | "color-name": { 875 | "version": "1.1.4", 876 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 877 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 878 | "dev": true 879 | }, 880 | "emoji-regex": { 881 | "version": "8.0.0", 882 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 883 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 884 | "dev": true 885 | }, 886 | "has-flag": { 887 | "version": "4.0.0", 888 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 889 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 890 | "dev": true 891 | }, 892 | "is-fullwidth-code-point": { 893 | "version": "3.0.0", 894 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 895 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 896 | "dev": true 897 | }, 898 | "string-width": { 899 | "version": "4.2.0", 900 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 901 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 902 | "dev": true, 903 | "requires": { 904 | "emoji-regex": "^8.0.0", 905 | "is-fullwidth-code-point": "^3.0.0", 906 | "strip-ansi": "^6.0.0" 907 | } 908 | }, 909 | "strip-ansi": { 910 | "version": "6.0.0", 911 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 912 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 913 | "dev": true, 914 | "requires": { 915 | "ansi-regex": "^5.0.0" 916 | } 917 | }, 918 | "supports-color": { 919 | "version": "7.1.0", 920 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 921 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 922 | "dev": true, 923 | "requires": { 924 | "has-flag": "^4.0.0" 925 | } 926 | } 927 | } 928 | }, 929 | "is-buffer": { 930 | "version": "2.0.4", 931 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 932 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 933 | "dev": true 934 | }, 935 | "is-callable": { 936 | "version": "1.1.4", 937 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 938 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 939 | "dev": true 940 | }, 941 | "is-date-object": { 942 | "version": "1.0.1", 943 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 944 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 945 | "dev": true 946 | }, 947 | "is-extglob": { 948 | "version": "2.1.1", 949 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 950 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 951 | "dev": true 952 | }, 953 | "is-fullwidth-code-point": { 954 | "version": "2.0.0", 955 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 956 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 957 | }, 958 | "is-glob": { 959 | "version": "4.0.1", 960 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 961 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 962 | "dev": true, 963 | "requires": { 964 | "is-extglob": "^2.1.1" 965 | } 966 | }, 967 | "is-regex": { 968 | "version": "1.0.4", 969 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 970 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 971 | "dev": true, 972 | "requires": { 973 | "has": "^1.0.1" 974 | } 975 | }, 976 | "is-symbol": { 977 | "version": "1.0.2", 978 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 979 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 980 | "dev": true, 981 | "requires": { 982 | "has-symbols": "^1.0.0" 983 | } 984 | }, 985 | "isarray": { 986 | "version": "1.0.0", 987 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 988 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 989 | }, 990 | "isexe": { 991 | "version": "2.0.0", 992 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 993 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 994 | "dev": true 995 | }, 996 | "jmespath": { 997 | "version": "0.15.0", 998 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 999 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=" 1000 | }, 1001 | "js-tokens": { 1002 | "version": "4.0.0", 1003 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1004 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1005 | "dev": true 1006 | }, 1007 | "js-yaml": { 1008 | "version": "3.13.1", 1009 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1010 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1011 | "dev": true, 1012 | "requires": { 1013 | "argparse": "^1.0.7", 1014 | "esprima": "^4.0.0" 1015 | } 1016 | }, 1017 | "json-schema-traverse": { 1018 | "version": "0.4.1", 1019 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1020 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1021 | "dev": true 1022 | }, 1023 | "json-stable-stringify-without-jsonify": { 1024 | "version": "1.0.1", 1025 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1026 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1027 | "dev": true 1028 | }, 1029 | "levn": { 1030 | "version": "0.3.0", 1031 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1032 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1033 | "dev": true, 1034 | "requires": { 1035 | "prelude-ls": "~1.1.2", 1036 | "type-check": "~0.3.2" 1037 | } 1038 | }, 1039 | "locate-path": { 1040 | "version": "3.0.0", 1041 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1042 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1043 | "requires": { 1044 | "p-locate": "^3.0.0", 1045 | "path-exists": "^3.0.0" 1046 | } 1047 | }, 1048 | "lodash": { 1049 | "version": "4.17.15", 1050 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 1051 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", 1052 | "dev": true 1053 | }, 1054 | "lodash.reduce": { 1055 | "version": "4.6.0", 1056 | "resolved": "https://registry.npmjs.org/lodash.reduce/-/lodash.reduce-4.6.0.tgz", 1057 | "integrity": "sha1-8atrg5KZrUj3hKu/R2WW8DuRTTs=" 1058 | }, 1059 | "log-symbols": { 1060 | "version": "2.2.0", 1061 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", 1062 | "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", 1063 | "dev": true, 1064 | "requires": { 1065 | "chalk": "^2.0.1" 1066 | } 1067 | }, 1068 | "mimic-fn": { 1069 | "version": "2.1.0", 1070 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1071 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1072 | "dev": true 1073 | }, 1074 | "minimatch": { 1075 | "version": "3.0.4", 1076 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1077 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1078 | "dev": true, 1079 | "requires": { 1080 | "brace-expansion": "^1.1.7" 1081 | } 1082 | }, 1083 | "minimist": { 1084 | "version": "1.2.5", 1085 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1086 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1087 | "dev": true 1088 | }, 1089 | "mkdirp": { 1090 | "version": "0.5.5", 1091 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1092 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1093 | "dev": true, 1094 | "requires": { 1095 | "minimist": "^1.2.5" 1096 | } 1097 | }, 1098 | "mocha": { 1099 | "version": "6.2.2", 1100 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-6.2.2.tgz", 1101 | "integrity": "sha512-FgDS9Re79yU1xz5d+C4rv1G7QagNGHZ+iXF81hO8zY35YZZcLEsJVfFolfsqKFWunATEvNzMK0r/CwWd/szO9A==", 1102 | "dev": true, 1103 | "requires": { 1104 | "ansi-colors": "3.2.3", 1105 | "browser-stdout": "1.3.1", 1106 | "debug": "3.2.6", 1107 | "diff": "3.5.0", 1108 | "escape-string-regexp": "1.0.5", 1109 | "find-up": "3.0.0", 1110 | "glob": "7.1.3", 1111 | "growl": "1.10.5", 1112 | "he": "1.2.0", 1113 | "js-yaml": "3.13.1", 1114 | "log-symbols": "2.2.0", 1115 | "minimatch": "3.0.4", 1116 | "mkdirp": "0.5.1", 1117 | "ms": "2.1.1", 1118 | "node-environment-flags": "1.0.5", 1119 | "object.assign": "4.1.0", 1120 | "strip-json-comments": "2.0.1", 1121 | "supports-color": "6.0.0", 1122 | "which": "1.3.1", 1123 | "wide-align": "1.1.3", 1124 | "yargs": "13.3.0", 1125 | "yargs-parser": "13.1.1", 1126 | "yargs-unparser": "1.6.0" 1127 | }, 1128 | "dependencies": { 1129 | "ansi-regex": { 1130 | "version": "4.1.0", 1131 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1132 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1133 | "dev": true 1134 | }, 1135 | "cliui": { 1136 | "version": "5.0.0", 1137 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 1138 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 1139 | "dev": true, 1140 | "requires": { 1141 | "string-width": "^3.1.0", 1142 | "strip-ansi": "^5.2.0", 1143 | "wrap-ansi": "^5.1.0" 1144 | } 1145 | }, 1146 | "find-up": { 1147 | "version": "3.0.0", 1148 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1149 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1150 | "dev": true, 1151 | "requires": { 1152 | "locate-path": "^3.0.0" 1153 | } 1154 | }, 1155 | "get-caller-file": { 1156 | "version": "2.0.5", 1157 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1158 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1159 | "dev": true 1160 | }, 1161 | "has-flag": { 1162 | "version": "3.0.0", 1163 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1164 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1165 | "dev": true 1166 | }, 1167 | "is-fullwidth-code-point": { 1168 | "version": "2.0.0", 1169 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1170 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1171 | "dev": true 1172 | }, 1173 | "locate-path": { 1174 | "version": "3.0.0", 1175 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1176 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1177 | "dev": true, 1178 | "requires": { 1179 | "p-locate": "^3.0.0", 1180 | "path-exists": "^3.0.0" 1181 | } 1182 | }, 1183 | "minimist": { 1184 | "version": "0.0.8", 1185 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1186 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1187 | "dev": true 1188 | }, 1189 | "mkdirp": { 1190 | "version": "0.5.1", 1191 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1192 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1193 | "dev": true, 1194 | "requires": { 1195 | "minimist": "0.0.8" 1196 | } 1197 | }, 1198 | "p-limit": { 1199 | "version": "2.2.1", 1200 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", 1201 | "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", 1202 | "dev": true, 1203 | "requires": { 1204 | "p-try": "^2.0.0" 1205 | } 1206 | }, 1207 | "p-locate": { 1208 | "version": "3.0.0", 1209 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1210 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1211 | "dev": true, 1212 | "requires": { 1213 | "p-limit": "^2.0.0" 1214 | } 1215 | }, 1216 | "require-main-filename": { 1217 | "version": "2.0.0", 1218 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1219 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1220 | "dev": true 1221 | }, 1222 | "string-width": { 1223 | "version": "3.1.0", 1224 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1225 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1226 | "dev": true, 1227 | "requires": { 1228 | "emoji-regex": "^7.0.1", 1229 | "is-fullwidth-code-point": "^2.0.0", 1230 | "strip-ansi": "^5.1.0" 1231 | } 1232 | }, 1233 | "strip-ansi": { 1234 | "version": "5.2.0", 1235 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1236 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1237 | "dev": true, 1238 | "requires": { 1239 | "ansi-regex": "^4.1.0" 1240 | } 1241 | }, 1242 | "supports-color": { 1243 | "version": "6.0.0", 1244 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 1245 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 1246 | "dev": true, 1247 | "requires": { 1248 | "has-flag": "^3.0.0" 1249 | } 1250 | }, 1251 | "which": { 1252 | "version": "1.3.1", 1253 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1254 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1255 | "dev": true, 1256 | "requires": { 1257 | "isexe": "^2.0.0" 1258 | } 1259 | }, 1260 | "wrap-ansi": { 1261 | "version": "5.1.0", 1262 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 1263 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 1264 | "dev": true, 1265 | "requires": { 1266 | "ansi-styles": "^3.2.0", 1267 | "string-width": "^3.0.0", 1268 | "strip-ansi": "^5.0.0" 1269 | } 1270 | }, 1271 | "y18n": { 1272 | "version": "4.0.0", 1273 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 1274 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 1275 | "dev": true 1276 | }, 1277 | "yargs": { 1278 | "version": "13.3.0", 1279 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", 1280 | "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", 1281 | "dev": true, 1282 | "requires": { 1283 | "cliui": "^5.0.0", 1284 | "find-up": "^3.0.0", 1285 | "get-caller-file": "^2.0.1", 1286 | "require-directory": "^2.1.1", 1287 | "require-main-filename": "^2.0.0", 1288 | "set-blocking": "^2.0.0", 1289 | "string-width": "^3.0.0", 1290 | "which-module": "^2.0.0", 1291 | "y18n": "^4.0.0", 1292 | "yargs-parser": "^13.1.1" 1293 | } 1294 | }, 1295 | "yargs-parser": { 1296 | "version": "13.1.1", 1297 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.1.tgz", 1298 | "integrity": "sha512-oVAVsHz6uFrg3XQheFII8ESO2ssAf9luWuAd6Wexsu4F3OtIW0o8IribPXYrD4WC24LWtPrJlGy87y5udK+dxQ==", 1299 | "dev": true, 1300 | "requires": { 1301 | "camelcase": "^5.0.0", 1302 | "decamelize": "^1.2.0" 1303 | } 1304 | } 1305 | } 1306 | }, 1307 | "mock-require": { 1308 | "version": "2.0.2", 1309 | "resolved": "https://registry.npmjs.org/mock-require/-/mock-require-2.0.2.tgz", 1310 | "integrity": "sha1-HqpxqtIwE3c9En3H6Ro/u0g31g0=", 1311 | "dev": true, 1312 | "requires": { 1313 | "caller-id": "^0.1.0" 1314 | } 1315 | }, 1316 | "ms": { 1317 | "version": "2.1.1", 1318 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1319 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1320 | "dev": true 1321 | }, 1322 | "mute-stream": { 1323 | "version": "0.0.8", 1324 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1325 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1326 | "dev": true 1327 | }, 1328 | "natural-compare": { 1329 | "version": "1.4.0", 1330 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1331 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1332 | "dev": true 1333 | }, 1334 | "nice-try": { 1335 | "version": "1.0.5", 1336 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1337 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1338 | "dev": true 1339 | }, 1340 | "node-environment-flags": { 1341 | "version": "1.0.5", 1342 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.5.tgz", 1343 | "integrity": "sha512-VNYPRfGfmZLx0Ye20jWzHUjyTW/c+6Wq+iLhDzUI4XmhrDd9l/FozXV3F2xOaXjvp0co0+v1YSR3CMP6g+VvLQ==", 1344 | "dev": true, 1345 | "requires": { 1346 | "object.getownpropertydescriptors": "^2.0.3", 1347 | "semver": "^5.7.0" 1348 | }, 1349 | "dependencies": { 1350 | "semver": { 1351 | "version": "5.7.1", 1352 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1353 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1354 | "dev": true 1355 | } 1356 | } 1357 | }, 1358 | "object-inspect": { 1359 | "version": "1.6.0", 1360 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.6.0.tgz", 1361 | "integrity": "sha512-GJzfBZ6DgDAmnuaM3104jR4s1Myxr3Y3zfIyN4z3UdqN69oSRacNK8UhnobDdC+7J2AHCjGwxQubNJfE70SXXQ==", 1362 | "dev": true 1363 | }, 1364 | "object-keys": { 1365 | "version": "1.1.1", 1366 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1367 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1368 | "dev": true 1369 | }, 1370 | "object.assign": { 1371 | "version": "4.1.0", 1372 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1373 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1374 | "dev": true, 1375 | "requires": { 1376 | "define-properties": "^1.1.2", 1377 | "function-bind": "^1.1.1", 1378 | "has-symbols": "^1.0.0", 1379 | "object-keys": "^1.0.11" 1380 | } 1381 | }, 1382 | "object.getownpropertydescriptors": { 1383 | "version": "2.0.3", 1384 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", 1385 | "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", 1386 | "dev": true, 1387 | "requires": { 1388 | "define-properties": "^1.1.2", 1389 | "es-abstract": "^1.5.1" 1390 | } 1391 | }, 1392 | "once": { 1393 | "version": "1.4.0", 1394 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1395 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1396 | "requires": { 1397 | "wrappy": "1" 1398 | } 1399 | }, 1400 | "onetime": { 1401 | "version": "5.1.0", 1402 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1403 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1404 | "dev": true, 1405 | "requires": { 1406 | "mimic-fn": "^2.1.0" 1407 | } 1408 | }, 1409 | "optionator": { 1410 | "version": "0.8.3", 1411 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 1412 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 1413 | "dev": true, 1414 | "requires": { 1415 | "deep-is": "~0.1.3", 1416 | "fast-levenshtein": "~2.0.6", 1417 | "levn": "~0.3.0", 1418 | "prelude-ls": "~1.1.2", 1419 | "type-check": "~0.3.2", 1420 | "word-wrap": "~1.2.3" 1421 | } 1422 | }, 1423 | "os-tmpdir": { 1424 | "version": "1.0.2", 1425 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1426 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1427 | "dev": true 1428 | }, 1429 | "p-limit": { 1430 | "version": "2.3.0", 1431 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1432 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1433 | "requires": { 1434 | "p-try": "^2.0.0" 1435 | } 1436 | }, 1437 | "p-locate": { 1438 | "version": "3.0.0", 1439 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1440 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1441 | "requires": { 1442 | "p-limit": "^2.0.0" 1443 | } 1444 | }, 1445 | "p-try": { 1446 | "version": "2.2.0", 1447 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1448 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" 1449 | }, 1450 | "parent-module": { 1451 | "version": "1.0.1", 1452 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1453 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1454 | "dev": true, 1455 | "requires": { 1456 | "callsites": "^3.0.0" 1457 | } 1458 | }, 1459 | "path-exists": { 1460 | "version": "3.0.0", 1461 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1462 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" 1463 | }, 1464 | "path-is-absolute": { 1465 | "version": "1.0.1", 1466 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1467 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1468 | "dev": true 1469 | }, 1470 | "path-key": { 1471 | "version": "2.0.1", 1472 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1473 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1474 | "dev": true 1475 | }, 1476 | "pathval": { 1477 | "version": "1.1.0", 1478 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz", 1479 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", 1480 | "dev": true 1481 | }, 1482 | "pino": { 1483 | "version": "4.7.2", 1484 | "resolved": "https://registry.npmjs.org/pino/-/pino-4.7.2.tgz", 1485 | "integrity": "sha1-VujnEmN2aQlfCmGyehVknWLeyM0=", 1486 | "dev": true, 1487 | "requires": { 1488 | "chalk": "^2.0.1", 1489 | "fast-json-parse": "^1.0.0", 1490 | "fast-safe-stringify": "^1.1.11", 1491 | "flatstr": "^1.0.4", 1492 | "pump": "^1.0.2", 1493 | "quick-format-unescaped": "^1.1.1", 1494 | "split2": "^2.0.1" 1495 | } 1496 | }, 1497 | "prelude-ls": { 1498 | "version": "1.1.2", 1499 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1500 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1501 | "dev": true 1502 | }, 1503 | "process-nextick-args": { 1504 | "version": "1.0.7", 1505 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 1506 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" 1507 | }, 1508 | "progress": { 1509 | "version": "2.0.3", 1510 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1511 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1512 | "dev": true 1513 | }, 1514 | "pump": { 1515 | "version": "1.0.2", 1516 | "resolved": "https://registry.npmjs.org/pump/-/pump-1.0.2.tgz", 1517 | "integrity": "sha1-Oz7mUS+U8OV1U4wXmV+fFpkKXVE=", 1518 | "requires": { 1519 | "end-of-stream": "^1.1.0", 1520 | "once": "^1.3.1" 1521 | } 1522 | }, 1523 | "punycode": { 1524 | "version": "1.3.2", 1525 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 1526 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" 1527 | }, 1528 | "querystring": { 1529 | "version": "0.2.0", 1530 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 1531 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" 1532 | }, 1533 | "quick-format-unescaped": { 1534 | "version": "1.1.1", 1535 | "resolved": "https://registry.npmjs.org/quick-format-unescaped/-/quick-format-unescaped-1.1.1.tgz", 1536 | "integrity": "sha1-53VV7z5m4QXUA54T73kgEoT+6RY=", 1537 | "dev": true, 1538 | "requires": { 1539 | "fast-safe-stringify": "^1.0.8" 1540 | } 1541 | }, 1542 | "readable-stream": { 1543 | "version": "2.3.3", 1544 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 1545 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 1546 | "requires": { 1547 | "core-util-is": "~1.0.0", 1548 | "inherits": "~2.0.3", 1549 | "isarray": "~1.0.0", 1550 | "process-nextick-args": "~1.0.6", 1551 | "safe-buffer": "~5.1.1", 1552 | "string_decoder": "~1.0.3", 1553 | "util-deprecate": "~1.0.1" 1554 | } 1555 | }, 1556 | "regexpp": { 1557 | "version": "2.0.1", 1558 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1559 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1560 | "dev": true 1561 | }, 1562 | "require-directory": { 1563 | "version": "2.1.1", 1564 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1565 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 1566 | }, 1567 | "require-main-filename": { 1568 | "version": "2.0.0", 1569 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1570 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" 1571 | }, 1572 | "resolve-from": { 1573 | "version": "4.0.0", 1574 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1575 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1576 | "dev": true 1577 | }, 1578 | "restore-cursor": { 1579 | "version": "3.1.0", 1580 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1581 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1582 | "dev": true, 1583 | "requires": { 1584 | "onetime": "^5.1.0", 1585 | "signal-exit": "^3.0.2" 1586 | } 1587 | }, 1588 | "rimraf": { 1589 | "version": "2.6.3", 1590 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1591 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1592 | "dev": true, 1593 | "requires": { 1594 | "glob": "^7.1.3" 1595 | } 1596 | }, 1597 | "run-async": { 1598 | "version": "2.4.1", 1599 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 1600 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 1601 | "dev": true 1602 | }, 1603 | "rxjs": { 1604 | "version": "6.5.5", 1605 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.5.tgz", 1606 | "integrity": "sha512-WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ==", 1607 | "dev": true, 1608 | "requires": { 1609 | "tslib": "^1.9.0" 1610 | } 1611 | }, 1612 | "safe-buffer": { 1613 | "version": "5.1.1", 1614 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1615 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 1616 | }, 1617 | "safer-buffer": { 1618 | "version": "2.1.2", 1619 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1620 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1621 | "dev": true 1622 | }, 1623 | "sax": { 1624 | "version": "1.2.1", 1625 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.1.tgz", 1626 | "integrity": "sha1-e45lYZCyKOgaZq6nSEgNgozS03o=" 1627 | }, 1628 | "semver": { 1629 | "version": "6.3.0", 1630 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1631 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1632 | "dev": true 1633 | }, 1634 | "set-blocking": { 1635 | "version": "2.0.0", 1636 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1637 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1638 | }, 1639 | "shebang-command": { 1640 | "version": "1.2.0", 1641 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1642 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1643 | "dev": true, 1644 | "requires": { 1645 | "shebang-regex": "^1.0.0" 1646 | } 1647 | }, 1648 | "shebang-regex": { 1649 | "version": "1.0.0", 1650 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1651 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1652 | "dev": true 1653 | }, 1654 | "signal-exit": { 1655 | "version": "3.0.3", 1656 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1657 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1658 | "dev": true 1659 | }, 1660 | "slice-ansi": { 1661 | "version": "2.1.0", 1662 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1663 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1664 | "dev": true, 1665 | "requires": { 1666 | "ansi-styles": "^3.2.0", 1667 | "astral-regex": "^1.0.0", 1668 | "is-fullwidth-code-point": "^2.0.0" 1669 | } 1670 | }, 1671 | "split2": { 1672 | "version": "2.1.1", 1673 | "resolved": "https://registry.npmjs.org/split2/-/split2-2.1.1.tgz", 1674 | "integrity": "sha1-eh9VHhdqkOzTNF9yRqDP4XXvT9A=", 1675 | "requires": { 1676 | "through2": "^2.0.2" 1677 | } 1678 | }, 1679 | "sprintf-js": { 1680 | "version": "1.0.3", 1681 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1682 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1683 | "dev": true 1684 | }, 1685 | "stack-trace": { 1686 | "version": "0.0.10", 1687 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 1688 | "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=", 1689 | "dev": true 1690 | }, 1691 | "string-width": { 1692 | "version": "2.1.1", 1693 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1694 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1695 | "dev": true, 1696 | "requires": { 1697 | "is-fullwidth-code-point": "^2.0.0", 1698 | "strip-ansi": "^4.0.0" 1699 | }, 1700 | "dependencies": { 1701 | "ansi-regex": { 1702 | "version": "3.0.0", 1703 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1704 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1705 | "dev": true 1706 | }, 1707 | "is-fullwidth-code-point": { 1708 | "version": "2.0.0", 1709 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1710 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1711 | "dev": true 1712 | }, 1713 | "strip-ansi": { 1714 | "version": "4.0.0", 1715 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1716 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1717 | "dev": true, 1718 | "requires": { 1719 | "ansi-regex": "^3.0.0" 1720 | } 1721 | } 1722 | } 1723 | }, 1724 | "string.prototype.trimleft": { 1725 | "version": "2.1.0", 1726 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.0.tgz", 1727 | "integrity": "sha512-FJ6b7EgdKxxbDxc79cOlok6Afd++TTs5szo+zJTUyow3ycrRfJVE2pq3vcN53XexvKZu/DJMDfeI/qMiZTrjTw==", 1728 | "dev": true, 1729 | "requires": { 1730 | "define-properties": "^1.1.3", 1731 | "function-bind": "^1.1.1" 1732 | } 1733 | }, 1734 | "string.prototype.trimright": { 1735 | "version": "2.1.0", 1736 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.0.tgz", 1737 | "integrity": "sha512-fXZTSV55dNBwv16uw+hh5jkghxSnc5oHq+5K/gXgizHwAvMetdAJlHqqoFC1FSDVPYWLkAKl2cxpUT41sV7nSg==", 1738 | "dev": true, 1739 | "requires": { 1740 | "define-properties": "^1.1.3", 1741 | "function-bind": "^1.1.1" 1742 | } 1743 | }, 1744 | "string_decoder": { 1745 | "version": "1.0.3", 1746 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 1747 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 1748 | "requires": { 1749 | "safe-buffer": "~5.1.0" 1750 | } 1751 | }, 1752 | "strip-ansi": { 1753 | "version": "5.2.0", 1754 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1755 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1756 | "requires": { 1757 | "ansi-regex": "^4.1.0" 1758 | } 1759 | }, 1760 | "strip-json-comments": { 1761 | "version": "2.0.1", 1762 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1763 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1764 | "dev": true 1765 | }, 1766 | "supports-color": { 1767 | "version": "4.4.0", 1768 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 1769 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 1770 | "dev": true, 1771 | "requires": { 1772 | "has-flag": "^2.0.0" 1773 | } 1774 | }, 1775 | "table": { 1776 | "version": "5.4.6", 1777 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1778 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1779 | "dev": true, 1780 | "requires": { 1781 | "ajv": "^6.10.2", 1782 | "lodash": "^4.17.14", 1783 | "slice-ansi": "^2.1.0", 1784 | "string-width": "^3.0.0" 1785 | }, 1786 | "dependencies": { 1787 | "string-width": { 1788 | "version": "3.1.0", 1789 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1790 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1791 | "dev": true, 1792 | "requires": { 1793 | "emoji-regex": "^7.0.1", 1794 | "is-fullwidth-code-point": "^2.0.0", 1795 | "strip-ansi": "^5.1.0" 1796 | } 1797 | } 1798 | } 1799 | }, 1800 | "text-table": { 1801 | "version": "0.2.0", 1802 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1803 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1804 | "dev": true 1805 | }, 1806 | "through": { 1807 | "version": "2.3.8", 1808 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1809 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1810 | "dev": true 1811 | }, 1812 | "through2": { 1813 | "version": "2.0.3", 1814 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", 1815 | "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", 1816 | "requires": { 1817 | "readable-stream": "^2.1.5", 1818 | "xtend": "~4.0.1" 1819 | } 1820 | }, 1821 | "tmp": { 1822 | "version": "0.0.33", 1823 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1824 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1825 | "dev": true, 1826 | "requires": { 1827 | "os-tmpdir": "~1.0.2" 1828 | } 1829 | }, 1830 | "tslib": { 1831 | "version": "1.11.1", 1832 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", 1833 | "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==", 1834 | "dev": true 1835 | }, 1836 | "type-check": { 1837 | "version": "0.3.2", 1838 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1839 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1840 | "dev": true, 1841 | "requires": { 1842 | "prelude-ls": "~1.1.2" 1843 | } 1844 | }, 1845 | "type-detect": { 1846 | "version": "4.0.8", 1847 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 1848 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 1849 | "dev": true 1850 | }, 1851 | "type-fest": { 1852 | "version": "0.8.1", 1853 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1854 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1855 | "dev": true 1856 | }, 1857 | "uri-js": { 1858 | "version": "4.2.2", 1859 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1860 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1861 | "dev": true, 1862 | "requires": { 1863 | "punycode": "^2.1.0" 1864 | }, 1865 | "dependencies": { 1866 | "punycode": { 1867 | "version": "2.1.1", 1868 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1869 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1870 | "dev": true 1871 | } 1872 | } 1873 | }, 1874 | "url": { 1875 | "version": "0.10.3", 1876 | "resolved": "https://registry.npmjs.org/url/-/url-0.10.3.tgz", 1877 | "integrity": "sha1-Ah5NnHcF8hu/N9A861h2dAJ3TGQ=", 1878 | "requires": { 1879 | "punycode": "1.3.2", 1880 | "querystring": "0.2.0" 1881 | } 1882 | }, 1883 | "util-deprecate": { 1884 | "version": "1.0.2", 1885 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1886 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1887 | }, 1888 | "uuid": { 1889 | "version": "3.3.2", 1890 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1891 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 1892 | }, 1893 | "v8-compile-cache": { 1894 | "version": "2.1.0", 1895 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 1896 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", 1897 | "dev": true 1898 | }, 1899 | "which": { 1900 | "version": "1.3.1", 1901 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1902 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1903 | "dev": true, 1904 | "requires": { 1905 | "isexe": "^2.0.0" 1906 | } 1907 | }, 1908 | "which-module": { 1909 | "version": "2.0.0", 1910 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1911 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" 1912 | }, 1913 | "wide-align": { 1914 | "version": "1.1.3", 1915 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1916 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1917 | "dev": true, 1918 | "requires": { 1919 | "string-width": "^1.0.2 || 2" 1920 | } 1921 | }, 1922 | "word-wrap": { 1923 | "version": "1.2.3", 1924 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1925 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1926 | "dev": true 1927 | }, 1928 | "wrap-ansi": { 1929 | "version": "5.1.0", 1930 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 1931 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 1932 | "requires": { 1933 | "ansi-styles": "^3.2.0", 1934 | "string-width": "^3.0.0", 1935 | "strip-ansi": "^5.0.0" 1936 | }, 1937 | "dependencies": { 1938 | "string-width": { 1939 | "version": "3.1.0", 1940 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1941 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1942 | "requires": { 1943 | "emoji-regex": "^7.0.1", 1944 | "is-fullwidth-code-point": "^2.0.0", 1945 | "strip-ansi": "^5.1.0" 1946 | } 1947 | } 1948 | } 1949 | }, 1950 | "wrappy": { 1951 | "version": "1.0.2", 1952 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1953 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1954 | }, 1955 | "write": { 1956 | "version": "1.0.3", 1957 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1958 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1959 | "dev": true, 1960 | "requires": { 1961 | "mkdirp": "^0.5.1" 1962 | } 1963 | }, 1964 | "xml2js": { 1965 | "version": "0.4.19", 1966 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.19.tgz", 1967 | "integrity": "sha512-esZnJZJOiJR9wWKMyuvSE1y6Dq5LCuJanqhxslH2bxM6duahNZ+HMpCLhBQGZkbX6xRf8x1Y2eJlgt2q3qo49Q==", 1968 | "requires": { 1969 | "sax": ">=0.6.0", 1970 | "xmlbuilder": "~9.0.1" 1971 | } 1972 | }, 1973 | "xmlbuilder": { 1974 | "version": "9.0.7", 1975 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", 1976 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=" 1977 | }, 1978 | "xtend": { 1979 | "version": "4.0.1", 1980 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 1981 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 1982 | }, 1983 | "y18n": { 1984 | "version": "4.0.0", 1985 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 1986 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==" 1987 | }, 1988 | "yargs": { 1989 | "version": "13.3.2", 1990 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 1991 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 1992 | "requires": { 1993 | "cliui": "^5.0.0", 1994 | "find-up": "^3.0.0", 1995 | "get-caller-file": "^2.0.1", 1996 | "require-directory": "^2.1.1", 1997 | "require-main-filename": "^2.0.0", 1998 | "set-blocking": "^2.0.0", 1999 | "string-width": "^3.0.0", 2000 | "which-module": "^2.0.0", 2001 | "y18n": "^4.0.0", 2002 | "yargs-parser": "^13.1.2" 2003 | }, 2004 | "dependencies": { 2005 | "string-width": { 2006 | "version": "3.1.0", 2007 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2008 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2009 | "requires": { 2010 | "emoji-regex": "^7.0.1", 2011 | "is-fullwidth-code-point": "^2.0.0", 2012 | "strip-ansi": "^5.1.0" 2013 | } 2014 | } 2015 | } 2016 | }, 2017 | "yargs-parser": { 2018 | "version": "13.1.2", 2019 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2020 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2021 | "requires": { 2022 | "camelcase": "^5.0.0", 2023 | "decamelize": "^1.2.0" 2024 | } 2025 | }, 2026 | "yargs-unparser": { 2027 | "version": "1.6.0", 2028 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 2029 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 2030 | "dev": true, 2031 | "requires": { 2032 | "flat": "^4.1.0", 2033 | "lodash": "^4.17.15", 2034 | "yargs": "^13.3.0" 2035 | }, 2036 | "dependencies": { 2037 | "ansi-regex": { 2038 | "version": "4.1.0", 2039 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2040 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2041 | "dev": true 2042 | }, 2043 | "cliui": { 2044 | "version": "5.0.0", 2045 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 2046 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 2047 | "dev": true, 2048 | "requires": { 2049 | "string-width": "^3.1.0", 2050 | "strip-ansi": "^5.2.0", 2051 | "wrap-ansi": "^5.1.0" 2052 | } 2053 | }, 2054 | "find-up": { 2055 | "version": "3.0.0", 2056 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 2057 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 2058 | "dev": true, 2059 | "requires": { 2060 | "locate-path": "^3.0.0" 2061 | } 2062 | }, 2063 | "get-caller-file": { 2064 | "version": "2.0.5", 2065 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2066 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2067 | "dev": true 2068 | }, 2069 | "is-fullwidth-code-point": { 2070 | "version": "2.0.0", 2071 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2072 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2073 | "dev": true 2074 | }, 2075 | "locate-path": { 2076 | "version": "3.0.0", 2077 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 2078 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 2079 | "dev": true, 2080 | "requires": { 2081 | "p-locate": "^3.0.0", 2082 | "path-exists": "^3.0.0" 2083 | } 2084 | }, 2085 | "p-limit": { 2086 | "version": "2.2.1", 2087 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", 2088 | "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", 2089 | "dev": true, 2090 | "requires": { 2091 | "p-try": "^2.0.0" 2092 | } 2093 | }, 2094 | "p-locate": { 2095 | "version": "3.0.0", 2096 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2097 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2098 | "dev": true, 2099 | "requires": { 2100 | "p-limit": "^2.0.0" 2101 | } 2102 | }, 2103 | "require-main-filename": { 2104 | "version": "2.0.0", 2105 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2106 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 2107 | "dev": true 2108 | }, 2109 | "string-width": { 2110 | "version": "3.1.0", 2111 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2112 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2113 | "dev": true, 2114 | "requires": { 2115 | "emoji-regex": "^7.0.1", 2116 | "is-fullwidth-code-point": "^2.0.0", 2117 | "strip-ansi": "^5.1.0" 2118 | } 2119 | }, 2120 | "strip-ansi": { 2121 | "version": "5.2.0", 2122 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2123 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2124 | "dev": true, 2125 | "requires": { 2126 | "ansi-regex": "^4.1.0" 2127 | } 2128 | }, 2129 | "wrap-ansi": { 2130 | "version": "5.1.0", 2131 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 2132 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 2133 | "dev": true, 2134 | "requires": { 2135 | "ansi-styles": "^3.2.0", 2136 | "string-width": "^3.0.0", 2137 | "strip-ansi": "^5.0.0" 2138 | } 2139 | }, 2140 | "y18n": { 2141 | "version": "4.0.0", 2142 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 2143 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 2144 | "dev": true 2145 | }, 2146 | "yargs": { 2147 | "version": "13.3.0", 2148 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", 2149 | "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", 2150 | "dev": true, 2151 | "requires": { 2152 | "cliui": "^5.0.0", 2153 | "find-up": "^3.0.0", 2154 | "get-caller-file": "^2.0.1", 2155 | "require-directory": "^2.1.1", 2156 | "require-main-filename": "^2.0.0", 2157 | "set-blocking": "^2.0.0", 2158 | "string-width": "^3.0.0", 2159 | "which-module": "^2.0.0", 2160 | "y18n": "^4.0.0", 2161 | "yargs-parser": "^13.1.1" 2162 | } 2163 | }, 2164 | "yargs-parser": { 2165 | "version": "13.1.2", 2166 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2167 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2168 | "dev": true, 2169 | "requires": { 2170 | "camelcase": "^5.0.0", 2171 | "decamelize": "^1.2.0" 2172 | } 2173 | } 2174 | } 2175 | } 2176 | } 2177 | } 2178 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pino-cloudwatch", 3 | "version": "0.7.0", 4 | "description": "CloudWatch Logs transport for pino", 5 | "main": "index.js", 6 | "bin": { 7 | "pino-cloudwatch": "bin/pino-cloudwatch.js" 8 | }, 9 | "scripts": { 10 | "test": "mocha test/specs/*", 11 | "lint": "eslint ." 12 | }, 13 | "keywords": [ 14 | "pino", 15 | "cloudwatch", 16 | "logs", 17 | "logger" 18 | ], 19 | "author": "David Howell (david@dynamicmethods.com.au)", 20 | "license": "MIT", 21 | "bugs": { 22 | "url": "https://github.com/dbhowell/pino-cloudwatch/issues" 23 | }, 24 | "homepage": "https://github.com/dbhowell/pino-cloudwatch#readme", 25 | "dependencies": { 26 | "async": "^3.2.0", 27 | "aws-sdk": "^2.668.0", 28 | "chunky-stream": "^0.3.0", 29 | "pump": "^1.0.2", 30 | "readable-stream": "^2.3.3", 31 | "split2": "^2.1.1", 32 | "yargs": "^13.3.0" 33 | }, 34 | "devDependencies": { 35 | "chai": "^4.2.0", 36 | "eslint": "^6.8.0", 37 | "mocha": "^6.2.2", 38 | "mock-require": "^2.0.2", 39 | "pino": "^4.7.2" 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /test/mocks/aws-sdk.js: -------------------------------------------------------------------------------- 1 | var CloudWatchLogs = require('./cloudwatch-logs'); 2 | 3 | module.exports = { 4 | CloudWatchLogs: CloudWatchLogs 5 | }; 6 | -------------------------------------------------------------------------------- /test/mocks/cloudwatch-logs.js: -------------------------------------------------------------------------------- 1 | const invalidSequenceTokenError = { 2 | code: 'InvalidSequenceTokenException' 3 | }; 4 | 5 | const invalidSequenceTokenRequest = { 6 | httpResponse: { 7 | body: '{"expectedSequenceToken": 1000}' 8 | } 9 | }; 10 | 11 | function CloudWatchLogs (options) { 12 | this.mode = options.region; 13 | } 14 | 15 | CloudWatchLogs.prototype.putLogEvents = function (options, callback) { 16 | if (this.mode === 'InvalidSequenceTokenException' && options.sequenceToken === 1) { 17 | var cb = callback.bind(invalidSequenceTokenRequest); 18 | 19 | return cb(invalidSequenceTokenError, null); 20 | } 21 | 22 | callback(null, { nextSequenceToken: options.sequenceToken++ }); 23 | }; 24 | 25 | CloudWatchLogs.prototype.createLogGroup = function (options, callback) { 26 | callback(); 27 | }; 28 | 29 | CloudWatchLogs.prototype.createLogStream = function (options, callback) { 30 | callback(); 31 | }; 32 | 33 | CloudWatchLogs.prototype.describeLogStreams = function (options, callback) { 34 | var data = { 35 | logStreams: [ 36 | { 37 | name: 'test', 38 | uploadSequenceToken: 1 39 | } 40 | ] 41 | }; 42 | 43 | callback(null, data); 44 | }; 45 | 46 | module.exports = CloudWatchLogs; 47 | -------------------------------------------------------------------------------- /test/mocks/log_empty.txt: -------------------------------------------------------------------------------- 1 | 2 | 3 | -------------------------------------------------------------------------------- /test/mocks/log_single.txt: -------------------------------------------------------------------------------- 1 | line 1 -------------------------------------------------------------------------------- /test/mocks/logs.txt: -------------------------------------------------------------------------------- 1 | line 1 2 | line 2 3 | line 3 4 | -------------------------------------------------------------------------------- /test/specs/cloudwatch-stream.spec.js: -------------------------------------------------------------------------------- 1 | require('chai').should(); 2 | var mockRequire = require('mock-require'); 3 | mockRequire('aws-sdk', require('../mocks/aws-sdk')); 4 | 5 | var fs = require('fs'); 6 | var path = require('path'); 7 | var pump = require('pump'); 8 | var split = require('split2'); 9 | var CloudWatchStream = require('../../lib/cloudwatch-stream'); 10 | 11 | describe('cloudwatch-stream', function () { 12 | it('should error if no Log Group name specified', function () { 13 | try { 14 | pump(CloudWatchStream({}), function (err) { 15 | if (err) { 16 | console.log(err); 17 | } 18 | }); 19 | } catch (err) { 20 | err.should.not.be.null; 21 | } 22 | }); 23 | 24 | it('should send the chunks to CloudWatch Logs', function (done) { 25 | var stream = new CloudWatchStream({ group: 'test' }); 26 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/logs.txt')); 27 | 28 | pump(inStream, split(), stream, function (err) { 29 | done(err); 30 | }); 31 | }); 32 | 33 | it('should recover from an InvalidSequenceTokenException', function (done) { 34 | var stream = new CloudWatchStream({ group: 'test', aws_region: 'InvalidSequenceTokenException' }); 35 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/logs.txt')); 36 | 37 | pump(inStream, split(), stream, function (err) { 38 | done(err); 39 | }); 40 | }); 41 | 42 | it('should emit a flushed event', function (done) { 43 | var stream = new CloudWatchStream({ group: 'test' }); 44 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/log_single.txt')); 45 | 46 | stream.on('flushed', function () { 47 | done(); 48 | }); 49 | 50 | pump(inStream, split(), stream); 51 | }); 52 | }); 53 | -------------------------------------------------------------------------------- /test/specs/index.spec.js: -------------------------------------------------------------------------------- 1 | var mockRequire = require('mock-require'); 2 | mockRequire('aws-sdk', require('../mocks/aws-sdk')); 3 | var index = require('../../index'); 4 | var fs = require('fs'); 5 | var path = require('path'); 6 | 7 | describe('pino-cloudwatch', function () { 8 | it('should send logs to CloudWatch Logs', function (done) { 9 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/logs.txt')); 10 | var pump = require('pump'); 11 | var split = require('split2'); 12 | 13 | pump(inStream, split(), index({ group: 'test' }), function (err) { 14 | done(err); 15 | }); 16 | }); 17 | 18 | it('should not send logs to CloudWatch Logs', function (done) { 19 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/log_empty.txt')); 20 | var pump = require('pump'); 21 | var split = require('split2'); 22 | 23 | pump(inStream, split(), index({ group: 'test' }), function (err) { 24 | done(err); 25 | }); 26 | }); 27 | 28 | it('should emit a flushed event', function (done) { 29 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/log_single.txt')); 30 | var pump = require('pump'); 31 | var split = require('split2'); 32 | var pinoCloudwatch = index({ group: 'test' }); 33 | 34 | pinoCloudwatch.on('flushed', function () { 35 | done(); 36 | }); 37 | 38 | pump(inStream, split(), pinoCloudwatch); 39 | }); 40 | }); 41 | -------------------------------------------------------------------------------- /test/specs/max-length.spec.js: -------------------------------------------------------------------------------- 1 | require('chai').should(); 2 | 3 | describe('max-length', function () { 4 | it('should return false when below MAX_LENGTH (10000)', function () { 5 | var maxLength = require('../../lib/max-length'); 6 | var newChunk = {}; 7 | var chunks = []; 8 | var result = maxLength(chunks, newChunk); 9 | 10 | result.should.be.false; 11 | }); 12 | 13 | it('should return true when equal MAX_LENGTH (10000)', function () { 14 | var maxLength = require('../../lib/max-length'); 15 | var newChunk = {}; 16 | var chunks = []; 17 | 18 | for (var i = 0; i < 10000; i++) { 19 | chunks.push({}); 20 | } 21 | 22 | var result = maxLength(chunks, newChunk); 23 | 24 | result.should.be.true; 25 | }); 26 | }); 27 | -------------------------------------------------------------------------------- /test/specs/max-size.spec.js: -------------------------------------------------------------------------------- 1 | var maxSize = require('../../lib/max-size'); 2 | require('chai').should(); 3 | 4 | describe('max-size', function () { 5 | it('should return false when below MAX_SIZE (1048576)', function () { 6 | var newChunk = '1'; 7 | var chunks = ['1', '2']; 8 | var result = maxSize(chunks, newChunk); 9 | 10 | result.should.be.false; 11 | }); 12 | 13 | it('should return true when size of all chunks plus new chunk is above MAX_SIZE (1048576)', function () { 14 | var newChunk = '1234567890'; 15 | var chunks = []; 16 | 17 | for (var i = 0; i < (1048576 / (10 + 26)) - 1; i++) { 18 | chunks.push('1234567890'); 19 | } 20 | 21 | var result = maxSize(chunks, newChunk); 22 | 23 | result.should.be.true; 24 | }); 25 | }); 26 | -------------------------------------------------------------------------------- /test/specs/stdout-stream.spec.js: -------------------------------------------------------------------------------- 1 | require('chai').should(); 2 | var mockRequire = require('mock-require'); 3 | mockRequire('aws-sdk', require('../mocks/aws-sdk')); 4 | 5 | var fs = require('fs'); 6 | var path = require('path'); 7 | var pump = require('pump'); 8 | var split = require('split2'); 9 | var StdoutStream = require('../../lib/stdout-stream'); 10 | 11 | describe('stdout-stream', function () { 12 | it('should copy input to stdout', function (done) { 13 | var didLog = false; 14 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/logs.txt')); 15 | var mockConsole = { 16 | log: function (/*message*/) { 17 | didLog = true; 18 | } 19 | }; 20 | var stream = new StdoutStream({ stdout: true, console: mockConsole }); 21 | 22 | pump(inStream, split(), stream, function (err) { 23 | didLog.should.be.true; 24 | done(err); 25 | }); 26 | }); 27 | 28 | it('should not copy input to stdout', function (done) { 29 | var didLog = false; 30 | var mockConsole = { 31 | log: function (/*message*/) { 32 | didLog = true; 33 | } 34 | }; 35 | var stream = new StdoutStream({ stdout: false, console: mockConsole }); 36 | var inStream = fs.createReadStream(path.resolve(__dirname, '../mocks/logs.txt')); 37 | 38 | pump(inStream, split(), stream, function (err) { 39 | didLog.should.be.false; 40 | done(err); 41 | }); 42 | }); 43 | }); 44 | --------------------------------------------------------------------------------