diff --git a/.babelrc b/.babelrc new file mode 100644 index 0000000..1adee71 --- /dev/null +++ b/.babelrc @@ -0,0 +1,12 @@ +{ + "presets": [ + [ + "@babel/preset-env", + { + "targets": { + "node": "current" + } + } + ] + ] +} diff --git a/.eslintrc b/.eslintrc new file mode 100644 index 0000000..2aa111d --- /dev/null +++ b/.eslintrc @@ -0,0 +1,7 @@ +{ + "extends": ["airbnb-base", "plugin:prettier/recommended"], + "plugins": ["prettier"], + "rules": { + "prettier/prettier": "error" + } +} diff --git a/.jsbeautifyrc b/.jsbeautifyrc deleted file mode 100644 index 230d6e2..0000000 --- a/.jsbeautifyrc +++ /dev/null @@ -1,7 +0,0 @@ -{ - "js": { - "jslint_happy": true, - "indent_size": 2, - "wrap_line_length": 80 - } -} diff --git a/.jshintrc b/.jshintrc deleted file mode 100644 index ef348a3..0000000 --- a/.jshintrc +++ /dev/null @@ -1,21 +0,0 @@ -{ - "bitwise": true, - "browser": true, - "camelcase": true, - "curly": true, - "eqeqeq": true, - "immed": true, - "latedef": true, - "newcap": true, - "noarg": true, - "node": true, - "proto": true, - "mocha": true, - "quotmark": "single", - "strict": true, - "undef": true, - "unused": true, - "expr": true, - "ignore": true, - "esversion": 9 -} \ No newline at end of file diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..81200f7 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,6 @@ +{ + "printWidth": 80, + "singleQuote": true, + "semi": true, + "trailingComma": "es5" +} diff --git a/Gruntfile.js b/Gruntfile.js deleted file mode 100644 index 24f1a0e..0000000 --- a/Gruntfile.js +++ /dev/null @@ -1,59 +0,0 @@ -'use strict'; - -module.exports = function (grunt) { - - // add grunt tasks. - grunt.loadNpmTasks('grunt-mocha-test'); - grunt.loadNpmTasks('grunt-contrib-jshint'); - grunt.loadNpmTasks('grunt-contrib-watch'); - - grunt.initConfig({ - // Configure a mochaTest task - mochaTest: { - integration: { - options: { - reporter: 'spec', - timeout: 80000 - }, - src: ['test/integration/**/*.js'] - }, - unit: { - options: { - reporter: 'spec', - timeout: 80000 - }, - src: ['test/unit/**/*.js'] - } - }, - jshint: { - options: { - reporter: require('jshint-stylish'), - jshintrc: '.jshintrc' - }, - all: [ - 'Gruntfile.js', - 'index.js', - 'lib/**/*.js', - 'test/**/*.js' - ] - }, - watch: { - all: { - files: [ - 'Gruntfile.js', - 'index.js', - 'lib/**/*.js', - 'test/**/*.js' - ], - tasks: ['default'] - } - } - }); - - //custom tasks - grunt.registerTask('default', ['jshint', 'mochaTest', 'watch']); - grunt.registerTask('unit', ['jshint', 'mochaTest:unit']); - grunt.registerTask('integration', ['jshint', 'mochaTest:integration']); - grunt.registerTask('test', ['jshint', 'mochaTest']); - -}; diff --git a/es/index.js b/es/index.js new file mode 100644 index 0000000..b2f5692 --- /dev/null +++ b/es/index.js @@ -0,0 +1,1868 @@ +import _ from 'lodash'; +import { isInstance, copyInstance } from '@lykmapipo/mongoose-common'; +import fake from '@lykmapipo/mongoose-faker'; +import search from 'mongoose-regex-search'; +import autopopulate from 'mongoose-autopopulate'; +import hide from 'mongoose-hidden'; +import exist from 'mongoose-exists'; +import taggable from '@lykmapipo/mongoose-taggable'; +import aggregatable from '@lykmapipo/mongoose-aggregatable'; +import async, { waterfall, parallel } from 'async'; +import { mergeObjects } from '@lykmapipo/common'; + +/** + * @module mongoose-rest-actions + * @function + * @name deletePlugin + * @namespace + * @description mongoose schema plugin to support http delete verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid delete plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.delete('/users/:id', function(request, response, next){ + * + * // obtain id + * const _id = request.params.id; + * + * // delete user + * User + * .del(_id, function(error, deleted){ + * ...handle error or reply + * }); + * }); + * + */ +function deletePlugin(Schema) { + const schema = Schema; + /* + *---------------------------------------------------------------------------- + * Instance + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name del + * @description delete model instance. more business logics can be + * implemented using beforeDelete and afterDelete model + * instance methods + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} deleted instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof deletePlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforeDelete = function (done) { + * ...called before delete(does not touch mongoose hooks) + * ...do any checkup if delete is allowed + * ...log, post to analytics etc + * ...throw error and delete wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterDelete = function (done) { + * ...called after delete(does not touch mongoose hooks) + * ...delete any cached instance + * ...delete any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already deleted(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.del(function(error, deleted){ + * ... + * }); + */ + schema.methods.del = function del(optns, callback) { + // normalize arguments + const defaults = { soft: false }; + const done = _.isFunction(optns) ? optns : callback; + const options = _.isFunction(optns) ? defaults : _.merge(defaults, optns); + + waterfall( + [ + /** + * @name beforeDelete + * @function beforeDelete + * @description perform pre delete logics + * @param {Function} next a callback to invoke after beforeDelete + * @returns {instance|error} + * @private + */ + function beforeDelete(next) { + // obtain before hooks + const before = this.beforeDelete || this.preDelete; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + function onBeforeDelete(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + // TODO use undefined + next(null, this); + } + }.bind(this), + + /** + * @name doDelete + * @function doDelete + * @description delete(remove) model instance + * @param {Function} next a callback to invoke after delete + * @returns {instance|error} + * @private + */ + function doDelete(instance, next) { + // TODO throw error if already deleted + // soft delete + const { soft } = options; + if (soft) { + const updates = { deletedAt: new Date() }; + instance.patch(updates, next); + } + // hard deletes + else { + instance.remove(function afterRemove(error, deleted) { + next(error, deleted); + }); + } + }, + + /** + * @name afterDelete + * @function afterDelete + * @description perform after delete logics + * @param {Function} next a callback to invoke after afterDelete + * @returns {instance|error} + * @private + */ + function afterDelete(instance, next) { + // obtain after hooks + const after = instance.afterDelete || instance.postDelete; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, function onAfterDelete(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + // TODO use undefined + next(null, instance); + } + }, + ], + + /** + * @function + * @name onDelete + * @description perform on delete logics + * @param {Object} error error object when fails to delete + * @param {Object} deleted model instance + * @private + */ + function onceDelete(err, deleted) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, deleted); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name del + * @description delete(remove) existing model instance + * @param {ObjectId|String} _id valid existing model object id + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} deleted instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof deletePlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .del(_id, function(error, deleted){ + * ... + * }); + */ + schema.statics.del = function del(optns, done) { + // normalize arguments + const defaults = { soft: false }; + let options = _.isPlainObject(optns) ? optns : { _id: optns }; + options = _.merge(defaults, options); + + const { _id, soft } = options; + + // ensure id + if (!_id) { + const error = new Error('Missing Instance Id'); + error.status = 400; + done(error); + } + + // continue with delete + waterfall( + [ + function findExisting(next) { + this.findById(_id) + .orFail() + .exec(next); // TODO use getById + }.bind(this), + + function afterFindExisting(instance, next) { + instance.del({ soft }, next); + }, + ], + function onceDelete(err, patched) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, patched); + } + ); + }; +} + +/* default get options */ +const defaults = { + filter: {}, + paginate: { + limit: 10, + skip: 0, + page: 1, + }, + populate: [], + select: {}, + sort: {}, +}; + +/** + * @module mongoose-rest-actions + * @function + * @name getPlugin + * @namespace + * @description mongoose schema plugin to support http get verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid get plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const expess = require('express'); + * const app = express(); + * + * ... + * + * app.get('/users', function(request, response, next){ + * + * // prepare options + * const options = { page: request.query.page, limit: request.query.limit} + * + * // get users + * User + * .get(options, function(error, results){ + * ...handle error or reply + * }); + * }); + * + * app.get('/users/:id', function(request, response, next){ + * + * // obtain id + * const _id = request.params.id; + * + * // get user + * User + * .getById(_id, function(error, user){ + * ...handle error or reply + * }); + * }); + * + * or + * + * app.get('/users/:id', function(request, response, next){ + * + * // obtain id + * const options = {_id : request.params.id, select: 'name -age'}; + * + * // get user + * User + * .getById(options, function(error, user){ + * ...handle error or reply + * }); + * }); + * + */ +function getPlugin(Schema, schemaOptns) { + const schema = Schema; + // normalize options + const schemaOptions = _.merge( + {}, + { + root: 'data', + }, + schemaOptns + ); + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @name getById + * @function getById + * @description find existing model instance by its id + * @param {Object|ObjectId|String} [optns={}] valid existing model object id + * of getById options + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} found instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * const options = {_id: ..id, select: 'name -age'}; + * User + * .getById(options, function(error, found){ + * ... + * }); + */ + schema.statics.getById = function getById(optns, done) { + // normalize options + let options = _.isFunction(optns) ? {} : optns; + const cb = _.isFunction(optns) ? optns : done; + options = _.isPlainObject(options) + ? options + : { + _id: options, + }; + options._id = options._id || options.id; // eslint-disable-line + const optionsId = options._id; // eslint-disable-line + delete options.id; + + // ensure id + if (!optionsId) { + const error = new Error('Missing Instance Id'); + error.status = 400; + cb(error); + } + + // continue with retrieving data + waterfall( + [ + /** + * @function + * @name beforeGetById + * @description perform pre getById logics + * @param {Function} next a callback to invoke after beforeGetById + * @returns {null|undefined|error} + * @private + */ + function beforeGetById(next) { + // obtain before hooks + const before = this.beforeGetById || this.preGetById; + + // run hook(s) + if (_.isFunction(before)) { + before.call(this, function onBeforeGetById(error) { + next(error); + }); + } + // no hook + else { + next(); + } + }.bind(this), + + /** + * @function + * @name doGetById + * @description obtain instance by id + * @param {Function} next a callback to invoke after getById + * @returns {instance|error} + * @private + */ + function doGetById(next) { + // prepare find query + const findQuery = this.findById(optionsId); + + // if select + if (options.select) { + findQuery.select(options.select); + } + + // if populate + if (options.populate) { + const populate = _.compact([].concat(options.populate)); + _.forEach(populate, populateOption => { + findQuery.populate(populateOption); + }); + } + + findQuery.orFail().exec(next); // TODO get cached + }.bind(this), + + /** + * @function + * @name afterGetById + * @description perform after getById logics + * @param {Function} next a callback to invoke after afterGetById + * @returns {instance|error} + * @private + */ + function afterGetById(instance, next) { + // obtain after hooks + const after = this.afterGetById || this.postGetById; + + // run hook(s) + if (_.isFunction(after)) { + after + .call(this, instance, function onAfterGetById(error, instanced) { + next(error, instanced || instance); + }) + .bind(this); + } + // no hook + else { + next(null, instance); + } + }.bind(this), + ], + function onceGetById(err, found) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, found); + } + ); + }; + + /** + * @function + * @name getHelperFn + * @description count and find existing model(s) based on specified options + * @param {Object} [optns={}] + * @param {Object|String} [optns.filter] valid mongoose query criteria + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Object|String} [optns.sort] valid mongoose query sort criteria + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Object} [optns.paginate={}] paging options + * @param {Number} [optns.paginate.skip=0] valid query skip option + * @param {Number} [optns.paginate.page=1] + * @param {Number} [optns.paginate.limit=10] valid query limit option + * @param {Object} [optns.headers={}] header for conditional get + * @param {Date} [optns.headers.ifModifiedSince] if modified since option + * @returns {Object} results + * @returns {Object[]} [results.data] array of documents + * @returns {Number} [results.total] total number of documents in collection + * that match a query + * @returns {Number} [results.size] length of current page documents + * @returns {Number} [results.limit] limit that was used + * @returns {Number} [results.skip] skip that was used + * @returns {Number} [results.page] page that was used + * @returns {Number} [results.pages] total number of pages that match a query + * @param {Function} done a callback to invoke on success or failure + * @returns {Object|error} results or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @private + * @example + * const User = mongoose.model('User'); + * + * User + * .getHelperFn(function(error, deleted){ + * ... + * }); + * + * or + * + * User + * .getHelperFn({page: 1}, function(error, deleted){ + * ... + * }); + */ + schema.statics.getHelperFn = function getHelperFn(optns, done) { + // normalize options & callback + const cb = _.isFunction(optns) ? optns : done; + + let options = _.isFunction(optns) ? {} : optns; + options = _.merge({}, defaults, options); + options = _.merge({}, options.paginate, options); + delete options.paginate; + + // obtain query criteria + let filter = options.query || options.criteria || options.filter; + + // obtain limit + let limit = options.limit || 10; + limit = limit > 0 ? limit : 10; + + // obtain skip + let skip = options.skip || options.offset || 0; + skip = skip > 0 ? skip : 0; + + // obtain page + const page = options.page || options.page; + + const populate = _.compact([].concat(options.populate)); + const select = options.select || {}; + const sort = options.sort || {}; + const headers = options.headers || {}; + + // extend headers with if-modified-since condition + const { UPDATED_AT_FIELD } = this; + if (headers.ifModifiedSince) { + const ifModifiedSince = new Date(headers.ifModifiedSince); + filter = _.merge({}, filter, { + [UPDATED_AT_FIELD]: { + $gt: ifModifiedSince, + }, + }); + } + + // initialize queries + const { q } = filter; + const conditions = _.omit(filter, 'q'); + const findQuery = this.search(q, conditions); + const countQuery = this.search(q, conditions).setOptions({ + autopopulate: false, + }); + const lastModifiedQuery = this.findOne( + {}, + { + [UPDATED_AT_FIELD]: 1, + }, + { + autopopulate: false, + } + ) // dont populate + .sort({ + [UPDATED_AT_FIELD]: -1, + }); + + if (page && page > 0) { + skip = (page - 1) * limit; + } + + if (select) { + findQuery.select(select); + } + + if (sort) { + findQuery.sort(sort); + } + + if (skip) { + findQuery.skip(skip); + } + + if (limit) { + findQuery.limit(limit); + } + + if (populate) { + _.forEach(populate, populateOption => { + findQuery.populate(populateOption); + }); + } + + parallel( + { + count: function countMatched(next) { + countQuery.countDocuments().exec(next); // TODO get cached + }, + + data: function paginateMatched(next) { + findQuery.exec(next); // TODO get cached + }, + + lastModified: function findLatestModified(next) { + lastModifiedQuery.exec(next); + }, + }, + function next(err, results) { + const error = err; + let mergedResults; + + if (!error && results) { + // prepare results + const defaultsResults = { + data: [], + total: 0, + size: 0, + pages: 0, + lastModified: undefined, + }; + mergedResults = _.merge({}, defaultsResults, results); + + // obtain latest modified date + const lastModified = mergedResults.lastModified + ? mergedResults.lastModified[UPDATED_AT_FIELD] + : undefined; + + // compute pages + const pages = Math.ceil(mergedResults.count / limit); + + // refine results + mergedResults = { + [schemaOptions.root]: results.data, + total: results.count, + size: results.data.length, + limit, + skip, + page, + pages, + lastModified, + hasMore: page > pages, + }; + } + + // ensure error status + if (error) { + error.status = error.status || 400; + mergedResults = undefined; + } + + cb(error, mergedResults); // TODO cache + } + ); + }; + + /** + * @function + * @name get + * @description count and find existing model(s) based on specified options + * @param {Object} [optns={}] + * @param {Object|String} [optns.filter] valid mongoose query criteria + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Object|String} [optns.sort] valid mongoose query sort criteria + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Object} [optns.paginate={}] paging options + * @param {Number} [optns.paginate.skip=0] valid query skip option + * @param {Number} [optns.paginate.page=1] + * @param {Number} [optns.paginate.limit=10] valid query limit option + * @returns {Object} results + * @returns {Object[]} [results.data] array of documents + * @returns {Number} [results.total] total number of documents in collection + * that match a query + * @returns {Number} [results.size] length of current page documents + * @returns {Number} [results.limit] limit that was used + * @returns {Number} [results.skip] skip that was used + * @returns {Number} [results.page] page that was used + * @returns {Number} [results.pages] total number of pages that match a query + * @param {Function} done a callback to invoke on success or failure + * @returns {Object|error} results or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .get(function(error, deleted){ + * ... + * }); + * + * or + * + * User + * .get({page: 1}, function(error, deleted){ + * ... + * }); + */ + schema.statics.get = function get(optns, done) { + // normalize options & callback + const cb = _.isFunction(optns) ? optns : done; + + // normalize options + const options = _.isFunction(optns) ? {} : optns; + delete options.headers; + + waterfall( + [ + /** + * @function + * @name beforeGet + * @description perform pre get logics + * @param {Function} next a callback to invoke after beforeGet + * @returns {null|undefined|error} + * @private + */ + function beforeGet(next) { + // obtain before hooks + const before = this.beforeGet || this.preGet; + + // run hook(s) + if (_.isFunction(before)) { + before.call(this, options, function onBeforeGet(error) { + next(error); + }); + } + // no hook + else { + next(); + } + }.bind(this), + + /** + * @function + * @name doGet + * @description query data + * @param {Function} next a callback to invoke after query data(get) + * @returns {instance|error} + * @private + */ + function doGet(next) { + this.getHelperFn(options, next); + }.bind(this), + + /** + * @function + * @name afterGet + * @description perform after query data logics + * @param {Function} next a callback to invoke after doGet + * @returns {context|error} + * @private + */ + function afterGet(results, next) { + // obtain hooks + const after = this.afterGet || this.postGet; + + // run hook(s) + if (_.isFunction(after)) { + after.call(this, options, results, function onAfterGet( + error, + resulted + ) { + next(error, resulted || results); + }); + } + // no hook + else { + next(null, results); + } + }.bind(this), + ], + function onceGet(err, got) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, got); + } + ); + }; + + /** + * @function + * @name fresh + * @description count and find existing model(s) based on specified options + * @param {Object} [optns={}] + * @param {Object|String} [optns.filter] valid mongoose query criteria + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Object|String} [optns.sort] valid mongoose query sort criteria + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Object} [optns.paginate={}] paging options + * @param {Number} [optns.paginate.skip=0] valid query skip option + * @param {Number} [optns.paginate.page=1] + * @param {Number} [optns.paginate.limit=10] valid query limit option + * @param {Object} [optns.headers={}] header for conditional get + * @param {Date} [optns.headers.ifModifiedSince] if modified since option + * @returns {Object} results + * @returns {Object[]} [results.data] array of documents + * @returns {Number} [results.total] total number of documents in collection + * that match a query + * @returns {Number} [results.size] length of current page documents + * @returns {Number} [results.limit] limit that was used + * @returns {Number} [results.skip] skip that was used + * @returns {Number} [results.page] page that was used + * @returns {Number} [results.pages] total number of pages that match a query + * @param {Function} done a callback to invoke on success or failure + * @returns {Object|error} results or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .fresh(function(error, deleted){ + * ... + * }); + * + * or + * + * User + * .fresh({page: 1}, function(error, deleted){ + * ... + * }); + */ + schema.statics.fresh = function fresh(...args) { + // query + this.getHelperFn(...args); + }; +} + +const updatesFor = (id, updates) => { + // ignore self instance updates + // eslint-disable-next-line + if (isInstance(updates) && updates._id === id) { + return updates; + } + // compute updates + const changes = mergeObjects(copyInstance(updates), { _id: id }); + return changes; +}; + +/** + * @function + * @name patchPlugin + * @namespace + * @description mongoose schema plugin to support http patch verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid patch plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.patch('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * updates._id = request.params.id; + * + * // patch user + * User + * .patch(updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + * or + * + * app.patch('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * const _id = request.params.id; + * + * // patch user + * User + * .patch(_id, updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + */ +function patchPlugin(Schema) { + const schema = Schema; + /* + *---------------------------------------------------------------------------- + * Instances + *---------------------------------------------------------------------------- + */ + + /** + * @name patch + * @function patch + * @description update and persist current model instance. more business + * logics can be implemented using beforePatch and afterPatch + * model instance methods + * @param {Object} updates updates to apply on model instance + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof patchPlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforePatch = function (done) { + * ...called before patch(does not touch mongoose hooks) + * ...do any checkup if patch is allowed + * ...log, post to analytics etc + * ...throw error and patch wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterPatch = function (done) { + * ...called after patch(does not touch mongoose hooks) + * ...update any cached instance + * ...update any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already patched(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.patch(updates, function(error, updated){ + * ... + * }); + */ + schema.methods.patch = function patch(updates, done) { + // normalize arguments + const body = _.isFunction(updates) ? {} : updatesFor(null, updates); + const cb = _.isFunction(updates) ? updates : done; + + // remove unused + delete body._id; // eslint-disable-line + delete body.updatedAt; + + waterfall( + [ + /** + * @function + * @name beforePatch + * @description perform pre(save/patch) logics + * @param {Function} next a callback to invoke after beforePatch + * @returns {instance|error} + * @private + */ + function beforePatch(next) { + // obtain before hooks + const before = + this.beforePatch || + this.prePatch || + this.beforeUpdate || + this.preUpdate; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + body, + function onBeforePatch(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + next(null, this); + } + }.bind(this), + + /** + * @function + * @name doPatch + * @description update and persist model instance + * @param {Function} next a callback to invoke after save + * @returns {instance|error} + * @private + */ + function doPatch(model, next) { + const instance = model; + // update & persist instance + if (body && !_.isEmpty(body)) { + instance.set(body); + } + instance.updatedAt = new Date(); + instance.save(function afterSave(error, saved) { + next(error, saved); + }); + }, + + /** + * @function + * @name afterPatch + * @description perform after(save/patch) logics + * @param {Function} next a callback to invoke after afterSave + * @returns {instance|error} + * @private + */ + function afterPatch(instance, next) { + // obtain after hooks + const after = + instance.afterPatch || + instance.postPatch || + instance.afterUpdate || + instance.postUpdate; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, body, function onAfterPatch(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + next(null, instance); + } + }, + ], + + /** + * @function + * @name onPatch + * @description perform on patch logics + * @param {Object} error error object when fails to patch + * @param {Object} patched model instance + * @private + */ + function oncePatch(err, patched) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, patched); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name patch + * @description update & persist(save) provided model + * @param {ObjectId|String} [id] valid instance object id + * @param {Object} updates model details to save + * @param {ObjectId|String} updates._id valid existing model object id + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof patchPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .patch({_id: ..., name: ...}, function(error, updated){ + * ... + * }); + */ + schema.statics.patch = function patch(id, updates, done) { + // ref + const Model = this; + + // normalize arguments + let model = updates; + let cb = done; + + // handle 3 args + if (arguments.length === 3) { + model = updatesFor(id, updates); + cb = done; + } + + // handle 2 args + else if (arguments.length === 2) { + model = updatesFor(_.get(id, '_id'), id); + cb = updates; + } + + // handle 1 args + else { + cb = id; + const error = new Error('Illegal Arguments'); + error.status = 400; + cb(error); + } + + // ensure id + model._id = model._id || model.id; // eslint-disable-line + const modelId = model._id; // eslint-disable-line + if (!modelId) { + const error = new Error('Missing Instance Id'); + error.status = 400; + cb(error); + } + + // continue with patch + waterfall( + [ + function findExisting(next) { + if (isInstance(model)) { + next(null, model); + } else { + Model.findById(modelId) + .orFail() + .exec(next); + } + }, + + function afterFindExisting(instance, next) { + // handle instance + if (isInstance(model)) { + model.patch({ updatedAt: new Date() }, next); + } + // handle updates + else { + delete model._id; // eslint-disable-line + delete model.id; + instance.patch(model, next); + } + }, + ], + function oncePatch(err, updated) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, updated); + } + ); + }; +} + +/** + * @function + * @name postPlugin + * @namespace + * @description mongoose schema plugin to support http post verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid post plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose from 'mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.post('/users', function(request, response, next){ + * + * // obtain user + * const body = request.body; + * + * // create user + * User + * .post(body, function(error, created){ + * ...handle error or reply + * }); + * }); + * + */ +function postPlugin(Schema) { + const schema = Schema; + /* + *---------------------------------------------------------------------------- + * Instances + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name post + * @description persist current model instance. more business logics can + * be implemented using beforePost and afterPost model instance + * methods + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} saved instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof postPlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforePost = function (done) { + * ...called before post(does not touch mongoose hooks) + * ...do any checkup if post is allowed + * ...log, post to analytics etc + * ...throw error and post wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterPost = function (done) { + * ...called after post(does not touch mongoose hooks) + * ...update any cached instance + * ...update any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already posted(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.post(function(error, saved){ + * ... + * }); + */ + schema.methods.post = function post(done) { + async.waterfall( + [ + /** + * @function + * @name beforePost + * @description perform pre(save/post) logics + * @param {Function} next a callback to invoke after beforePost + * @returns {instance|error} + * @private + */ + function beforePost(next) { + // obtain before hooks + const before = + this.beforePost || this.prePost || this.beforeSave || this.preSave; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + function onBeforePost(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + next(null, this); + } + }.bind(this), + + /** + * @function + * @name doPost + * @description persist model instance + * @param {Function} next a callback to invoke after save + * @returns {instance|error} + * @private + */ + function doPost(instance, next) { + instance.save(function afterSave(error, saved) { + next(error, saved); + }); + }, + + /** + * @function + * @name afterPost + * @description perform after(save/post) logics + * @param {Function} next a callback to invoke after afterSave + * @returns {instance|error} + * @private + */ + function afterPost(instance, next) { + // obtain after hooks + const after = + instance.afterPost || + instance.postPost || + instance.afterSave || + instance.postSave; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, function onAfterPost(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + next(null, instance); + } + }, + ], + + /** + * @function + * @name onSave + * @param {Object} error error object when fails to post + * @param {Object} saved model instance + * @private + */ + function oncePost(err, saved) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, saved); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name post + * @description persist(save) provided model + * @param {Object} body model details to save + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} saved instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof postPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User.post({}, function(error, saved){ + * ... + * }); + */ + schema.statics.post = function post(body, done) { + // instantiate model + const instance = isInstance(body) ? body : new this(copyInstance(body)); + + // persist model + instance.post(done); + }; +} + +const updatesFor$1 = (id, updates) => { + // ignore self instance updates + // eslint-disable-next-line + if (isInstance(updates) && updates._id === id) { + return updates; + } + // compute updates + const changes = mergeObjects(copyInstance(updates), { _id: id }); + return changes; +}; + +/** + * @function + * @name putPlugin + * @namespace + * @description mongoose schema plugin to support http put verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid put plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.put('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * updates._id = request.params.id; + * + * // put user + * User + * .put(updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + * or + * + * app.put('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * const _id = request.params.id; + * + * // put user + * User + * .put(_id, updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + */ +function putPlugin(Schema) { + const schema = Schema; + + /* + *---------------------------------------------------------------------------- + * Instances + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name put + * @description update and persist current model instance. more business + * logics can be implemented using beforePut and afterPut + * model instance methods + * @param {Object} updates updates to apply on model instance + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof putPlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforePut = function (done) { + * ...called before put(does not touch mongoose hooks) + * ...do any checkup if put is allowed + * ...log, post to analytics etc + * ...throw error and put wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterPut = function (done) { + * ...called after put(does not touch mongoose hooks) + * ...delete any cached instance + * ...delete any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already updated(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.put(updates, function(error, updated){ + * ... + * }); + */ + schema.methods.put = function put(updates, done) { + // normalize arguments + const body = _.isFunction(updates) ? {} : updatesFor$1(null, updates); + const cb = _.isFunction(updates) ? updates : done; + + // remove unused + delete body._id; // eslint-disable-line + delete body.updatedAt; + + waterfall( + [ + /** + * @name beforePut + * @function beforePut + * @description perform pre(save/put) logics + * @param {Function} next a callback to invoke after beforePut + * @returns {instance|error} + * @private + */ + function beforePut(next) { + // obtain before hooks + const before = + this.beforePut || + this.prePut || + this.beforeUpdate || + this.preUpdate; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + body, + function onBeforePut(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + next(null, this); + } + }.bind(this), + + /** + * @name doPut + * @function doPut + * @description update and persist model instance + * @param {Function} next a callback to invoke after save + * @returns {instance|error} + * @private + */ + function doPut(model, next) { + const instance = model; + // update & persist instance + if (body && !_.isEmpty(body)) { + instance.set(body); + } + instance.updatedAt = new Date(); + instance.save(function afterSave(error, saved) { + next(error, saved); + }); + }, + + /** + * @name afterPut + * @function afterPut + * @description perform after(save/put) logics + * @param {Function} next a callback to invoke after afterSave + * @returns {instance|error} + * @private + */ + function afterPut(instance, next) { + // obtain after hooks + const after = + instance.afterPut || + instance.postPut || + instance.afterUpdate || + instance.postUpdate; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, body, function onAfterPut(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + next(null, instance); + } + }, + ], + + /** + * @function + * @name onPut + * @description perform on put logics + * @param {Object} error error object when fails to put + * @param {Object} puted model instance + * @private + */ + function oncePut(err, puted) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, puted); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name put + * @description update & persist(save) provided model + * @param {ObjectId|String} [id] valid instance object id + * @param {Object} updates model details to save + * @param {ObjectId|String} updates._id valid existing model object id + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.2.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof putPlugin + * @public + * @example + * + * const User = mongoose.model('User'); + * User.put(id, updates, (error, updated) => { ... }); + * User.put({_id: ..., name: ...}, (error, updated) => { ... }); + * + */ + schema.statics.put = function put(id, updates, done) { + // ref + const Model = this; + + // normalize arguments + let model = updates; + let cb = done; + + // handle 3 args + if (arguments.length === 3) { + model = updatesFor$1(id, updates); + cb = done; + } + + // handle 2 args + else if (arguments.length === 2) { + model = updatesFor$1(_.get(id, '_id'), id); + cb = updates; + } + + // handle 1 args + else { + cb = id; + const error = new Error('Illegal Arguments'); + error.status = 400; + cb(error); + } + + // ensure id + model._id = model._id || model.id; // eslint-disable-line + const modelId = model._id; // eslint-disable-line + if (!modelId) { + const error = new Error('Missing Instance Id'); + error.status = 400; + cb(error); + } + + // continue with put + waterfall( + [ + function findExisting(next) { + if (isInstance(model)) { + next(null, model); + } else { + Model.findById(modelId) + .orFail() + .exec(next); + } + }, + + function afterFindExisting(instance, next) { + // handle instance + if (isInstance(model)) { + model.put({ updatedAt: new Date() }, next); + } + // handle updates + else { + delete model._id; // eslint-disable-line + delete model.id; + instance.put(model, next); + } + }, + ], + function oncePut(err, updated) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, updated); + } + ); + }; +} + +// constants +const defaultHidden = { + defaultHidden: { + password: true, + __v: true, + __t: true, + }, + virtuals: { + id: 'hideJSON', + runInBackgroundQueue: 'hide', + runInBackgroundOptions: 'hide', + }, +}; + +/** + * @module mongoose-rest-actions + * @name restActions + * @function restActions + * @description mongoose schema plugins to support http verb(s) + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid delete plugin options + * @param {String} [schemaOptns.root] a field name to use to hold results. + * default to `data` + * + * @author lally elias + * @version 0.18.0 + * @since 0.1.0 + * @example + * + * const { Schema } = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * + * const User = new Schema({ + * name: { type: String } + * }); + * User.plugin(actions); + * + */ +function restActions(Schema, schemaOptns) { + const schema = Schema; + /* @todo refactor and simplify */ + + // ignore if already plugged-in + if (schema.statics.get) { + return; + } + + // normalize options + const schemaOptions = _.merge( + {}, + { + root: 'data', + }, + schemaOptns + ); + + // ensure indexed timestamps fields + // currently mongoose does not index them + // see https:// github.com/Automattic/mongoose/blob/master/lib/schema.js#L1002 + const hasTimeStamps = _.get(schema, 'options.timestamps', false); + if (hasTimeStamps) { + // obtain timestamps paths + const createdAtField = _.isBoolean(hasTimeStamps) + ? 'createdAt' + : hasTimeStamps.createdAt; + schema.statics.CREATED_AT_FIELD = createdAtField; + + const updatedAtField = _.isBoolean(hasTimeStamps) + ? 'updatedAt' + : hasTimeStamps.updatedAt; + schema.statics.UPDATED_AT_FIELD = updatedAtField; + + // ensure index on create timestamp path if not exists + if (schema.paths[createdAtField]) { + schema.paths[createdAtField].options.index = true; + schema.index({ + [createdAtField]: 1, + }); + } + + // ensure index on update timestamp path if not exists + if (schema.paths[updatedAtField]) { + schema.paths[updatedAtField].options.index = true; + schema.index({ + [updatedAtField]: 1, + }); + } + } + + // extend schema with deletedAt timestamp + schema.add({ + deletedAt: { + type: Date, + index: true, + }, + }); + + // rest actions plugin + getPlugin(schema, schemaOptions); + postPlugin(schema, schemaOptions); + putPlugin(schema, schemaOptions); + patchPlugin(schema, schemaOptions); + deletePlugin(schema, schemaOptions); + + // lastly common plugins + fake(schema, schemaOptions); + exist(schema, schemaOptions); + taggable(schema, schemaOptions); + search(schema, schemaOptions); + autopopulate(schema, schemaOptions); + aggregatable(schema, schemaOptions); + hide(defaultHidden)(schema, schemaOptions); +} + +export default restActions; diff --git a/lib/index.js b/lib/index.js new file mode 100644 index 0000000..738002f --- /dev/null +++ b/lib/index.js @@ -0,0 +1,1870 @@ +'use strict'; + +const _ = require('lodash'); +const mongooseCommon = require('@lykmapipo/mongoose-common'); +const fake = require('@lykmapipo/mongoose-faker'); +const search = require('mongoose-regex-search'); +const autopopulate = require('mongoose-autopopulate'); +const hide = require('mongoose-hidden'); +const exist = require('mongoose-exists'); +const taggable = require('@lykmapipo/mongoose-taggable'); +const aggregatable = require('@lykmapipo/mongoose-aggregatable'); +const async = require('async'); +const common = require('@lykmapipo/common'); + +/** + * @module mongoose-rest-actions + * @function + * @name deletePlugin + * @namespace + * @description mongoose schema plugin to support http delete verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid delete plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.delete('/users/:id', function(request, response, next){ + * + * // obtain id + * const _id = request.params.id; + * + * // delete user + * User + * .del(_id, function(error, deleted){ + * ...handle error or reply + * }); + * }); + * + */ +function deletePlugin(Schema) { + const schema = Schema; + /* + *---------------------------------------------------------------------------- + * Instance + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name del + * @description delete model instance. more business logics can be + * implemented using beforeDelete and afterDelete model + * instance methods + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} deleted instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof deletePlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforeDelete = function (done) { + * ...called before delete(does not touch mongoose hooks) + * ...do any checkup if delete is allowed + * ...log, post to analytics etc + * ...throw error and delete wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterDelete = function (done) { + * ...called after delete(does not touch mongoose hooks) + * ...delete any cached instance + * ...delete any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already deleted(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.del(function(error, deleted){ + * ... + * }); + */ + schema.methods.del = function del(optns, callback) { + // normalize arguments + const defaults = { soft: false }; + const done = _.isFunction(optns) ? optns : callback; + const options = _.isFunction(optns) ? defaults : _.merge(defaults, optns); + + async.waterfall( + [ + /** + * @name beforeDelete + * @function beforeDelete + * @description perform pre delete logics + * @param {Function} next a callback to invoke after beforeDelete + * @returns {instance|error} + * @private + */ + function beforeDelete(next) { + // obtain before hooks + const before = this.beforeDelete || this.preDelete; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + function onBeforeDelete(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + // TODO use undefined + next(null, this); + } + }.bind(this), + + /** + * @name doDelete + * @function doDelete + * @description delete(remove) model instance + * @param {Function} next a callback to invoke after delete + * @returns {instance|error} + * @private + */ + function doDelete(instance, next) { + // TODO throw error if already deleted + // soft delete + const { soft } = options; + if (soft) { + const updates = { deletedAt: new Date() }; + instance.patch(updates, next); + } + // hard deletes + else { + instance.remove(function afterRemove(error, deleted) { + next(error, deleted); + }); + } + }, + + /** + * @name afterDelete + * @function afterDelete + * @description perform after delete logics + * @param {Function} next a callback to invoke after afterDelete + * @returns {instance|error} + * @private + */ + function afterDelete(instance, next) { + // obtain after hooks + const after = instance.afterDelete || instance.postDelete; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, function onAfterDelete(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + // TODO use undefined + next(null, instance); + } + }, + ], + + /** + * @function + * @name onDelete + * @description perform on delete logics + * @param {Object} error error object when fails to delete + * @param {Object} deleted model instance + * @private + */ + function onceDelete(err, deleted) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, deleted); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name del + * @description delete(remove) existing model instance + * @param {ObjectId|String} _id valid existing model object id + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} deleted instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof deletePlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .del(_id, function(error, deleted){ + * ... + * }); + */ + schema.statics.del = function del(optns, done) { + // normalize arguments + const defaults = { soft: false }; + let options = _.isPlainObject(optns) ? optns : { _id: optns }; + options = _.merge(defaults, options); + + const { _id, soft } = options; + + // ensure id + if (!_id) { + const error = new Error('Missing Instance Id'); + error.status = 400; + done(error); + } + + // continue with delete + async.waterfall( + [ + function findExisting(next) { + this.findById(_id) + .orFail() + .exec(next); // TODO use getById + }.bind(this), + + function afterFindExisting(instance, next) { + instance.del({ soft }, next); + }, + ], + function onceDelete(err, patched) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, patched); + } + ); + }; +} + +/* default get options */ +const defaults = { + filter: {}, + paginate: { + limit: 10, + skip: 0, + page: 1, + }, + populate: [], + select: {}, + sort: {}, +}; + +/** + * @module mongoose-rest-actions + * @function + * @name getPlugin + * @namespace + * @description mongoose schema plugin to support http get verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid get plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const expess = require('express'); + * const app = express(); + * + * ... + * + * app.get('/users', function(request, response, next){ + * + * // prepare options + * const options = { page: request.query.page, limit: request.query.limit} + * + * // get users + * User + * .get(options, function(error, results){ + * ...handle error or reply + * }); + * }); + * + * app.get('/users/:id', function(request, response, next){ + * + * // obtain id + * const _id = request.params.id; + * + * // get user + * User + * .getById(_id, function(error, user){ + * ...handle error or reply + * }); + * }); + * + * or + * + * app.get('/users/:id', function(request, response, next){ + * + * // obtain id + * const options = {_id : request.params.id, select: 'name -age'}; + * + * // get user + * User + * .getById(options, function(error, user){ + * ...handle error or reply + * }); + * }); + * + */ +function getPlugin(Schema, schemaOptns) { + const schema = Schema; + // normalize options + const schemaOptions = _.merge( + {}, + { + root: 'data', + }, + schemaOptns + ); + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @name getById + * @function getById + * @description find existing model instance by its id + * @param {Object|ObjectId|String} [optns={}] valid existing model object id + * of getById options + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} found instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * const options = {_id: ..id, select: 'name -age'}; + * User + * .getById(options, function(error, found){ + * ... + * }); + */ + schema.statics.getById = function getById(optns, done) { + // normalize options + let options = _.isFunction(optns) ? {} : optns; + const cb = _.isFunction(optns) ? optns : done; + options = _.isPlainObject(options) + ? options + : { + _id: options, + }; + options._id = options._id || options.id; // eslint-disable-line + const optionsId = options._id; // eslint-disable-line + delete options.id; + + // ensure id + if (!optionsId) { + const error = new Error('Missing Instance Id'); + error.status = 400; + cb(error); + } + + // continue with retrieving data + async.waterfall( + [ + /** + * @function + * @name beforeGetById + * @description perform pre getById logics + * @param {Function} next a callback to invoke after beforeGetById + * @returns {null|undefined|error} + * @private + */ + function beforeGetById(next) { + // obtain before hooks + const before = this.beforeGetById || this.preGetById; + + // run hook(s) + if (_.isFunction(before)) { + before.call(this, function onBeforeGetById(error) { + next(error); + }); + } + // no hook + else { + next(); + } + }.bind(this), + + /** + * @function + * @name doGetById + * @description obtain instance by id + * @param {Function} next a callback to invoke after getById + * @returns {instance|error} + * @private + */ + function doGetById(next) { + // prepare find query + const findQuery = this.findById(optionsId); + + // if select + if (options.select) { + findQuery.select(options.select); + } + + // if populate + if (options.populate) { + const populate = _.compact([].concat(options.populate)); + _.forEach(populate, populateOption => { + findQuery.populate(populateOption); + }); + } + + findQuery.orFail().exec(next); // TODO get cached + }.bind(this), + + /** + * @function + * @name afterGetById + * @description perform after getById logics + * @param {Function} next a callback to invoke after afterGetById + * @returns {instance|error} + * @private + */ + function afterGetById(instance, next) { + // obtain after hooks + const after = this.afterGetById || this.postGetById; + + // run hook(s) + if (_.isFunction(after)) { + after + .call(this, instance, function onAfterGetById(error, instanced) { + next(error, instanced || instance); + }) + .bind(this); + } + // no hook + else { + next(null, instance); + } + }.bind(this), + ], + function onceGetById(err, found) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, found); + } + ); + }; + + /** + * @function + * @name getHelperFn + * @description count and find existing model(s) based on specified options + * @param {Object} [optns={}] + * @param {Object|String} [optns.filter] valid mongoose query criteria + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Object|String} [optns.sort] valid mongoose query sort criteria + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Object} [optns.paginate={}] paging options + * @param {Number} [optns.paginate.skip=0] valid query skip option + * @param {Number} [optns.paginate.page=1] + * @param {Number} [optns.paginate.limit=10] valid query limit option + * @param {Object} [optns.headers={}] header for conditional get + * @param {Date} [optns.headers.ifModifiedSince] if modified since option + * @returns {Object} results + * @returns {Object[]} [results.data] array of documents + * @returns {Number} [results.total] total number of documents in collection + * that match a query + * @returns {Number} [results.size] length of current page documents + * @returns {Number} [results.limit] limit that was used + * @returns {Number} [results.skip] skip that was used + * @returns {Number} [results.page] page that was used + * @returns {Number} [results.pages] total number of pages that match a query + * @param {Function} done a callback to invoke on success or failure + * @returns {Object|error} results or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @private + * @example + * const User = mongoose.model('User'); + * + * User + * .getHelperFn(function(error, deleted){ + * ... + * }); + * + * or + * + * User + * .getHelperFn({page: 1}, function(error, deleted){ + * ... + * }); + */ + schema.statics.getHelperFn = function getHelperFn(optns, done) { + // normalize options & callback + const cb = _.isFunction(optns) ? optns : done; + + let options = _.isFunction(optns) ? {} : optns; + options = _.merge({}, defaults, options); + options = _.merge({}, options.paginate, options); + delete options.paginate; + + // obtain query criteria + let filter = options.query || options.criteria || options.filter; + + // obtain limit + let limit = options.limit || 10; + limit = limit > 0 ? limit : 10; + + // obtain skip + let skip = options.skip || options.offset || 0; + skip = skip > 0 ? skip : 0; + + // obtain page + const page = options.page || options.page; + + const populate = _.compact([].concat(options.populate)); + const select = options.select || {}; + const sort = options.sort || {}; + const headers = options.headers || {}; + + // extend headers with if-modified-since condition + const { UPDATED_AT_FIELD } = this; + if (headers.ifModifiedSince) { + const ifModifiedSince = new Date(headers.ifModifiedSince); + filter = _.merge({}, filter, { + [UPDATED_AT_FIELD]: { + $gt: ifModifiedSince, + }, + }); + } + + // initialize queries + const { q } = filter; + const conditions = _.omit(filter, 'q'); + const findQuery = this.search(q, conditions); + const countQuery = this.search(q, conditions).setOptions({ + autopopulate: false, + }); + const lastModifiedQuery = this.findOne( + {}, + { + [UPDATED_AT_FIELD]: 1, + }, + { + autopopulate: false, + } + ) // dont populate + .sort({ + [UPDATED_AT_FIELD]: -1, + }); + + if (page && page > 0) { + skip = (page - 1) * limit; + } + + if (select) { + findQuery.select(select); + } + + if (sort) { + findQuery.sort(sort); + } + + if (skip) { + findQuery.skip(skip); + } + + if (limit) { + findQuery.limit(limit); + } + + if (populate) { + _.forEach(populate, populateOption => { + findQuery.populate(populateOption); + }); + } + + async.parallel( + { + count: function countMatched(next) { + countQuery.countDocuments().exec(next); // TODO get cached + }, + + data: function paginateMatched(next) { + findQuery.exec(next); // TODO get cached + }, + + lastModified: function findLatestModified(next) { + lastModifiedQuery.exec(next); + }, + }, + function next(err, results) { + const error = err; + let mergedResults; + + if (!error && results) { + // prepare results + const defaultsResults = { + data: [], + total: 0, + size: 0, + pages: 0, + lastModified: undefined, + }; + mergedResults = _.merge({}, defaultsResults, results); + + // obtain latest modified date + const lastModified = mergedResults.lastModified + ? mergedResults.lastModified[UPDATED_AT_FIELD] + : undefined; + + // compute pages + const pages = Math.ceil(mergedResults.count / limit); + + // refine results + mergedResults = { + [schemaOptions.root]: results.data, + total: results.count, + size: results.data.length, + limit, + skip, + page, + pages, + lastModified, + hasMore: page > pages, + }; + } + + // ensure error status + if (error) { + error.status = error.status || 400; + mergedResults = undefined; + } + + cb(error, mergedResults); // TODO cache + } + ); + }; + + /** + * @function + * @name get + * @description count and find existing model(s) based on specified options + * @param {Object} [optns={}] + * @param {Object|String} [optns.filter] valid mongoose query criteria + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Object|String} [optns.sort] valid mongoose query sort criteria + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Object} [optns.paginate={}] paging options + * @param {Number} [optns.paginate.skip=0] valid query skip option + * @param {Number} [optns.paginate.page=1] + * @param {Number} [optns.paginate.limit=10] valid query limit option + * @returns {Object} results + * @returns {Object[]} [results.data] array of documents + * @returns {Number} [results.total] total number of documents in collection + * that match a query + * @returns {Number} [results.size] length of current page documents + * @returns {Number} [results.limit] limit that was used + * @returns {Number} [results.skip] skip that was used + * @returns {Number} [results.page] page that was used + * @returns {Number} [results.pages] total number of pages that match a query + * @param {Function} done a callback to invoke on success or failure + * @returns {Object|error} results or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .get(function(error, deleted){ + * ... + * }); + * + * or + * + * User + * .get({page: 1}, function(error, deleted){ + * ... + * }); + */ + schema.statics.get = function get(optns, done) { + // normalize options & callback + const cb = _.isFunction(optns) ? optns : done; + + // normalize options + const options = _.isFunction(optns) ? {} : optns; + delete options.headers; + + async.waterfall( + [ + /** + * @function + * @name beforeGet + * @description perform pre get logics + * @param {Function} next a callback to invoke after beforeGet + * @returns {null|undefined|error} + * @private + */ + function beforeGet(next) { + // obtain before hooks + const before = this.beforeGet || this.preGet; + + // run hook(s) + if (_.isFunction(before)) { + before.call(this, options, function onBeforeGet(error) { + next(error); + }); + } + // no hook + else { + next(); + } + }.bind(this), + + /** + * @function + * @name doGet + * @description query data + * @param {Function} next a callback to invoke after query data(get) + * @returns {instance|error} + * @private + */ + function doGet(next) { + this.getHelperFn(options, next); + }.bind(this), + + /** + * @function + * @name afterGet + * @description perform after query data logics + * @param {Function} next a callback to invoke after doGet + * @returns {context|error} + * @private + */ + function afterGet(results, next) { + // obtain hooks + const after = this.afterGet || this.postGet; + + // run hook(s) + if (_.isFunction(after)) { + after.call(this, options, results, function onAfterGet( + error, + resulted + ) { + next(error, resulted || results); + }); + } + // no hook + else { + next(null, results); + } + }.bind(this), + ], + function onceGet(err, got) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, got); + } + ); + }; + + /** + * @function + * @name fresh + * @description count and find existing model(s) based on specified options + * @param {Object} [optns={}] + * @param {Object|String} [optns.filter] valid mongoose query criteria + * @param {Object|String} [optns.select] valid mongoose query projections + * @param {Object|String} [optns.sort] valid mongoose query sort criteria + * @param {Array} [optns.populate] valid mongoose query population options + * @param {Object} [optns.paginate={}] paging options + * @param {Number} [optns.paginate.skip=0] valid query skip option + * @param {Number} [optns.paginate.page=1] + * @param {Number} [optns.paginate.limit=10] valid query limit option + * @param {Object} [optns.headers={}] header for conditional get + * @param {Date} [optns.headers.ifModifiedSince] if modified since option + * @returns {Object} results + * @returns {Object[]} [results.data] array of documents + * @returns {Number} [results.total] total number of documents in collection + * that match a query + * @returns {Number} [results.size] length of current page documents + * @returns {Number} [results.limit] limit that was used + * @returns {Number} [results.skip] skip that was used + * @returns {Number} [results.page] page that was used + * @returns {Number} [results.pages] total number of pages that match a query + * @param {Function} done a callback to invoke on success or failure + * @returns {Object|error} results or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof getPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .fresh(function(error, deleted){ + * ... + * }); + * + * or + * + * User + * .fresh({page: 1}, function(error, deleted){ + * ... + * }); + */ + schema.statics.fresh = function fresh(...args) { + // query + this.getHelperFn(...args); + }; +} + +const updatesFor = (id, updates) => { + // ignore self instance updates + // eslint-disable-next-line + if (mongooseCommon.isInstance(updates) && updates._id === id) { + return updates; + } + // compute updates + const changes = common.mergeObjects(mongooseCommon.copyInstance(updates), { _id: id }); + return changes; +}; + +/** + * @function + * @name patchPlugin + * @namespace + * @description mongoose schema plugin to support http patch verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid patch plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.patch('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * updates._id = request.params.id; + * + * // patch user + * User + * .patch(updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + * or + * + * app.patch('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * const _id = request.params.id; + * + * // patch user + * User + * .patch(_id, updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + */ +function patchPlugin(Schema) { + const schema = Schema; + /* + *---------------------------------------------------------------------------- + * Instances + *---------------------------------------------------------------------------- + */ + + /** + * @name patch + * @function patch + * @description update and persist current model instance. more business + * logics can be implemented using beforePatch and afterPatch + * model instance methods + * @param {Object} updates updates to apply on model instance + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof patchPlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforePatch = function (done) { + * ...called before patch(does not touch mongoose hooks) + * ...do any checkup if patch is allowed + * ...log, post to analytics etc + * ...throw error and patch wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterPatch = function (done) { + * ...called after patch(does not touch mongoose hooks) + * ...update any cached instance + * ...update any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already patched(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.patch(updates, function(error, updated){ + * ... + * }); + */ + schema.methods.patch = function patch(updates, done) { + // normalize arguments + const body = _.isFunction(updates) ? {} : updatesFor(null, updates); + const cb = _.isFunction(updates) ? updates : done; + + // remove unused + delete body._id; // eslint-disable-line + delete body.updatedAt; + + async.waterfall( + [ + /** + * @function + * @name beforePatch + * @description perform pre(save/patch) logics + * @param {Function} next a callback to invoke after beforePatch + * @returns {instance|error} + * @private + */ + function beforePatch(next) { + // obtain before hooks + const before = + this.beforePatch || + this.prePatch || + this.beforeUpdate || + this.preUpdate; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + body, + function onBeforePatch(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + next(null, this); + } + }.bind(this), + + /** + * @function + * @name doPatch + * @description update and persist model instance + * @param {Function} next a callback to invoke after save + * @returns {instance|error} + * @private + */ + function doPatch(model, next) { + const instance = model; + // update & persist instance + if (body && !_.isEmpty(body)) { + instance.set(body); + } + instance.updatedAt = new Date(); + instance.save(function afterSave(error, saved) { + next(error, saved); + }); + }, + + /** + * @function + * @name afterPatch + * @description perform after(save/patch) logics + * @param {Function} next a callback to invoke after afterSave + * @returns {instance|error} + * @private + */ + function afterPatch(instance, next) { + // obtain after hooks + const after = + instance.afterPatch || + instance.postPatch || + instance.afterUpdate || + instance.postUpdate; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, body, function onAfterPatch(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + next(null, instance); + } + }, + ], + + /** + * @function + * @name onPatch + * @description perform on patch logics + * @param {Object} error error object when fails to patch + * @param {Object} patched model instance + * @private + */ + function oncePatch(err, patched) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, patched); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name patch + * @description update & persist(save) provided model + * @param {ObjectId|String} [id] valid instance object id + * @param {Object} updates model details to save + * @param {ObjectId|String} updates._id valid existing model object id + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof patchPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User + * .patch({_id: ..., name: ...}, function(error, updated){ + * ... + * }); + */ + schema.statics.patch = function patch(id, updates, done) { + // ref + const Model = this; + + // normalize arguments + let model = updates; + let cb = done; + + // handle 3 args + if (arguments.length === 3) { + model = updatesFor(id, updates); + cb = done; + } + + // handle 2 args + else if (arguments.length === 2) { + model = updatesFor(_.get(id, '_id'), id); + cb = updates; + } + + // handle 1 args + else { + cb = id; + const error = new Error('Illegal Arguments'); + error.status = 400; + cb(error); + } + + // ensure id + model._id = model._id || model.id; // eslint-disable-line + const modelId = model._id; // eslint-disable-line + if (!modelId) { + const error = new Error('Missing Instance Id'); + error.status = 400; + cb(error); + } + + // continue with patch + async.waterfall( + [ + function findExisting(next) { + if (mongooseCommon.isInstance(model)) { + next(null, model); + } else { + Model.findById(modelId) + .orFail() + .exec(next); + } + }, + + function afterFindExisting(instance, next) { + // handle instance + if (mongooseCommon.isInstance(model)) { + model.patch({ updatedAt: new Date() }, next); + } + // handle updates + else { + delete model._id; // eslint-disable-line + delete model.id; + instance.patch(model, next); + } + }, + ], + function oncePatch(err, updated) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, updated); + } + ); + }; +} + +/** + * @function + * @name postPlugin + * @namespace + * @description mongoose schema plugin to support http post verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid post plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose from 'mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.post('/users', function(request, response, next){ + * + * // obtain user + * const body = request.body; + * + * // create user + * User + * .post(body, function(error, created){ + * ...handle error or reply + * }); + * }); + * + */ +function postPlugin(Schema) { + const schema = Schema; + /* + *---------------------------------------------------------------------------- + * Instances + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name post + * @description persist current model instance. more business logics can + * be implemented using beforePost and afterPost model instance + * methods + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} saved instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof postPlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforePost = function (done) { + * ...called before post(does not touch mongoose hooks) + * ...do any checkup if post is allowed + * ...log, post to analytics etc + * ...throw error and post wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterPost = function (done) { + * ...called after post(does not touch mongoose hooks) + * ...update any cached instance + * ...update any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already posted(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.post(function(error, saved){ + * ... + * }); + */ + schema.methods.post = function post(done) { + async.waterfall( + [ + /** + * @function + * @name beforePost + * @description perform pre(save/post) logics + * @param {Function} next a callback to invoke after beforePost + * @returns {instance|error} + * @private + */ + function beforePost(next) { + // obtain before hooks + const before = + this.beforePost || this.prePost || this.beforeSave || this.preSave; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + function onBeforePost(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + next(null, this); + } + }.bind(this), + + /** + * @function + * @name doPost + * @description persist model instance + * @param {Function} next a callback to invoke after save + * @returns {instance|error} + * @private + */ + function doPost(instance, next) { + instance.save(function afterSave(error, saved) { + next(error, saved); + }); + }, + + /** + * @function + * @name afterPost + * @description perform after(save/post) logics + * @param {Function} next a callback to invoke after afterSave + * @returns {instance|error} + * @private + */ + function afterPost(instance, next) { + // obtain after hooks + const after = + instance.afterPost || + instance.postPost || + instance.afterSave || + instance.postSave; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, function onAfterPost(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + next(null, instance); + } + }, + ], + + /** + * @function + * @name onSave + * @param {Object} error error object when fails to post + * @param {Object} saved model instance + * @private + */ + function oncePost(err, saved) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, saved); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name post + * @description persist(save) provided model + * @param {Object} body model details to save + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} saved instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof postPlugin + * @public + * @example + * const User = mongoose.model('User'); + * + * User.post({}, function(error, saved){ + * ... + * }); + */ + schema.statics.post = function post(body, done) { + // instantiate model + const instance = mongooseCommon.isInstance(body) ? body : new this(mongooseCommon.copyInstance(body)); + + // persist model + instance.post(done); + }; +} + +const updatesFor$1 = (id, updates) => { + // ignore self instance updates + // eslint-disable-next-line + if (mongooseCommon.isInstance(updates) && updates._id === id) { + return updates; + } + // compute updates + const changes = common.mergeObjects(mongooseCommon.copyInstance(updates), { _id: id }); + return changes; +}; + +/** + * @function + * @name putPlugin + * @namespace + * @description mongoose schema plugin to support http put verb + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid put plugin options + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @example + * + * const mongoose = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * mongoose.plugin(actions); + * + * const express = require('express'); + * const app = express(); + * + * ... + * + * app.put('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * updates._id = request.params.id; + * + * // put user + * User + * .put(updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + * or + * + * app.put('/users/:id', function(request, response, next){ + * + * // obtain user + * const updates = request.body; + * + * // obtain id + * const _id = request.params.id; + * + * // put user + * User + * .put(_id, updates, function(error, updated){ + * ...handle error or reply + * }); + * }); + * + */ +function putPlugin(Schema) { + const schema = Schema; + + /* + *---------------------------------------------------------------------------- + * Instances + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name put + * @description update and persist current model instance. more business + * logics can be implemented using beforePut and afterPut + * model instance methods + * @param {Object} updates updates to apply on model instance + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.1.0 + * @since 0.1.0 + * @author lally elias + * @instance + * @memberof putPlugin + * @public + * @example + * + * const UserSchema = new Schema({ + * name: { type: String } + * }); + * + * UserSchema.methods.beforePut = function (done) { + * ...called before put(does not touch mongoose hooks) + * ...do any checkup if put is allowed + * ...log, post to analytics etc + * ...throw error and put wont happen i.e done(error) + * ...once through call done() + * done(); + * }; + * + * UserSchema.methods.afterPut = function (done) { + * ...called after put(does not touch mongoose hooks) + * ...delete any cached instance + * ...delete any related instances + * ...log, post to analytics, initiate background job etc + * ...instance is already updated(any throws wont stop it) + * ...once through call done() + * done(); + * }; + * + * const User = mongoose.model('User', UserSchema); + * + * const user = ...find user + * user.put(updates, function(error, updated){ + * ... + * }); + */ + schema.methods.put = function put(updates, done) { + // normalize arguments + const body = _.isFunction(updates) ? {} : updatesFor$1(null, updates); + const cb = _.isFunction(updates) ? updates : done; + + // remove unused + delete body._id; // eslint-disable-line + delete body.updatedAt; + + async.waterfall( + [ + /** + * @name beforePut + * @function beforePut + * @description perform pre(save/put) logics + * @param {Function} next a callback to invoke after beforePut + * @returns {instance|error} + * @private + */ + function beforePut(next) { + // obtain before hooks + const before = + this.beforePut || + this.prePut || + this.beforeUpdate || + this.preUpdate; + + // run hook(s) + if (_.isFunction(before)) { + before.call( + this, + body, + function onBeforePut(error, instance) { + next(error, instance || this); + }.bind(this) + ); + } + // no hook + else { + next(null, this); + } + }.bind(this), + + /** + * @name doPut + * @function doPut + * @description update and persist model instance + * @param {Function} next a callback to invoke after save + * @returns {instance|error} + * @private + */ + function doPut(model, next) { + const instance = model; + // update & persist instance + if (body && !_.isEmpty(body)) { + instance.set(body); + } + instance.updatedAt = new Date(); + instance.save(function afterSave(error, saved) { + next(error, saved); + }); + }, + + /** + * @name afterPut + * @function afterPut + * @description perform after(save/put) logics + * @param {Function} next a callback to invoke after afterSave + * @returns {instance|error} + * @private + */ + function afterPut(instance, next) { + // obtain after hooks + const after = + instance.afterPut || + instance.postPut || + instance.afterUpdate || + instance.postUpdate; + + // run hook(s) + if (_.isFunction(after)) { + after.call(instance, body, function onAfterPut(error, instanced) { + next(error, instanced || instance); + }); + } + // no hook + else { + next(null, instance); + } + }, + ], + + /** + * @function + * @name onPut + * @description perform on put logics + * @param {Object} error error object when fails to put + * @param {Object} puted model instance + * @private + */ + function oncePut(err, puted) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, puted); + } + ); + }; + + /* + *---------------------------------------------------------------------------- + * Statics + *---------------------------------------------------------------------------- + */ + + /** + * @function + * @name put + * @description update & persist(save) provided model + * @param {ObjectId|String} [id] valid instance object id + * @param {Object} updates model details to save + * @param {ObjectId|String} updates._id valid existing model object id + * @param {Function} done a callback to invoke on success or failure + * @returns {instance|error} updated instance or error + * @version 0.2.0 + * @since 0.1.0 + * @author lally elias + * @static + * @memberof putPlugin + * @public + * @example + * + * const User = mongoose.model('User'); + * User.put(id, updates, (error, updated) => { ... }); + * User.put({_id: ..., name: ...}, (error, updated) => { ... }); + * + */ + schema.statics.put = function put(id, updates, done) { + // ref + const Model = this; + + // normalize arguments + let model = updates; + let cb = done; + + // handle 3 args + if (arguments.length === 3) { + model = updatesFor$1(id, updates); + cb = done; + } + + // handle 2 args + else if (arguments.length === 2) { + model = updatesFor$1(_.get(id, '_id'), id); + cb = updates; + } + + // handle 1 args + else { + cb = id; + const error = new Error('Illegal Arguments'); + error.status = 400; + cb(error); + } + + // ensure id + model._id = model._id || model.id; // eslint-disable-line + const modelId = model._id; // eslint-disable-line + if (!modelId) { + const error = new Error('Missing Instance Id'); + error.status = 400; + cb(error); + } + + // continue with put + async.waterfall( + [ + function findExisting(next) { + if (mongooseCommon.isInstance(model)) { + next(null, model); + } else { + Model.findById(modelId) + .orFail() + .exec(next); + } + }, + + function afterFindExisting(instance, next) { + // handle instance + if (mongooseCommon.isInstance(model)) { + model.put({ updatedAt: new Date() }, next); + } + // handle updates + else { + delete model._id; // eslint-disable-line + delete model.id; + instance.put(model, next); + } + }, + ], + function oncePut(err, updated) { + const error = err; + if (error) { + error.status = error.status || 400; + } + cb(error, updated); + } + ); + }; +} + +// constants +const defaultHidden = { + defaultHidden: { + password: true, + __v: true, + __t: true, + }, + virtuals: { + id: 'hideJSON', + runInBackgroundQueue: 'hide', + runInBackgroundOptions: 'hide', + }, +}; + +/** + * @module mongoose-rest-actions + * @name restActions + * @function restActions + * @description mongoose schema plugins to support http verb(s) + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid delete plugin options + * @param {String} [schemaOptns.root] a field name to use to hold results. + * default to `data` + * + * @author lally elias + * @version 0.18.0 + * @since 0.1.0 + * @example + * + * const { Schema } = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * + * const User = new Schema({ + * name: { type: String } + * }); + * User.plugin(actions); + * + */ +function restActions(Schema, schemaOptns) { + const schema = Schema; + /* @todo refactor and simplify */ + + // ignore if already plugged-in + if (schema.statics.get) { + return; + } + + // normalize options + const schemaOptions = _.merge( + {}, + { + root: 'data', + }, + schemaOptns + ); + + // ensure indexed timestamps fields + // currently mongoose does not index them + // see https:// github.com/Automattic/mongoose/blob/master/lib/schema.js#L1002 + const hasTimeStamps = _.get(schema, 'options.timestamps', false); + if (hasTimeStamps) { + // obtain timestamps paths + const createdAtField = _.isBoolean(hasTimeStamps) + ? 'createdAt' + : hasTimeStamps.createdAt; + schema.statics.CREATED_AT_FIELD = createdAtField; + + const updatedAtField = _.isBoolean(hasTimeStamps) + ? 'updatedAt' + : hasTimeStamps.updatedAt; + schema.statics.UPDATED_AT_FIELD = updatedAtField; + + // ensure index on create timestamp path if not exists + if (schema.paths[createdAtField]) { + schema.paths[createdAtField].options.index = true; + schema.index({ + [createdAtField]: 1, + }); + } + + // ensure index on update timestamp path if not exists + if (schema.paths[updatedAtField]) { + schema.paths[updatedAtField].options.index = true; + schema.index({ + [updatedAtField]: 1, + }); + } + } + + // extend schema with deletedAt timestamp + schema.add({ + deletedAt: { + type: Date, + index: true, + }, + }); + + // rest actions plugin + getPlugin(schema, schemaOptions); + postPlugin(schema, schemaOptions); + putPlugin(schema, schemaOptions); + patchPlugin(schema, schemaOptions); + deletePlugin(schema, schemaOptions); + + // lastly common plugins + fake(schema, schemaOptions); + exist(schema, schemaOptions); + taggable(schema, schemaOptions); + search(schema, schemaOptions); + autopopulate(schema, schemaOptions); + aggregatable(schema, schemaOptions); + hide(defaultHidden)(schema, schemaOptions); +} + +module.exports = restActions; diff --git a/package-lock.json b/package-lock.json index e1e46e2..00a87b1 100644 --- a/package-lock.json +++ b/package-lock.json @@ -4,941 +4,5117 @@ "lockfileVersion": 1, "requires": true, "dependencies": { - "@benmaruchu/faker": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/@benmaruchu/faker/-/faker-4.2.1.tgz", - "integrity": "sha512-VyOCOhm2/O/f/yqURU2JO4B8s0CyNaoUZ3/LrPuh7zgcE/f08Uay+l51wpa43kN7DX9pgg8OtgNpWNyZA9Y5SA==" + "@babel/cli": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.4.4.tgz", + "integrity": "sha512-XGr5YjQSjgTa6OzQZY57FAJsdeVSAKR/u/KA5exWIz66IKtv/zXtHy+fIZcMry/EgYegwuHE7vzGnrFhjdIAsQ==", + "dev": true, + "requires": { + "chokidar": "^2.0.4", + "commander": "^2.8.1", + "convert-source-map": "^1.1.0", + "fs-readdir-recursive": "^1.1.0", + "glob": "^7.0.0", + "lodash": "^4.17.11", + "mkdirp": "^0.5.1", + "output-file-sync": "^2.0.0", + "slash": "^2.0.0", + "source-map": "^0.5.0" + }, + "dependencies": { + "slash": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz", + "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==", + "dev": true + } + } }, - "@lykmapipo/common": { - "version": "0.17.4", - "resolved": "https://registry.npmjs.org/@lykmapipo/common/-/common-0.17.4.tgz", - "integrity": "sha512-3jdLPpixP6xmNV7xrE0qQZ8vGMAqFenAqZDQ5nFiWTDSPZOyp7zcltjtVowBbXTcjsaXTJla+wFaS8t+za7Lzg==", + "@babel/code-frame": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", + "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", + "dev": true, "requires": { - "lodash": ">=4.17.11", - "read-pkg": ">=5.1.1", - "statuses": ">=1.5.0" + "@babel/highlight": "^7.0.0" + } + }, + "@babel/core": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.4.4.tgz", + "integrity": "sha512-lQgGX3FPRgbz2SKmhMtYgJvVzGZrmjaF4apZ2bLwofAKiSjxU0drPh4S/VasyYXwaTs+A1gvQ45BN8SQJzHsQQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/generator": "^7.4.4", + "@babel/helpers": "^7.4.4", + "@babel/parser": "^7.4.4", + "@babel/template": "^7.4.4", + "@babel/traverse": "^7.4.4", + "@babel/types": "^7.4.4", + "convert-source-map": "^1.1.0", + "debug": "^4.1.0", + "json5": "^2.1.0", + "lodash": "^4.17.11", + "resolve": "^1.3.2", + "semver": "^5.4.1", + "source-map": "^0.5.0" }, "dependencies": { - "normalize-package-data": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", - "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", - "requires": { - "hosted-git-info": "^2.1.4", - "resolve": "^1.10.0", - "semver": "2 || 3 || 4 || 5", - "validate-npm-package-license": "^3.0.1" - } - }, - "parse-json": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", - "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", - "requires": { - "error-ex": "^1.3.1", - "json-parse-better-errors": "^1.0.1" - } - }, - "read-pkg": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.1.1.tgz", - "integrity": "sha512-dFcTLQi6BZ+aFUaICg7er+/usEoqFdQxiEBsEMNGoipenihtxxtdrQuBXvyANCEI8VuUIVYFgeHGx9sLLvim4w==", - "requires": { - "@types/normalize-package-data": "^2.4.0", - "normalize-package-data": "^2.5.0", - "parse-json": "^4.0.0", - "type-fest": "^0.4.1" - } - }, "resolve": { "version": "1.10.1", "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.1.tgz", "integrity": "sha512-KuIe4mf++td/eFb6wkaPbMDnP6kObCaEtIDuHOUED6MNUo4K670KZUHuuvYPZDxNF0WVLw49n06M2m2dXphEzA==", + "dev": true, "requires": { "path-parse": "^1.0.6" } } } }, - "@lykmapipo/env": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/@lykmapipo/env/-/env-0.7.4.tgz", - "integrity": "sha512-sd3SQQ7wSvOm8/a9rZINbrhPswJuZrXT8nhev1wBWHT/xtMJ8T1m6BkAhnxVYfTGbGqKGh1U7G2PVYmZT/6bGw==", + "@babel/generator": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.4.4.tgz", + "integrity": "sha512-53UOLK6TVNqKxf7RUh8NE851EHRxOOeVXKbK2bivdb+iziMyk03Sr4eaE9OELCbyZAAafAKPDwF2TPUES5QbxQ==", + "dev": true, "requires": { - "dotenv": ">=7.0.0", - "lodash": ">=4.17.11", - "semver": ">=6.0.0" - }, - "dependencies": { - "semver": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", - "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==" - } + "@babel/types": "^7.4.4", + "jsesc": "^2.5.1", + "lodash": "^4.17.11", + "source-map": "^0.5.0", + "trim-right": "^1.0.1" } }, - "@lykmapipo/include": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/@lykmapipo/include/-/include-0.2.3.tgz", - "integrity": "sha512-c7/3dBjQtqxJiZRGV76p/JxmI5RyehyK/ea/cCoXnS9J213WRdJo2anWMQWtoLMrx0b9+pjmV/EERPjDsfJhnQ==", + "@babel/helper-annotate-as-pure": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.0.0.tgz", + "integrity": "sha512-3UYcJUj9kvSLbLbUIfQTqzcy5VX7GRZ/CCDrnOaZorFFM01aXp1+GJwuFGV4NDDoAS+mOUyHcO6UD/RfqOks3Q==", + "dev": true, "requires": { - "lodash": ">=4.17.11" + "@babel/types": "^7.0.0" } }, - "@lykmapipo/mongoose-aggregatable": { - "version": "0.2.4", - "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-aggregatable/-/mongoose-aggregatable-0.2.4.tgz", - "integrity": "sha512-Pm1p6wJrBaqaRxqGoyhtb6e7MMBZ/vsAjCpSwdZh+6qKDRUueT8aeW6+VJgfQB0weAyf78s1IUlhe7ivim79LA==", + "@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.1.0.tgz", + "integrity": "sha512-qNSR4jrmJ8M1VMM9tibvyRAHXQs2PmaksQF7c1CGJNipfe3D8p+wgNwgso/P2A2r2mdgBWAXljNWR0QRZAMW8w==", + "dev": true, "requires": { - "@lykmapipo/common": ">=0.17.3", - "@lykmapipo/include": ">=0.2.2", - "@lykmapipo/mongoose-common": ">=0.23.0", - "async": ">=2.6.2", - "inflection": ">=1.12.0", - "lodash": ">=4.17.11" + "@babel/helper-explode-assignable-expression": "^7.1.0", + "@babel/types": "^7.0.0" } }, - "@lykmapipo/mongoose-common": { - "version": "0.23.0", - "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-common/-/mongoose-common-0.23.0.tgz", - "integrity": "sha512-TpHaSe2XF5vWQzDSy4PBxI8fX8rbuQQOK9/qrBK9/5mZCvjzJ1fngmK2aofSXxaxnQNCX+PHOHhiUkD3W+HuJg==", + "@babel/helper-call-delegate": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-call-delegate/-/helper-call-delegate-7.4.4.tgz", + "integrity": "sha512-l79boDFJ8S1c5hvQvG+rc+wHw6IuH7YldmRKsYtpbawsxURu/paVy57FZMomGK22/JckepaikOkY0MoAmdyOlQ==", + "dev": true, "requires": { - "@lykmapipo/common": ">=0.17.3", - "@lykmapipo/env": ">=0.7.5", - "@lykmapipo/include": ">=0.2.2", - "async": ">=2.6.2", - "lodash": ">=4.17.11", - "mongoose-schema-jsonschema": ">=1.2.1", - "mongoose-valid8": ">=1.5.2" - }, - "dependencies": { - "@lykmapipo/env": { - "version": "0.7.5", - "resolved": "https://registry.npmjs.org/@lykmapipo/env/-/env-0.7.5.tgz", - "integrity": "sha512-u+pmVMaWPv3QomyuDLIPO+4gidyhwN5FXP3iUXVQJ2+asgNTq7eieXea/RRUoEZP3oOznNK8MY2SEU3kOF9iGw==", - "requires": { - "dotenv": ">=8.0.0", - "lodash": ">=4.17.11", - "semver": ">=6.0.0" - } - }, - "dotenv": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.0.0.tgz", - "integrity": "sha512-30xVGqjLjiUOArT4+M5q9sYdvuR4riM6yK9wMcas9Vbp6zZa+ocC9dp6QoftuhTPhFAiLK/0C5Ni2nou/Bk8lg==" - }, - "semver": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", - "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==" - } + "@babel/helper-hoist-variables": "^7.4.4", + "@babel/traverse": "^7.4.4", + "@babel/types": "^7.4.4" } }, - "@lykmapipo/mongoose-faker": { - "version": "0.9.4", - "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-faker/-/mongoose-faker-0.9.4.tgz", - "integrity": "sha512-JRuSwHf0eeh7vfJbqsY09clc3kTbV1qKmWykxwWvNIlQVEiddxMKO+/6CE9Ww/H2xT49OzLoBBXlCm6slHg/YA==", + "@babel/helper-define-map": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-define-map/-/helper-define-map-7.4.4.tgz", + "integrity": "sha512-IX3Ln8gLhZpSuqHJSnTNBWGDE9kdkTEWl21A/K7PQ00tseBwbqCHTvNLHSBd9M0R5rER4h5Rsvj9vw0R5SieBg==", + "dev": true, "requires": { - "@benmaruchu/faker": ">=4.2.1", - "lodash": ">=4.17.11" + "@babel/helper-function-name": "^7.1.0", + "@babel/types": "^7.4.4", + "lodash": "^4.17.11" } }, - "@lykmapipo/mongoose-taggable": { - "version": "0.4.3", - "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-taggable/-/mongoose-taggable-0.4.3.tgz", - "integrity": "sha512-o71dIgQd7XL6Jfux9bZY1k1XXVyZNoENkH+izBr75NohLdXknrYSOW+eo4y1M1W7yy8xe6P46OEOFjzV2uXRMA==", + "@babel/helper-explode-assignable-expression": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.1.0.tgz", + "integrity": "sha512-NRQpfHrJ1msCHtKjbzs9YcMmJZOg6mQMmGRB+hbamEdG5PNpaSm95275VD92DvJKuyl0s2sFiDmMZ+EnnvufqA==", + "dev": true, "requires": { - "@lykmapipo/env": ">=0.7.5", - "@lykmapipo/mongoose-common": ">=0.23.0", - "async": ">=2.6.2", - "lodash": ">=4.17.11", - "moment": ">=2.24.0", - "stopwords-iso": ">=0.4.0", - "traverse": ">=0.6.6" - }, - "dependencies": { - "@lykmapipo/env": { - "version": "0.7.6", - "resolved": "https://registry.npmjs.org/@lykmapipo/env/-/env-0.7.6.tgz", - "integrity": "sha512-hm7deczdmULcqONUHCviF5uJTMjo/YZymNolfWZVAk3mz7qmwmw66dR4Mcx0SvECytqal8p5j4nu60AefICCug==", - "requires": { - "dotenv": ">=8.0.0", - "lodash": ">=4.17.11", - "semver": ">=6.0.0" - } - }, - "dotenv": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.0.0.tgz", - "integrity": "sha512-30xVGqjLjiUOArT4+M5q9sYdvuR4riM6yK9wMcas9Vbp6zZa+ocC9dp6QoftuhTPhFAiLK/0C5Ni2nou/Bk8lg==" - }, - "semver": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", - "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==" - } + "@babel/traverse": "^7.1.0", + "@babel/types": "^7.0.0" } }, - "@lykmapipo/mongoose-test-helpers": { - "version": "0.7.2", - "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-test-helpers/-/mongoose-test-helpers-0.7.2.tgz", - "integrity": "sha512-hagYk5Xy/1OB/SAukCqrq2gJLy3BHdBptO4l+AxsjwHgXtWDEYtPTxLtqBN14NdluGERaXQA84D6R7ad3Ka+BQ==", + "@babel/helper-function-name": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.1.0.tgz", + "integrity": "sha512-A95XEoCpb3TO+KZzJ4S/5uW5fNe26DjBGqf1o9ucyLyCmi1dXq/B3c8iaWTfBk3VvetUxl16e8tIrd5teOCfGw==", "dev": true, "requires": { - "@benmaruchu/faker": ">=4.2.1", - "@lykmapipo/mongoose-common": ">=0.23.0", - "@lykmapipo/mongoose-faker": ">=0.9.4", - "@lykmapipo/test-helpers": ">=0.2.2", - "async": ">=2.6.2", - "chai": ">=4.2.0", - "lodash": ">=4.17.11", - "sinon": ">=7.3.2", - "sinon-chai": ">=3.3.0", - "sinon-mongoose": ">=2.3.0" + "@babel/helper-get-function-arity": "^7.0.0", + "@babel/template": "^7.1.0", + "@babel/types": "^7.0.0" } }, - "@lykmapipo/phone": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@lykmapipo/phone/-/phone-0.3.3.tgz", - "integrity": "sha512-rm831xbACan+/Ql9GUVfWH02WjoZxfmRGy5pkbwMxBiTXRZQ1cdVlCTq6MCaavr3tvBhbBxKhiBv4UiRsSG9Bg==", + "@babel/helper-get-function-arity": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.0.0.tgz", + "integrity": "sha512-r2DbJeg4svYvt3HOS74U4eWKsUAMRH01Z1ds1zx8KNTPtpTL5JAsdFv8BNyOpVqdFhHkkRDIg5B4AsxmkjAlmQ==", + "dev": true, "requires": { - "@lykmapipo/env": ">=0.7.4", - "google-libphonenumber": ">=3.2.2", - "lodash": ">=4.17.11", - "os-locale": ">=3.1.0" + "@babel/types": "^7.0.0" } }, - "@lykmapipo/test-helpers": { - "version": "0.2.2", - "resolved": "https://registry.npmjs.org/@lykmapipo/test-helpers/-/test-helpers-0.2.2.tgz", - "integrity": "sha512-VD/U4AeyXL1Utdzdxj4fXuLLUL9GIMH2QJ4Gz8wr6j3HztXwj0RdvOnzyC+y6fDxDC3N7twl3JOfcs8ZPBWarQ==", + "@babel/helper-hoist-variables": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.4.4.tgz", + "integrity": "sha512-VYk2/H/BnYbZDDg39hr3t2kKyifAm1W6zHRfhx8jGjIHpQEBv9dry7oQ2f3+J703TLu69nYdxsovl0XYfcnK4w==", "dev": true, "requires": { - "@benmaruchu/faker": ">=4.2.1", - "chai": ">=4.2.0", - "sinon": ">=7.3.2", - "sinon-chai": ">=3.3.0" + "@babel/types": "^7.4.4" } }, - "@sinonjs/commons": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.4.0.tgz", - "integrity": "sha512-9jHK3YF/8HtJ9wCAbG+j8cD0i0+ATS9A7gXFqS36TblLPNy6rEEc+SB0imo91eCboGaBYGV/MT1/br/J+EE7Tw==", + "@babel/helper-member-expression-to-functions": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.0.0.tgz", + "integrity": "sha512-avo+lm/QmZlv27Zsi0xEor2fKcqWG56D5ae9dzklpIaY7cQMK5N8VSpaNVPPagiqmy7LrEjK1IWdGMOqPu5csg==", "dev": true, "requires": { - "type-detect": "4.0.8" + "@babel/types": "^7.0.0" } }, - "@sinonjs/formatio": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/@sinonjs/formatio/-/formatio-3.2.1.tgz", - "integrity": "sha512-tsHvOB24rvyvV2+zKMmPkZ7dXX6LSLKZ7aOtXY6Edklp0uRcgGpOsQTTGTcWViFyx4uhWc6GV8QdnALbIbIdeQ==", + "@babel/helper-module-imports": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.0.0.tgz", + "integrity": "sha512-aP/hlLq01DWNEiDg4Jn23i+CXxW/owM4WpDLFUbpjxe4NS3BhLVZQ5i7E0ZrxuQ/vwekIeciyamgB1UIYxxM6A==", "dev": true, "requires": { - "@sinonjs/commons": "^1", - "@sinonjs/samsam": "^3.1.0" + "@babel/types": "^7.0.0" } }, - "@sinonjs/samsam": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/@sinonjs/samsam/-/samsam-3.3.1.tgz", - "integrity": "sha512-wRSfmyd81swH0hA1bxJZJ57xr22kC07a1N4zuIL47yTS04bDk6AoCkczcqHEjcRPmJ+FruGJ9WBQiJwMtIElFw==", + "@babel/helper-module-transforms": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.4.4.tgz", + "integrity": "sha512-3Z1yp8TVQf+B4ynN7WoHPKS8EkdTbgAEy0nU0rs/1Kw4pDgmvYH3rz3aI11KgxKCba2cn7N+tqzV1mY2HMN96w==", "dev": true, "requires": { - "@sinonjs/commons": "^1.0.2", - "array-from": "^2.1.1", + "@babel/helper-module-imports": "^7.0.0", + "@babel/helper-simple-access": "^7.1.0", + "@babel/helper-split-export-declaration": "^7.4.4", + "@babel/template": "^7.4.4", + "@babel/types": "^7.4.4", "lodash": "^4.17.11" } }, - "@sinonjs/text-encoding": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/@sinonjs/text-encoding/-/text-encoding-0.7.1.tgz", - "integrity": "sha512-+iTbntw2IZPb/anVDbypzfQa+ay64MW0Zo8aJ8gZPWMMK6/OubMVb6lUPMagqjOPnmtauXnFCACVl3O7ogjeqQ==", - "dev": true - }, - "@types/normalize-package-data": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz", - "integrity": "sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==" + "@babel/helper-optimise-call-expression": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.0.0.tgz", + "integrity": "sha512-u8nd9NQePYNQV8iPWu/pLLYBqZBa4ZaY1YWRFMuxrid94wKI1QNt67NEZ7GAe5Kc/0LLScbim05xZFWkAdrj9g==", + "dev": true, + "requires": { + "@babel/types": "^7.0.0" + } }, - "abbrev": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", - "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", + "@babel/helper-plugin-utils": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.0.0.tgz", + "integrity": "sha512-CYAOUCARwExnEixLdB6sDm2dIJ/YgEAKDM1MOeMeZu9Ld/bDgVo8aiWrXwcY7OBh+1Ea2uUcVRcxKk0GJvW7QA==", "dev": true }, - "ansi-colors": { - "version": "3.2.3", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", - "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", - "dev": true + "@babel/helper-regex": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-regex/-/helper-regex-7.4.4.tgz", + "integrity": "sha512-Y5nuB/kESmR3tKjU8Nkn1wMGEx1tjJX076HBMeL3XLQCu6vA/YRzuTW0bbb+qRnXvQGn+d6Rx953yffl8vEy7Q==", + "dev": true, + "requires": { + "lodash": "^4.17.11" + } }, - "ansi-regex": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", - "dev": true + "@babel/helper-remap-async-to-generator": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.1.0.tgz", + "integrity": "sha512-3fOK0L+Fdlg8S5al8u/hWE6vhufGSn0bN09xm2LXMy//REAF8kDCrYoOBKYmA8m5Nom+sV9LyLCwrFynA8/slg==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.0.0", + "@babel/helper-wrap-function": "^7.1.0", + "@babel/template": "^7.1.0", + "@babel/traverse": "^7.1.0", + "@babel/types": "^7.0.0" + } }, - "ansi-styles": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", - "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", - "dev": true - }, - "argparse": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "@babel/helper-replace-supers": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.4.4.tgz", + "integrity": "sha512-04xGEnd+s01nY1l15EuMS1rfKktNF+1CkKmHoErDppjAAZL+IUBZpzT748x262HF7fibaQPhbvWUl5HeSt1EXg==", "dev": true, "requires": { - "sprintf-js": "~1.0.2" - }, - "dependencies": { - "sprintf-js": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", - "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", - "dev": true - } + "@babel/helper-member-expression-to-functions": "^7.0.0", + "@babel/helper-optimise-call-expression": "^7.0.0", + "@babel/traverse": "^7.4.4", + "@babel/types": "^7.4.4" } }, - "array-find-index": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", - "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=", - "dev": true + "@babel/helper-simple-access": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.1.0.tgz", + "integrity": "sha512-Vk+78hNjRbsiu49zAPALxTb+JUQCz1aolpd8osOF16BGnLtseD21nbHgLPGUwrXEurZgiCOUmvs3ExTu4F5x6w==", + "dev": true, + "requires": { + "@babel/template": "^7.1.0", + "@babel/types": "^7.0.0" + } }, - "array-from": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/array-from/-/array-from-2.1.1.tgz", - "integrity": "sha1-z+nYwmYoudxa7MYqn12PHzUsEZU=", - "dev": true + "@babel/helper-split-export-declaration": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.4.4.tgz", + "integrity": "sha512-Ro/XkzLf3JFITkW6b+hNxzZ1n5OQ80NvIUdmHspih1XAhtN3vPTuUFT4eQnela+2MaZ5ulH+iyP513KJrxbN7Q==", + "dev": true, + "requires": { + "@babel/types": "^7.4.4" + } }, - "assertion-error": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", - "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", - "dev": true + "@babel/helper-wrap-function": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.2.0.tgz", + "integrity": "sha512-o9fP1BZLLSrYlxYEYyl2aS+Flun5gtjTIG8iln+XuEzQTs0PLagAGSXUcqruJwD5fM48jzIEggCKpIfWTcR7pQ==", + "dev": true, + "requires": { + "@babel/helper-function-name": "^7.1.0", + "@babel/template": "^7.1.0", + "@babel/traverse": "^7.1.0", + "@babel/types": "^7.2.0" + } }, - "async": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/async/-/async-2.6.2.tgz", - "integrity": "sha512-H1qVYh1MYhEEFLsP97cVKqCGo7KfCyTt6uEWqsTBr9SO84oK9Uwbyd/yCW+6rKJLHksBNUVWZDAjfS+Ccx0Bbg==", + "@babel/helpers": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.4.4.tgz", + "integrity": "sha512-igczbR/0SeuPR8RFfC7tGrbdTbFL3QTvH6D+Z6zNxnTe//GyqmtHmDkzrqDmyZ3eSwPqB/LhyKoU5DXsp+Vp2A==", + "dev": true, "requires": { - "lodash": "^4.17.11" + "@babel/template": "^7.4.4", + "@babel/traverse": "^7.4.4", + "@babel/types": "^7.4.4" } }, - "balanced-match": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", - "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", - "dev": true + "@babel/highlight": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", + "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", + "dev": true, + "requires": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^4.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } }, - "beeper": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/beeper/-/beeper-1.1.1.tgz", - "integrity": "sha1-5tXqjF2tABMEpwsiY4RH9pyy+Ak=", - "dev": true + "@babel/node": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/@babel/node/-/node-7.2.2.tgz", + "integrity": "sha512-jPqgTycE26uFsuWpLika9Ohz9dmLQHWjOnMNxBOjYb1HXO+eLKxEr5FfKSXH/tBvFwwaw+pzke3gagnurGOfCA==", + "dev": true, + "requires": { + "@babel/polyfill": "^7.0.0", + "@babel/register": "^7.0.0", + "commander": "^2.8.1", + "lodash": "^4.17.10", + "v8flags": "^3.1.1" + } }, - "bluebird": { - "version": "3.5.1", - "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", - "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==", + "@babel/parser": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.4.4.tgz", + "integrity": "sha512-5pCS4mOsL+ANsFZGdvNLybx4wtqAZJ0MJjMHxvzI3bvIsz6sQvzW8XX92EYIkiPtIvcfG3Aj+Ir5VNyjnZhP7w==", "dev": true }, - "body": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/body/-/body-5.1.0.tgz", - "integrity": "sha1-5LoM5BCkaTYyM2dgnstOZVMSUGk=", + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.2.0.tgz", + "integrity": "sha512-+Dfo/SCQqrwx48ptLVGLdE39YtWRuKc/Y9I5Fy0P1DDBB9lsAHpjcEJQt+4IifuSOSTLBKJObJqMvaO1pIE8LQ==", "dev": true, "requires": { - "continuable-cache": "^0.3.1", - "error": "^7.0.0", - "raw-body": "~1.1.0", - "safe-json-parse": "~1.0.1" + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-remap-async-to-generator": "^7.1.0", + "@babel/plugin-syntax-async-generators": "^7.2.0" } }, - "brace-expansion": { - "version": "1.1.8", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", - "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", + "@babel/plugin-proposal-json-strings": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.2.0.tgz", + "integrity": "sha512-MAFV1CA/YVmYwZG0fBQyXhmj0BHCB5egZHCKWIFVv/XCxAeVGIHfos3SwDck4LvCllENIAg7xMKOG5kH0dzyUg==", "dev": true, "requires": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-json-strings": "^7.2.0" } }, - "browser-stdout": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", - "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", - "dev": true + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.4.4.tgz", + "integrity": "sha512-dMBG6cSPBbHeEBdFXeQ2QLc5gUpg4Vkaz8octD4aoW/ISO+jBOcsuxYL7bsb5WSu8RLP6boxrBIALEHgoHtO9g==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-object-rest-spread": "^7.2.0" + } }, - "bson": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.1.tgz", - "integrity": "sha512-jCGVYLoYMHDkOsbwJZBCqwMHyH4c+wzgI9hG7Z6SZJRXWr+x58pdIbm2i9a/jFGCkRJqRUr8eoI7lDWa0hTkxg==", - "dev": true + "@babel/plugin-proposal-optional-catch-binding": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.2.0.tgz", + "integrity": "sha512-mgYj3jCcxug6KUcX4OBoOJz3CMrwRfQELPQ5560F70YQUBZB7uac9fqaWamKR1iWUzGiK2t0ygzjTScZnVz75g==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-optional-catch-binding": "^7.2.0" + } }, - "builtin-modules": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", - "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", - "dev": true + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.4.4.tgz", + "integrity": "sha512-j1NwnOqMG9mFUOH58JTFsA/+ZYzQLUZ/drqWUqxCYLGeu2JFZL8YrNC9hBxKmWtAuOCHPcRpgv7fhap09Fb4kA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-regex": "^7.4.4", + "regexpu-core": "^4.5.4" + } }, - "bytes": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", - "integrity": "sha1-NWnt6Lo0MV+rmcPpLLBMciDeH6g=", - "dev": true + "@babel/plugin-syntax-async-generators": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.2.0.tgz", + "integrity": "sha512-1ZrIRBv2t0GSlcwVoQ6VgSLpLgiN/FVQUzt9znxo7v2Ov4jJrs8RY8tv0wvDmFN3qIdMKWrmMMW6yZ0G19MfGg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "camelcase": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", - "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=", - "dev": true + "@babel/plugin-syntax-json-strings": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.2.0.tgz", + "integrity": "sha512-5UGYnMSLRE1dqqZwug+1LISpA403HzlSfsg6P9VXU6TBjcSHeNlw4DxDx7LgpF+iKZoOG/+uzqoRHTdcUpiZNg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "camelcase-keys": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", - "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.2.0.tgz", + "integrity": "sha512-t0JKGgqk2We+9may3t0xDdmneaXmyxq0xieYcKHxIsrJO64n1OiMWNUtc5gQK1PA0NpdCRrtZp4z+IUaKugrSA==", "dev": true, "requires": { - "camelcase": "^2.0.0", - "map-obj": "^1.0.0" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "chai": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", - "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.2.0.tgz", + "integrity": "sha512-bDe4xKNhb0LI7IvZHiA13kff0KEfaGX/Hv4lMA9+7TEc63hMNvfKo6ZFpXhKuEp+II/q35Gc4NoMeDZyaUbj9w==", "dev": true, "requires": { - "assertion-error": "^1.1.0", - "check-error": "^1.0.2", - "deep-eql": "^3.0.1", - "get-func-name": "^2.0.0", - "pathval": "^1.1.0", - "type-detect": "^4.0.5" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "chalk": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", - "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "@babel/plugin-transform-arrow-functions": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.2.0.tgz", + "integrity": "sha512-ER77Cax1+8/8jCB9fo4Ud161OZzWN5qawi4GusDuRLcDbDG+bIGYY20zb2dfAFdTRGzrfq2xZPvF0R64EHnimg==", "dev": true, "requires": { - "ansi-styles": "^2.2.1", - "escape-string-regexp": "^1.0.2", - "has-ansi": "^2.0.0", - "strip-ansi": "^3.0.0", - "supports-color": "^2.0.0" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "check-error": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", - "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", - "dev": true + "@babel/plugin-transform-async-to-generator": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.4.4.tgz", + "integrity": "sha512-YiqW2Li8TXmzgbXw+STsSqPBPFnGviiaSp6CYOq55X8GQ2SGVLrXB6pNid8HkqkZAzOH6knbai3snhP7v0fNwA==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.0.0", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-remap-async-to-generator": "^7.1.0" + } }, - "cli": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/cli/-/cli-1.0.1.tgz", - "integrity": "sha1-IoF1NPJL+klQw01TLUjsvGIbjBQ=", + "@babel/plugin-transform-block-scoped-functions": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.2.0.tgz", + "integrity": "sha512-ntQPR6q1/NKuphly49+QiQiTN0O63uOwjdD6dhIjSWBI5xlrbUFh720TIpzBhpnrLfv2tNH/BXvLIab1+BAI0w==", "dev": true, "requires": { - "exit": "0.1.2", - "glob": "^7.1.1" - }, - "dependencies": { - "glob": { - "version": "7.1.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", - "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", - "dev": true, - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.4", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - } + "@babel/helper-plugin-utils": "^7.0.0" } }, - "cliui": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", - "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", + "@babel/plugin-transform-block-scoping": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.4.4.tgz", + "integrity": "sha512-jkTUyWZcTrwxu5DD4rWz6rDB5Cjdmgz6z7M7RLXOJyCUkFBawssDGcGh8M/0FTSB87avyJI1HsTwUXp9nKA1PA==", "dev": true, "requires": { - "string-width": "^2.1.1", - "strip-ansi": "^4.0.0", - "wrap-ansi": "^2.0.0" - }, - "dependencies": { - "ansi-regex": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", - "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", - "dev": true - }, - "strip-ansi": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", - "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", - "dev": true, - "requires": { - "ansi-regex": "^3.0.0" - } - } + "@babel/helper-plugin-utils": "^7.0.0", + "lodash": "^4.17.11" } }, - "code-point-at": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", - "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", - "dev": true + "@babel/plugin-transform-classes": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.4.4.tgz", + "integrity": "sha512-/e44eFLImEGIpL9qPxSRat13I5QNRgBLu2hOQJCF7VLy/otSM/sypV1+XaIw5+502RX/+6YaSAPmldk+nhHDPw==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.0.0", + "@babel/helper-define-map": "^7.4.4", + "@babel/helper-function-name": "^7.1.0", + "@babel/helper-optimise-call-expression": "^7.0.0", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-replace-supers": "^7.4.4", + "@babel/helper-split-export-declaration": "^7.4.4", + "globals": "^11.1.0" + } }, - "coffeescript": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/coffeescript/-/coffeescript-1.10.0.tgz", - "integrity": "sha1-56qDAZF+9iGzXYo580jc3R234z4=", - "dev": true + "@babel/plugin-transform-computed-properties": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.2.0.tgz", + "integrity": "sha512-kP/drqTxY6Xt3NNpKiMomfgkNn4o7+vKxK2DDKcBG9sHj51vHqMBGy8wbDS/J4lMxnqs153/T3+DmCEAkC5cpA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "@babel/plugin-transform-destructuring": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.4.4.tgz", + "integrity": "sha512-/aOx+nW0w8eHiEHm+BTERB2oJn5D127iye/SUQl7NjHy0lf+j7h4MKMMSOwdazGq9OxgiNADncE+SRJkCxjZpQ==", "dev": true, "requires": { - "color-name": "1.1.3" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", - "dev": true + "@babel/plugin-transform-dotall-regex": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.4.4.tgz", + "integrity": "sha512-P05YEhRc2h53lZDjRPk/OektxCVevFzZs2Gfjd545Wde3k+yFDbXORgl2e0xpbq8mLcKJ7Idss4fAg0zORN/zg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-regex": "^7.4.4", + "regexpu-core": "^4.5.4" + } }, - "colors": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", - "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=", - "dev": true + "@babel/plugin-transform-duplicate-keys": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.2.0.tgz", + "integrity": "sha512-q+yuxW4DsTjNceUiTzK0L+AfQ0zD9rWaTLiUqHA8p0gxx7lu1EylenfzjeIWNkPy6e/0VG/Wjw9uf9LueQwLOw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "commander": { - "version": "2.20.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz", - "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==", - "dev": true + "@babel/plugin-transform-exponentiation-operator": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.2.0.tgz", + "integrity": "sha512-umh4hR6N7mu4Elq9GG8TOu9M0bakvlsREEC+ialrQN6ABS4oDQ69qJv1VtR3uxlKMCQMCvzk7vr17RHKcjx68A==", + "dev": true, + "requires": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.1.0", + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", - "dev": true + "@babel/plugin-transform-for-of": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.4.4.tgz", + "integrity": "sha512-9T/5Dlr14Z9TIEXLXkt8T1DU7F24cbhwhMNUziN3hB1AXoZcdzPcTiKGRn/6iOymDqtTKWnr/BtRKN9JwbKtdQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "config-chain": { - "version": "1.1.12", - "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.12.tgz", - "integrity": "sha512-a1eOIcu8+7lUInge4Rpf/n4Krkf3Dd9lqhljRzII1/Zno/kRtUWnznPO3jOKBmTEktkt3fkxisUcivoj0ebzoA==", + "@babel/plugin-transform-function-name": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.4.4.tgz", + "integrity": "sha512-iU9pv7U+2jC9ANQkKeNF6DrPy4GBa4NWQtl6dHB4Pb3izX2JOEvDTFarlNsBj/63ZEzNNIAMs3Qw4fNCcSOXJA==", "dev": true, "requires": { - "ini": "^1.3.4", - "proto-list": "~1.2.1" + "@babel/helper-function-name": "^7.1.0", + "@babel/helper-plugin-utils": "^7.0.0" } }, - "console-browserify": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", - "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", + "@babel/plugin-transform-literals": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.2.0.tgz", + "integrity": "sha512-2ThDhm4lI4oV7fVQ6pNNK+sx+c/GM5/SaML0w/r4ZB7sAneD/piDJtwdKlNckXeyGK7wlwg2E2w33C/Hh+VFCg==", "dev": true, "requires": { - "date-now": "^0.1.4" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "continuable-cache": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/continuable-cache/-/continuable-cache-0.3.1.tgz", - "integrity": "sha1-vXJ6f67XfnH/OYWskzUakSczrQ8=", - "dev": true + "@babel/plugin-transform-member-expression-literals": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.2.0.tgz", + "integrity": "sha512-HiU3zKkSU6scTidmnFJ0bMX8hz5ixC93b4MHMiYebmk2lUVNGOboPsqQvx5LzooihijUoLR/v7Nc1rbBtnc7FA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "core-util-is": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", - "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", - "dev": true + "@babel/plugin-transform-modules-amd": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.2.0.tgz", + "integrity": "sha512-mK2A8ucqz1qhrdqjS9VMIDfIvvT2thrEsIQzbaTdc5QFzhDjQv2CkJJ5f6BXIkgbmaoax3zBr2RyvV/8zeoUZw==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.1.0", + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "cross-spawn": { - "version": "6.0.5", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", - "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "@babel/plugin-transform-modules-commonjs": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.4.4.tgz", + "integrity": "sha512-4sfBOJt58sEo9a2BQXnZq+Q3ZTSAUXyK3E30o36BOGnJ+tvJ6YSxF0PG6kERvbeISgProodWuI9UVG3/FMY6iw==", + "dev": true, "requires": { - "nice-try": "^1.0.4", - "path-key": "^2.0.1", - "semver": "^5.5.0", - "shebang-command": "^1.2.0", - "which": "^1.2.9" + "@babel/helper-module-transforms": "^7.4.4", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-simple-access": "^7.1.0" } }, - "currently-unhandled": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", - "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", + "@babel/plugin-transform-modules-systemjs": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.4.4.tgz", + "integrity": "sha512-MSiModfILQc3/oqnG7NrP1jHaSPryO6tA2kOMmAQApz5dayPxWiHqmq4sWH2xF5LcQK56LlbKByCd8Aah/OIkQ==", "dev": true, "requires": { - "array-find-index": "^1.0.1" + "@babel/helper-hoist-variables": "^7.4.4", + "@babel/helper-plugin-utils": "^7.0.0" } }, - "date-now": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", - "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", - "dev": true + "@babel/plugin-transform-modules-umd": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.2.0.tgz", + "integrity": "sha512-BV3bw6MyUH1iIsGhXlOK6sXhmSarZjtJ/vMiD9dNmpY8QXFFQTj+6v92pcfy1iqa8DeAfJFwoxcrS/TUZda6sw==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.1.0", + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "dateformat": { - "version": "1.0.12", - "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-1.0.12.tgz", - "integrity": "sha1-nxJLZ1lMk3/3BpMuSmQsyo27/uk=", + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.4.4.tgz", + "integrity": "sha512-Ki+Y9nXBlKfhD+LXaRS7v95TtTGYRAf9Y1rTDiE75zf8YQz4GDaWRXosMfJBXxnk88mGFjWdCRIeqDbon7spYA==", "dev": true, "requires": { - "get-stdin": "^4.0.1", - "meow": "^3.3.0" + "regexp-tree": "^0.1.0" } }, - "debug": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", - "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "@babel/plugin-transform-new-target": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.4.4.tgz", + "integrity": "sha512-r1z3T2DNGQwwe2vPGZMBNjioT2scgWzK9BCnDEh+46z8EEwXBq24uRzd65I7pjtugzPSj921aM15RpESgzsSuA==", + "dev": true, "requires": { - "ms": "^2.1.1" - }, - "dependencies": { - "ms": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", - "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" - } + "@babel/helper-plugin-utils": "^7.0.0" } }, - "decamelize": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", - "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", - "dev": true + "@babel/plugin-transform-object-super": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.2.0.tgz", + "integrity": "sha512-VMyhPYZISFZAqAPVkiYb7dUe2AsVi2/wCT5+wZdsNO31FojQJa9ns40hzZ6U9f50Jlq4w6qwzdBB2uwqZ00ebg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-replace-supers": "^7.1.0" + } }, - "deep-eql": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", - "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", + "@babel/plugin-transform-parameters": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.4.4.tgz", + "integrity": "sha512-oMh5DUO1V63nZcu/ZVLQFqiihBGo4OpxJxR1otF50GMeCLiRx5nUdtokd+u9SuVJrvvuIh9OosRFPP4pIPnwmw==", "dev": true, "requires": { - "type-detect": "^4.0.0" + "@babel/helper-call-delegate": "^7.4.4", + "@babel/helper-get-function-arity": "^7.0.0", + "@babel/helper-plugin-utils": "^7.0.0" } }, - "define-properties": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", - "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "@babel/plugin-transform-property-literals": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.2.0.tgz", + "integrity": "sha512-9q7Dbk4RhgcLp8ebduOpCbtjh7C0itoLYHXd9ueASKAG/is5PQtMR5VJGka9NKqGhYEGn5ITahd4h9QeBMylWQ==", "dev": true, "requires": { - "object-keys": "^1.0.12" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "diff": { - "version": "3.5.0", - "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", - "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", - "dev": true + "@babel/plugin-transform-regenerator": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.4.4.tgz", + "integrity": "sha512-Zz3w+pX1SI0KMIiqshFZkwnVGUhDZzpX2vtPzfJBKQQq8WsP/Xy9DNdELWivxcKOCX/Pywge4SiEaPaLtoDT4g==", + "dev": true, + "requires": { + "regenerator-transform": "^0.13.4" + } }, - "dom-serializer": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.1.1.tgz", - "integrity": "sha512-l0IU0pPzLWSHBcieZbpOKgkIn3ts3vAh7ZuFyXNwJxJXk/c4Gwj9xaTJwIDVQCXawWD0qb3IzMGH5rglQaO0XA==", + "@babel/plugin-transform-reserved-words": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.2.0.tgz", + "integrity": "sha512-fz43fqW8E1tAB3DKF19/vxbpib1fuyCwSPE418ge5ZxILnBhWyhtPgz8eh1RCGGJlwvksHkyxMxh0eenFi+kFw==", "dev": true, "requires": { - "domelementtype": "^1.3.0", - "entities": "^1.1.1" - }, - "dependencies": { - "entities": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", - "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==", - "dev": true - } + "@babel/helper-plugin-utils": "^7.0.0" } }, - "domelementtype": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", - "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", - "dev": true + "@babel/plugin-transform-shorthand-properties": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.2.0.tgz", + "integrity": "sha512-QP4eUM83ha9zmYtpbnyjTLAGKQritA5XW/iG9cjtuOI8s1RuL/3V6a3DeSHfKutJQ+ayUfeZJPcnCYEQzaPQqg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "domhandler": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.3.0.tgz", - "integrity": "sha1-LeWaCCLVAn+r/28DLCsloqir5zg=", + "@babel/plugin-transform-spread": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.2.2.tgz", + "integrity": "sha512-KWfky/58vubwtS0hLqEnrWJjsMGaOeSBn90Ezn5Jeg9Z8KKHmELbP1yGylMlm5N6TPKeY9A2+UaSYLdxahg01w==", "dev": true, "requires": { - "domelementtype": "1" + "@babel/helper-plugin-utils": "^7.0.0" } }, - "domutils": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", - "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", + "@babel/plugin-transform-sticky-regex": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.2.0.tgz", + "integrity": "sha512-KKYCoGaRAf+ckH8gEL3JHUaFVyNHKe3ASNsZ+AlktgHevvxGigoIttrEJb8iKN03Q7Eazlv1s6cx2B2cQ3Jabw==", "dev": true, "requires": { - "dom-serializer": "0", - "domelementtype": "1" + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-regex": "^7.0.0" } }, - "dotenv": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-7.0.0.tgz", - "integrity": "sha512-M3NhsLbV1i6HuGzBUH8vXrtxOk+tWmzWKDMbAVSUp3Zsjm7ywFeuwrUXhmhQyRK1q5B5GGy7hcXPbj3bnfZg2g==" + "@babel/plugin-transform-template-literals": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.4.4.tgz", + "integrity": "sha512-mQrEC4TWkhLN0z8ygIvEL9ZEToPhG5K7KDW3pzGqOfIGZ28Jb0POUkeWcoz8HnHvhFy6dwAT1j8OzqN8s804+g==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.0.0", + "@babel/helper-plugin-utils": "^7.0.0" + } }, - "editorconfig": { - "version": "0.15.3", - "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", - "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", + "@babel/plugin-transform-typeof-symbol": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.2.0.tgz", + "integrity": "sha512-2LNhETWYxiYysBtrBTqL8+La0jIoQQnIScUJc74OYvUGRmkskNY4EzLCnjHBzdmb38wqtTaixpo1NctEcvMDZw==", "dev": true, "requires": { - "commander": "^2.19.0", - "lru-cache": "^4.1.5", - "semver": "^5.6.0", - "sigmund": "^1.0.1" + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.4.4.tgz", + "integrity": "sha512-il+/XdNw01i93+M9J9u4T7/e/Ue/vWfNZE4IRUQjplu2Mqb/AFTDimkw2tdEdSH50wuQXZAbXSql0UphQke+vA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/helper-regex": "^7.4.4", + "regexpu-core": "^4.5.4" + } + }, + "@babel/polyfill": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/polyfill/-/polyfill-7.4.4.tgz", + "integrity": "sha512-WlthFLfhQQhh+A2Gn5NSFl0Huxz36x86Jn+E9OW7ibK8edKPq+KLy4apM1yDpQ8kJOVi1OVjpP4vSDLdrI04dg==", + "dev": true, + "requires": { + "core-js": "^2.6.5", + "regenerator-runtime": "^0.13.2" }, "dependencies": { - "semver": { - "version": "5.7.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", - "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", + "regenerator-runtime": { + "version": "0.13.2", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.2.tgz", + "integrity": "sha512-S/TQAZJO+D3m9xeN1WTI8dLKBBiRgXBlTJvbWjCThHWZj9EvHK70Ff50/tYj2J/fvBY6JtFVwRuazHN2E7M9BA==", "dev": true } } }, - "emoji-regex": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", - "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", - "dev": true - }, - "end-of-stream": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", - "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", + "@babel/preset-env": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.4.4.tgz", + "integrity": "sha512-FU1H+ACWqZZqfw1x2G1tgtSSYSfxJLkpaUQL37CenULFARDo+h4xJoVHzRoHbK+85ViLciuI7ME4WTIhFRBBlw==", + "dev": true, "requires": { - "once": "^1.4.0" + "@babel/helper-module-imports": "^7.0.0", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-async-generator-functions": "^7.2.0", + "@babel/plugin-proposal-json-strings": "^7.2.0", + "@babel/plugin-proposal-object-rest-spread": "^7.4.4", + "@babel/plugin-proposal-optional-catch-binding": "^7.2.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", + "@babel/plugin-syntax-async-generators": "^7.2.0", + "@babel/plugin-syntax-json-strings": "^7.2.0", + "@babel/plugin-syntax-object-rest-spread": "^7.2.0", + "@babel/plugin-syntax-optional-catch-binding": "^7.2.0", + "@babel/plugin-transform-arrow-functions": "^7.2.0", + "@babel/plugin-transform-async-to-generator": "^7.4.4", + "@babel/plugin-transform-block-scoped-functions": "^7.2.0", + "@babel/plugin-transform-block-scoping": "^7.4.4", + "@babel/plugin-transform-classes": "^7.4.4", + "@babel/plugin-transform-computed-properties": "^7.2.0", + "@babel/plugin-transform-destructuring": "^7.4.4", + "@babel/plugin-transform-dotall-regex": "^7.4.4", + "@babel/plugin-transform-duplicate-keys": "^7.2.0", + "@babel/plugin-transform-exponentiation-operator": "^7.2.0", + "@babel/plugin-transform-for-of": "^7.4.4", + "@babel/plugin-transform-function-name": "^7.4.4", + "@babel/plugin-transform-literals": "^7.2.0", + "@babel/plugin-transform-member-expression-literals": "^7.2.0", + "@babel/plugin-transform-modules-amd": "^7.2.0", + "@babel/plugin-transform-modules-commonjs": "^7.4.4", + "@babel/plugin-transform-modules-systemjs": "^7.4.4", + "@babel/plugin-transform-modules-umd": "^7.2.0", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.4.4", + "@babel/plugin-transform-new-target": "^7.4.4", + "@babel/plugin-transform-object-super": "^7.2.0", + "@babel/plugin-transform-parameters": "^7.4.4", + "@babel/plugin-transform-property-literals": "^7.2.0", + "@babel/plugin-transform-regenerator": "^7.4.4", + "@babel/plugin-transform-reserved-words": "^7.2.0", + "@babel/plugin-transform-shorthand-properties": "^7.2.0", + "@babel/plugin-transform-spread": "^7.2.0", + "@babel/plugin-transform-sticky-regex": "^7.2.0", + "@babel/plugin-transform-template-literals": "^7.4.4", + "@babel/plugin-transform-typeof-symbol": "^7.2.0", + "@babel/plugin-transform-unicode-regex": "^7.4.4", + "@babel/types": "^7.4.4", + "browserslist": "^4.5.2", + "core-js-compat": "^3.0.0", + "invariant": "^2.2.2", + "js-levenshtein": "^1.1.3", + "semver": "^5.5.0" + } + }, + "@babel/register": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/register/-/register-7.4.4.tgz", + "integrity": "sha512-sn51H88GRa00+ZoMqCVgOphmswG4b7mhf9VOB0LUBAieykq2GnRFerlN+JQkO/ntT7wz4jaHNSRPg9IdMPEUkA==", + "dev": true, + "requires": { + "core-js": "^3.0.0", + "find-cache-dir": "^2.0.0", + "lodash": "^4.17.11", + "mkdirp": "^0.5.1", + "pirates": "^4.0.0", + "source-map-support": "^0.5.9" + }, + "dependencies": { + "core-js": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.0.1.tgz", + "integrity": "sha512-sco40rF+2KlE0ROMvydjkrVMMG1vYilP2ALoRXcYR4obqbYIuV3Bg+51GEDW+HF8n7NRA+iaA4qD0nD9lo9mew==", + "dev": true + } } }, - "entities": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-1.0.0.tgz", - "integrity": "sha1-sph6o4ITR/zeZCsk/fyeT7cSvyY=", - "dev": true - }, - "error": { - "version": "7.0.2", - "resolved": "https://registry.npmjs.org/error/-/error-7.0.2.tgz", - "integrity": "sha1-pfdf/02ZJhJt2sDqXcOOaJFTywI=", + "@babel/runtime": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.4.4.tgz", + "integrity": "sha512-w0+uT71b6Yi7i5SE0co4NioIpSYS6lLiXvCzWzGSKvpK5vdQtCbICHMj+gbAKAOtxiV6HsVh/MBdaF9EQ6faSg==", "dev": true, "requires": { - "string-template": "~0.2.1", - "xtend": "~4.0.0" + "regenerator-runtime": "^0.13.2" + }, + "dependencies": { + "regenerator-runtime": { + "version": "0.13.2", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.2.tgz", + "integrity": "sha512-S/TQAZJO+D3m9xeN1WTI8dLKBBiRgXBlTJvbWjCThHWZj9EvHK70Ff50/tYj2J/fvBY6JtFVwRuazHN2E7M9BA==", + "dev": true + } } }, - "error-ex": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", - "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", + "@babel/template": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.4.4.tgz", + "integrity": "sha512-CiGzLN9KgAvgZsnivND7rkA+AeJ9JB0ciPOD4U59GKbQP2iQl+olF1l76kJOupqidozfZ32ghwBEJDhnk9MEcw==", + "dev": true, "requires": { - "is-arrayish": "^0.2.1" + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.4.4", + "@babel/types": "^7.4.4" } }, - "es-abstract": { - "version": "1.13.0", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", - "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", + "@babel/traverse": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.4.4.tgz", + "integrity": "sha512-Gw6qqkw/e6AGzlyj9KnkabJX7VcubqPtkUQVAwkc0wUMldr3A/hezNB3Rc5eIvId95iSGkGIOe5hh1kMKf951A==", "dev": true, "requires": { - "es-to-primitive": "^1.2.0", - "function-bind": "^1.1.1", - "has": "^1.0.3", - "is-callable": "^1.1.4", - "is-regex": "^1.0.4", - "object-keys": "^1.0.12" + "@babel/code-frame": "^7.0.0", + "@babel/generator": "^7.4.4", + "@babel/helper-function-name": "^7.1.0", + "@babel/helper-split-export-declaration": "^7.4.4", + "@babel/parser": "^7.4.4", + "@babel/types": "^7.4.4", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.11" } }, - "es-to-primitive": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", - "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", + "@babel/types": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.4.4.tgz", + "integrity": "sha512-dOllgYdnEFOebhkKCjzSVFqw/PmmB8pH6RGOWkY4GsboQNd47b1fBThBSwlHAq9alF9vc1M3+6oqR47R50L0tQ==", "dev": true, "requires": { - "is-callable": "^1.1.4", - "is-date-object": "^1.0.1", - "is-symbol": "^1.0.2" + "esutils": "^2.0.2", + "lodash": "^4.17.11", + "to-fast-properties": "^2.0.0" } }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", - "dev": true + "@benmaruchu/faker": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/@benmaruchu/faker/-/faker-4.2.1.tgz", + "integrity": "sha512-VyOCOhm2/O/f/yqURU2JO4B8s0CyNaoUZ3/LrPuh7zgcE/f08Uay+l51wpa43kN7DX9pgg8OtgNpWNyZA9Y5SA==" }, - "esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "dev": true - }, - "eventemitter2": { - "version": "0.4.14", - "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-0.4.14.tgz", - "integrity": "sha1-j2G3XN4BKy6esoTUVFWDtWQ7Yas=", - "dev": true - }, - "execa": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", - "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "@commitlint/cli": { + "version": "7.6.1", + "resolved": "https://registry.npmjs.org/@commitlint/cli/-/cli-7.6.1.tgz", + "integrity": "sha512-HEJwQ/aK0AOcAwn77ZKbb/GZhlGxBSPhtVp07uoJFVqM12l2Ia2JHA+MTpfHCFdVahKyYGREZgxde6LyKyG8aQ==", + "dev": true, "requires": { - "cross-spawn": "^6.0.0", - "get-stream": "^4.0.0", - "is-stream": "^1.1.0", - "npm-run-path": "^2.0.0", - "p-finally": "^1.0.0", - "signal-exit": "^3.0.0", - "strip-eof": "^1.0.0" + "@commitlint/format": "^7.6.1", + "@commitlint/lint": "^7.6.0", + "@commitlint/load": "^7.6.1", + "@commitlint/read": "^7.6.0", + "babel-polyfill": "6.26.0", + "chalk": "2.3.1", + "get-stdin": "7.0.0", + "lodash": "4.17.11", + "meow": "5.0.0", + "resolve-from": "5.0.0", + "resolve-global": "1.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "camelcase": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", + "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", + "dev": true + }, + "camelcase-keys": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-4.2.0.tgz", + "integrity": "sha1-oqpfsa9oh1glnDLBQUJteJI7m3c=", + "dev": true, + "requires": { + "camelcase": "^4.1.0", + "map-obj": "^2.0.0", + "quick-lru": "^1.0.0" + } + }, + "chalk": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.1.tgz", + "integrity": "sha512-QUU4ofkDoMIVO7hcx1iPTISs88wsO8jA92RQIm4JAwZvFGGAV2hSAA1NX7oVj2Ej2Q6NDTcRDjPTFrMCRZoJ6g==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.2.0" + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "get-stdin": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-7.0.0.tgz", + "integrity": "sha512-zRKcywvrXlXsA0v0i9Io4KDRaAw7+a1ZpjRwl9Wox8PFlVCCHra7E9c4kqXCoCM9nR5tBkaTTZRBoCm60bFqTQ==", + "dev": true + }, + "indent-string": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", + "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", + "dev": true + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "map-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-2.0.0.tgz", + "integrity": "sha1-plzSkIepJZi4eRJXpSPgISIqwfk=", + "dev": true + }, + "meow": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/meow/-/meow-5.0.0.tgz", + "integrity": "sha512-CbTqYU17ABaLefO8vCU153ZZlprKYWDljcndKKDCFcYQITzWCXZAVk4QMFZPgvzrnUQ3uItnIE/LoUOwrT15Ig==", + "dev": true, + "requires": { + "camelcase-keys": "^4.0.0", + "decamelize-keys": "^1.0.0", + "loud-rejection": "^1.0.0", + "minimist-options": "^3.0.1", + "normalize-package-data": "^2.3.4", + "read-pkg-up": "^3.0.0", + "redent": "^2.0.0", + "trim-newlines": "^2.0.0", + "yargs-parser": "^10.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-3.0.0.tgz", + "integrity": "sha1-PtSWaF26D4/hGNBpHcUfSh/5bwc=", + "dev": true, + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^3.0.0" + } + }, + "redent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-2.0.0.tgz", + "integrity": "sha1-wbIAe0LVfrE4kHmzyDM2OdXhzKo=", + "dev": true, + "requires": { + "indent-string": "^3.0.0", + "strip-indent": "^2.0.0" + } + }, + "resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "strip-indent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-2.0.0.tgz", + "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "trim-newlines": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-2.0.0.tgz", + "integrity": "sha1-tAPQuRvlDDMd/EuC7s6yLD3hbSA=", + "dev": true + }, + "yargs-parser": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-10.1.0.tgz", + "integrity": "sha512-VCIyR1wJoEBZUqk5PA+oOBF6ypbwh5aNB3I50guxAL/quggdfs4TtNHQrSazFA3fYZ+tEqfs0zIGlv0c/rgjbQ==", + "dev": true, + "requires": { + "camelcase": "^4.1.0" + } + } } }, - "exit": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", - "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=", + "@commitlint/config-conventional": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/config-conventional/-/config-conventional-7.6.0.tgz", + "integrity": "sha512-1Gnv5p3tc1VsEK25oTIRBO86czLtX6s/jeLNPAQRzdCnyEmsxkbx/sfoUJ1dwv7v8W++xckVnnuvdZv2Hp8yCw==", "dev": true }, - "faye-websocket": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", - "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", + "@commitlint/ensure": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/ensure/-/ensure-7.6.0.tgz", + "integrity": "sha512-pSUrNud5L/8y+cLWo3LEa8Ce4bAAR33xMderFUhuNPHj7TwpNS7L4ROMnhL4ZlCYRazCRDlnPaJLPikMoWThfA==", "dev": true, "requires": { - "websocket-driver": ">=0.5.1" + "lodash": "4.17.11" } }, - "find-up": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", - "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "@commitlint/execute-rule": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/execute-rule/-/execute-rule-7.6.0.tgz", + "integrity": "sha512-0inGOIlLefPDtiDOaZ6WoE1p+GEZZIj2VwUftUozD3C71TiwP9UfKAVVtUDFPIeL6RgSqCkCf7zsy6NKNxwkBg==", "dev": true, "requires": { - "path-exists": "^2.0.0", - "pinkie-promise": "^2.0.0" + "babel-runtime": "6.26.0" } }, - "findup-sync": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-0.3.0.tgz", - "integrity": "sha1-N5MKpdgWt3fANEXhlmzGeQpMCxY=", + "@commitlint/format": { + "version": "7.6.1", + "resolved": "https://registry.npmjs.org/@commitlint/format/-/format-7.6.1.tgz", + "integrity": "sha512-Ldzf5N2Sr9RQqvlYwaQn4vz1WOZ7byYinspC/WCrbfcETGy28j7QE4OueZU6nNB9TjwwEorKm13uy7tDWPR7dg==", "dev": true, "requires": { - "glob": "~5.0.0" + "babel-runtime": "^6.23.0", + "chalk": "^2.0.1" }, "dependencies": { - "glob": { - "version": "5.0.15", - "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", - "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", "dev": true, "requires": { - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "2 || 3", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" } } } }, - "flat": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", - "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", + "@commitlint/is-ignored": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/is-ignored/-/is-ignored-7.6.0.tgz", + "integrity": "sha512-By/mLNhz+6Rtix9+Kyof1gdKiELchAnQHpdeKIHIOe9sjbvd3HqDoFHh/mGMMRnGIPMZOX5TO8Fqy3A/2HqlTw==", "dev": true, "requires": { - "is-buffer": "~2.0.3" + "semver": "6.0.0" + }, + "dependencies": { + "semver": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", + "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==", + "dev": true + } } }, - "fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", - "dev": true + "@commitlint/lint": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/lint/-/lint-7.6.0.tgz", + "integrity": "sha512-aUIFX0lPRZL7WmT8W8qzogJD4LmHk6JPG3XUAX+K0pOHGjC/0ALvSAytvoLXy4fvmSnGJkXmWhzSW7c0Spa14Q==", + "dev": true, + "requires": { + "@commitlint/is-ignored": "^7.6.0", + "@commitlint/parse": "^7.6.0", + "@commitlint/rules": "^7.6.0", + "babel-runtime": "^6.23.0", + "lodash": "4.17.11" + } }, - "function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "@commitlint/load": { + "version": "7.6.2", + "resolved": "https://registry.npmjs.org/@commitlint/load/-/load-7.6.2.tgz", + "integrity": "sha512-I+xk+BkXAG1roXNrPsR1eOd5hEa+oLc6HLYnHAT/HLGKKB3E01IGg3O5SGlg7lpf1yiAaYI+wAnNTr3f3sIbWQ==", + "dev": true, + "requires": { + "@commitlint/execute-rule": "^7.6.0", + "@commitlint/resolve-extends": "^7.6.0", + "babel-runtime": "^6.23.0", + "cosmiconfig": "^5.2.0", + "lodash": "4.17.11", + "resolve-from": "^5.0.0" + }, + "dependencies": { + "resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true + } + } + }, + "@commitlint/message": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/message/-/message-7.6.0.tgz", + "integrity": "sha512-PtP4jhBYGXLaQQC5jel+RQczG2tS3Cy6rRxQioUfCUaEg/LV029ao/KcL1kHEBJ8hSW/SUmnvDaD9Y6nozLQMA==", "dev": true }, - "gaze": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.2.tgz", - "integrity": "sha1-hHIkZ3rbiHDWeSV+0ziP22HkAQU=", + "@commitlint/parse": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/parse/-/parse-7.6.0.tgz", + "integrity": "sha512-1x60kTqz2VBCjYE+8MV5BhE+ShPo7MgVlrMWSlxiiJDWP5CvWa+SBbUayDJ7rtOXimjTASZ9ZNZTuFPdJE/Y7A==", "dev": true, "requires": { - "globule": "^1.0.0" + "conventional-changelog-angular": "^1.3.3", + "conventional-commits-parser": "^2.1.0", + "lodash": "^4.17.11" } }, - "get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "dev": true + "@commitlint/read": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/read/-/read-7.6.0.tgz", + "integrity": "sha512-OyligtK/e4xnQklrQqTcSMM27eNhq+LqXfoeVouuPx059oDEw9wZYNN4HGzyxs4Pb6GdMpzRHLdeMQ24M+AiYw==", + "dev": true, + "requires": { + "@commitlint/top-level": "^7.6.0", + "@marionebl/sander": "^0.6.0", + "babel-runtime": "^6.23.0", + "git-raw-commits": "^1.3.0" + } }, - "get-func-name": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", - "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", - "dev": true + "@commitlint/resolve-extends": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/resolve-extends/-/resolve-extends-7.6.0.tgz", + "integrity": "sha512-fk8KvNiEbRc+p8nPFuysVP2O95+sb8vlIDTjqtGVObqrzFINRfERXwqBmTBtcu556BoDAR2hwRVXmuwhns+Duw==", + "dev": true, + "requires": { + "babel-runtime": "6.26.0", + "import-fresh": "^3.0.0", + "lodash": "4.17.11", + "resolve-from": "^5.0.0", + "resolve-global": "^1.0.0" + }, + "dependencies": { + "resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true + } + } + }, + "@commitlint/rules": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/rules/-/rules-7.6.0.tgz", + "integrity": "sha512-shLJdMUwdVeE5UgOE8E+c+PFS7+0FFGfheMa3s6ZK+xX8pTUxseXZu9iCF4mwF+WWkVk518xPuNLvmYE96salQ==", + "dev": true, + "requires": { + "@commitlint/ensure": "^7.6.0", + "@commitlint/message": "^7.6.0", + "@commitlint/to-lines": "^7.6.0", + "babel-runtime": "^6.23.0" + } + }, + "@commitlint/to-lines": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/to-lines/-/to-lines-7.6.0.tgz", + "integrity": "sha512-L/Vl5ThRuBHnSNZBtc+p2LCs2ayxWodC+I/X3NKUywSmr6kKpJJCFqHHHqPu+yXwGUPwqCMQhogIGLuv9TtWWw==", + "dev": true + }, + "@commitlint/top-level": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@commitlint/top-level/-/top-level-7.6.0.tgz", + "integrity": "sha512-R2RzJZDuT2TU2dZMrRd7olax5IDVcUB/O8k76d1LW13CQ9/2ArJi3TCFXSZIaGpCUnyAYA5KiCZ+c1opnyQuog==", + "dev": true, + "requires": { + "find-up": "^2.1.0" + }, + "dependencies": { + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + } + } + }, + "@commitlint/travis-cli": { + "version": "7.6.1", + "resolved": "https://registry.npmjs.org/@commitlint/travis-cli/-/travis-cli-7.6.1.tgz", + "integrity": "sha512-oDtO0T0BIJs+nXxubdSaPRVni4RZ9SQA2N7gPDfsSzEVJZMqp23FOX/IO/K3dJS49Q9dbK6wqBl8jmSlva8r1w==", + "dev": true, + "requires": { + "@commitlint/cli": "^7.6.1", + "babel-runtime": "6.26.0", + "execa": "0.9.0" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", + "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "execa": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-0.9.0.tgz", + "integrity": "sha512-BbUMBiX4hqiHZUA5+JujIjNb6TyAlp2D5KLheMjMluwOuzcnylDL4AxZYLLn1n2AGB49eSWwyKvvEQoRpnAtmA==", + "dev": true, + "requires": { + "cross-spawn": "^5.0.1", + "get-stream": "^3.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "get-stream": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", + "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", + "dev": true + } + } + }, + "@lykmapipo/common": { + "version": "0.17.4", + "resolved": "https://registry.npmjs.org/@lykmapipo/common/-/common-0.17.4.tgz", + "integrity": "sha512-3jdLPpixP6xmNV7xrE0qQZ8vGMAqFenAqZDQ5nFiWTDSPZOyp7zcltjtVowBbXTcjsaXTJla+wFaS8t+za7Lzg==", + "requires": { + "lodash": ">=4.17.11", + "read-pkg": ">=5.1.1", + "statuses": ">=1.5.0" + }, + "dependencies": { + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "read-pkg": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.1.1.tgz", + "integrity": "sha512-dFcTLQi6BZ+aFUaICg7er+/usEoqFdQxiEBsEMNGoipenihtxxtdrQuBXvyANCEI8VuUIVYFgeHGx9sLLvim4w==", + "requires": { + "@types/normalize-package-data": "^2.4.0", + "normalize-package-data": "^2.5.0", + "parse-json": "^4.0.0", + "type-fest": "^0.4.1" + } + }, + "resolve": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.1.tgz", + "integrity": "sha512-KuIe4mf++td/eFb6wkaPbMDnP6kObCaEtIDuHOUED6MNUo4K670KZUHuuvYPZDxNF0WVLw49n06M2m2dXphEzA==", + "requires": { + "path-parse": "^1.0.6" + } + } + } + }, + "@lykmapipo/env": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/@lykmapipo/env/-/env-0.7.4.tgz", + "integrity": "sha512-sd3SQQ7wSvOm8/a9rZINbrhPswJuZrXT8nhev1wBWHT/xtMJ8T1m6BkAhnxVYfTGbGqKGh1U7G2PVYmZT/6bGw==", + "requires": { + "dotenv": ">=7.0.0", + "lodash": ">=4.17.11", + "semver": ">=6.0.0" + }, + "dependencies": { + "semver": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", + "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==" + } + } + }, + "@lykmapipo/include": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@lykmapipo/include/-/include-0.2.3.tgz", + "integrity": "sha512-c7/3dBjQtqxJiZRGV76p/JxmI5RyehyK/ea/cCoXnS9J213WRdJo2anWMQWtoLMrx0b9+pjmV/EERPjDsfJhnQ==", + "requires": { + "lodash": ">=4.17.11" + } + }, + "@lykmapipo/mongoose-aggregatable": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-aggregatable/-/mongoose-aggregatable-0.2.4.tgz", + "integrity": "sha512-Pm1p6wJrBaqaRxqGoyhtb6e7MMBZ/vsAjCpSwdZh+6qKDRUueT8aeW6+VJgfQB0weAyf78s1IUlhe7ivim79LA==", + "requires": { + "@lykmapipo/common": ">=0.17.3", + "@lykmapipo/include": ">=0.2.2", + "@lykmapipo/mongoose-common": ">=0.23.0", + "async": ">=2.6.2", + "inflection": ">=1.12.0", + "lodash": ">=4.17.11" + } + }, + "@lykmapipo/mongoose-common": { + "version": "0.23.0", + "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-common/-/mongoose-common-0.23.0.tgz", + "integrity": "sha512-TpHaSe2XF5vWQzDSy4PBxI8fX8rbuQQOK9/qrBK9/5mZCvjzJ1fngmK2aofSXxaxnQNCX+PHOHhiUkD3W+HuJg==", + "requires": { + "@lykmapipo/common": ">=0.17.3", + "@lykmapipo/env": ">=0.7.5", + "@lykmapipo/include": ">=0.2.2", + "async": ">=2.6.2", + "lodash": ">=4.17.11", + "mongoose-schema-jsonschema": ">=1.2.1", + "mongoose-valid8": ">=1.5.2" + }, + "dependencies": { + "@lykmapipo/env": { + "version": "0.7.5", + "resolved": "https://registry.npmjs.org/@lykmapipo/env/-/env-0.7.5.tgz", + "integrity": "sha512-u+pmVMaWPv3QomyuDLIPO+4gidyhwN5FXP3iUXVQJ2+asgNTq7eieXea/RRUoEZP3oOznNK8MY2SEU3kOF9iGw==", + "requires": { + "dotenv": ">=8.0.0", + "lodash": ">=4.17.11", + "semver": ">=6.0.0" + } + }, + "dotenv": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.0.0.tgz", + "integrity": "sha512-30xVGqjLjiUOArT4+M5q9sYdvuR4riM6yK9wMcas9Vbp6zZa+ocC9dp6QoftuhTPhFAiLK/0C5Ni2nou/Bk8lg==" + }, + "semver": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", + "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==" + } + } + }, + "@lykmapipo/mongoose-faker": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-faker/-/mongoose-faker-0.9.4.tgz", + "integrity": "sha512-JRuSwHf0eeh7vfJbqsY09clc3kTbV1qKmWykxwWvNIlQVEiddxMKO+/6CE9Ww/H2xT49OzLoBBXlCm6slHg/YA==", + "requires": { + "@benmaruchu/faker": ">=4.2.1", + "lodash": ">=4.17.11" + } + }, + "@lykmapipo/mongoose-taggable": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-taggable/-/mongoose-taggable-0.4.3.tgz", + "integrity": "sha512-o71dIgQd7XL6Jfux9bZY1k1XXVyZNoENkH+izBr75NohLdXknrYSOW+eo4y1M1W7yy8xe6P46OEOFjzV2uXRMA==", + "requires": { + "@lykmapipo/env": ">=0.7.5", + "@lykmapipo/mongoose-common": ">=0.23.0", + "async": ">=2.6.2", + "lodash": ">=4.17.11", + "moment": ">=2.24.0", + "stopwords-iso": ">=0.4.0", + "traverse": ">=0.6.6" + }, + "dependencies": { + "@lykmapipo/env": { + "version": "0.7.6", + "resolved": "https://registry.npmjs.org/@lykmapipo/env/-/env-0.7.6.tgz", + "integrity": "sha512-hm7deczdmULcqONUHCviF5uJTMjo/YZymNolfWZVAk3mz7qmwmw66dR4Mcx0SvECytqal8p5j4nu60AefICCug==", + "requires": { + "dotenv": ">=8.0.0", + "lodash": ">=4.17.11", + "semver": ">=6.0.0" + } + }, + "dotenv": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.0.0.tgz", + "integrity": "sha512-30xVGqjLjiUOArT4+M5q9sYdvuR4riM6yK9wMcas9Vbp6zZa+ocC9dp6QoftuhTPhFAiLK/0C5Ni2nou/Bk8lg==" + }, + "semver": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", + "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==" + } + } + }, + "@lykmapipo/mongoose-test-helpers": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/@lykmapipo/mongoose-test-helpers/-/mongoose-test-helpers-0.7.2.tgz", + "integrity": "sha512-hagYk5Xy/1OB/SAukCqrq2gJLy3BHdBptO4l+AxsjwHgXtWDEYtPTxLtqBN14NdluGERaXQA84D6R7ad3Ka+BQ==", + "dev": true, + "requires": { + "@benmaruchu/faker": ">=4.2.1", + "@lykmapipo/mongoose-common": ">=0.23.0", + "@lykmapipo/mongoose-faker": ">=0.9.4", + "@lykmapipo/test-helpers": ">=0.2.2", + "async": ">=2.6.2", + "chai": ">=4.2.0", + "lodash": ">=4.17.11", + "sinon": ">=7.3.2", + "sinon-chai": ">=3.3.0", + "sinon-mongoose": ">=2.3.0" + } + }, + "@lykmapipo/phone": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@lykmapipo/phone/-/phone-0.3.3.tgz", + "integrity": "sha512-rm831xbACan+/Ql9GUVfWH02WjoZxfmRGy5pkbwMxBiTXRZQ1cdVlCTq6MCaavr3tvBhbBxKhiBv4UiRsSG9Bg==", + "requires": { + "@lykmapipo/env": ">=0.7.4", + "google-libphonenumber": ">=3.2.2", + "lodash": ">=4.17.11", + "os-locale": ">=3.1.0" + } + }, + "@lykmapipo/test-helpers": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/@lykmapipo/test-helpers/-/test-helpers-0.2.2.tgz", + "integrity": "sha512-VD/U4AeyXL1Utdzdxj4fXuLLUL9GIMH2QJ4Gz8wr6j3HztXwj0RdvOnzyC+y6fDxDC3N7twl3JOfcs8ZPBWarQ==", + "dev": true, + "requires": { + "@benmaruchu/faker": ">=4.2.1", + "chai": ">=4.2.0", + "sinon": ">=7.3.2", + "sinon-chai": ">=3.3.0" + } + }, + "@marionebl/sander": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/@marionebl/sander/-/sander-0.6.1.tgz", + "integrity": "sha1-GViWWHTyS8Ub5Ih1/rUNZC/EH3s=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.3", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.2" + } + }, + "@samverschueren/stream-to-observable": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/@samverschueren/stream-to-observable/-/stream-to-observable-0.3.0.tgz", + "integrity": "sha512-MI4Xx6LHs4Webyvi6EbspgyAb4D2Q2VtnCQ1blOJcoLS6mVa8lNN2rkIy1CVxfTUpoyIbCTkXES1rLXztFD1lg==", + "dev": true, + "requires": { + "any-observable": "^0.3.0" + } + }, + "@sinonjs/commons": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.4.0.tgz", + "integrity": "sha512-9jHK3YF/8HtJ9wCAbG+j8cD0i0+ATS9A7gXFqS36TblLPNy6rEEc+SB0imo91eCboGaBYGV/MT1/br/J+EE7Tw==", + "dev": true, + "requires": { + "type-detect": "4.0.8" + } + }, + "@sinonjs/formatio": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/@sinonjs/formatio/-/formatio-3.2.1.tgz", + "integrity": "sha512-tsHvOB24rvyvV2+zKMmPkZ7dXX6LSLKZ7aOtXY6Edklp0uRcgGpOsQTTGTcWViFyx4uhWc6GV8QdnALbIbIdeQ==", + "dev": true, + "requires": { + "@sinonjs/commons": "^1", + "@sinonjs/samsam": "^3.1.0" + } + }, + "@sinonjs/samsam": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/@sinonjs/samsam/-/samsam-3.3.1.tgz", + "integrity": "sha512-wRSfmyd81swH0hA1bxJZJ57xr22kC07a1N4zuIL47yTS04bDk6AoCkczcqHEjcRPmJ+FruGJ9WBQiJwMtIElFw==", + "dev": true, + "requires": { + "@sinonjs/commons": "^1.0.2", + "array-from": "^2.1.1", + "lodash": "^4.17.11" + } + }, + "@sinonjs/text-encoding": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/@sinonjs/text-encoding/-/text-encoding-0.7.1.tgz", + "integrity": "sha512-+iTbntw2IZPb/anVDbypzfQa+ay64MW0Zo8aJ8gZPWMMK6/OubMVb6lUPMagqjOPnmtauXnFCACVl3O7ogjeqQ==", + "dev": true + }, + "@types/estree": { + "version": "0.0.39", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", + "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", + "dev": true + }, + "@types/node": { + "version": "11.13.10", + "resolved": "https://registry.npmjs.org/@types/node/-/node-11.13.10.tgz", + "integrity": "sha512-leUNzbFTMX94TWaIKz8N15Chu55F9QSH+INKayQr5xpkasBQBRF3qQXfo3/dOnMU/dEIit+Y/SU8HyOjq++GwA==", + "dev": true + }, + "@types/normalize-package-data": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz", + "integrity": "sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==" + }, + "JSONStream": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.5.tgz", + "integrity": "sha512-E+iruNOY8VV9s4JEbe1aNEm6MiszPRr/UfcHMz0TQh1BXSxHK+ASV1R6W4HpjBhSeS+54PIsAMCBmwD06LLsqQ==", + "dev": true, + "requires": { + "jsonparse": "^1.2.0", + "through": ">=2.2.7 <3" + } + }, + "abbrev": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", + "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", + "dev": true + }, + "acorn": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", + "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", + "dev": true + }, + "acorn-jsx": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", + "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", + "dev": true + }, + "ajv": { + "version": "6.10.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", + "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", + "dev": true, + "requires": { + "fast-deep-equal": "^2.0.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ansi-colors": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", + "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", + "dev": true + }, + "ansi-escapes": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", + "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", + "dev": true + }, + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", + "dev": true + }, + "any-observable": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/any-observable/-/any-observable-0.3.0.tgz", + "integrity": "sha512-/FQM1EDkTsf63Ub2C6O7GuYFDsSXUwsaZDurV0np41ocwq0jthUAYCmhBX9f+KwlaCgIuWyr/4WlUQUBfKfZog==", + "dev": true + }, + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "dev": true, + "optional": true, + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + }, + "dependencies": { + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "optional": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + } + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + }, + "dependencies": { + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + } + } + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", + "dev": true + }, + "array-find-index": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", + "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=", + "dev": true + }, + "array-from": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/array-from/-/array-from-2.1.1.tgz", + "integrity": "sha1-z+nYwmYoudxa7MYqn12PHzUsEZU=", + "dev": true + }, + "array-ify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-ify/-/array-ify-1.0.0.tgz", + "integrity": "sha1-nlKHYrSpBmrRY6aWKjZEGOlibs4=", + "dev": true + }, + "array-includes": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", + "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", + "dev": true, + "requires": { + "define-properties": "^1.1.2", + "es-abstract": "^1.7.0" + } + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "dev": true, + "requires": { + "array-uniq": "^1.0.1" + } + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", + "dev": true + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", + "dev": true + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", + "dev": true + }, + "assertion-error": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", + "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", + "dev": true + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", + "dev": true + }, + "astral-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", + "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", + "dev": true + }, + "async": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.2.tgz", + "integrity": "sha512-H1qVYh1MYhEEFLsP97cVKqCGo7KfCyTt6uEWqsTBr9SO84oK9Uwbyd/yCW+6rKJLHksBNUVWZDAjfS+Ccx0Bbg==", + "requires": { + "lodash": "^4.17.11" + } + }, + "async-each": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", + "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==", + "dev": true, + "optional": true + }, + "atob": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", + "dev": true + }, + "babel-polyfill": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-polyfill/-/babel-polyfill-6.26.0.tgz", + "integrity": "sha1-N5k3q8Z9eJWXCtxiHyhM2WbPIVM=", + "dev": true, + "requires": { + "babel-runtime": "^6.26.0", + "core-js": "^2.5.0", + "regenerator-runtime": "^0.10.5" + }, + "dependencies": { + "regenerator-runtime": { + "version": "0.10.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz", + "integrity": "sha1-M2w+/BIgrc7dosn6tntaeVWjNlg=", + "dev": true + } + } + }, + "babel-runtime": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", + "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", + "dev": true, + "requires": { + "core-js": "^2.4.0", + "regenerator-runtime": "^0.11.0" + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "dev": true, + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "beeper": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/beeper/-/beeper-1.1.1.tgz", + "integrity": "sha1-5tXqjF2tABMEpwsiY4RH9pyy+Ak=", + "dev": true + }, + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", + "dev": true, + "optional": true + }, + "bluebird": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", + "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==", + "dev": true + }, + "body": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/body/-/body-5.1.0.tgz", + "integrity": "sha1-5LoM5BCkaTYyM2dgnstOZVMSUGk=", + "dev": true, + "requires": { + "continuable-cache": "^0.3.1", + "error": "^7.0.0", + "raw-body": "~1.1.0", + "safe-json-parse": "~1.0.1" + } + }, + "brace-expansion": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", + "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "dev": true, + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "browser-stdout": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", + "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", + "dev": true + }, + "browserslist": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.6.0.tgz", + "integrity": "sha512-Jk0YFwXBuMOOol8n6FhgkDzn3mY9PYLYGk29zybF05SbRTsMgPqmTNeQQhOghCxq5oFqAXE3u4sYddr4C0uRhg==", + "dev": true, + "requires": { + "caniuse-lite": "^1.0.30000967", + "electron-to-chromium": "^1.3.133", + "node-releases": "^1.1.19" + } + }, + "bson": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.1.tgz", + "integrity": "sha512-jCGVYLoYMHDkOsbwJZBCqwMHyH4c+wzgI9hG7Z6SZJRXWr+x58pdIbm2i9a/jFGCkRJqRUr8eoI7lDWa0hTkxg==", + "dev": true + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", + "dev": true + }, + "builtin-modules": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", + "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", + "dev": true + }, + "bytes": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", + "integrity": "sha1-NWnt6Lo0MV+rmcPpLLBMciDeH6g=", + "dev": true + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "dev": true, + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "cachedir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cachedir/-/cachedir-2.1.0.tgz", + "integrity": "sha512-xGBpPqoBvn3unBW7oxgb8aJn42K0m9m1/wyjmazah10Fq7bROGG3kRAE6OIyr3U3PIJUqGuebhCEdMk9OKJG0A==", + "dev": true + }, + "caller-callsite": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", + "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", + "dev": true, + "requires": { + "callsites": "^2.0.0" + }, + "dependencies": { + "callsites": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", + "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=", + "dev": true + } + } + }, + "caller-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", + "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", + "dev": true, + "requires": { + "caller-callsite": "^2.0.0" + } + }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + }, + "camelcase": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", + "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=", + "dev": true + }, + "camelcase-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", + "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", + "dev": true, + "requires": { + "camelcase": "^2.0.0", + "map-obj": "^1.0.0" + } + }, + "caniuse-lite": { + "version": "1.0.30000967", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000967.tgz", + "integrity": "sha512-rUBIbap+VJfxTzrM4akJ00lkvVb5/n5v3EGXfWzSH5zT8aJmGzjA8HWhJ4U6kCpzxozUSnB+yvAYDRPY6mRpgQ==", + "dev": true + }, + "chai": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", + "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", + "dev": true, + "requires": { + "assertion-error": "^1.1.0", + "check-error": "^1.0.2", + "deep-eql": "^3.0.1", + "get-func-name": "^2.0.0", + "pathval": "^1.1.0", + "type-detect": "^4.0.5" + } + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "dev": true, + "requires": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + } + }, + "chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", + "dev": true + }, + "check-error": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", + "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", + "dev": true + }, + "chokidar": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.5.tgz", + "integrity": "sha512-i0TprVWp+Kj4WRPtInjexJ8Q+BqTE909VpH8xVhXrJkoc5QC8VO9TryGOqTr+2hljzc1sC62t22h5tZePodM/A==", + "dev": true, + "optional": true, + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + } + }, + "ci-info": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", + "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", + "dev": true + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "cli": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cli/-/cli-1.0.1.tgz", + "integrity": "sha1-IoF1NPJL+klQw01TLUjsvGIbjBQ=", + "dev": true, + "requires": { + "exit": "0.1.2", + "glob": "^7.1.1" + }, + "dependencies": { + "glob": { + "version": "7.1.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", + "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + } + } + }, + "cli-cursor": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", + "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", + "dev": true, + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "cli-truncate": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-0.2.1.tgz", + "integrity": "sha1-nxXPuwcFAFNpIWxiasfQWrkN1XQ=", + "dev": true, + "requires": { + "slice-ansi": "0.0.4", + "string-width": "^1.0.1" + }, + "dependencies": { + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "slice-ansi": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-0.0.4.tgz", + "integrity": "sha1-7b+JA/ZvfOL46v1s7tZeJkyDGzU=", + "dev": true + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + } + } + }, + "cli-width": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", + "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", + "dev": true + }, + "cliui": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", + "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", + "dev": true, + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0", + "wrap-ansi": "^2.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", + "dev": true + }, + "coffeescript": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/coffeescript/-/coffeescript-1.10.0.tgz", + "integrity": "sha1-56qDAZF+9iGzXYo580jc3R234z4=", + "dev": true + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "dev": true, + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "colors": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", + "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=", + "dev": true + }, + "commander": { + "version": "2.20.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz", + "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==", + "dev": true + }, + "commitizen": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/commitizen/-/commitizen-3.1.1.tgz", + "integrity": "sha512-n5pnG8sNM5a3dS3Kkh3rYr+hFdPWZlqV6pfz6KGLmWV/gsIiTqAwhTgFKkcF/paKUpfIMp0x4YZlD0xLBNTW9g==", + "dev": true, + "requires": { + "cachedir": "2.1.0", + "cz-conventional-changelog": "2.1.0", + "dedent": "0.7.0", + "detect-indent": "^5.0.0", + "find-node-modules": "2.0.0", + "find-root": "1.1.0", + "fs-extra": "^7.0.0", + "glob": "7.1.3", + "inquirer": "6.2.0", + "is-utf8": "^0.2.1", + "lodash": "4.17.11", + "minimist": "1.2.0", + "shelljs": "0.7.6", + "strip-bom": "3.0.0", + "strip-json-comments": "2.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "glob": { + "version": "7.1.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", + "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "inquirer": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.0.tgz", + "integrity": "sha512-QIEQG4YyQ2UYZGDC4srMZ7BjHOmNk1lR2JQj5UknBapklm6WHA+VVH7N+sUdX3A7NeCfGF8o4X1S3Ao7nAcIeg==", + "dev": true, + "requires": { + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.0", + "cli-cursor": "^2.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.0", + "figures": "^2.0.0", + "lodash": "^4.17.10", + "mute-stream": "0.0.7", + "run-async": "^2.2.0", + "rxjs": "^6.1.0", + "string-width": "^2.1.0", + "strip-ansi": "^4.0.0", + "through": "^2.3.6" + } + }, + "shelljs": { + "version": "0.7.6", + "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.7.6.tgz", + "integrity": "sha1-N5zM+1a5HIYB5HkzVutTgpJN6a0=", + "dev": true, + "requires": { + "glob": "^7.0.0", + "interpret": "^1.0.0", + "rechoir": "^0.6.2" + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", + "dev": true + }, + "compare-func": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/compare-func/-/compare-func-1.3.2.tgz", + "integrity": "sha1-md0LpFfh+bxyKxLAjsM+6rMfpkg=", + "dev": true, + "requires": { + "array-ify": "^1.0.0", + "dot-prop": "^3.0.0" + } + }, + "component-emitter": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", + "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "config-chain": { + "version": "1.1.12", + "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.12.tgz", + "integrity": "sha512-a1eOIcu8+7lUInge4Rpf/n4Krkf3Dd9lqhljRzII1/Zno/kRtUWnznPO3jOKBmTEktkt3fkxisUcivoj0ebzoA==", + "dev": true, + "requires": { + "ini": "^1.3.4", + "proto-list": "~1.2.1" + } + }, + "console-browserify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", + "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", + "dev": true, + "requires": { + "date-now": "^0.1.4" + } + }, + "contains-path": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", + "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", + "dev": true + }, + "continuable-cache": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/continuable-cache/-/continuable-cache-0.3.1.tgz", + "integrity": "sha1-vXJ6f67XfnH/OYWskzUakSczrQ8=", + "dev": true + }, + "conventional-changelog-angular": { + "version": "1.6.6", + "resolved": "https://registry.npmjs.org/conventional-changelog-angular/-/conventional-changelog-angular-1.6.6.tgz", + "integrity": "sha512-suQnFSqCxRwyBxY68pYTsFkG0taIdinHLNEAX5ivtw8bCRnIgnpvcHmlR/yjUyZIrNPYAoXlY1WiEKWgSE4BNg==", + "dev": true, + "requires": { + "compare-func": "^1.3.1", + "q": "^1.5.1" + } + }, + "conventional-commit-types": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/conventional-commit-types/-/conventional-commit-types-2.1.1.tgz", + "integrity": "sha512-0Ts+fEdmjqYDOQ1yZ+LNgdSPO335XZw9qC10M7CxtLP3nIMGmeMhmkM8Taffa4+MXN13bRPlp0CtH+QfOzKTzw==", + "dev": true + }, + "conventional-commits-parser": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/conventional-commits-parser/-/conventional-commits-parser-2.1.7.tgz", + "integrity": "sha512-BoMaddIEJ6B4QVMSDu9IkVImlGOSGA1I2BQyOZHeLQ6qVOJLcLKn97+fL6dGbzWEiqDzfH4OkcveULmeq2MHFQ==", + "dev": true, + "requires": { + "JSONStream": "^1.0.4", + "is-text-path": "^1.0.0", + "lodash": "^4.2.1", + "meow": "^4.0.0", + "split2": "^2.0.0", + "through2": "^2.0.0", + "trim-off-newlines": "^1.0.0" + }, + "dependencies": { + "camelcase": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", + "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", + "dev": true + }, + "camelcase-keys": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-4.2.0.tgz", + "integrity": "sha1-oqpfsa9oh1glnDLBQUJteJI7m3c=", + "dev": true, + "requires": { + "camelcase": "^4.1.0", + "map-obj": "^2.0.0", + "quick-lru": "^1.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "indent-string": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", + "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", + "dev": true + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "map-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-2.0.0.tgz", + "integrity": "sha1-plzSkIepJZi4eRJXpSPgISIqwfk=", + "dev": true + }, + "meow": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/meow/-/meow-4.0.1.tgz", + "integrity": "sha512-xcSBHD5Z86zaOc+781KrupuHAzeGXSLtiAOmBsiLDiPSaYSB6hdew2ng9EBAnZ62jagG9MHAOdxpDi/lWBFJ/A==", + "dev": true, + "requires": { + "camelcase-keys": "^4.0.0", + "decamelize-keys": "^1.0.0", + "loud-rejection": "^1.0.0", + "minimist": "^1.1.3", + "minimist-options": "^3.0.1", + "normalize-package-data": "^2.3.4", + "read-pkg-up": "^3.0.0", + "redent": "^2.0.0", + "trim-newlines": "^2.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-3.0.0.tgz", + "integrity": "sha1-PtSWaF26D4/hGNBpHcUfSh/5bwc=", + "dev": true, + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^3.0.0" + } + }, + "redent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-2.0.0.tgz", + "integrity": "sha1-wbIAe0LVfrE4kHmzyDM2OdXhzKo=", + "dev": true, + "requires": { + "indent-string": "^3.0.0", + "strip-indent": "^2.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "strip-indent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-2.0.0.tgz", + "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", + "dev": true + }, + "trim-newlines": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-2.0.0.tgz", + "integrity": "sha1-tAPQuRvlDDMd/EuC7s6yLD3hbSA=", + "dev": true + } + } + }, + "convert-source-map": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.6.0.tgz", + "integrity": "sha512-eFu7XigvxdZ1ETfbgPBohgyQ/Z++C0eEhTor0qRwBw9unw+L0/6V8wkSuGgzdThkiS5lSpdptOQPD8Ak40a+7A==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.1" + } + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", + "dev": true + }, + "core-js": { + "version": "2.6.5", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.5.tgz", + "integrity": "sha512-klh/kDpwX8hryYL14M9w/xei6vrv6sE8gTHDG7/T/+SEovB/G4ejwcfE/CBzO6Edsu+OETZMZ3wcX/EjUkrl5A==", + "dev": true + }, + "core-js-compat": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.0.1.tgz", + "integrity": "sha512-2pC3e+Ht/1/gD7Sim/sqzvRplMiRnFQVlPpDVaHtY9l7zZP7knamr3VRD6NyGfHd84MrDC0tAM9ulNxYMW0T3g==", + "dev": true, + "requires": { + "browserslist": "^4.5.4", + "core-js": "3.0.1", + "core-js-pure": "3.0.1", + "semver": "^6.0.0" + }, + "dependencies": { + "core-js": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.0.1.tgz", + "integrity": "sha512-sco40rF+2KlE0ROMvydjkrVMMG1vYilP2ALoRXcYR4obqbYIuV3Bg+51GEDW+HF8n7NRA+iaA4qD0nD9lo9mew==", + "dev": true + }, + "semver": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.0.0.tgz", + "integrity": "sha512-0UewU+9rFapKFnlbirLi3byoOuhrSsli/z/ihNnvM24vgF+8sNBiI1LZPBSH9wJKUwaUbw+s3hToDLCXkrghrQ==", + "dev": true + } + } + }, + "core-js-pure": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.0.1.tgz", + "integrity": "sha512-mSxeQ6IghKW3MoyF4cz19GJ1cMm7761ON+WObSyLfTu/Jn3x7w4NwNFnrZxgl4MTSvYYepVLNuRtlB4loMwJ5g==", + "dev": true + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", + "dev": true + }, + "cosmiconfig": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.0.tgz", + "integrity": "sha512-nxt+Nfc3JAqf4WIWd0jXLjTJZmsPLrA9DDc4nRw2KFJQJK7DNooqSXrNI7tzLG50CF8axczly5UV929tBmh/7g==", + "dev": true, + "requires": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.0", + "parse-json": "^4.0.0" + }, + "dependencies": { + "import-fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", + "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", + "dev": true, + "requires": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "resolve-from": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", + "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=", + "dev": true + } + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "currently-unhandled": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", + "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", + "dev": true, + "requires": { + "array-find-index": "^1.0.1" + } + }, + "cz-conventional-changelog": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cz-conventional-changelog/-/cz-conventional-changelog-2.1.0.tgz", + "integrity": "sha1-L0vHOQ4yROTfKT5ro1Hkx0Cnx2Q=", + "dev": true, + "requires": { + "conventional-commit-types": "^2.0.0", + "lodash.map": "^4.5.1", + "longest": "^1.0.1", + "right-pad": "^1.0.1", + "word-wrap": "^1.0.3" + } + }, + "dargs": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/dargs/-/dargs-4.1.0.tgz", + "integrity": "sha1-A6nbtLXC8Tm/FK5T8LiipqhvThc=", + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "date-fns": { + "version": "1.30.1", + "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-1.30.1.tgz", + "integrity": "sha512-hBSVCvSmWC+QypYObzwGOd9wqdDpOt+0wl0KbU+R+uuZBS1jN8VsD1ss3irQDknRj5NvxiTF6oj/nDRnN/UQNw==", + "dev": true + }, + "date-now": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", + "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", + "dev": true + }, + "dateformat": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-1.0.12.tgz", + "integrity": "sha1-nxJLZ1lMk3/3BpMuSmQsyo27/uk=", + "dev": true, + "requires": { + "get-stdin": "^4.0.1", + "meow": "^3.3.0" + } + }, + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + }, + "dependencies": { + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", + "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" + } + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "decamelize-keys": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/decamelize-keys/-/decamelize-keys-1.1.0.tgz", + "integrity": "sha1-0XGoeTMlKAfrPLYdwcFEXQeN8tk=", + "dev": true, + "requires": { + "decamelize": "^1.1.0", + "map-obj": "^1.0.0" + } + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "dev": true + }, + "dedent": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", + "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", + "dev": true + }, + "deep-eql": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", + "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", + "dev": true, + "requires": { + "type-detect": "^4.0.0" + } + }, + "deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", + "dev": true + }, + "define-properties": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", + "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "dev": true, + "requires": { + "object-keys": "^1.0.12" + } + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "dev": true, + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "del": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/del/-/del-3.0.0.tgz", + "integrity": "sha1-U+z2mf/LyzljdpGrE7rxYIGXZuU=", + "dev": true, + "requires": { + "globby": "^6.1.0", + "is-path-cwd": "^1.0.0", + "is-path-in-cwd": "^1.0.0", + "p-map": "^1.1.1", + "pify": "^3.0.0", + "rimraf": "^2.2.8" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "detect-file": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-1.0.0.tgz", + "integrity": "sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc=", + "dev": true + }, + "detect-indent": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-5.0.0.tgz", + "integrity": "sha1-OHHMCmoALow+Wzz38zYmRnXwa50=", + "dev": true + }, + "diff": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", + "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", + "dev": true + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "dom-serializer": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.1.1.tgz", + "integrity": "sha512-l0IU0pPzLWSHBcieZbpOKgkIn3ts3vAh7ZuFyXNwJxJXk/c4Gwj9xaTJwIDVQCXawWD0qb3IzMGH5rglQaO0XA==", + "dev": true, + "requires": { + "domelementtype": "^1.3.0", + "entities": "^1.1.1" + }, + "dependencies": { + "entities": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", + "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==", + "dev": true + } + } + }, + "domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", + "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", + "dev": true + }, + "domhandler": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.3.0.tgz", + "integrity": "sha1-LeWaCCLVAn+r/28DLCsloqir5zg=", + "dev": true, + "requires": { + "domelementtype": "1" + } + }, + "domutils": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", + "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", + "dev": true, + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "dot-prop": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-3.0.0.tgz", + "integrity": "sha1-G3CK8JSknJoOfbyteQq6U52sEXc=", + "dev": true, + "requires": { + "is-obj": "^1.0.0" + } + }, + "dotenv": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-7.0.0.tgz", + "integrity": "sha512-M3NhsLbV1i6HuGzBUH8vXrtxOk+tWmzWKDMbAVSUp3Zsjm7ywFeuwrUXhmhQyRK1q5B5GGy7hcXPbj3bnfZg2g==" + }, + "editorconfig": { + "version": "0.15.3", + "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", + "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", + "dev": true, + "requires": { + "commander": "^2.19.0", + "lru-cache": "^4.1.5", + "semver": "^5.6.0", + "sigmund": "^1.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", + "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", + "dev": true + } + } + }, + "electron-to-chromium": { + "version": "1.3.133", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.133.tgz", + "integrity": "sha512-lyoC8aoqbbDqsprb6aPdt9n3DpOZZzdz/T4IZKsR0/dkZIxnJVUjjcpOSwA66jPRIOyDAamCTAUqweU05kKNSg==", + "dev": true + }, + "elegant-spinner": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/elegant-spinner/-/elegant-spinner-1.0.1.tgz", + "integrity": "sha1-2wQ1IcldfjA/2PNFvtwzSc+wcp4=", + "dev": true + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", + "dev": true + }, + "end-of-stream": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", + "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", + "requires": { + "once": "^1.4.0" + } + }, + "entities": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.0.0.tgz", + "integrity": "sha1-sph6o4ITR/zeZCsk/fyeT7cSvyY=", + "dev": true + }, + "error": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/error/-/error-7.0.2.tgz", + "integrity": "sha1-pfdf/02ZJhJt2sDqXcOOaJFTywI=", + "dev": true, + "requires": { + "string-template": "~0.2.1", + "xtend": "~4.0.0" + } + }, + "error-ex": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", + "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.13.0", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", + "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", + "dev": true, + "requires": { + "es-to-primitive": "^1.2.0", + "function-bind": "^1.1.1", + "has": "^1.0.3", + "is-callable": "^1.1.4", + "is-regex": "^1.0.4", + "object-keys": "^1.0.12" + } + }, + "es-to-primitive": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", + "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", + "dev": true, + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "eslint": { + "version": "5.16.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz", + "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "ajv": "^6.9.1", + "chalk": "^2.1.0", + "cross-spawn": "^6.0.5", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "eslint-scope": "^4.0.3", + "eslint-utils": "^1.3.1", + "eslint-visitor-keys": "^1.0.0", + "espree": "^5.0.1", + "esquery": "^1.0.1", + "esutils": "^2.0.2", + "file-entry-cache": "^5.0.1", + "functional-red-black-tree": "^1.0.1", + "glob": "^7.1.2", + "globals": "^11.7.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "inquirer": "^6.2.2", + "js-yaml": "^3.13.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.3.0", + "lodash": "^4.17.11", + "minimatch": "^3.0.4", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "optionator": "^0.8.2", + "path-is-inside": "^1.0.2", + "progress": "^2.0.0", + "regexpp": "^2.0.1", + "semver": "^5.5.1", + "strip-ansi": "^4.0.0", + "strip-json-comments": "^2.0.1", + "table": "^5.2.3", + "text-table": "^0.2.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "glob": { + "version": "7.1.4", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", + "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "semver": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", + "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", + "dev": true + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "eslint-config-airbnb-base": { + "version": "13.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.1.0.tgz", + "integrity": "sha512-XWwQtf3U3zIoKO1BbHh6aUhJZQweOwSt4c2JrPDg9FP3Ltv3+YfEv7jIDB8275tVnO/qOHbfuYg3kzw6Je7uWw==", + "dev": true, + "requires": { + "eslint-restricted-globals": "^0.1.1", + "object.assign": "^4.1.0", + "object.entries": "^1.0.4" + } + }, + "eslint-config-prettier": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-4.2.0.tgz", + "integrity": "sha512-y0uWc/FRfrHhpPZCYflWC8aE0KRJRY04rdZVfl8cL3sEZmOYyaBdhdlQPjKZBnuRMyLVK+JUZr7HaZFClQiH4w==", + "dev": true, + "requires": { + "get-stdin": "^6.0.0" + }, + "dependencies": { + "get-stdin": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", + "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", + "dev": true + } + } + }, + "eslint-import-resolver-node": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", + "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", + "dev": true, + "requires": { + "debug": "^2.6.9", + "resolve": "^1.5.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "resolve": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.1.tgz", + "integrity": "sha512-KuIe4mf++td/eFb6wkaPbMDnP6kObCaEtIDuHOUED6MNUo4K670KZUHuuvYPZDxNF0WVLw49n06M2m2dXphEzA==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + } + } + }, + "eslint-module-utils": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.0.tgz", + "integrity": "sha512-14tltLm38Eu3zS+mt0KvILC3q8jyIAH518MlG+HO0p+yK885Lb1UHTY/UgR91eOyGdmxAPb+OLoW4znqIT6Ndw==", + "dev": true, + "requires": { + "debug": "^2.6.8", + "pkg-dir": "^2.0.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "eslint-plugin-import": { + "version": "2.17.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.17.2.tgz", + "integrity": "sha512-m+cSVxM7oLsIpmwNn2WXTJoReOF9f/CtLMo7qOVmKd1KntBy0hEcuNZ3erTmWjx+DxRO0Zcrm5KwAvI9wHcV5g==", + "dev": true, + "requires": { + "array-includes": "^3.0.3", + "contains-path": "^0.1.0", + "debug": "^2.6.9", + "doctrine": "1.5.0", + "eslint-import-resolver-node": "^0.3.2", + "eslint-module-utils": "^2.4.0", + "has": "^1.0.3", + "lodash": "^4.17.11", + "minimatch": "^3.0.4", + "read-pkg-up": "^2.0.0", + "resolve": "^1.10.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "doctrine": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", + "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", + "dev": true, + "requires": { + "esutils": "^2.0.2", + "isarray": "^1.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + }, + "load-json-file": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", + "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^2.2.0", + "pify": "^2.0.0", + "strip-bom": "^3.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-type": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", + "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", + "dev": true, + "requires": { + "pify": "^2.0.0" + } + }, + "read-pkg": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", + "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", + "dev": true, + "requires": { + "load-json-file": "^2.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^2.0.0" + } + }, + "read-pkg-up": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", + "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", + "dev": true, + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^2.0.0" + } + }, + "resolve": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.1.tgz", + "integrity": "sha512-KuIe4mf++td/eFb6wkaPbMDnP6kObCaEtIDuHOUED6MNUo4K670KZUHuuvYPZDxNF0WVLw49n06M2m2dXphEzA==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + } + } + }, + "eslint-plugin-mocha": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-mocha/-/eslint-plugin-mocha-5.3.0.tgz", + "integrity": "sha512-3uwlJVLijjEmBeNyH60nzqgA1gacUWLUmcKV8PIGNvj1kwP/CTgAWQHn2ayyJVwziX+KETkr9opNwT1qD/RZ5A==", + "dev": true, + "requires": { + "ramda": "^0.26.1" + } + }, + "eslint-plugin-prettier": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.1.0.tgz", + "integrity": "sha512-XWX2yVuwVNLOUhQijAkXz+rMPPoCr7WFiAl8ig6I7Xn+pPVhDhzg4DxHpmbeb0iqjO9UronEA3Tb09ChnFVHHA==", + "dev": true, + "requires": { + "prettier-linter-helpers": "^1.0.0" + } + }, + "eslint-restricted-globals": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/eslint-restricted-globals/-/eslint-restricted-globals-0.1.1.tgz", + "integrity": "sha1-NfDVy8ZMLj7WLpO0saevBbp+1Nc=", + "dev": true + }, + "eslint-scope": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", + "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", + "dev": true, + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", + "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", + "dev": true + }, + "eslint-visitor-keys": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", + "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", + "dev": true + }, + "espree": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", + "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", + "dev": true, + "requires": { + "acorn": "^6.0.7", + "acorn-jsx": "^5.0.0", + "eslint-visitor-keys": "^1.0.0" + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esquery": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", + "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", + "dev": true, + "requires": { + "estraverse": "^4.0.0" + } + }, + "esrecurse": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", + "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", + "dev": true, + "requires": { + "estraverse": "^4.1.0" + } + }, + "estraverse": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", + "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", + "dev": true + }, + "esutils": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", + "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", + "dev": true + }, + "eventemitter2": { + "version": "0.4.14", + "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-0.4.14.tgz", + "integrity": "sha1-j2G3XN4BKy6esoTUVFWDtWQ7Yas=", + "dev": true + }, + "execa": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "requires": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "exit": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", + "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=", + "dev": true + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "dev": true, + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "expand-tilde": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-2.0.2.tgz", + "integrity": "sha1-l+gBqgUt8CRU3kawK/YhZCzchQI=", + "dev": true, + "requires": { + "homedir-polyfill": "^1.0.1" + } + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "dev": true, + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "external-editor": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", + "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", + "dev": true, + "requires": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "dev": true, + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "fast-deep-equal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", + "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", + "dev": true + }, + "fast-diff": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", + "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", + "dev": true + }, + "fast-json-stable-stringify": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", + "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", + "dev": true + }, + "faye-websocket": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", + "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", + "dev": true, + "requires": { + "websocket-driver": ">=0.5.1" + } + }, + "figures": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", + "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "file-entry-cache": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", + "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", + "dev": true, + "requires": { + "flat-cache": "^2.0.1" + } + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + }, + "dependencies": { + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + } + } + }, + "find-node-modules": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/find-node-modules/-/find-node-modules-2.0.0.tgz", + "integrity": "sha512-8MWIBRgJi/WpjjfVXumjPKCtmQ10B+fjx6zmSA+770GMJirLhWIzg8l763rhjl9xaeaHbnxPNRQKq2mgMhr+aw==", + "dev": true, + "requires": { + "findup-sync": "^3.0.0", + "merge": "^1.2.1" + }, + "dependencies": { + "findup-sync": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-3.0.0.tgz", + "integrity": "sha512-YbffarhcicEhOrm4CtrwdKBdCuz576RLdhJDsIfvNtxUuhdRet1qZcsMjqbePtAseKdAnDyM/IyXbu7PRPRLYg==", + "dev": true, + "requires": { + "detect-file": "^1.0.0", + "is-glob": "^4.0.0", + "micromatch": "^3.0.4", + "resolve-dir": "^1.0.1" + } + } + } + }, + "find-parent-dir": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/find-parent-dir/-/find-parent-dir-0.3.0.tgz", + "integrity": "sha1-M8RLQpqysvBkYpnF+fcY83b/jVQ=", + "dev": true + }, + "find-root": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", + "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==", + "dev": true + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "dev": true, + "requires": { + "path-exists": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "findup-sync": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-0.3.0.tgz", + "integrity": "sha1-N5MKpdgWt3fANEXhlmzGeQpMCxY=", + "dev": true, + "requires": { + "glob": "~5.0.0" + }, + "dependencies": { + "glob": { + "version": "5.0.15", + "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", + "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", + "dev": true, + "requires": { + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "2 || 3", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + } + } + }, + "flat": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", + "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", + "dev": true, + "requires": { + "is-buffer": "~2.0.3" + } + }, + "flat-cache": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", + "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", + "dev": true, + "requires": { + "flatted": "^2.0.0", + "rimraf": "2.6.3", + "write": "1.0.3" + } + }, + "flatted": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", + "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", + "dev": true + }, + "fn-name": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fn-name/-/fn-name-2.0.1.tgz", + "integrity": "sha1-UhTXU3pNBqSjAcDMJi/rhBiAAuc=", + "dev": true + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "dev": true, + "requires": { + "map-cache": "^0.2.2" + } + }, + "fs-extra": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", + "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs-readdir-recursive": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz", + "integrity": "sha512-GNanXlVr2pf02+sPN40XN8HG+ePaNcvM0q5mZBd668Obwb0yD5GiUbZOFgwn8kGMY6I3mdyDJzieUy3PTYyTRA==", + "dev": true + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "fsevents": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz", + "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==", + "dev": true, + "optional": true, + "requires": { + "nan": "^2.12.1", + "node-pre-gyp": "^0.12.0" + }, + "dependencies": { + "abbrev": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "aproba": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + } + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "chownr": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "dev": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "debug": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "ms": "^2.1.1" + } + }, + "deep-extend": { + "version": "0.6.0", + "bundled": true, + "dev": true, + "optional": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.3", + "bundled": true, + "dev": true, + "optional": true + }, + "fs-minipass": { + "version": "1.2.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minipass": "^2.2.1" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + } + }, + "glob": { + "version": "7.1.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "iconv-lite": { + "version": "0.4.24", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "ignore-walk": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minimatch": "^3.0.4" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true, + "dev": true + }, + "ini": { + "version": "1.3.5", + "bundled": true, + "dev": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "dev": true + }, + "minipass": { + "version": "2.3.5", + "bundled": true, + "dev": true, + "requires": { + "safe-buffer": "^5.1.2", + "yallist": "^3.0.0" + } + }, + "minizlib": { + "version": "1.2.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "minipass": "^2.2.1" + } + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "needle": { + "version": "2.3.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "debug": "^4.1.0", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + } + }, + "node-pre-gyp": { + "version": "0.12.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "detect-libc": "^1.0.2", + "mkdirp": "^0.5.1", + "needle": "^2.2.1", + "nopt": "^4.0.1", + "npm-packlist": "^1.1.6", + "npmlog": "^4.0.2", + "rc": "^1.2.7", + "rimraf": "^2.6.1", + "semver": "^5.3.0", + "tar": "^4" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "abbrev": "1", + "osenv": "^0.1.4" + } + }, + "npm-bundled": { + "version": "1.0.6", + "bundled": true, + "dev": true, + "optional": true + }, + "npm-packlist": { + "version": "1.4.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "ignore-walk": "^3.0.1", + "npm-bundled": "^1.0.1" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "osenv": { + "version": "0.1.5", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "process-nextick-args": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "rc": { + "version": "1.2.8", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "deep-extend": "^0.6.0", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.3.6", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rimraf": { + "version": "2.6.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-buffer": { + "version": "5.1.2", + "bundled": true, + "dev": true + }, + "safer-buffer": { + "version": "2.1.2", + "bundled": true, + "dev": true, + "optional": true + }, + "sax": { + "version": "1.2.4", + "bundled": true, + "dev": true, + "optional": true + }, + "semver": { + "version": "5.7.0", + "bundled": true, + "dev": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "string_decoder": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "tar": { + "version": "4.4.8", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "chownr": "^1.1.1", + "fs-minipass": "^1.2.5", + "minipass": "^2.3.4", + "minizlib": "^1.1.1", + "mkdirp": "^0.5.0", + "safe-buffer": "^5.1.2", + "yallist": "^3.0.2" + } + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "wide-align": { + "version": "1.1.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "string-width": "^1.0.2 || 2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "yallist": { + "version": "3.0.3", + "bundled": true, + "dev": true + } + } + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", + "dev": true + }, + "g-status": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/g-status/-/g-status-2.0.2.tgz", + "integrity": "sha512-kQoE9qH+T1AHKgSSD0Hkv98bobE90ILQcXAF4wvGgsr7uFqNvwmh8j+Lq3l0RVt3E3HjSbv2B9biEGcEtpHLCA==", + "dev": true, + "requires": { + "arrify": "^1.0.1", + "matcher": "^1.0.0", + "simple-git": "^1.85.0" + } + }, + "gaze": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.2.tgz", + "integrity": "sha1-hHIkZ3rbiHDWeSV+0ziP22HkAQU=", + "dev": true, + "requires": { + "globule": "^1.0.0" + } + }, + "generate-changelog": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/generate-changelog/-/generate-changelog-1.7.1.tgz", + "integrity": "sha512-f57zId4iD0AVRyjHHH6SwOdevrW+5ikjr6ooqlzUf7Z27DBW4BZvWZtlXmy+LShf5C52aFBCvKVwd86ZA56ObQ==", + "dev": true, + "requires": { + "bluebird": "^3.0.6", + "commander": "^2.9.0", + "github-url-from-git": "^1.4.0" + } + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true + }, + "get-func-name": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", + "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", + "dev": true + }, + "get-own-enumerable-property-symbols": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.0.tgz", + "integrity": "sha512-CIJYJC4GGF06TakLg8z4GQKvDsx9EMspVxOYih7LerEL/WosUnFIww45CGfxfeKHqlg3twgUrYRT1O3WQqjGCg==", + "dev": true + }, + "get-stdin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", + "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4=", + "dev": true + }, + "get-stream": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", + "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "requires": { + "pump": "^3.0.0" + } + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", + "dev": true + }, + "getobject": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/getobject/-/getobject-0.1.0.tgz", + "integrity": "sha1-BHpEl4n6Fg0Bj1SG7ZEyC27HiFw=", + "dev": true + }, + "git-raw-commits": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/git-raw-commits/-/git-raw-commits-1.3.6.tgz", + "integrity": "sha512-svsK26tQ8vEKnMshTDatSIQSMDdz8CxIIqKsvPqbtV23Etmw6VNaFAitu8zwZ0VrOne7FztwPyRLxK7/DIUTQg==", + "dev": true, + "requires": { + "dargs": "^4.0.1", + "lodash.template": "^4.0.2", + "meow": "^4.0.0", + "split2": "^2.0.0", + "through2": "^2.0.0" + }, + "dependencies": { + "camelcase": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", + "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", + "dev": true + }, + "camelcase-keys": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-4.2.0.tgz", + "integrity": "sha1-oqpfsa9oh1glnDLBQUJteJI7m3c=", + "dev": true, + "requires": { + "camelcase": "^4.1.0", + "map-obj": "^2.0.0", + "quick-lru": "^1.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "indent-string": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", + "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", + "dev": true + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "map-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-2.0.0.tgz", + "integrity": "sha1-plzSkIepJZi4eRJXpSPgISIqwfk=", + "dev": true + }, + "meow": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/meow/-/meow-4.0.1.tgz", + "integrity": "sha512-xcSBHD5Z86zaOc+781KrupuHAzeGXSLtiAOmBsiLDiPSaYSB6hdew2ng9EBAnZ62jagG9MHAOdxpDi/lWBFJ/A==", + "dev": true, + "requires": { + "camelcase-keys": "^4.0.0", + "decamelize-keys": "^1.0.0", + "loud-rejection": "^1.0.0", + "minimist": "^1.1.3", + "minimist-options": "^3.0.1", + "normalize-package-data": "^2.3.4", + "read-pkg-up": "^3.0.0", + "redent": "^2.0.0", + "trim-newlines": "^2.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-3.0.0.tgz", + "integrity": "sha1-PtSWaF26D4/hGNBpHcUfSh/5bwc=", + "dev": true, + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^3.0.0" + } + }, + "redent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-2.0.0.tgz", + "integrity": "sha1-wbIAe0LVfrE4kHmzyDM2OdXhzKo=", + "dev": true, + "requires": { + "indent-string": "^3.0.0", + "strip-indent": "^2.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "strip-indent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-2.0.0.tgz", + "integrity": "sha1-XvjbKV0B5u1sv3qrlpmNeCJSe2g=", + "dev": true + }, + "trim-newlines": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-2.0.0.tgz", + "integrity": "sha1-tAPQuRvlDDMd/EuC7s6yLD3hbSA=", + "dev": true + } + } + }, + "github-url-from-git": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/github-url-from-git/-/github-url-from-git-1.5.0.tgz", + "integrity": "sha1-+YX+3MCpqledyI16/waNVcxiUaA=", + "dev": true + }, + "glob": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.0.6.tgz", + "integrity": "sha1-IRuvr0nlJbjNkyYNFKsTYVKz9Xo=", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.2", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "optional": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "optional": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "global-dirs": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz", + "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=", + "dev": true, + "requires": { + "ini": "^1.3.4" + } }, - "get-stdin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", - "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4=", - "dev": true + "global-modules": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", + "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", + "dev": true, + "requires": { + "global-prefix": "^1.0.1", + "is-windows": "^1.0.1", + "resolve-dir": "^1.0.0" + } }, - "get-stream": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", - "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "global-prefix": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-1.0.2.tgz", + "integrity": "sha1-2/dDxsFJklk8ZVVoy2btMsASLr4=", + "dev": true, "requires": { - "pump": "^3.0.0" + "expand-tilde": "^2.0.2", + "homedir-polyfill": "^1.0.1", + "ini": "^1.3.4", + "is-windows": "^1.0.1", + "which": "^1.2.14" } }, - "getobject": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/getobject/-/getobject-0.1.0.tgz", - "integrity": "sha1-BHpEl4n6Fg0Bj1SG7ZEyC27HiFw=", + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", "dev": true }, - "glob": { - "version": "7.0.6", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.0.6.tgz", - "integrity": "sha1-IRuvr0nlJbjNkyYNFKsTYVKz9Xo=", + "globby": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", + "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", "dev": true, "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.2", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" } }, "globule": { @@ -1200,12 +5376,59 @@ "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", "dev": true }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "dev": true, + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, "he": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", "dev": true }, + "homedir-polyfill": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz", + "integrity": "sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==", + "dev": true, + "requires": { + "parse-passwd": "^1.0.0" + } + }, "hooker": { "version": "0.2.3", "resolved": "https://registry.npmjs.org/hooker/-/hooker-0.2.3.tgz", @@ -1236,6 +5459,93 @@ "integrity": "sha1-uc+/Sizybw/DSxDKFImid3HjR08=", "dev": true }, + "husky": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/husky/-/husky-2.3.0.tgz", + "integrity": "sha512-A/ZQSEILoq+mQM3yC3RIBSaw1bYXdkKnyyKVSUiJl+iBjVZc5LQEXdGY1ZjrDxC4IzfRPiJ0IqzEQGCN5TQa/A==", + "dev": true, + "requires": { + "cosmiconfig": "^5.2.0", + "execa": "^1.0.0", + "find-up": "^3.0.0", + "get-stdin": "^7.0.0", + "is-ci": "^2.0.0", + "pkg-dir": "^4.1.0", + "please-upgrade-node": "^3.1.1", + "read-pkg": "^5.1.1", + "run-node": "^1.0.0", + "slash": "^3.0.0" + }, + "dependencies": { + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "get-stdin": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-7.0.0.tgz", + "integrity": "sha512-zRKcywvrXlXsA0v0i9Io4KDRaAw7+a1ZpjRwl9Wox8PFlVCCHra7E9c4kqXCoCM9nR5tBkaTTZRBoCm60bFqTQ==", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "pkg-dir": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.1.0.tgz", + "integrity": "sha512-55k9QN4saZ8q518lE6EFgYiu95u3BWkSajCifhdQjvLvmr8IpnRbhI+UGpWJQfa0KzDguHeeWT1ccO1PmkOi3A==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "read-pkg": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.1.1.tgz", + "integrity": "sha512-dFcTLQi6BZ+aFUaICg7er+/usEoqFdQxiEBsEMNGoipenihtxxtdrQuBXvyANCEI8VuUIVYFgeHGx9sLLvim4w==", + "dev": true, + "requires": { + "@types/normalize-package-data": "^2.4.0", + "normalize-package-data": "^2.5.0", + "parse-json": "^4.0.0", + "type-fest": "^0.4.1" + } + }, + "resolve": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.1.tgz", + "integrity": "sha512-KuIe4mf++td/eFb6wkaPbMDnP6kObCaEtIDuHOUED6MNUo4K670KZUHuuvYPZDxNF0WVLw49n06M2m2dXphEzA==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + } + } + }, "iconv-lite": { "version": "0.4.24", "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", @@ -1245,6 +5555,36 @@ "safer-buffer": ">= 2.1.2 < 3" } }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true + }, + "import-fresh": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", + "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "dependencies": { + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + } + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true + }, "indent-string": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz", @@ -1281,6 +5621,88 @@ "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", "dev": true }, + "inquirer": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.3.1.tgz", + "integrity": "sha512-MmL624rfkFt4TG9y/Jvmt8vdmOo836U7Y0Hxr2aFk3RelZEGX4Igk0KabWrcaaZaTv9uzglOqWh1Vly+FAWAXA==", + "dev": true, + "requires": { + "ansi-escapes": "^3.2.0", + "chalk": "^2.4.2", + "cli-cursor": "^2.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.3", + "figures": "^2.0.0", + "lodash": "^4.17.11", + "mute-stream": "0.0.7", + "run-async": "^2.2.0", + "rxjs": "^6.4.0", + "string-width": "^2.1.0", + "strip-ansi": "^5.1.0", + "through": "^2.3.6" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "interpret": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.2.0.tgz", + "integrity": "sha512-mT34yGKMNceBQUoVn7iCDKDntA7SC6gycMAWzGx1z/CMCTV7b2AAtXlo3nRyHZ1FelRkQbQjprHSYGwzLtkVbw==", + "dev": true + }, + "invariant": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", + "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", + "dev": true, + "requires": { + "loose-envify": "^1.0.0" + } + }, "invert-kv": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", @@ -1292,11 +5714,47 @@ "integrity": "sha1-LKmwM2UREYVUEvFr5dd8YqRYp2Y=", "dev": true }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, "is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "dev": true, + "optional": true, + "requires": { + "binary-extensions": "^1.0.0" + } + }, "is-buffer": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.3.tgz", @@ -1312,16 +5770,88 @@ "builtin-modules": "^1.0.0" } }, - "is-callable": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", - "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", + "is-callable": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", + "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", + "dev": true + }, + "is-ci": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", + "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", + "dev": true, + "requires": { + "ci-info": "^2.0.0" + } + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-date-object": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", + "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", + "dev": true + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true + } + } + }, + "is-directory": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", + "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", "dev": true }, - "is-date-object": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", - "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", "dev": true }, "is-finite": { @@ -1339,6 +5869,101 @@ "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", "dev": true }, + "is-glob": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", + "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", + "dev": true + }, + "is-observable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-observable/-/is-observable-1.1.0.tgz", + "integrity": "sha512-NqCa4Sa2d+u7BWc6CukaObG3Fh+CU9bvixbpcXYhy2VvYS7vVGIdAgnIS5Ks3A/cqk4rebLJ9s8zBstT2aKnIA==", + "dev": true, + "requires": { + "symbol-observable": "^1.1.0" + } + }, + "is-path-cwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", + "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", + "dev": true + }, + "is-path-in-cwd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz", + "integrity": "sha512-FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ==", + "dev": true, + "requires": { + "is-path-inside": "^1.0.0" + } + }, + "is-path-inside": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", + "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", + "dev": true, + "requires": { + "path-is-inside": "^1.0.1" + } + }, + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", + "dev": true + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", + "dev": true + }, "is-regex": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", @@ -1348,6 +5973,12 @@ "has": "^1.0.1" } }, + "is-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", + "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=", + "dev": true + }, "is-stream": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", @@ -1362,12 +5993,27 @@ "has-symbols": "^1.0.0" } }, + "is-text-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-text-path/-/is-text-path-1.0.1.tgz", + "integrity": "sha1-Thqg+1G/vLPpJogAE5cgLBd1tm4=", + "dev": true, + "requires": { + "text-extensions": "^1.0.0" + } + }, "is-utf8": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", "dev": true }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true + }, "isarray": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", @@ -1379,6 +6025,12 @@ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true + }, "js-beautify": { "version": "1.10.0", "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.10.0.tgz", @@ -1418,6 +6070,18 @@ } } }, + "js-levenshtein": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/js-levenshtein/-/js-levenshtein-1.1.6.tgz", + "integrity": "sha512-X2BB11YZtrRqY4EnQcLX5Rh373zbK4alC1FW7D7MBhL2gtcC17cTnr6DmfHZeS0s2rTHjUTMMHfG7gO8SSdw+g==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, "js-yaml": { "version": "3.13.1", "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", @@ -1428,6 +6092,12 @@ "esprima": "^4.0.0" } }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true + }, "jshint": { "version": "2.10.2", "resolved": "https://registry.npmjs.org/jshint/-/jshint-2.10.2.tgz", @@ -1463,6 +6133,42 @@ "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", + "dev": true + }, + "json5": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.0.tgz", + "integrity": "sha512-8Mh9h6xViijj36g7Dxi+Y4S6hNGV96vcJZr/SrlHh1LR/pEn/8j/+qIBbs44YKl69Lrfctp4QD+AdWLTMqEZAQ==", + "dev": true, + "requires": { + "minimist": "^1.2.0" + } + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "jsonparse": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz", + "integrity": "sha1-P02uSpH6wxX3EGL4UhzCOfE2YoA=", + "dev": true + }, "just-extend": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/just-extend/-/just-extend-4.0.2.tgz", @@ -1475,6 +6181,12 @@ "integrity": "sha512-6hHxsp9e6zQU8nXsP+02HGWXwTkOEw6IROhF2ZA28cYbUk4eJ6QbtZvdqZOdD9YPKghG3apk5eOCvs+tLl3lRg==", "dev": true }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true + }, "lcid": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", @@ -1483,6 +6195,218 @@ "invert-kv": "^2.0.0" } }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "dev": true, + "requires": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + } + }, + "lint-staged": { + "version": "8.1.6", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-8.1.6.tgz", + "integrity": "sha512-QT13AniHN6swAtTjsrzxOfE4TVCiQ39xESwLmjGVNCMMZ/PK5aopwvbxLrzw+Zf9OxM3cQG6WCx9lceLzETOnQ==", + "dev": true, + "requires": { + "chalk": "^2.3.1", + "commander": "^2.14.1", + "cosmiconfig": "^5.0.2", + "debug": "^3.1.0", + "dedent": "^0.7.0", + "del": "^3.0.0", + "execa": "^1.0.0", + "find-parent-dir": "^0.3.0", + "g-status": "^2.0.2", + "is-glob": "^4.0.0", + "is-windows": "^1.0.2", + "listr": "^0.14.2", + "listr-update-renderer": "^0.5.0", + "lodash": "^4.17.11", + "log-symbols": "^2.2.0", + "micromatch": "^3.1.8", + "npm-which": "^3.0.1", + "p-map": "^1.1.1", + "path-is-inside": "^1.0.2", + "pify": "^3.0.0", + "please-upgrade-node": "^3.0.2", + "staged-git-files": "1.1.2", + "string-argv": "^0.0.2", + "stringify-object": "^3.2.2", + "yup": "^0.27.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "log-symbols": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", + "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", + "dev": true, + "requires": { + "chalk": "^2.0.1" + } + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", + "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", + "dev": true + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "listr": { + "version": "0.14.3", + "resolved": "https://registry.npmjs.org/listr/-/listr-0.14.3.tgz", + "integrity": "sha512-RmAl7su35BFd/xoMamRjpIE4j3v+L28o8CT5YhAXQJm1fD+1l9ngXY8JAQRJ+tFK2i5njvi0iRUKV09vPwA0iA==", + "dev": true, + "requires": { + "@samverschueren/stream-to-observable": "^0.3.0", + "is-observable": "^1.1.0", + "is-promise": "^2.1.0", + "is-stream": "^1.1.0", + "listr-silent-renderer": "^1.1.1", + "listr-update-renderer": "^0.5.0", + "listr-verbose-renderer": "^0.5.0", + "p-map": "^2.0.0", + "rxjs": "^6.3.3" + }, + "dependencies": { + "p-map": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", + "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==", + "dev": true + } + } + }, + "listr-silent-renderer": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/listr-silent-renderer/-/listr-silent-renderer-1.1.1.tgz", + "integrity": "sha1-kktaN1cVN3C/Go4/v3S4u/P5JC4=", + "dev": true + }, + "listr-update-renderer": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/listr-update-renderer/-/listr-update-renderer-0.5.0.tgz", + "integrity": "sha512-tKRsZpKz8GSGqoI/+caPmfrypiaq+OQCbd+CovEC24uk1h952lVj5sC7SqyFUm+OaJ5HN/a1YLt5cit2FMNsFA==", + "dev": true, + "requires": { + "chalk": "^1.1.3", + "cli-truncate": "^0.2.1", + "elegant-spinner": "^1.0.1", + "figures": "^1.7.0", + "indent-string": "^3.0.0", + "log-symbols": "^1.0.2", + "log-update": "^2.3.0", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "figures": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-1.7.0.tgz", + "integrity": "sha1-y+Hjr/zxzUS4DK3+0o3Hk6lwHS4=", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.5", + "object-assign": "^4.1.0" + } + }, + "indent-string": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", + "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", + "dev": true + } + } + }, + "listr-verbose-renderer": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/listr-verbose-renderer/-/listr-verbose-renderer-0.5.0.tgz", + "integrity": "sha512-04PDPqSlsqIOaaaGZ+41vq5FejI9auqTInicFRndCBgE3bXG8D6W1I+mWhk+1nqbHmyhla/6BUrd5OSiHwKRXw==", + "dev": true, + "requires": { + "chalk": "^2.4.1", + "cli-cursor": "^2.1.0", + "date-fns": "^1.27.2", + "figures": "^2.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, "livereload-js": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/livereload-js/-/livereload-js-2.3.0.tgz", @@ -1525,13 +6449,82 @@ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" }, + "lodash._reinterpolate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", + "integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0=", + "dev": true + }, + "lodash.map": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/lodash.map/-/lodash.map-4.6.0.tgz", + "integrity": "sha1-dx7Hg540c9nEzeKLGTlMNWL09tM=", + "dev": true + }, + "lodash.template": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/lodash.template/-/lodash.template-4.4.0.tgz", + "integrity": "sha1-5zoDhcg1VZF0bgILmWecaQ5o+6A=", + "dev": true, + "requires": { + "lodash._reinterpolate": "~3.0.0", + "lodash.templatesettings": "^4.0.0" + } + }, + "lodash.templatesettings": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/lodash.templatesettings/-/lodash.templatesettings-4.1.0.tgz", + "integrity": "sha1-K01OlbpEDZFf8IvImeRVNmZxMxY=", + "dev": true, + "requires": { + "lodash._reinterpolate": "~3.0.0" + } + }, "log-symbols": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-1.0.2.tgz", "integrity": "sha1-N2/3tY6jCGoPCfrMdGF+ylAeGhg=", "dev": true, "requires": { - "chalk": "^1.0.0" + "chalk": "^1.0.0" + } + }, + "log-update": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/log-update/-/log-update-2.3.0.tgz", + "integrity": "sha1-iDKP19HOeTiykoN0bwsbwSayRwg=", + "dev": true, + "requires": { + "ansi-escapes": "^3.0.0", + "cli-cursor": "^2.0.0", + "wrap-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + }, + "wrap-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-3.0.1.tgz", + "integrity": "sha1-KIoE2H7aXChuBg3+jxNc6NAH+Lo=", + "dev": true, + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0" + } + } } }, "lolex": { @@ -1540,6 +6533,21 @@ "integrity": "sha512-UHuOBZ5jjsKuzbB/gRNNW8Vg8f00Emgskdq2kvZxgBJCS0aqquAuXai/SkWORlKeZEiNQWZjFZOqIUcH9LqKCw==", "dev": true }, + "longest": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", + "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=", + "dev": true + }, + "loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "dev": true, + "requires": { + "js-tokens": "^3.0.0 || ^4.0.0" + } + }, "loud-rejection": { "version": "1.6.0", "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", @@ -1560,6 +6568,30 @@ "yallist": "^2.1.2" } }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "dependencies": { + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true + }, + "semver": { + "version": "5.7.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", + "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", + "dev": true + } + } + }, "map-age-cleaner": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", @@ -1568,12 +6600,36 @@ "p-defer": "^1.0.0" } }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", + "dev": true + }, "map-obj": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=", "dev": true }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "dev": true, + "requires": { + "object-visit": "^1.0.0" + } + }, + "matcher": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/matcher/-/matcher-1.1.1.tgz", + "integrity": "sha512-+BmqxWIubKTRKNWx/ahnCkk3mG8m7OturVlqq6HiojGJTd5hVYbgZm6WzcYPCoB+KBT4Vd6R7WSRG2OADNaCjg==", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.4" + } + }, "mem": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", @@ -1609,6 +6665,33 @@ "trim-newlines": "^1.0.0" } }, + "merge": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/merge/-/merge-1.2.1.tgz", + "integrity": "sha512-VjFo4P5Whtj4vsLzsYBu5ayHhoHJ0UqNm7ibvShmbmoz7tGi0vXaoJbGdB+GmDMLUdg8DpQXEIeVDAe8MaABvQ==", + "dev": true + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + } + }, "mimic-fn": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", @@ -1629,6 +6712,37 @@ "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", "dev": true }, + "minimist-options": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-3.0.2.tgz", + "integrity": "sha512-FyBrT/d0d4+uiZRbqznPXqw3IpZZG3gl3wKWiX784FycUKVwBt0uLBFkQrtE4tZOrgo78nZp2jnKz3L65T5LdQ==", + "dev": true, + "requires": { + "arrify": "^1.0.1", + "is-plain-obj": "^1.1.0" + } + }, + "mixin-deep": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", + "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", + "dev": true, + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, "mkdirp": { "version": "0.5.1", "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", @@ -1971,6 +7085,44 @@ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", "dev": true }, + "mute-stream": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", + "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", + "dev": true + }, + "nan": { + "version": "2.13.2", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.13.2.tgz", + "integrity": "sha512-TghvYc72wlMGMVMluVo9WRJc0mB8KxxF/gZ4YYFy7V2ZQX9l7rgbPg7vjS9mt6U5HXODVFVI2bOduCzwOMv/lw==", + "dev": true, + "optional": true + }, + "nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", + "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + } + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, "nice-try": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", @@ -2015,6 +7167,21 @@ } } }, + "node-modules-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz", + "integrity": "sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=", + "dev": true + }, + "node-releases": { + "version": "1.1.19", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.19.tgz", + "integrity": "sha512-SH/B4WwovHbulIALsQllAVwqZZD1kPmKCqrhGfR29dXjLAVZMHvBjD3S6nL9D/J9QkmZ1R92/0wCMDKXUUvyyA==", + "dev": true, + "requires": { + "semver": "^5.3.0" + } + }, "nopt": { "version": "3.0.6", "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", @@ -2036,6 +7203,22 @@ "validate-npm-package-license": "^3.0.1" } }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "optional": true + }, + "npm-path": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/npm-path/-/npm-path-2.0.4.tgz", + "integrity": "sha512-IFsj0R9C7ZdR5cP+ET342q77uSRdtWOlWpih5eC+lu29tIDbNEgDbzgVJ5UFvYHWhxDZ5TFkJafFioO0pPQjCw==", + "dev": true, + "requires": { + "which": "^1.2.10" + } + }, "npm-run-path": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", @@ -2044,6 +7227,17 @@ "path-key": "^2.0.0" } }, + "npm-which": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/npm-which/-/npm-which-3.0.1.tgz", + "integrity": "sha1-kiXybsOihcIJyuZ8OxGmtKtxQKo=", + "dev": true, + "requires": { + "commander": "^2.9.0", + "npm-path": "^2.0.2", + "which": "^1.2.10" + } + }, "number-is-nan": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", @@ -2056,12 +7250,58 @@ "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", "dev": true }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "dev": true, + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, "object-keys": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", "dev": true }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "dev": true, + "requires": { + "isobject": "^3.0.0" + } + }, "object.assign": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", @@ -2074,6 +7314,18 @@ "object-keys": "^1.0.11" } }, + "object.entries": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", + "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.12.0", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, "object.getownpropertydescriptors": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", @@ -2084,6 +7336,15 @@ "es-abstract": "^1.5.1" } }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, "once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -2092,6 +7353,37 @@ "wrappy": "1" } }, + "onetime": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", + "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + }, + "dependencies": { + "mimic-fn": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", + "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", + "dev": true + } + } + }, + "optionator": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", + "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", + "dev": true, + "requires": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.4", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "wordwrap": "~1.0.0" + } + }, "os-homedir": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", @@ -2124,6 +7416,17 @@ "os-tmpdir": "^1.0.0" } }, + "output-file-sync": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/output-file-sync/-/output-file-sync-2.0.1.tgz", + "integrity": "sha512-mDho4qm7WgIXIGf4eYU1RHN2UU5tPfVYVSRwDJw0uTmj35DQUt/eNp19N7v6T3SrR0ESTEf2up2CGO73qI35zQ==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "is-plain-obj": "^1.1.0", + "mkdirp": "^0.5.1" + } + }, "p-defer": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", @@ -2157,12 +7460,27 @@ "p-limit": "^2.0.0" } }, + "p-map": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-1.2.0.tgz", + "integrity": "sha512-r6zKACMNhjPJMTl8KcFH4li//gkrXWfbD6feV8l6doRHlzljFWGJ2AP6iKaCJXyZmAUMOPtvbW7EXkbWO/pLEA==", + "dev": true + }, "p-try": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", "dev": true }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + } + }, "parse-json": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", @@ -2172,6 +7490,25 @@ "error-ex": "^1.2.0" } }, + "parse-passwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", + "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=", + "dev": true + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", + "dev": true + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", + "dev": true, + "optional": true + }, "path-exists": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", @@ -2187,6 +7524,12 @@ "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", "dev": true }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", + "dev": true + }, "path-key": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", @@ -2244,6 +7587,84 @@ "pinkie": "^2.0.0" } }, + "pirates": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.1.tgz", + "integrity": "sha512-WuNqLTbMI3tmfef2TKxlQmAiLHKtFhlsCZnPIpuv2Ow0RDVO8lfy1Opf4NUzlMXLjPl+Men7AuVdX6TA+s+uGA==", + "dev": true, + "requires": { + "node-modules-regexp": "^1.0.0" + } + }, + "pkg-dir": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", + "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", + "dev": true, + "requires": { + "find-up": "^2.1.0" + }, + "dependencies": { + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + } + } + }, + "please-upgrade-node": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/please-upgrade-node/-/please-upgrade-node-3.1.1.tgz", + "integrity": "sha512-KY1uHnQ2NlQHqIJQpnh/i54rKkuxCEBx+voJIS/Mvb+L2iYd2NMotwduhKTMjfC1uKoX3VXOxLjIYG66dfJTVQ==", + "dev": true, + "requires": { + "semver-compare": "^1.0.0" + } + }, "plur": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/plur/-/plur-2.1.2.tgz", @@ -2253,10 +7674,61 @@ "irregular-plurals": "^1.0.0" } }, - "pluralize": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", - "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==" + "pluralize": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", + "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==" + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", + "dev": true + }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "dev": true + }, + "prettier": { + "version": "1.17.1", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.17.1.tgz", + "integrity": "sha512-TzGRNvuUSmPgwivDqkZ9tM/qTGW9hqDKWOE9YHiyQdixlKbv7kvEqsmDPrcHJTKwthU774TQwZXVtaQ/mMsvjg==", + "dev": true + }, + "prettier-linter-helpers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", + "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", + "dev": true, + "requires": { + "fast-diff": "^1.1.2" + } + }, + "private": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", + "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", + "dev": true + }, + "process-nextick-args": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", + "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", + "dev": true + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true + }, + "property-expr": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/property-expr/-/property-expr-1.5.1.tgz", + "integrity": "sha512-CGuc0VUTGthpJXL36ydB6jnbyOf/rAHFvmVrJlH+Rg0DqqLFQGAP6hIaxD/G0OAmBJPhXDHuEJigrp0e0wFV6g==", + "dev": true }, "proto-list": { "version": "1.2.4", @@ -2279,12 +7751,36 @@ "once": "^1.3.1" } }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "dev": true + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", + "dev": true + }, "qs": { "version": "6.5.2", "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", "dev": true }, + "quick-lru": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-1.1.0.tgz", + "integrity": "sha1-Q2CxfGETatOAeDl/8RQW4Ybc+7g=", + "dev": true + }, + "ramda": { + "version": "0.26.1", + "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.26.1.tgz", + "integrity": "sha512-hLWjpy7EnsDBb0p+Z3B7rPi3GDeRG5ZtiI33kJhTt+ORCd38AbAIjB/9zRIUoeTbE/AVX5ZkU7m6bznsvrf8eQ==", + "dev": true + }, "raw-body": { "version": "1.1.7", "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-1.1.7.tgz", @@ -2328,6 +7824,62 @@ "string_decoder": "~0.10.x" } }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "dev": true, + "optional": true, + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + }, + "dependencies": { + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true, + "optional": true + }, + "readable-stream": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", + "dev": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "rechoir": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", + "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", + "dev": true, + "requires": { + "resolve": "^1.1.6" + } + }, "redent": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/redent/-/redent-1.0.0.tgz", @@ -2338,12 +7890,120 @@ "strip-indent": "^1.0.1" } }, + "regenerate": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz", + "integrity": "sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg==", + "dev": true + }, + "regenerate-unicode-properties": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-8.1.0.tgz", + "integrity": "sha512-LGZzkgtLY79GeXLm8Dp0BVLdQlWICzBnJz/ipWUgo59qBaZ+BHtq51P2q1uVZlppMuUAT37SDk39qUbjTWB7bA==", + "dev": true, + "requires": { + "regenerate": "^1.4.0" + } + }, + "regenerator-runtime": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", + "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", + "dev": true + }, + "regenerator-transform": { + "version": "0.13.4", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.13.4.tgz", + "integrity": "sha512-T0QMBjK3J0MtxjPmdIMXm72Wvj2Abb0Bd4HADdfijwMdoIsyQZ6fWC7kDFhk2YinBBEMZDL7Y7wh0J1sGx3S4A==", + "dev": true, + "requires": { + "private": "^0.1.6" + } + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, "regexp-clone": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz", "integrity": "sha1-p8LgmJH9vzj7sQ03b7cwA+aKxYk=", "dev": true }, + "regexp-tree": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/regexp-tree/-/regexp-tree-0.1.6.tgz", + "integrity": "sha512-LFrA98Dw/heXqDojz7qKFdygZmFoiVlvE1Zp7Cq2cvF+ZA+03Gmhy0k0PQlsC1jvHPiTUSs+pDHEuSWv6+6D7w==", + "dev": true + }, + "regexpp": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", + "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", + "dev": true + }, + "regexpu-core": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.5.4.tgz", + "integrity": "sha512-BtizvGtFQKGPUcTy56o3nk1bGRp4SZOTYrDtGNlqCQufptV5IkkLN6Emw+yunAJjzf+C9FQFtvq7IoA3+oMYHQ==", + "dev": true, + "requires": { + "regenerate": "^1.4.0", + "regenerate-unicode-properties": "^8.0.2", + "regjsgen": "^0.5.0", + "regjsparser": "^0.6.0", + "unicode-match-property-ecmascript": "^1.0.4", + "unicode-match-property-value-ecmascript": "^1.1.0" + } + }, + "regjsgen": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.5.0.tgz", + "integrity": "sha512-RnIrLhrXCX5ow/E5/Mh2O4e/oa1/jW0eaBKTSy3LaCj+M3Bqvm97GWDp2yUtzIs4LEn65zR2yiYGFqb2ApnzDA==", + "dev": true + }, + "regjsparser": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.0.tgz", + "integrity": "sha512-RQ7YyokLiQBomUJuUG8iGVvkgOLxwyZM8k6d3q5SAXpg4r5TZJZigKFvC6PpD+qQ98bCDC5YelPeA3EucDoNeQ==", + "dev": true, + "requires": { + "jsesc": "~0.5.0" + }, + "dependencies": { + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", + "dev": true + } + } + }, + "remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", + "dev": true, + "optional": true + }, + "repeat-element": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", + "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", + "dev": true + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", + "dev": true + }, "repeating": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", @@ -2381,12 +8041,59 @@ "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", "dev": true }, + "resolve-dir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-1.0.1.tgz", + "integrity": "sha1-eaQGRMNivoLybv/nOcm7U4IEb0M=", + "dev": true, + "requires": { + "expand-tilde": "^2.0.0", + "global-modules": "^1.0.0" + } + }, "resolve-from": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=", "dev": true }, + "resolve-global": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/resolve-global/-/resolve-global-1.0.0.tgz", + "integrity": "sha512-zFa12V4OLtT5XUX/Q4VLvTfBf+Ok0SPc1FNGM/z9ctUdiU618qwKpWnd0CHs3+RqROfyEg/DhuHbMWYqcgljEw==", + "dev": true, + "requires": { + "global-dirs": "^0.1.1" + } + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", + "dev": true + }, + "restore-cursor": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", + "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", + "dev": true, + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", + "dev": true + }, + "right-pad": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/right-pad/-/right-pad-1.0.1.tgz", + "integrity": "sha1-jKCMLLtbVedNr6lr9/0aJ9VoyNA=", + "dev": true + }, "rimraf": { "version": "2.6.3", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", @@ -2397,9 +8104,9 @@ }, "dependencies": { "glob": { - "version": "7.1.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", - "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "version": "7.1.4", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", + "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", "dev": true, "requires": { "fs.realpath": "^1.0.0", @@ -2412,6 +8119,41 @@ } } }, + "rollup": { + "version": "1.11.3", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.11.3.tgz", + "integrity": "sha512-81MR7alHcFKxgWzGfG7jSdv+JQxSOIOD/Fa3iNUmpzbd7p+V19e1l9uffqT8/7YAHgGOzmoPGN3Fx3L2ptOf5g==", + "dev": true, + "requires": { + "@types/estree": "0.0.39", + "@types/node": "^11.13.9", + "acorn": "^6.1.1" + } + }, + "run-async": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", + "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", + "dev": true, + "requires": { + "is-promise": "^2.1.0" + } + }, + "run-node": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/run-node/-/run-node-1.0.0.tgz", + "integrity": "sha512-kc120TBlQ3mih1LSzdAJXo4xn/GWS2ec0l3S+syHDXP9uRr0JAT8Qd3mdMuyjqCzeZktgP3try92cEgf9Nks8A==", + "dev": true + }, + "rxjs": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", + "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", + "dev": true, + "requires": { + "tslib": "^1.9.0" + } + }, "safe-buffer": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", @@ -2424,6 +8166,15 @@ "integrity": "sha1-PnZyPjjf3aE8mx0poeB//uSzC1c=", "dev": true }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "dev": true, + "requires": { + "ret": "~0.1.10" + } + }, "safer-buffer": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", @@ -2445,12 +8196,41 @@ "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==" }, + "semver-compare": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", + "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=", + "dev": true + }, "set-blocking": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", "dev": true }, + "set-value": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", + "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, "shebang-command": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", @@ -2487,6 +8267,15 @@ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" }, + "simple-git": { + "version": "1.113.0", + "resolved": "https://registry.npmjs.org/simple-git/-/simple-git-1.113.0.tgz", + "integrity": "sha512-i9WVsrK2u0G/cASI9nh7voxOk9mhanWY9eGtWBDSYql6m49Yk5/Fan6uZsDr/xmzv8n+eQ8ahKCoEr8cvU3h+g==", + "dev": true, + "requires": { + "debug": "^4.0.1" + } + }, "sinon": { "version": "7.3.2", "resolved": "https://registry.npmjs.org/sinon/-/sinon-7.3.2.tgz", @@ -2502,33 +8291,226 @@ "supports-color": "^5.5.0" }, "dependencies": { - "supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "sinon-chai": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/sinon-chai/-/sinon-chai-3.3.0.tgz", + "integrity": "sha512-r2JhDY7gbbmh5z3Q62pNbrjxZdOAjpsqW/8yxAZRSqLZqowmfGZPGUZPFf3UX36NLis0cv8VEM5IJh9HgkSOAA==", + "dev": true + }, + "sinon-mongoose": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/sinon-mongoose/-/sinon-mongoose-2.3.0.tgz", + "integrity": "sha512-d0rrL53wuDDs91GMCFAvQam64IpdVfkaxA4cGLTZfw1d5tTg6+F/D7F080d1n3d1gSHJBZLUf9pGpijC/x7xKQ==", + "dev": true + }, + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true + }, + "slice-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", + "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "astral-regex": "^1.0.0", + "is-fullwidth-code-point": "^2.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + } + } + }, + "sliced": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", + "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=", + "dev": true + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "dev": true, + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "dev": true, + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "dev": true, + "requires": { + "kind-of": "^3.2.0" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", "dev": true, "requires": { - "has-flag": "^3.0.0" + "is-buffer": "^1.1.5" } } } }, - "sinon-chai": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/sinon-chai/-/sinon-chai-3.3.0.tgz", - "integrity": "sha512-r2JhDY7gbbmh5z3Q62pNbrjxZdOAjpsqW/8yxAZRSqLZqowmfGZPGUZPFf3UX36NLis0cv8VEM5IJh9HgkSOAA==", + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true }, - "sinon-mongoose": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/sinon-mongoose/-/sinon-mongoose-2.3.0.tgz", - "integrity": "sha512-d0rrL53wuDDs91GMCFAvQam64IpdVfkaxA4cGLTZfw1d5tTg6+F/D7F080d1n3d1gSHJBZLUf9pGpijC/x7xKQ==", - "dev": true + "source-map-resolve": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", + "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", + "dev": true, + "requires": { + "atob": "^2.1.1", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } }, - "sliced": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", - "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=", + "source-map-support": { + "version": "0.5.12", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.12.tgz", + "integrity": "sha512-4h2Pbvyy15EE02G+JOZpUCmqWJuqrs+sEkzewTm++BPi7Hvn/HwcqLAcNxYAyI0x13CpPPn+kMjl+hplXMHITQ==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "source-map-url": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", "dev": true }, "sparse-bitfield": { @@ -2569,12 +8551,57 @@ "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.0.tgz", "integrity": "sha512-2+EPwgbnmOIl8HjGBXXMd9NAu02vLjOO1nWw4kmeRDFyHn+M/ETfHxQUK0oXg8ctgVnl9t3rosNVsZ1jG61nDA==" }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "split2": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/split2/-/split2-2.2.0.tgz", + "integrity": "sha512-RAb22TG39LhI31MbreBgIuKiIKhVsawfTgEGqKHTK87aG+ul/PB8Sqoi3I7kVdRWiCfrKxK3uo4/YUkpNvhPbw==", + "dev": true, + "requires": { + "through2": "^2.0.2" + } + }, "sprintf-js": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.2.tgz", "integrity": "sha512-VE0SOVEHCk7Qc8ulkWw3ntAzXuqf7S2lvwQaDLRnUeIEaKNQJzV6BwmLKhOqT61aGhfUMrXeaBk+oDGCzvhcug==", "dev": true }, + "staged-git-files": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/staged-git-files/-/staged-git-files-1.1.2.tgz", + "integrity": "sha512-0Eyrk6uXW6tg9PYkhi/V/J4zHp33aNyi2hOCmhFLqLTIhbgqWn5jlSzI+IU0VqrZq6+DbHcabQl/WP6P3BG0QA==", + "dev": true + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "dev": true, + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, "statuses": { "version": "1.5.0", "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", @@ -2585,6 +8612,12 @@ "resolved": "https://registry.npmjs.org/stopwords-iso/-/stopwords-iso-0.4.0.tgz", "integrity": "sha1-qqpcylsLaMBQJGh9BkUib6SnSR4=" }, + "string-argv": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.0.2.tgz", + "integrity": "sha1-2sMECGkMIfPDYwo/86BYd73L1zY=", + "dev": true + }, "string-length": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/string-length/-/string-length-1.0.1.tgz", @@ -2633,6 +8666,17 @@ "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", "dev": true }, + "stringify-object": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", + "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", + "dev": true, + "requires": { + "get-own-enumerable-property-symbols": "^3.0.0", + "is-obj": "^1.0.1", + "is-regexp": "^1.0.0" + } + }, "strip-ansi": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", @@ -2677,12 +8721,118 @@ "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", "dev": true }, + "symbol-observable": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.2.0.tgz", + "integrity": "sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ==", + "dev": true + }, + "synchronous-promise": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/synchronous-promise/-/synchronous-promise-2.0.7.tgz", + "integrity": "sha512-16GbgwTmFMYFyQMLvtQjvNWh30dsFe1cAW5Fg1wm5+dg84L9Pe36mftsIRU95/W2YsISxsz/xq4VB23sqpgb/A==", + "dev": true + }, + "table": { + "version": "5.3.3", + "resolved": "https://registry.npmjs.org/table/-/table-5.3.3.tgz", + "integrity": "sha512-3wUNCgdWX6PNpOe3amTTPWPuF6VGvgzjKCaO1snFj0z7Y3mUPWf5+zDtxUVGispJkDECPmR29wbzh6bVMOHbcw==", + "dev": true, + "requires": { + "ajv": "^6.9.1", + "lodash": "^4.17.11", + "slice-ansi": "^2.1.0", + "string-width": "^3.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "text-extensions": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/text-extensions/-/text-extensions-1.9.0.tgz", + "integrity": "sha512-wiBrwC1EhBelW12Zy26JeOUkQ5mRu+5o8rpsJk5+2t+Y5vE7e842qtZDQ2g1NpX/29HdyFeJ4nSIhI47ENSxlQ==", + "dev": true + }, "text-table": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", "dev": true }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", + "dev": true + }, + "through2": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", + "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", + "dev": true, + "requires": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + }, + "dependencies": { + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + }, + "readable-stream": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, "tiny-lr": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/tiny-lr/-/tiny-lr-1.1.1.tgz", @@ -2708,6 +8858,75 @@ } } }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", + "dev": true + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "dev": true, + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "toposort": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/toposort/-/toposort-2.0.2.tgz", + "integrity": "sha1-riF2gXXRVZ1IvvNUILL0li8JwzA=", + "dev": true + }, "traverse": { "version": "0.6.6", "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.6.6.tgz", @@ -2719,6 +8938,33 @@ "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=", "dev": true }, + "trim-off-newlines": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/trim-off-newlines/-/trim-off-newlines-1.0.1.tgz", + "integrity": "sha1-n5up2e+odkw4dpi8v+sshI8RrbM=", + "dev": true + }, + "trim-right": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", + "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", + "dev": true + }, + "tslib": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", + "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", + "dev": true + }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "dev": true, + "requires": { + "prelude-ls": "~1.1.2" + } + }, "type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -2740,12 +8986,164 @@ "util-deprecate": "^1.0.2" } }, + "unicode-canonical-property-names-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", + "integrity": "sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==", + "dev": true + }, + "unicode-match-property-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz", + "integrity": "sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg==", + "dev": true, + "requires": { + "unicode-canonical-property-names-ecmascript": "^1.0.4", + "unicode-property-aliases-ecmascript": "^1.0.4" + } + }, + "unicode-match-property-value-ecmascript": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.1.0.tgz", + "integrity": "sha512-hDTHvaBk3RmFzvSl0UVrUmC3PuW9wKVnpoUDYH0JDkSIovzw+J5viQmeYHxVSBptubnr7PbH2e0fnpDRQnQl5g==", + "dev": true + }, + "unicode-property-aliases-ecmascript": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.0.5.tgz", + "integrity": "sha512-L5RAqCfXqAwR3RriF8pM0lU0w4Ryf/GgzONwi6KnL1taJQa7x1TCxdJnILX59WIGOwR57IVxn7Nej0fz1Ny6fw==", + "dev": true + }, + "union-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", + "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^0.4.3" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "set-value": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", + "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.1", + "to-object-path": "^0.3.0" + } + } + } + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "dev": true, + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "dev": true, + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + } + } + }, + "upath": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.2.tgz", + "integrity": "sha512-kXpym8nmDmlCBr7nKdIx8P2jNBa+pBpIUFRnKJ4dr8htyYGJFokkr2ZvERRtUN+9SY+JqXouNgUPtv6JQva/2Q==", + "dev": true, + "optional": true + }, + "uri-js": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", + "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", + "dev": true + }, + "use": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", + "dev": true + }, "util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", "dev": true }, + "v8flags": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.3.tgz", + "integrity": "sha512-amh9CCg3ZxkzQ48Mhcb8iX7xpAfYJgePHxWMQCBWECpOSqJUXgY26ncA61UTV0BkPqfhcy6mzwCIoP4ygxpW8w==", + "dev": true, + "requires": { + "homedir-polyfill": "^1.0.1" + } + }, "validate-npm-package-license": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.3.tgz", @@ -2799,6 +9197,18 @@ "string-width": "^1.0.2 || 2" } }, + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", + "dev": true + }, + "wordwrap": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", + "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", + "dev": true + }, "wrap-ansi": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", @@ -2836,6 +9246,15 @@ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" }, + "write": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", + "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", + "dev": true, + "requires": { + "mkdirp": "^0.5.1" + } + }, "xtend": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", @@ -2997,6 +9416,20 @@ } } } + }, + "yup": { + "version": "0.27.0", + "resolved": "https://registry.npmjs.org/yup/-/yup-0.27.0.tgz", + "integrity": "sha512-v1yFnE4+u9za42gG/b/081E7uNW9mUj3qtkmelLbW5YPROZzSH/KUUyJu9Wt8vxFJcT9otL/eZopS0YK1L5yPQ==", + "dev": true, + "requires": { + "@babel/runtime": "^7.0.0", + "fn-name": "~2.0.1", + "lodash": "^4.17.11", + "property-expr": "^1.5.0", + "synchronous-promise": "^2.0.6", + "toposort": "^2.0.2" + } } } } diff --git a/package.json b/package.json index 3b5dc2a..77ec1f0 100644 --- a/package.json +++ b/package.json @@ -20,9 +20,19 @@ "stale", "fresh" ], - "main": "index.js", + "main": "lib/index.js", + "module":"es/index.js", "scripts": { - "test": "grunt test" + "clean": "rimraf lib dist es umd", + "prebuild": "npm test && npm run clean", + "build": "rollup -c", + "lint": "eslint --fix --ext .js src/ test/ rollup.config.js", + "pretest": "npm run lint", + "test": "NODE_ENV=test mocha --exit --require @babel/register test/**/*.spec.js", + "cmt": "git add -A && git-cz", + "commit": "git-cz", + "commit:all": "git add -A && git-cz", + "changelog": "changelog" }, "repository": { "type": "git", @@ -45,16 +55,39 @@ } ], "devDependencies": { + "@babel/cli": "7.4.4", + "@babel/core": "7.4.4", + "@babel/node": "7.2.2", + "@babel/preset-env": "7.4.4", + "@babel/register": "7.4.4", + "@commitlint/cli": "^7.6.1", + "@commitlint/config-conventional": "^7.6.0", + "@commitlint/travis-cli": "^7.6.1", "@lykmapipo/mongoose-test-helpers": ">=0.7.2", + "chai": "^4.2.0", + "commitizen": "^3.1.1", + "cz-conventional-changelog": "^2.1.0", + "eslint": "^5.16.0", + "eslint-config-airbnb-base": "^13.1.0", + "eslint-config-prettier": "^4.2.0", + "eslint-plugin-import": "^2.17.2", + "eslint-plugin-mocha": "^5.3.0", + "eslint-plugin-prettier": "^3.1.0", + "generate-changelog": "^1.7.1", "grunt": "^1.0.4", "grunt-contrib-jshint": "^2.1.0", "grunt-contrib-watch": "^1.1.0", "grunt-mocha-test": "^0.13.3", + "husky": "^2.3.0", "js-beautify": "^1.10.0", "jshint": "^2.10.2", "jshint-stylish": "^2.2.1", + "lint-staged": "^8.1.6", "mocha": "^6.1.4", - "mongoose": ">=5.5.7" + "mongoose": ">=5.5.7", + "prettier": "^1.17.1", + "rimraf": "^2.6.3", + "rollup": "^1.11.3" }, "peerDependencies": { "mongoose": ">=5.5.7" @@ -73,5 +106,27 @@ "mongoose-exists": ">=0.7.1", "mongoose-hidden": ">=1.6.1", "mongoose-regex-search": ">=0.7.3" + }, + "config": { + "commitizen": { + "path": "./node_modules/cz-conventional-changelog" + } + }, + "commitlint": { + "extends": [ + "@commitlint/config-conventional" + ] + }, + "lint-staged": { + "src/**/*.js": [ + "npm run lint", + "git add -A" + ] + }, + "husky": { + "hooks": { + "pre-commit": "lint-staged", + "commit-msg": "commitlint -E HUSKY_GIT_PARAMS" + } } } diff --git a/rollup.config.js b/rollup.config.js new file mode 100644 index 0000000..0e8b21c --- /dev/null +++ b/rollup.config.js @@ -0,0 +1,19 @@ +import pkg from './package.json'; + +export default [ + { + input: 'src/index.js', + external: ['lodash'], + output: [ + { + file: pkg.main, + format: 'cjs', + interop: false, + esModule: false, + preferConst: true, + strict: true, + }, + { file: pkg.module, format: 'es' }, + ], + }, +]; diff --git a/lib/delete.js b/src/delete.js similarity index 72% rename from lib/delete.js rename to src/delete.js index 9433656..be22b40 100644 --- a/lib/delete.js +++ b/src/delete.js @@ -1,10 +1,5 @@ -'use strict'; - - -/* dependencies */ -const _ = require('lodash'); -const { waterfall } = require('async'); - +import _ from 'lodash'; +import { waterfall } from 'async'; /** * @module mongoose-rest-actions @@ -30,10 +25,10 @@ const { waterfall } = require('async'); * * app.delete('/users/:id', function(request, response, next){ * - * //obtain id + * // obtain id * const _id = request.params.id; * - * //delete user + * // delete user * User * .del(_id, function(error, deleted){ * ...handle error or reply @@ -41,15 +36,14 @@ const { waterfall } = require('async'); * }); * */ -module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { - +function deletePlugin(Schema) { + const schema = Schema; /* *---------------------------------------------------------------------------- * Instance *---------------------------------------------------------------------------- */ - /** * @function * @name del @@ -96,14 +90,14 @@ module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { * ... * }); */ - schema.methods.del = function del(options, done) { - // normalize arguments + schema.methods.del = function del(optns, callback) { + // normalize arguments const defaults = { soft: false }; - done = _.isFunction(options) ? options : done; - options = _.isFunction(options) ? defaults : _.merge(defaults, options); - - waterfall([ + const done = _.isFunction(optns) ? optns : callback; + const options = _.isFunction(optns) ? defaults : _.merge(defaults, optns); + waterfall( + [ /** * @name beforeDelete * @function beforeDelete @@ -113,21 +107,23 @@ module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { * @private */ function beforeDelete(next) { - //obtain before hooks - const before = (this.beforeDelete || this.preDelete); + // obtain before hooks + const before = this.beforeDelete || this.preDelete; - //run hook(s) + // run hook(s) if (_.isFunction(before)) { - before.call(this, function (error, instance) { - next(error, instance || this); - }.bind(this)); + before.call( + this, + function onBeforeDelete(error, instance) { + next(error, instance || this); + }.bind(this) + ); } - //no hook + // no hook else { - //TODO use undefined + // TODO use undefined next(null, this); } - }.bind(this), /** @@ -139,14 +135,14 @@ module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { * @private */ function doDelete(instance, next) { - //TODO throw error if already deleted - // soft delete + // TODO throw error if already deleted + // soft delete const { soft } = options; if (soft) { const updates = { deletedAt: new Date() }; instance.patch(updates, next); } - // hard deletes + // hard deletes else { instance.remove(function afterRemove(error, deleted) { next(error, deleted); @@ -163,23 +159,21 @@ module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { * @private */ function afterDelete(instance, next) { - //obtain after hooks - const after = (instance.afterDelete || instance.postDelete); + // obtain after hooks + const after = instance.afterDelete || instance.postDelete; - //run hook(s) + // run hook(s) if (_.isFunction(after)) { - after.call(instance, function (error, instanced) { + after.call(instance, function onAfterDelete(error, instanced) { next(error, instanced || instance); }); } - //no hook + // no hook else { - //TODO use undefined + // TODO use undefined next(null, instance); } - - } - + }, ], /** @@ -190,23 +184,22 @@ module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { * @param {Object} deleted model instance * @private */ - function onceDelete(error, deleted) { + function onceDelete(err, deleted) { + const error = err; if (error) { - error.status = (error.status || 400); + error.status = error.status || 400; } done(error, deleted); - }); - + } + ); }; - /* *---------------------------------------------------------------------------- * Statics *---------------------------------------------------------------------------- */ - /** * @function * @name del @@ -228,39 +221,43 @@ module.exports = exports = function deletePlugin(schema /*, schemaOptns*/ ) { * ... * }); */ - schema.statics.del = function del(options, done) { - // normalize arguments + schema.statics.del = function del(optns, done) { + // normalize arguments const defaults = { soft: false }; - options = _.isPlainObject(options) ? options : { _id: options }; + let options = _.isPlainObject(optns) ? optns : { _id: optns }; options = _.merge(defaults, options); const { _id, soft } = options; - //ensure id + // ensure id if (!_id) { - let error = new Error('Missing Instance Id'); + const error = new Error('Missing Instance Id'); error.status = 400; - return done(error); + done(error); } - //continue with delete - waterfall([ - - function findExisting(next) { - this.findById(_id).orFail().exec(next); //TODO use getById - }.bind(this), - - function afterFindExisting(instance, next) { - instance.del({ soft }, next); - } + // continue with delete + waterfall( + [ + function findExisting(next) { + this.findById(_id) + .orFail() + .exec(next); // TODO use getById + }.bind(this), - ], function onceDelete(error, patched) { - if (error) { - error.status = (error.status || 400); + function afterFindExisting(instance, next) { + instance.del({ soft }, next); + }, + ], + function onceDelete(err, patched) { + const error = err; + if (error) { + error.status = error.status || 400; + } + done(error, patched); } - done(error, patched); - }); - + ); }; +} -}; +export default deletePlugin; diff --git a/lib/get.js b/src/get.js similarity index 53% rename from lib/get.js rename to src/get.js index 90d13bb..d8923dc 100644 --- a/lib/get.js +++ b/src/get.js @@ -1,25 +1,19 @@ -'use strict'; +import _ from 'lodash'; +import { waterfall, parallel } from 'async'; - -/* dependencies */ -const _ = require('lodash'); -const { waterfall, parallel } = require('async'); - - -//default get options +/* default get options */ const defaults = { filter: {}, paginate: { limit: 10, skip: 0, - page: 1 + page: 1, }, populate: [], select: {}, - sort: {} + sort: {}, }; - /** * @module mongoose-rest-actions * @function @@ -44,10 +38,10 @@ const defaults = { * * app.get('/users', function(request, response, next){ * - * //prepare options + * // prepare options * const options = { page: request.query.page, limit: request.query.limit} * - * //get users + * // get users * User * .get(options, function(error, results){ * ...handle error or reply @@ -56,10 +50,10 @@ const defaults = { * * app.get('/users/:id', function(request, response, next){ * - * //obtain id + * // obtain id * const _id = request.params.id; * - * //get user + * // get user * User * .getById(_id, function(error, user){ * ...handle error or reply @@ -70,10 +64,10 @@ const defaults = { * * app.get('/users/:id', function(request, response, next){ * - * //obtain id + * // obtain id * const options = {_id : request.params.id, select: 'name -age'}; * - * //get user + * // get user * User * .getById(options, function(error, user){ * ...handle error or reply @@ -81,12 +75,16 @@ const defaults = { * }); * */ -module.exports = exports = function getPlugin(schema, schemaOptns) { - - //normalize options - const schemaOptions = _.merge({}, { - root: 'data' - }, schemaOptns); +function getPlugin(Schema, schemaOptns) { + const schema = Schema; + // normalize options + const schemaOptions = _.merge( + {}, + { + root: 'data', + }, + schemaOptns + ); /* *---------------------------------------------------------------------------- @@ -94,7 +92,6 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { *---------------------------------------------------------------------------- */ - /** * @name getById * @function getById @@ -121,119 +118,119 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * }); */ schema.statics.getById = function getById(optns, done) { - - //normalize options + // normalize options let options = _.isFunction(optns) ? {} : optns; const cb = _.isFunction(optns) ? optns : done; - options = _.isPlainObject(options) ? options : { - _id: options - }; - options._id = options._id || options.id; + options = _.isPlainObject(options) + ? options + : { + _id: options, + }; + options._id = options._id || options.id; // eslint-disable-line + const optionsId = options._id; // eslint-disable-line delete options.id; - //ensure id - if (!options._id) { - let error = new Error('Missing Instance Id'); + // ensure id + if (!optionsId) { + const error = new Error('Missing Instance Id'); error.status = 400; - return cb(error); + cb(error); } - //continue with retrieving data - waterfall([ - - /** - * @function - * @name beforeGetById - * @description perform pre getById logics - * @param {Function} next a callback to invoke after beforeGetById - * @returns {null|undefined|error} - * @private - */ - function beforeGetById(next) { - //obtain before hooks - const before = (this.beforeGetById || this.preGetById); - - //run hook(s) - if (_.isFunction(before)) { - before.call(this, function (error) { - next(error); - }.bind(this)); + // continue with retrieving data + waterfall( + [ + /** + * @function + * @name beforeGetById + * @description perform pre getById logics + * @param {Function} next a callback to invoke after beforeGetById + * @returns {null|undefined|error} + * @private + */ + function beforeGetById(next) { + // obtain before hooks + const before = this.beforeGetById || this.preGetById; + + // run hook(s) + if (_.isFunction(before)) { + before.call(this, function onBeforeGetById(error) { + next(error); + }); + } + // no hook + else { + next(); + } + }.bind(this), + + /** + * @function + * @name doGetById + * @description obtain instance by id + * @param {Function} next a callback to invoke after getById + * @returns {instance|error} + * @private + */ + function doGetById(next) { + // prepare find query + const findQuery = this.findById(optionsId); + + // if select + if (options.select) { + findQuery.select(options.select); + } + + // if populate + if (options.populate) { + const populate = _.compact([].concat(options.populate)); + _.forEach(populate, populateOption => { + findQuery.populate(populateOption); + }); + } + + findQuery.orFail().exec(next); // TODO get cached + }.bind(this), + + /** + * @function + * @name afterGetById + * @description perform after getById logics + * @param {Function} next a callback to invoke after afterGetById + * @returns {instance|error} + * @private + */ + function afterGetById(instance, next) { + // obtain after hooks + const after = this.afterGetById || this.postGetById; + + // run hook(s) + if (_.isFunction(after)) { + after + .call(this, instance, function onAfterGetById(error, instanced) { + next(error, instanced || instance); + }) + .bind(this); + } + // no hook + else { + next(null, instance); + } + }.bind(this), + ], + function onceGetById(err, found) { + const error = err; + if (error) { + error.status = error.status || 400; } - //no hook - else { - next(); - } - - }.bind(this), - - /** - * @function - * @name doGetById - * @description obtain instance by id - * @param {Function} next a callback to invoke after getById - * @returns {instance|error} - * @private - */ - function doGetById(next) { - - //prepare find query - const findQuery = this.findById(options._id); - - //if select - if (options.select) { - findQuery.select(options.select); - } - - //if populate - if (options.populate) { - const populate = _.compact([].concat(options.populate)); - _.forEach(populate, function (populateOption) { - findQuery.populate(populateOption); - }); - } - - findQuery.orFail().exec(next); //TODO get cached - - }.bind(this), - - /** - * @function - * @name afterGetById - * @description perform after getById logics - * @param {Function} next a callback to invoke after afterGetById - * @returns {instance|error} - * @private - */ - function afterGetById(instance, next) { - //obtain after hooks - const after = (this.afterGetById || this.postGetById); - - //run hook(s) - if (_.isFunction(after)) { - after.call(this, instance, function (error, instanced) { - next(error, instanced || instance); - }).bind(this); - } - //no hook - else { - next(null, instance); - } - - }.bind(this) - - ], function onceGetById(error, found) { - if (error) { - error.status = (error.status || 400); + cb(error, found); } - cb(error, found); - }); - + ); }; - /** * @function - * @name _get + * @name getHelperFn * @description count and find existing model(s) based on specified options * @param {Object} [optns={}] * @param {Object|String} [optns.filter] valid mongoose query criteria @@ -248,7 +245,7 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * @param {Date} [optns.headers.ifModifiedSince] if modified since option * @returns {Object} results * @returns {Object[]} [results.data] array of documents - * @returns {Number} [results.total] total number of documents in collection + * @returns {Number} [results.total] total number of documents in collection * that match a query * @returns {Number} [results.size] length of current page documents * @returns {Number} [results.limit] limit that was used @@ -267,20 +264,19 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * const User = mongoose.model('User'); * * User - * ._get(function(error, deleted){ + * .getHelperFn(function(error, deleted){ * ... * }); * * or * * User - * ._get({page: 1}, function(error, deleted){ + * .getHelperFn({page: 1}, function(error, deleted){ * ... * }); */ - schema.statics._get = function _get(optns, done) { - - //normalize options & callback + schema.statics.getHelperFn = function getHelperFn(optns, done) { + // normalize options & callback const cb = _.isFunction(optns) ? optns : done; let options = _.isFunction(optns) ? {} : optns; @@ -288,52 +284,54 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { options = _.merge({}, options.paginate, options); delete options.paginate; - //obtain query criteria - let filter = (options.query || options.criteria || options.filter); + // obtain query criteria + let filter = options.query || options.criteria || options.filter; - //obtain limit - let limit = (options.limit || 10); + // obtain limit + let limit = options.limit || 10; limit = limit > 0 ? limit : 10; - //obtain skip - let skip = (options.skip || options.offset || 0); + // obtain skip + let skip = options.skip || options.offset || 0; skip = skip > 0 ? skip : 0; - //obtain page - let page = (options.page || options.page); + // obtain page + const page = options.page || options.page; - let populate = _.compact([].concat(options.populate)); - let select = (options.select || {}); - let sort = (options.sort || {}); - let headers = (options.headers || {}); + const populate = _.compact([].concat(options.populate)); + const select = options.select || {}; + const sort = options.sort || {}; + const headers = options.headers || {}; - //extend headers with if-modified-since condition - const UPDATED_AT_FIELD = this.UPDATED_AT_FIELD; + // extend headers with if-modified-since condition + const { UPDATED_AT_FIELD } = this; if (headers.ifModifiedSince) { const ifModifiedSince = new Date(headers.ifModifiedSince); filter = _.merge({}, filter, { [UPDATED_AT_FIELD]: { - $gt: ifModifiedSince - } + $gt: ifModifiedSince, + }, }); } - - //initialize queries - const q = filter.q; + // initialize queries + const { q } = filter; const conditions = _.omit(filter, 'q'); const findQuery = this.search(q, conditions); - const countQuery = - this.search(q, conditions).setOptions({ - autopopulate: false - }); - let lastModifiedQuery = this.findOne({}, { - [UPDATED_AT_FIELD]: 1 - }, { - autopopulate: false - }) //dont populate + const countQuery = this.search(q, conditions).setOptions({ + autopopulate: false, + }); + const lastModifiedQuery = this.findOne( + {}, + { + [UPDATED_AT_FIELD]: 1, + }, + { + autopopulate: false, + } + ) // dont populate .sort({ - [UPDATED_AT_FIELD]: -1 + [UPDATED_AT_FIELD]: -1, }); if (page && page > 0) { @@ -357,75 +355,73 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { } if (populate) { - _.forEach(populate, function (populateOption) { + _.forEach(populate, populateOption => { findQuery.populate(populateOption); }); } - parallel({ + parallel( + { + count: function countMatched(next) { + countQuery.countDocuments().exec(next); // TODO get cached + }, - count: function countMatched(next) { - countQuery.countDocuments().exec(next); //TODO get cached - }, + data: function paginateMatched(next) { + findQuery.exec(next); // TODO get cached + }, - data: function paginateMatched(next) { - findQuery.exec(next); //TODO get cached + lastModified: function findLatestModified(next) { + lastModifiedQuery.exec(next); + }, }, + function next(err, results) { + const error = err; + let mergedResults; + + if (!error && results) { + // prepare results + const defaultsResults = { + data: [], + total: 0, + size: 0, + pages: 0, + lastModified: undefined, + }; + mergedResults = _.merge({}, defaultsResults, results); + + // obtain latest modified date + const lastModified = mergedResults.lastModified + ? mergedResults.lastModified[UPDATED_AT_FIELD] + : undefined; + + // compute pages + const pages = Math.ceil(mergedResults.count / limit); + + // refine results + mergedResults = { + [schemaOptions.root]: results.data, + total: results.count, + size: results.data.length, + limit, + skip, + page, + pages, + lastModified, + hasMore: page > pages, + }; + } - lastModified: function findLatestModified(next) { - lastModifiedQuery.exec(next); - } - - }, function (error, results) { - - if (!error && results) { - //prepare results - const defaults = { - data: [], - total: 0, - size: 0, - pages: 0, - lastModified: undefined - }; - results = _.merge({}, defaults, results); - - //obtain latest modified date - const lastModified = ( - results.lastModified ? - results.lastModified[UPDATED_AT_FIELD] : - undefined - ); - - //compute pages - const pages = Math.ceil(results.count / limit); - - //refine results - results = { - [schemaOptions.root]: results.data, - total: results.count, - size: results.data.length, - limit: limit, - skip: skip, - page: page, - pages: pages, - lastModified: lastModified, - hasMore: page > pages - }; - } + // ensure error status + if (error) { + error.status = error.status || 400; + mergedResults = undefined; + } - //ensure error status - if (error) { - error.status = (error.status || 400); - results = undefined; + cb(error, mergedResults); // TODO cache } - - cb(error, results); //TODO cache - - }); - + ); }; - /** * @function * @name get @@ -441,7 +437,7 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * @param {Number} [optns.paginate.limit=10] valid query limit option * @returns {Object} results * @returns {Object[]} [results.data] array of documents - * @returns {Number} [results.total] total number of documents in collection + * @returns {Number} [results.total] total number of documents in collection * that match a query * @returns {Number} [results.size] length of current page documents * @returns {Number} [results.limit] limit that was used @@ -472,87 +468,88 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * }); */ schema.statics.get = function get(optns, done) { - - //normalize options & callback + // normalize options & callback const cb = _.isFunction(optns) ? optns : done; - //normalize options + // normalize options const options = _.isFunction(optns) ? {} : optns; delete options.headers; - waterfall([ - /** - * @function - * @name beforeGet - * @description perform pre get logics - * @param {Function} next a callback to invoke after beforeGet - * @returns {null|undefined|error} - * @private - */ - function beforeGet(next) { - //obtain before hooks - const before = (this.beforeGet || this.preGet); - - //run hook(s) - if (_.isFunction(before)) { - before.call(this, options, function (error) { - next(error); - }.bind(this)); + waterfall( + [ + /** + * @function + * @name beforeGet + * @description perform pre get logics + * @param {Function} next a callback to invoke after beforeGet + * @returns {null|undefined|error} + * @private + */ + function beforeGet(next) { + // obtain before hooks + const before = this.beforeGet || this.preGet; + + // run hook(s) + if (_.isFunction(before)) { + before.call(this, options, function onBeforeGet(error) { + next(error); + }); + } + // no hook + else { + next(); + } + }.bind(this), + + /** + * @function + * @name doGet + * @description query data + * @param {Function} next a callback to invoke after query data(get) + * @returns {instance|error} + * @private + */ + function doGet(next) { + this.getHelperFn(options, next); + }.bind(this), + + /** + * @function + * @name afterGet + * @description perform after query data logics + * @param {Function} next a callback to invoke after doGet + * @returns {context|error} + * @private + */ + function afterGet(results, next) { + // obtain hooks + const after = this.afterGet || this.postGet; + + // run hook(s) + if (_.isFunction(after)) { + after.call(this, options, results, function onAfterGet( + error, + resulted + ) { + next(error, resulted || results); + }); + } + // no hook + else { + next(null, results); + } + }.bind(this), + ], + function onceGet(err, got) { + const error = err; + if (error) { + error.status = error.status || 400; } - //no hook - else { - next(); - } - - }.bind(this), - - /** - * @function - * @name doGet - * @description query data - * @param {Function} next a callback to invoke after query data(get) - * @returns {instance|error} - * @private - */ - function doGet(next) { - this._get(options, next); - }.bind(this), - - /** - * @function - * @name afterGet - * @description perform after query data logics - * @param {Function} next a callback to invoke after doGet - * @returns {context|error} - * @private - */ - function afterGet(results, next) { - //obtain hooks - const after = (this.afterGet || this.postGet); - - //run hook(s) - if (_.isFunction(after)) { - after.call(this, options, results, function (error, resulted) { - next(error, resulted || results); - }); - } - //no hook - else { - next(null, results); - } - - }.bind(this) - - ], function onceGet(error, got) { - if (error) { - error.status = (error.status || 400); + cb(error, got); } - cb(error, got); - }); - + ); }; - /** * @function * @name fresh @@ -570,7 +567,7 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * @param {Date} [optns.headers.ifModifiedSince] if modified since option * @returns {Object} results * @returns {Object[]} [results.data] array of documents - * @returns {Number} [results.total] total number of documents in collection + * @returns {Number} [results.total] total number of documents in collection * that match a query * @returns {Number} [results.size] length of current page documents * @returns {Number} [results.limit] limit that was used @@ -600,11 +597,10 @@ module.exports = exports = function getPlugin(schema, schemaOptns) { * ... * }); */ - schema.statics.fresh = function fresh() { - - //query - this._get.apply(this, arguments); - + schema.statics.fresh = function fresh(...args) { + // query + this.getHelperFn(...args); }; +} -}; +export default getPlugin; diff --git a/src/index.js b/src/index.js new file mode 100644 index 0000000..efba43d --- /dev/null +++ b/src/index.js @@ -0,0 +1,134 @@ +import _ from 'lodash'; +import '@lykmapipo/mongoose-common'; + +// common plugins +import fake from '@lykmapipo/mongoose-faker'; +import search from 'mongoose-regex-search'; +import autopopulate from 'mongoose-autopopulate'; +import hide from 'mongoose-hidden'; +import exist from 'mongoose-exists'; +import taggable from '@lykmapipo/mongoose-taggable'; +import aggregatable from '@lykmapipo/mongoose-aggregatable'; + +/* import rest plugins */ +import del from './delete'; +import get from './get'; +import patch from './patch'; +import post from './post'; +import put from './put'; + +// constants +const defaultHidden = { + defaultHidden: { + password: true, + __v: true, + __t: true, + }, + virtuals: { + id: 'hideJSON', + runInBackgroundQueue: 'hide', + runInBackgroundOptions: 'hide', + }, +}; + +/** + * @module mongoose-rest-actions + * @name restActions + * @function restActions + * @description mongoose schema plugins to support http verb(s) + * @param {Schema} schema valid mongoose schema + * @param {Object} [schemaOptns] valid delete plugin options + * @param {String} [schemaOptns.root] a field name to use to hold results. + * default to `data` + * + * @author lally elias + * @version 0.18.0 + * @since 0.1.0 + * @example + * + * const { Schema } = require('mongoose'); + * const actions = require('mongoose-rest-actions'); + * + * const User = new Schema({ + * name: { type: String } + * }); + * User.plugin(actions); + * + */ +function restActions(Schema, schemaOptns) { + const schema = Schema; + /* @todo refactor and simplify */ + + // ignore if already plugged-in + if (schema.statics.get) { + return; + } + + // normalize options + const schemaOptions = _.merge( + {}, + { + root: 'data', + }, + schemaOptns + ); + + // ensure indexed timestamps fields + // currently mongoose does not index them + // see https:// github.com/Automattic/mongoose/blob/master/lib/schema.js#L1002 + const hasTimeStamps = _.get(schema, 'options.timestamps', false); + if (hasTimeStamps) { + // obtain timestamps paths + const createdAtField = _.isBoolean(hasTimeStamps) + ? 'createdAt' + : hasTimeStamps.createdAt; + schema.statics.CREATED_AT_FIELD = createdAtField; + + const updatedAtField = _.isBoolean(hasTimeStamps) + ? 'updatedAt' + : hasTimeStamps.updatedAt; + schema.statics.UPDATED_AT_FIELD = updatedAtField; + + // ensure index on create timestamp path if not exists + if (schema.paths[createdAtField]) { + schema.paths[createdAtField].options.index = true; + schema.index({ + [createdAtField]: 1, + }); + } + + // ensure index on update timestamp path if not exists + if (schema.paths[updatedAtField]) { + schema.paths[updatedAtField].options.index = true; + schema.index({ + [updatedAtField]: 1, + }); + } + } + + // extend schema with deletedAt timestamp + schema.add({ + deletedAt: { + type: Date, + index: true, + }, + }); + + // rest actions plugin + get(schema, schemaOptions); + post(schema, schemaOptions); + put(schema, schemaOptions); + patch(schema, schemaOptions); + del(schema, schemaOptions); + + // lastly common plugins + fake(schema, schemaOptions); + exist(schema, schemaOptions); + taggable(schema, schemaOptions); + search(schema, schemaOptions); + autopopulate(schema, schemaOptions); + aggregatable(schema, schemaOptions); + hide(defaultHidden)(schema, schemaOptions); +} + +export default restActions; diff --git a/lib/patch.js b/src/patch.js similarity index 69% rename from lib/patch.js rename to src/patch.js index b4e7fc6..89b1c00 100644 --- a/lib/patch.js +++ b/src/patch.js @@ -1,19 +1,15 @@ -'use strict'; - - -/* dependencies */ -const _ = require('lodash'); -const { waterfall } = require('async'); -const { mergeObjects } = require('@lykmapipo/common'); -const { copyInstance, isInstance } = require('@lykmapipo/mongoose-common'); - +import _ from 'lodash'; +import { waterfall } from 'async'; +import { mergeObjects } from '@lykmapipo/common'; +import { copyInstance, isInstance } from '@lykmapipo/mongoose-common'; const updatesFor = (id, updates) => { - // ignore self instance updates + // ignore self instance updates + // eslint-disable-next-line if (isInstance(updates) && updates._id === id) { return updates; } - // compute updates + // compute updates const changes = mergeObjects(copyInstance(updates), { _id: id }); return changes; }; @@ -41,13 +37,13 @@ const updatesFor = (id, updates) => { * * app.patch('/users/:id', function(request, response, next){ * - * //obtain user + * // obtain user * const updates = request.body; * - * //obtain id + * // obtain id * updates._id = request.params.id; * - * //patch user + * // patch user * User * .patch(updates, function(error, updated){ * ...handle error or reply @@ -58,13 +54,13 @@ const updatesFor = (id, updates) => { * * app.patch('/users/:id', function(request, response, next){ * - * //obtain user + * // obtain user * const updates = request.body; * - * //obtain id + * // obtain id * const _id = request.params.id; * - * //patch user + * // patch user * User * .patch(_id, updates, function(error, updated){ * ...handle error or reply @@ -72,15 +68,14 @@ const updatesFor = (id, updates) => { * }); * */ -module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { - +function patchPlugin(Schema) { + const schema = Schema; /* *---------------------------------------------------------------------------- * Instances *---------------------------------------------------------------------------- */ - /** * @name patch * @function patch @@ -129,17 +124,16 @@ module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { * }); */ schema.methods.patch = function patch(updates, done) { - - //normalize arguments + // normalize arguments const body = _.isFunction(updates) ? {} : updatesFor(null, updates); const cb = _.isFunction(updates) ? updates : done; - //remove unused - delete body._id; + // remove unused + delete body._id; // eslint-disable-line delete body.updatedAt; - waterfall([ - + waterfall( + [ /** * @function * @name beforePatch @@ -149,22 +143,27 @@ module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { * @private */ function beforePatch(next) { - //obtain before hooks + // obtain before hooks const before = - (this.beforePatch || this.prePatch || - this.beforeUpdate || this.preUpdate); + this.beforePatch || + this.prePatch || + this.beforeUpdate || + this.preUpdate; - //run hook(s) + // run hook(s) if (_.isFunction(before)) { - before.call(this, body, function (error, instance) { - next(error, instance || this); - }.bind(this)); + before.call( + this, + body, + function onBeforePatch(error, instance) { + next(error, instance || this); + }.bind(this) + ); } - //no hook + // no hook else { next(null, this); } - }.bind(this), /** @@ -175,8 +174,9 @@ module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { * @returns {instance|error} * @private */ - function doPatch(instance, next) { - //update & persist instance + function doPatch(model, next) { + const instance = model; + // update & persist instance if (body && !_.isEmpty(body)) { instance.set(body); } @@ -195,24 +195,24 @@ module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { * @private */ function afterPatch(instance, next) { - //obtain after hooks + // obtain after hooks const after = - (instance.afterPatch || instance.postPatch || - instance.afterUpdate || instance.postUpdate); + instance.afterPatch || + instance.postPatch || + instance.afterUpdate || + instance.postUpdate; - //run hook(s) + // run hook(s) if (_.isFunction(after)) { - after.call(instance, body, function (error, instanced) { + after.call(instance, body, function onAfterPatch(error, instanced) { next(error, instanced || instance); }); } - //no hook + // no hook else { next(null, instance); } - - } - + }, ], /** @@ -223,23 +223,22 @@ module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { * @param {Object} patched model instance * @private */ - function oncePatch(error, patched) { + function oncePatch(err, patched) { + const error = err; if (error) { - error.status = (error.status || 400); + error.status = error.status || 400; } cb(error, patched); - }); - + } + ); }; - /* *---------------------------------------------------------------------------- * Statics *---------------------------------------------------------------------------- */ - /** * @function * @name patch @@ -267,70 +266,74 @@ module.exports = exports = function patchPlugin(schema /*, schemaOptns*/ ) { // ref const Model = this; - //normalize arguments + // normalize arguments let model = updates; let cb = done; - //handle 3 args + // handle 3 args if (arguments.length === 3) { model = updatesFor(id, updates); cb = done; } - //handle 2 args + // handle 2 args else if (arguments.length === 2) { model = updatesFor(_.get(id, '_id'), id); cb = updates; } - //handle 1 args + // handle 1 args else { cb = id; - let error = new Error('Illegal Arguments'); + const error = new Error('Illegal Arguments'); error.status = 400; - return cb(error); + cb(error); } - //ensure id - model._id = (model._id || model.id); - if (!model._id) { - let error = new Error('Missing Instance Id'); + // ensure id + model._id = model._id || model.id; // eslint-disable-line + const modelId = model._id; // eslint-disable-line + if (!modelId) { + const error = new Error('Missing Instance Id'); error.status = 400; - return cb(error); + cb(error); } + // continue with patch + waterfall( + [ + function findExisting(next) { + if (isInstance(model)) { + next(null, model); + } else { + Model.findById(modelId) + .orFail() + .exec(next); + } + }, - //continue with patch - waterfall([ - - function findExisting(next) { - if (isInstance(model)) { - next(null, model); - } else { - Model.findById(model._id).orFail().exec(next); - } - }, - - function afterFindExisting(instance, next) { - // handle instance - if (isInstance(model)) { - model.patch({ updatedAt: new Date() }, next); - } - // handle updates - else { - delete model._id; - delete model.id; - instance.patch(model, next); + function afterFindExisting(instance, next) { + // handle instance + if (isInstance(model)) { + model.patch({ updatedAt: new Date() }, next); + } + // handle updates + else { + delete model._id; // eslint-disable-line + delete model.id; + instance.patch(model, next); + } + }, + ], + function oncePatch(err, updated) { + const error = err; + if (error) { + error.status = error.status || 400; } + cb(error, updated); } - - ], function oncePatch(error, updated) { - if (error) { - error.status = (error.status || 400); - } - cb(error, updated); - }); - + ); }; +} -}; +export default patchPlugin; diff --git a/lib/post.js b/src/post.js similarity index 79% rename from lib/post.js rename to src/post.js index 7e20e66..78262f6 100644 --- a/lib/post.js +++ b/src/post.js @@ -1,11 +1,6 @@ -'use strict'; - - -/* dependencies */ -const _ = require('lodash'); -const async = require('async'); -const { isInstance, copyInstance } = require('@lykmapipo/mongoose-common'); - +import _ from 'lodash'; +import async from 'async'; +import { isInstance, copyInstance } from '@lykmapipo/mongoose-common'; /** * @function @@ -19,7 +14,7 @@ const { isInstance, copyInstance } = require('@lykmapipo/mongoose-common'); * @author lally elias * @example * - * const mongoose = require('mongoose'); + * const mongoose from 'mongoose'); * const actions = require('mongoose-rest-actions'); * mongoose.plugin(actions); * @@ -30,10 +25,10 @@ const { isInstance, copyInstance } = require('@lykmapipo/mongoose-common'); * * app.post('/users', function(request, response, next){ * - * //obtain user + * // obtain user * const body = request.body; * - * //create user + * // create user * User * .post(body, function(error, created){ * ...handle error or reply @@ -41,15 +36,14 @@ const { isInstance, copyInstance } = require('@lykmapipo/mongoose-common'); * }); * */ -module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { - +function postPlugin(Schema) { + const schema = Schema; /* *---------------------------------------------------------------------------- * Instances *---------------------------------------------------------------------------- */ - /** * @function * @name post @@ -97,10 +91,8 @@ module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { * }); */ schema.methods.post = function post(done) { - - async.waterfall([ - - + async.waterfall( + [ /** * @function * @name beforePost @@ -110,25 +102,25 @@ module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { * @private */ function beforePost(next) { - //obtain before hooks + // obtain before hooks const before = - (this.beforePost || this.prePost || - this.beforeSave || this.preSave); + this.beforePost || this.prePost || this.beforeSave || this.preSave; - //run hook(s) + // run hook(s) if (_.isFunction(before)) { - before.call(this, function (error, instance) { - next(error, instance || this); - }.bind(this)); + before.call( + this, + function onBeforePost(error, instance) { + next(error, instance || this); + }.bind(this) + ); } - //no hook + // no hook else { next(null, this); } - }.bind(this), - /** * @function * @name doPost @@ -143,7 +135,6 @@ module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { }); }, - /** * @function * @name afterPost @@ -153,26 +144,26 @@ module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { * @private */ function afterPost(instance, next) { - //obtain after hooks + // obtain after hooks const after = - (instance.afterPost || instance.postPost || - instance.afterSave || instance.postSave); + instance.afterPost || + instance.postPost || + instance.afterSave || + instance.postSave; - //run hook(s) + // run hook(s) if (_.isFunction(after)) { - after.call(instance, function (error, instanced) { + after.call(instance, function onAfterPost(error, instanced) { next(error, instanced || instance); }); } - //no hook + // no hook else { next(null, instance); } - - } + }, ], - /** * @function * @name onSave @@ -180,23 +171,22 @@ module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { * @param {Object} saved model instance * @private */ - function oncePost(error, saved) { + function oncePost(err, saved) { + const error = err; if (error) { - error.status = (error.status || 400); + error.status = error.status || 400; } done(error, saved); - }); - + } + ); }; - /* *---------------------------------------------------------------------------- * Statics *---------------------------------------------------------------------------- */ - /** * @function * @name post @@ -218,17 +208,12 @@ module.exports = exports = function postPlugin(schema /*, schemaOptns*/ ) { * }); */ schema.statics.post = function post(body, done) { + // instantiate model + const instance = isInstance(body) ? body : new this(copyInstance(body)); - //instantiate model - const instance = ( - isInstance(body) ? - body : - new this(copyInstance(body)) - ); - - //persist model + // persist model instance.post(done); - }; +} -}; +export default postPlugin; diff --git a/lib/put.js b/src/put.js similarity index 70% rename from lib/put.js rename to src/put.js index a8fce8f..8dd874a 100644 --- a/lib/put.js +++ b/src/put.js @@ -1,15 +1,11 @@ -'use strict'; - - -/* dependencies */ -const _ = require('lodash'); -const { waterfall } = require('async'); -const { mergeObjects } = require('@lykmapipo/common'); -const { copyInstance, isInstance } = require('@lykmapipo/mongoose-common'); - +import _ from 'lodash'; +import { waterfall } from 'async'; +import { mergeObjects } from '@lykmapipo/common'; +import { copyInstance, isInstance } from '@lykmapipo/mongoose-common'; const updatesFor = (id, updates) => { // ignore self instance updates + // eslint-disable-next-line if (isInstance(updates) && updates._id === id) { return updates; } @@ -18,7 +14,6 @@ const updatesFor = (id, updates) => { return changes; }; - /** * @function * @name putPlugin @@ -42,13 +37,13 @@ const updatesFor = (id, updates) => { * * app.put('/users/:id', function(request, response, next){ * - * //obtain user + * // obtain user * const updates = request.body; * - * //obtain id + * // obtain id * updates._id = request.params.id; * - * //put user + * // put user * User * .put(updates, function(error, updated){ * ...handle error or reply @@ -59,13 +54,13 @@ const updatesFor = (id, updates) => { * * app.put('/users/:id', function(request, response, next){ * - * //obtain user + * // obtain user * const updates = request.body; * - * //obtain id + * // obtain id * const _id = request.params.id; * - * //put user + * // put user * User * .put(_id, updates, function(error, updated){ * ...handle error or reply @@ -73,7 +68,8 @@ const updatesFor = (id, updates) => { * }); * */ -module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { +function putPlugin(Schema) { + const schema = Schema; /* *---------------------------------------------------------------------------- @@ -81,7 +77,6 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { *---------------------------------------------------------------------------- */ - /** * @function * @name put @@ -130,16 +125,16 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { * }); */ schema.methods.put = function put(updates, done) { - //normalize arguments + // normalize arguments const body = _.isFunction(updates) ? {} : updatesFor(null, updates); const cb = _.isFunction(updates) ? updates : done; - //remove unused - delete body._id; + // remove unused + delete body._id; // eslint-disable-line delete body.updatedAt; - waterfall([ - + waterfall( + [ /** * @name beforePut * @function beforePut @@ -149,22 +144,27 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { * @private */ function beforePut(next) { - //obtain before hooks + // obtain before hooks const before = - (this.beforePut || this.prePut || - this.beforeUpdate || this.preUpdate); + this.beforePut || + this.prePut || + this.beforeUpdate || + this.preUpdate; - //run hook(s) + // run hook(s) if (_.isFunction(before)) { - before.call(this, body, function (error, instance) { - next(error, instance || this); - }.bind(this)); + before.call( + this, + body, + function onBeforePut(error, instance) { + next(error, instance || this); + }.bind(this) + ); } - //no hook + // no hook else { next(null, this); } - }.bind(this), /** @@ -175,8 +175,9 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { * @returns {instance|error} * @private */ - function doPut(instance, next) { - //update & persist instance + function doPut(model, next) { + const instance = model; + // update & persist instance if (body && !_.isEmpty(body)) { instance.set(body); } @@ -195,24 +196,24 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { * @private */ function afterPut(instance, next) { - //obtain after hooks + // obtain after hooks const after = - (instance.afterPut || instance.postPut || - instance.afterUpdate || instance.postUpdate); + instance.afterPut || + instance.postPut || + instance.afterUpdate || + instance.postUpdate; - //run hook(s) + // run hook(s) if (_.isFunction(after)) { - after.call(instance, body, function (error, instanced) { + after.call(instance, body, function onAfterPut(error, instanced) { next(error, instanced || instance); }); } - //no hook + // no hook else { next(null, instance); } - - } - + }, ], /** @@ -223,23 +224,22 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { * @param {Object} puted model instance * @private */ - function oncePut(error, puted) { + function oncePut(err, puted) { + const error = err; if (error) { - error.status = (error.status || 400); + error.status = error.status || 400; } cb(error, puted); - }); - + } + ); }; - /* *---------------------------------------------------------------------------- * Statics *---------------------------------------------------------------------------- */ - /** * @function * @name put @@ -256,79 +256,84 @@ module.exports = exports = function putPlugin(schema /*, schemaOptns*/ ) { * @memberof putPlugin * @public * @example - * + * * const User = mongoose.model('User'); * User.put(id, updates, (error, updated) => { ... }); * User.put({_id: ..., name: ...}, (error, updated) => { ... }); - * + * */ schema.statics.put = function put(id, updates, done) { - // ref + // ref const Model = this; - //normalize arguments + // normalize arguments let model = updates; let cb = done; - //handle 3 args + // handle 3 args if (arguments.length === 3) { model = updatesFor(id, updates); cb = done; } - //handle 2 args + // handle 2 args else if (arguments.length === 2) { model = updatesFor(_.get(id, '_id'), id); cb = updates; } - //handle 1 args + // handle 1 args else { cb = id; - let error = new Error('Illegal Arguments'); + const error = new Error('Illegal Arguments'); error.status = 400; - return cb(error); + cb(error); } - //ensure id - model._id = (model._id || model.id); - if (!model._id) { - let error = new Error('Missing Instance Id'); + // ensure id + model._id = model._id || model.id; // eslint-disable-line + const modelId = model._id; // eslint-disable-line + if (!modelId) { + const error = new Error('Missing Instance Id'); error.status = 400; - return cb(error); + cb(error); } - //continue with put - waterfall([ - - function findExisting(next) { - if (isInstance(model)) { - next(null, model); - } else { - Model.findById(model._id).orFail().exec(next); - } - }, + // continue with put + waterfall( + [ + function findExisting(next) { + if (isInstance(model)) { + next(null, model); + } else { + Model.findById(modelId) + .orFail() + .exec(next); + } + }, - function afterFindExisting(instance, next) { - // handle instance - if (isInstance(model)) { - model.put({ updatedAt: new Date() }, next); - } - // handle updates - else { - delete model._id; - delete model.id; - instance.put(model, next); + function afterFindExisting(instance, next) { + // handle instance + if (isInstance(model)) { + model.put({ updatedAt: new Date() }, next); + } + // handle updates + else { + delete model._id; // eslint-disable-line + delete model.id; + instance.put(model, next); + } + }, + ], + function oncePut(err, updated) { + const error = err; + if (error) { + error.status = error.status || 400; } + cb(error, updated); } - - ], function oncePut(error, updated) { - if (error) { - error.status = (error.status || 400); - } - cb(error, updated); - }); - + ); }; +} -}; +export default putPlugin; diff --git a/test/.eslintrc b/test/.eslintrc new file mode 100644 index 0000000..2482b69 --- /dev/null +++ b/test/.eslintrc @@ -0,0 +1,13 @@ +{ + "extends": ["airbnb-base", "plugin:prettier/recommended"], + "plugins": ["prettier", "mocha"], + "rules": { + "prettier/prettier": "error", + "mocha/no-exclusive-tests": "off", + "no-unused-expressions": "off", + "no-underscore-dangle": "off" + }, + "env": { + "mocha": true + } +} diff --git a/test/integration/boostrap.spec.js b/test/integration/boostrap.spec.js index a33a92a..c3fce94 100644 --- a/test/integration/boostrap.spec.js +++ b/test/integration/boostrap.spec.js @@ -1,17 +1,10 @@ -'use strict'; - - -/* dependencies */ -const { connect, clear, drop } = require('@lykmapipo/mongoose-test-helpers'); - +import { connect, clear, drop } from '@lykmapipo/mongoose-test-helpers'; /* setup database */ before(done => connect(done)); - /* clear database */ before(done => clear(done)); - /* drop database */ after(done => drop(done)); diff --git a/test/integration/delete.spec.js b/test/integration/delete.spec.js index cccd699..af54c27 100644 --- a/test/integration/delete.spec.js +++ b/test/integration/delete.spec.js @@ -1,23 +1,17 @@ -'use strict'; - -/* dependencies */ -const { include } = require('@lykmapipo/include'); -const { +import { expect, clear, create, - createTestModel -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); - + createTestModel, +} from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('delete', () => { - const User = createTestModel({}, actions); - let father = User.fake(); - let mother = User.fake(); - let aunt = User.fake(); - let child = User.fake(); + const father = User.fake(); + const mother = User.fake(); + const aunt = User.fake(); + const child = User.fake(); before(done => clear(User, done)); @@ -79,5 +73,4 @@ describe('delete', () => { }); after(done => clear(User, done)); - }); diff --git a/test/integration/get.spec.js b/test/integration/get.spec.js index e53e69e..c72dfc2 100644 --- a/test/integration/get.spec.js +++ b/test/integration/get.spec.js @@ -1,32 +1,34 @@ -'use strict'; - -/* dependencies */ -const _ = require('lodash'); -const { include } = require('@lykmapipo/include'); -const { ObjectId } = require('@lykmapipo/mongoose-common'); -const { +import _ from 'lodash'; +import { ObjectId } from '@lykmapipo/mongoose-common'; +import { expect, create, clear, - createTestModel -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); + createTestModel, +} from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('get', () => { - - const Guardian = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() }, - age: { type: Number, min: 30, fake: true }, - }, actions); - - const Child = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() }, - age: { type: Number, min: 3, fake: true }, - father: { type: ObjectId, ref: Guardian.modelName } - }, actions); - - let father = Guardian.fake(); - let children = _.map(Child.fake(32), child => { + const Guardian = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + age: { type: Number, min: 30, fake: true }, + }, + actions + ); + + const Child = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + age: { type: Number, min: 3, fake: true }, + father: { type: ObjectId, ref: Guardian.modelName }, + }, + actions + ); + + const father = Guardian.fake(); + const children = _.map(Child.fake(32), kid => { + const child = kid; child.father = father; return child; }); @@ -55,8 +57,9 @@ describe('get', () => { expect(results.pages).to.be.equal(4); expect(results.lastModified).to.exist; expect(results.hasMore).to.exist; - expect(_.maxBy(results.data, 'updatedAt').updatedAt) - .to.be.at.most(results.lastModified); + expect(_.maxBy(results.data, 'updatedAt').updatedAt).to.be.at.most( + results.lastModified + ); done(error, results); }); }); @@ -80,8 +83,9 @@ describe('get', () => { expect(results.pages).to.be.equal(2); expect(results.lastModified).to.exist; expect(results.hasMore).to.exist; - expect(_.maxBy(results.data, 'updatedAt').updatedAt) - .to.be.at.most(results.lastModified); + expect(_.maxBy(results.data, 'updatedAt').updatedAt).to.be.at.most( + results.lastModified + ); done(error, results); }); }); @@ -105,8 +109,9 @@ describe('get', () => { expect(results.pages).to.be.equal(1); expect(results.lastModified).to.exist; expect(results.hasMore).to.exist; - expect(_.maxBy(results.data, 'updatedAt').updatedAt) - .to.be.at.most(results.lastModified); + expect(_.maxBy(results.data, 'updatedAt').updatedAt).to.be.at.most( + results.lastModified + ); done(error, results); }); }); @@ -130,8 +135,9 @@ describe('get', () => { expect(results.pages).to.be.equal(1); expect(results.lastModified).to.exist; expect(results.hasMore).to.exist; - expect(_.maxBy(results.data, 'updatedAt').updatedAt) - .to.be.at.most(results.lastModified); + expect(_.maxBy(results.data, 'updatedAt').updatedAt).to.be.at.most( + results.lastModified + ); done(error, results); }); }); @@ -140,8 +146,8 @@ describe('get', () => { const options = { filter: { q: children[0].name, - age: { $eq: children[0].age } - } + age: { $eq: children[0].age }, + }, }; Child.get(options, (error, results) => { expect(error).to.not.exist; @@ -160,8 +166,9 @@ describe('get', () => { expect(results.pages).to.be.equal(1); expect(results.lastModified).to.exist; expect(results.hasMore).to.exist; - expect(_.maxBy(results.data, 'updatedAt').updatedAt) - .to.be.at.most(results.lastModified); + expect(_.maxBy(results.data, 'updatedAt').updatedAt).to.be.at.most( + results.lastModified + ); done(error, results); }); }); @@ -173,10 +180,9 @@ describe('get', () => { expect(results).to.not.exist; expect(error.status).to.be.equal(400); expect(error.name).to.be.equal('MongoError'); - expect(error.message) - .to.be.equal( - 'Projection cannot have a mix of inclusion and exclusion.' - ); + expect(error.message).to.be.equal( + 'Projection cannot have a mix of inclusion and exclusion.' + ); done(); }); }); @@ -207,5 +213,4 @@ describe('get', () => { }); after(done => clear(Guardian, Child, done)); - }); diff --git a/test/integration/getById.spec.js b/test/integration/getById.spec.js index 4b4f379..aac6307 100644 --- a/test/integration/getById.spec.js +++ b/test/integration/getById.spec.js @@ -1,29 +1,30 @@ -'use strict'; - -/* dependencies */ -const { include } = require('@lykmapipo/include'); -const { ObjectId } = require('@lykmapipo/mongoose-common'); -const { +import { ObjectId } from '@lykmapipo/mongoose-common'; +import { expect, create, clear, - createTestModel -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); + createTestModel, +} from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('getById', () => { + const Guardian = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + }, + actions + ); - const Guardian = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() } - }, actions); - - const Child = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() }, - father: { type: ObjectId, ref: Guardian.modelName } - }, actions); + const Child = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + father: { type: ObjectId, ref: Guardian.modelName }, + }, + actions + ); - let father = Guardian.fake(); - let child = Child.fake(); + const father = Guardian.fake(); + const child = Child.fake(); child.father = father; before(done => clear(Guardian, Child, done)); @@ -58,22 +59,21 @@ describe('getById', () => { }); }); - it('should fail using `getById` static method if instance not exist', - done => { - const guardian = Guardian.fake(); - Guardian.getById(guardian._id, error => { - expect(error).to.exist; - expect(error.name).to.be.equal('DocumentNotFoundError'); - expect(error.status).to.exist.and.be.equal(400); - done(); - }); + it('should fail using `getById` static method if instance not exist', done => { + const guardian = Guardian.fake(); + Guardian.getById(guardian._id, error => { + expect(error).to.exist; + expect(error.name).to.be.equal('DocumentNotFoundError'); + expect(error.status).to.exist.and.be.equal(400); + done(); }); + }); it('should work with options using `getById` static method', done => { const options = { _id: child._id, select: 'name', - populate: [{ path: 'father', select: 'name' }] + populate: [{ path: 'father', select: 'name' }], }; Child.getById(options, (error, found) => { expect(error).to.not.exist; @@ -92,5 +92,4 @@ describe('getById', () => { }); after(done => clear(Guardian, Child, done)); - }); diff --git a/test/integration/patch.spec.js b/test/integration/patch.spec.js index 15ccd59..ef466af 100644 --- a/test/integration/patch.spec.js +++ b/test/integration/patch.spec.js @@ -1,27 +1,28 @@ -'use strict'; - -/* dependencies */ -const _ = require('lodash'); -const { include } = require('@lykmapipo/include'); -const { ObjectId } = require('@lykmapipo/mongoose-common'); -const { +import _ from 'lodash'; +import { ObjectId } from '@lykmapipo/mongoose-common'; +import { expect, create, clear, - createTestModel -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); + createTestModel, +} from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('patch', () => { - - const Guardian = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() } - }, actions); - - const Child = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() }, - father: { type: ObjectId, ref: Guardian.modelName } - }, actions); + const Guardian = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + }, + actions + ); + + const Child = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + father: { type: ObjectId, ref: Guardian.modelName }, + }, + actions + ); let father; let child; @@ -151,9 +152,9 @@ describe('patch', () => { }); }); - // + // // instances - // + // it('should work on instance with updates', done => { const updates = _.pick(Guardian.fake(), 'name'); father.patch(updates, (error, updated) => { @@ -184,5 +185,4 @@ describe('patch', () => { }); after(done => clear(Guardian, Child, done)); - }); diff --git a/test/integration/post.spec.js b/test/integration/post.spec.js index 7a00cfe..83f910d 100644 --- a/test/integration/post.spec.js +++ b/test/integration/post.spec.js @@ -1,29 +1,30 @@ -'use strict'; - -/* dependencies */ -const _ = require('lodash'); -const { include } = require('@lykmapipo/include'); -const { ObjectId } = require('@lykmapipo/mongoose-common'); -const { +import _ from 'lodash'; +import { ObjectId } from '@lykmapipo/mongoose-common'; +import { expect, create, clear, - createTestModel -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); + createTestModel, +} from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('post', () => { - - const Guardian = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() } - }, actions); - - const Child = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() }, - father: { type: ObjectId, ref: Guardian.modelName } - }, actions); - - let father = Guardian.fake(); + const Guardian = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + }, + actions + ); + + const Child = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + father: { type: ObjectId, ref: Guardian.modelName }, + }, + actions + ); + + const father = Guardian.fake(); before(done => clear(Guardian, Child, done)); @@ -144,5 +145,4 @@ describe('post', () => { }); after(done => clear(Guardian, Child, done)); - }); diff --git a/test/integration/put.spec.js b/test/integration/put.spec.js index 6086611..1bb9686 100644 --- a/test/integration/put.spec.js +++ b/test/integration/put.spec.js @@ -1,27 +1,28 @@ -'use strict'; - -/* dependencies */ -const _ = require('lodash'); -const { include } = require('@lykmapipo/include'); -const { ObjectId } = require('@lykmapipo/mongoose-common'); -const { +import _ from 'lodash'; +import { ObjectId } from '@lykmapipo/mongoose-common'; +import { expect, create, clear, - createTestModel -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); + createTestModel, +} from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('put', () => { - - const Guardian = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() } - }, actions); - - const Child = createTestModel({ - email: { type: String, unique: true, fake: f => f.internet.email() }, - father: { type: ObjectId, ref: Guardian.modelName } - }, actions); + const Guardian = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + }, + actions + ); + + const Child = createTestModel( + { + email: { type: String, unique: true, fake: f => f.internet.email() }, + father: { type: ObjectId, ref: Guardian.modelName }, + }, + actions + ); let father; let child; @@ -151,9 +152,9 @@ describe('put', () => { }); }); - // + // // instances - // + // it('should work on instance with updates', done => { const updates = _.pick(Guardian.fake(), 'name'); father.put(updates, (error, updated) => { @@ -184,5 +185,4 @@ describe('put', () => { }); after(done => clear(Guardian, Child, done)); - }); diff --git a/test/unit/delete.spec.js b/test/unit/delete.spec.js index 54594bb..187859e 100644 --- a/test/unit/delete.spec.js +++ b/test/unit/delete.spec.js @@ -1,26 +1,23 @@ -'use strict'; - - -/* dependencies */ -const { include } = require('@lykmapipo/include'); -const { +import { sinon, expect, createTestModel, mockModel, - mockInstance -} = require('@lykmapipo/mongoose-test-helpers'); -const del = include(__dirname, '..', '..', 'lib', 'delete'); - + mockInstance, +} from '@lykmapipo/mongoose-test-helpers'; +import del from '../../src/delete'; describe('delete', () => { - it('should work using `del` static method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforeDelete = done => done(); - schema.methods.afterDelete = done => done(); - }, del); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforeDelete = doneCb => doneCb(); + schema.methods.afterDelete = doneCb => doneCb(); + }, + del + ); const user = User.fake(); const Mock = mockModel(User); @@ -51,11 +48,15 @@ describe('delete', () => { }); it('should work using `del` instance method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforeDelete = done => done(); - schema.methods.afterDelete = done => done(); - }, del); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforeDelete = doneCb => doneCb(); + schema.methods.afterDelete = doneCb => doneCb(); + }, + del + ); const user = User.fake(); const mock = mockInstance(user); @@ -75,5 +76,4 @@ describe('delete', () => { done(error, deleted); }); }); - }); diff --git a/test/unit/get.spec.js b/test/unit/get.spec.js index bdc3e6e..4e711bc 100644 --- a/test/unit/get.spec.js +++ b/test/unit/get.spec.js @@ -1,26 +1,23 @@ -'use strict'; - - -/* dependencies */ -const { include } = require('@lykmapipo/include'); -const { +import { sinon, expect, createTestModel, - mockModel -} = require('@lykmapipo/mongoose-test-helpers'); -const searchable = require('mongoose-regex-search'); -const get = include(__dirname, '..', '..', 'lib', 'get'); - + mockModel, +} from '@lykmapipo/mongoose-test-helpers'; +import searchable from 'mongoose-regex-search'; +import get from '../../src'; describe('get', () => { - it('should work using `getById` static method', done => { - - const User = createTestModel({}, schema => { - schema.statics.beforeGetById = (done) => done(); - schema.statics.afterGetById = (instance, done) => done(); - }, get); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.statics.beforeGetById = doneCb => doneCb(); + schema.statics.afterGetById = (instance, doneCb) => doneCb(); + }, + get + ); const user = User.fake(); const Mock = mockModel(User); @@ -44,11 +41,16 @@ describe('get', () => { }); it('should work using `get` static method', done => { - - const User = createTestModel({}, schema => { - schema.statics.beforeGet = (options, done) => done(); - schema.statics.afterGet = (options, results, done) => done(); - }, searchable, get); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.statics.beforeGet = (options, doneCb) => doneCb(); + schema.statics.afterGet = (options, results, doneCb) => doneCb(); + }, + searchable, + get + ); const options = { page: 1, limit: 10 }; const results = { @@ -59,19 +61,18 @@ describe('get', () => { skip: 0, page: 1, pages: 10, - lastModified: new Date() + lastModified: new Date(), }; const Mock = mockModel(User); const beforeGet = sinon.spy(User, 'beforeGet'); const afterGet = sinon.spy(User, 'afterGet'); - const find = Mock.expects('_get').yields(null, results); - + const find = Mock.expects('getHelperFn').yields(null, results); User.get(options, (error, found) => { Mock.verify(); - Mock.restore(); + Mock.restore(); expect(find).to.have.been.calledOnce; expect(beforeGet).to.have.been.calledOnce; expect(afterGet).to.have.been.calledOnce; @@ -79,5 +80,4 @@ describe('get', () => { done(error, found); }); }); - }); diff --git a/test/unit/index.spec.js b/test/unit/index.spec.js index 97d35bc..0e57afb 100644 --- a/test/unit/index.spec.js +++ b/test/unit/index.spec.js @@ -1,22 +1,20 @@ -'use strict'; - - -/* dependencies */ -const { include } = require('@lykmapipo/include'); -const { Schema } = require('@lykmapipo/mongoose-common'); -const { - expect, - createTestModel, -} = require('@lykmapipo/mongoose-test-helpers'); -const actions = include(__dirname, '..', '..'); +import { Schema } from '@lykmapipo/mongoose-common'; +import { expect, createTestModel } from '@lykmapipo/mongoose-test-helpers'; +import actions from '../../src'; describe('index', () => { - - const User = createTestModel({ - name: { type: String, fake: f => f.name.findName() }, - address: { type: String, hide: true, fake: f => f.address.streetAddress() }, - password: { type: String, fake: f => f.internet.password() } - }, actions); + const User = createTestModel( + { + name: { type: String, fake: f => f.name.findName() }, + address: { + type: String, + hide: true, + fake: f => f.address.streetAddress(), + }, + password: { type: String, fake: f => f.internet.password() }, + }, + actions + ); it('should be able to generate fake instance', () => { expect(User.fake).to.exist; @@ -76,5 +74,4 @@ describe('index', () => { expect(name).to.exist; expect(name).to.be.instanceof(Schema.Types.String); }); - }); diff --git a/test/unit/patch.spec.js b/test/unit/patch.spec.js index 3433d10..1c2bacb 100644 --- a/test/unit/patch.spec.js +++ b/test/unit/patch.spec.js @@ -1,27 +1,24 @@ -'use strict'; - - -/* dependencies */ -const _ = require('lodash'); -const { include } = require('@lykmapipo/include'); -const { +import _ from 'lodash'; +import { sinon, expect, createTestModel, mockModel, - mockInstance -} = require('@lykmapipo/mongoose-test-helpers'); -const patch = include(__dirname, '..', '..', 'lib', 'patch'); - + mockInstance, +} from '@lykmapipo/mongoose-test-helpers'; +import patch from '../../src/patch'; describe('patch', () => { - it('should work using `patch` static method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforePatch = (updates, done) => done(); - schema.methods.afterPatch = (updates, done) => done(); - }, patch); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforePatch = (updates, doneCb) => doneCb(); + schema.methods.afterPatch = (updates, doneCb) => doneCb(); + }, + patch + ); const user = User.fake(); const Mock = mockModel(User); @@ -53,11 +50,15 @@ describe('patch', () => { }); it('should work using `patch` instance method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforePatch = (updates, done) => done(); - schema.methods.afterPatch = (updates, done) => done(); - }, patch); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforePatch = (updates, doneCb) => doneCb(); + schema.methods.afterPatch = (updates, doneCb) => doneCb(); + }, + patch + ); const user = User.fake(); const mock = mockInstance(user); @@ -78,5 +79,4 @@ describe('patch', () => { done(error, updated); }); }); - }); diff --git a/test/unit/post.spec.js b/test/unit/post.spec.js index 00d87e0..85b64ac 100644 --- a/test/unit/post.spec.js +++ b/test/unit/post.spec.js @@ -1,25 +1,22 @@ -'use strict'; - - -/* dependencies */ -const { include } = require('@lykmapipo/include'); -const { +import { sinon, expect, createTestModel, - mockInstance -} = require('@lykmapipo/mongoose-test-helpers'); -const post = include(__dirname, '..', '..', 'lib', 'post'); - + mockInstance, +} from '@lykmapipo/mongoose-test-helpers'; +import post from '../../src/post'; describe('post', () => { - it('should work using `post` static method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforePost = done => done(); - schema.methods.afterPost = done => done(); - }, post); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforePost = doneCb => doneCb(); + schema.methods.afterPost = doneCb => doneCb(); + }, + post + ); const user = User.fake(); const mock = mockInstance(user); @@ -41,11 +38,15 @@ describe('post', () => { }); it('should work using `post` instance method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforePost = done => done(); - schema.methods.afterPost = done => done(); - }, post); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforePost = doneCb => doneCb(); + schema.methods.afterPost = doneCb => doneCb(); + }, + post + ); const user = User.fake(); const mock = mockInstance(user); @@ -65,5 +66,4 @@ describe('post', () => { done(error, created); }); }); - }); diff --git a/test/unit/put.spec.js b/test/unit/put.spec.js index d0c3dac..acebdf2 100644 --- a/test/unit/put.spec.js +++ b/test/unit/put.spec.js @@ -1,27 +1,24 @@ -'use strict'; - - -/* dependencies */ -const _ = require('lodash'); -const { include } = require('@lykmapipo/include'); -const { +import _ from 'lodash'; +import { sinon, expect, createTestModel, mockModel, - mockInstance -} = require('@lykmapipo/mongoose-test-helpers'); -const put = include(__dirname, '..', '..', 'lib', 'put'); - + mockInstance, +} from '@lykmapipo/mongoose-test-helpers'; +import put from '../../src/put'; describe('put', () => { - it('should work using `put` static method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforePut = (updates, done) => done(); - schema.methods.afterPut = (updates, done) => done(); - }, put); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforePut = (updates, doneCb) => doneCb(); + schema.methods.afterPut = (updates, doneCb) => doneCb(); + }, + put + ); const user = User.fake(); const Mock = mockModel(User); @@ -53,11 +50,15 @@ describe('put', () => { }); it('should work using `put` instance method', done => { - - const User = createTestModel({}, schema => { - schema.methods.beforePut = (updates, done) => done(); - schema.methods.afterPut = (updates, done) => done(); - }, put); + const User = createTestModel( + {}, + Schema => { + const schema = Schema; + schema.methods.beforePut = (updates, doneCb) => doneCb(); + schema.methods.afterPut = (updates, doneCb) => doneCb(); + }, + put + ); const user = User.fake(); const mock = mockInstance(user); @@ -78,5 +79,4 @@ describe('put', () => { done(error, updated); }); }); - });