From e19df65a5197240efd832b0eceb48723260f053f Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 4 Mar 2018 04:11:39 +0000 Subject: [PATCH 01/17] add cli param to specify the backup entry point. prep for parallelization --- bin/firestore-backup.js | 14 +- dist/index.js | 17 +- dist/index.js.flow | 19 +- dist/types.js | 33 +- dist/types.js.flow | 36 +- dist/utility.js | 10 +- dist/utility.js.flow | 6 + lib/index.js | 19 +- lib/types.js | 34 +- lib/utility.js | 12 + package-lock.json | 1753 ++++++++++++++------------------------- package.json | 2 + 12 files changed, 830 insertions(+), 1125 deletions(-) diff --git a/bin/firestore-backup.js b/bin/firestore-backup.js index a894f14..c9cd9e6 100755 --- a/bin/firestore-backup.js +++ b/bin/firestore-backup.js @@ -17,10 +17,14 @@ var backupPathParamDescription = 'Path to store backup.' var prettyPrintParamKey = 'prettyPrint' var prettyPrintParamDescription = 'JSON backups done with pretty-printing.' +var databaseStartPathParamKey = 'databaseStartPath' +var databaseStartPathParamDescription = 'The database collection or document path to begin backup.' + commander.version('1.0.1') .option('-a, --' + accountCredentialsPathParamKey + ' ', accountCredentialsPathParamDescription) .option('-B, --' + backupPathParamKey + ' ', backupPathParamDescription) .option('-P, --' + prettyPrintParamKey, prettyPrintParamDescription) + .option('-S, --' + databaseStartPathParamKey + ' ', databaseStartPathParamDescription) .parse(process.argv) const accountCredentialsPath = commander[accountCredentialsPathParamKey] @@ -45,12 +49,14 @@ if (!backupPath) { const prettyPrint = commander[prettyPrintParamKey] !== undefined && commander[prettyPrintParamKey] !== null +const databaseStartPath = (commander[databaseStartPathParamKey] || '').replace(/^\//, '') + var firestoreBackup = require('../dist/index.js') try { - firestoreBackup.default(accountCredentialsPath, backupPath, prettyPrint) - .then(() => { - console.log(colors.bold(colors.green('All done 💫'))) - }) + firestoreBackup.default(accountCredentialsPath, databaseStartPath, backupPath, prettyPrint) + .then(() => { + console.log(colors.bold(colors.green('All done 💫'))) + }) } catch (error) { console.log(colors.red(error)) process.exit(1) diff --git a/dist/index.js b/dist/index.js index 980bea3..9369fc3 100644 --- a/dist/index.js +++ b/dist/index.js @@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", { var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; -exports.default = function (accountCredentials, backupPath, prettyPrintJSON) { +exports.default = function (accountCredentials, databaseStartPath, backupPath, prettyPrintJSON) { var accountCredentialsContents = void 0; if (typeof accountCredentials === 'string') { try { @@ -32,6 +32,19 @@ exports.default = function (accountCredentials, backupPath, prettyPrintJSON) { } var database = _firebaseAdmin2.default.firestore(); + var databasePath = databaseStartPath || ''; + + if ((0, _types.isDocumentPath)(databasePath)) { + var databaseDocument = database.doc(databasePath); + return databaseDocument.get().then(function (document) { + return (0, _firestore.backupDocument)(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON); + }); + } + if ((0, _types.isCollectionPath)(databaseStartPath)) { + var databaseCollection = database.collection(databasePath); + return (0, _firestore.backupCollection)(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON); + } + return (0, _firestore.backupRootCollections)(database, backupPath, prettyPrintJSON); }; @@ -49,4 +62,6 @@ var _mkdirp2 = _interopRequireDefault(_mkdirp); var _firestore = require('./firestore'); +var _types = require('./types'); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } \ No newline at end of file diff --git a/dist/index.js.flow b/dist/index.js.flow index 77dc996..7d3d085 100644 --- a/dist/index.js.flow +++ b/dist/index.js.flow @@ -5,9 +5,10 @@ import Firebase from 'firebase-admin' import fs from 'fs' import mkdirp from 'mkdirp' -import { backupRootCollections } from './firestore' +import { backupRootCollections, backupCollection, backupDocument } from './firestore' +import { isDocumentPath, isCollectionPath } from './types' -export default function (accountCredentials: string | Object, backupPath: string, prettyPrintJSON: boolean) { +export default function(accountCredentials: string | Object, databaseStartPath: string, backupPath: string, prettyPrintJSON: boolean) { let accountCredentialsContents: Object if (typeof accountCredentials === 'string') { try { @@ -33,5 +34,19 @@ export default function (accountCredentials: string | Object, backupPath: string } const database = Firebase.firestore() + const databasePath = (databaseStartPath || ''); + + if(isDocumentPath(databasePath)) { + const databaseDocument = database.doc(databasePath) + return databaseDocument.get() + .then((document)=>{ + return backupDocument(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON) + }) + } + if(isCollectionPath(databaseStartPath)) { + const databaseCollection = database.collection(databasePath) + return backupCollection(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON) + } + return backupRootCollections(database, backupPath, prettyPrintJSON) } diff --git a/dist/types.js b/dist/types.js index d5b1c32..8e2710e 100644 --- a/dist/types.js +++ b/dist/types.js @@ -3,9 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true }); +exports.isCollectionPath = exports.isDocumentPath = exports.isReference = exports.isDate = exports.isBoolean = exports.isUndefined = exports.isNull = exports.isObject = exports.isArray = exports.isNumber = exports.isString = undefined; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; +var _utility = require('./utility'); + // Returns if a value is a string var isString = exports.isString = function isString(value) { if (typeof value === 'string' || value instanceof String) { @@ -18,8 +21,6 @@ var isString = exports.isString = function isString(value) { }; // Returns if a value is really a number - - var isNumber = exports.isNumber = function isNumber(value) { if (typeof value === 'number' && isFinite(value)) { return { @@ -108,4 +109,32 @@ var isReference = exports.isReference = function isReference(value) { }; } return false; +}; + +/** + * Indicates whether this ResourcePath points to a document. + */ +var isDocumentPath = exports.isDocumentPath = function isDocumentPath(value) { + var segments = (0, _utility.getSegments)(value); + if (segments.length > 0 && segments.length % 2 === 0) { + return { + value: value, + type: 'DocumentPath' + }; + } + return false; +}; + +/** + * Indicates whether this ResourcePath points to a collection. + */ +var isCollectionPath = exports.isCollectionPath = function isCollectionPath(value) { + var segments = (0, _utility.getSegments)(value); + if (segments.length % 2 === 1) { + return { + value: value, + type: 'CollectionPath' + }; + } + return false; }; \ No newline at end of file diff --git a/dist/types.js.flow b/dist/types.js.flow index b30ae80..f4a7b4d 100644 --- a/dist/types.js.flow +++ b/dist/types.js.flow @@ -1,8 +1,10 @@ /* @flow */ +import { getSegments } from './utility' + export type ValueDescription = { - value: any, - type: string + value: any, + type: string } export type ValidationResult = ValueDescription | false; @@ -42,7 +44,7 @@ export const isArray = (value: any): ValidationResult => { return false } -const isObjectOfType = (value: any, type: Class, typeName: string): ValidationResult => { +const isObjectOfType = (value: any, type: Class < any > , typeName: string): ValidationResult => { if (value && typeof value === 'object' && value.constructor === type) { return { value, @@ -110,3 +112,31 @@ export const isReference = (value: any): ValidationResult => { } return false } + +/** + * Indicates whether this ResourcePath points to a document. + */ +export const isDocumentPath = (value: string): ValidationResult => { + const segments = getSegments(value) + if (segments.length > 0 && segments.length % 2 === 0) { + return { + value, + type: 'DocumentPath' + } + } + return false +} + +/** + * Indicates whether this ResourcePath points to a collection. + */ +export const isCollectionPath = (value: string): ValidationResult => { + const segments = getSegments(value) + if (segments.length % 2 === 1) { + return { + value, + type: 'CollectionPath' + } + } + return false +} diff --git a/dist/utility.js b/dist/utility.js index 72508a6..841c793 100644 --- a/dist/utility.js +++ b/dist/utility.js @@ -1,4 +1,4 @@ -"use strict"; +'use strict'; Object.defineProperty(exports, "__esModule", { value: true @@ -13,4 +13,12 @@ var promiseSerial = exports.promiseSerial = function promiseSerial(funcs) { }); }); }, Promise.resolve([])); +}; + +var getSegments = exports.getSegments = function getSegments(relativePath) { + // We may have an empty segment at the beginning or end if they had a + // leading or trailing slash (which we allow). + return relativePath.split('/').filter(function (segment) { + return segment.length > 0; + }); }; \ No newline at end of file diff --git a/dist/utility.js.flow b/dist/utility.js.flow index 134ccd7..3eec3c6 100644 --- a/dist/utility.js.flow +++ b/dist/utility.js.flow @@ -10,3 +10,9 @@ export const promiseSerial = (funcs) => { }) }, Promise.resolve([])) } + +export const getSegments = (relativePath) => { + // We may have an empty segment at the beginning or end if they had a + // leading or trailing slash (which we allow). + return relativePath.split('/').filter(segment => segment.length > 0); +} diff --git a/lib/index.js b/lib/index.js index 77dc996..7d3d085 100644 --- a/lib/index.js +++ b/lib/index.js @@ -5,9 +5,10 @@ import Firebase from 'firebase-admin' import fs from 'fs' import mkdirp from 'mkdirp' -import { backupRootCollections } from './firestore' +import { backupRootCollections, backupCollection, backupDocument } from './firestore' +import { isDocumentPath, isCollectionPath } from './types' -export default function (accountCredentials: string | Object, backupPath: string, prettyPrintJSON: boolean) { +export default function(accountCredentials: string | Object, databaseStartPath: string, backupPath: string, prettyPrintJSON: boolean) { let accountCredentialsContents: Object if (typeof accountCredentials === 'string') { try { @@ -33,5 +34,19 @@ export default function (accountCredentials: string | Object, backupPath: string } const database = Firebase.firestore() + const databasePath = (databaseStartPath || ''); + + if(isDocumentPath(databasePath)) { + const databaseDocument = database.doc(databasePath) + return databaseDocument.get() + .then((document)=>{ + return backupDocument(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON) + }) + } + if(isCollectionPath(databaseStartPath)) { + const databaseCollection = database.collection(databasePath) + return backupCollection(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON) + } + return backupRootCollections(database, backupPath, prettyPrintJSON) } diff --git a/lib/types.js b/lib/types.js index b30ae80..217d329 100644 --- a/lib/types.js +++ b/lib/types.js @@ -1,8 +1,10 @@ /* @flow */ +import { getSegments } from './utility' + export type ValueDescription = { - value: any, - type: string + value: any, + type: string } export type ValidationResult = ValueDescription | false; @@ -110,3 +112,31 @@ export const isReference = (value: any): ValidationResult => { } return false } + +/** + * Indicates whether this ResourcePath points to a document. + */ +export const isDocumentPath = (value: string): ValidationResult => { + const segments = getSegments(value) + if (segments.length > 0 && segments.length % 2 === 0) { + return { + value, + type: 'DocumentPath' + } + } + return false +} + +/** + * Indicates whether this ResourcePath points to a collection. + */ +export const isCollectionPath = (value: string): ValidationResult => { + const segments = getSegments(value) + if (segments.length % 2 === 1) { + return { + value, + type: 'CollectionPath' + } + } + return false +} diff --git a/lib/utility.js b/lib/utility.js index 134ccd7..8ba0b40 100644 --- a/lib/utility.js +++ b/lib/utility.js @@ -10,3 +10,15 @@ export const promiseSerial = (funcs) => { }) }, Promise.resolve([])) } + +/** + * Splits a string into path segments, using slashes as separators. + * + * @param {string} relativePath - The path to split. + * @returns {Array.} - The split path segments. + */ +export const getSegments = (relativePath) => { + // We may have an empty segment at the beginning or end if they had a + // leading or trailing slash (which we allow). + return relativePath.split('/').filter(segment => segment.length > 0); +} diff --git a/package-lock.json b/package-lock.json index 828ed1d..11e2265 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,31 +1,33 @@ { "name": "firestore-backup", - "version": "1.2.0", + "version": "2.0.0", "lockfileVersion": 1, "requires": true, "dependencies": { "@firebase/app": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/@firebase/app/-/app-0.1.6.tgz", - "integrity": "sha512-zvA+Tsc6lmuMYmDYsgoXpmPzzLLhdeH97/UVN79YGlFqCihrYAaKUi1/osoAhjXPZaV1+TXoqiSEB2vWHU7Puw==", + "version": "0.1.10", + "resolved": "https://registry.npmjs.org/@firebase/app/-/app-0.1.10.tgz", + "integrity": "sha512-2GTXt3b2QZXkmx6/5nNJq+pEN/VTjAG55MFJS1WMoLVZkwKuNpWNk65QVyPaoL88x1iHtuLqAMFgJUOnhOg+Pw==", "requires": { - "@firebase/app-types": "0.1.1", - "@firebase/util": "0.1.6" + "@firebase/app-types": "0.1.2", + "@firebase/util": "0.1.10", + "tslib": "1.9.0" } }, "@firebase/app-types": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.1.1.tgz", - "integrity": "sha512-0CmY/orojHIJiTyDXUqrAtCSmk2nWw7h7qamJUPcBRgAIfc3ZsjFBLo1zj0sRVzZYbTWS9cKBC8tnpFZlEMLPw==" + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.1.2.tgz", + "integrity": "sha512-bCIZGeMtP0ibrXNNaU214/1tRNw0jHnir/cfiAao1gjUyIS7RzOTQoH+zbwPJNEwUqJ0T3ykw/Tv4/khGqbVBg==" }, "@firebase/database": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.1.7.tgz", - "integrity": "sha512-he63TYGm1IynaaavMEguglgc6o0dhJoBQ9otNM7CIIUadhYbLZU8QZ9gmFhnYj77Qck1H5cJAwTdnZXoIMK6Iw==", - "requires": { - "@firebase/database-types": "0.1.1", - "@firebase/util": "0.1.6", - "faye-websocket": "0.11.1" + "version": "0.1.11", + "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.1.11.tgz", + "integrity": "sha512-1TX8YlL3BCjgsbe1qvgg/r0SxOvIlJdmaktXXm6fnaPCjSD0Vhm5ln2EX3xGY97ft/Lruy9AA/7TfnAKIYA/+w==", + "requires": { + "@firebase/database-types": "0.1.2", + "@firebase/util": "0.1.10", + "faye-websocket": "0.11.1", + "tslib": "1.9.0" }, "dependencies": { "faye-websocket": { @@ -39,28 +41,31 @@ } }, "@firebase/database-types": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.1.1.tgz", - "integrity": "sha512-LbLnwXFeQuxQrsuUccbiXX4j3wdajLPNcbivzypJhww+VU4W/4grnbVn/zPlRlMcG6jTwSyBnjdtJFKMSeNU+A==" + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.1.2.tgz", + "integrity": "sha512-WDqyclInvbD6qNtbVlatzXW6SpsV8V1Nz7DaTM8z27CwxRtXakAXxERPnGipA0ZbZV4v+Xs1+6wC7Xc6T4EVaw==" }, "@firebase/util": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/@firebase/util/-/util-0.1.6.tgz", - "integrity": "sha512-VgEmNlyCOjV69XA1ctGYLqXzRKMG2oEo4L936F8FoDDrkP9+ZKe46ap3prZBbuKLClon7c1JapAnZpMTHwjgBQ==" + "version": "0.1.10", + "resolved": "https://registry.npmjs.org/@firebase/util/-/util-0.1.10.tgz", + "integrity": "sha512-XEogRfUQBZ4T37TMq/3ZbuiTdRAKX8hF3TgJglUZNCJf/6QnQ+jlupCuMAXBqCGfw2Mw0m2matoCUBWpsyevOA==", + "requires": { + "tslib": "1.9.0" + } }, "@google-cloud/common": { - "version": "0.15.1", - "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-0.15.1.tgz", - "integrity": "sha512-cnVtHLvyiSQvb1RzXWDp7PA1sA8Jmc47+wp/xwHwdGOlQZfKog5iluZ0C/LB8iklFXpcTwlNMorqLuZ/qH0DDA==", + "version": "0.16.1", + "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-0.16.1.tgz", + "integrity": "sha512-1sufDsSfgJ7fuBLq+ux8t3TlydMlyWl9kPZx2WdLINkGtf5RjvXX6EWYZiCMKe8flJ3oC0l95j5atN2uX5n3rg==", "requires": { "array-uniq": "1.0.3", "arrify": "1.0.1", "concat-stream": "1.6.0", "create-error-class": "3.0.2", - "duplexify": "3.5.3", + "duplexify": "3.5.4", "ent": "2.2.0", "extend": "3.0.1", - "google-auto-auth": "0.8.2", + "google-auto-auth": "0.9.5", "is": "3.2.1", "log-driver": "1.2.5", "methmeth": "1.1.0", @@ -74,105 +79,58 @@ } }, "@google-cloud/common-grpc": { - "version": "0.5.3", - "resolved": "https://registry.npmjs.org/@google-cloud/common-grpc/-/common-grpc-0.5.3.tgz", - "integrity": "sha512-doRfpmOz1aSYHn8OXWMQbbfswtOFX+Vvs7N2U3wUKu3fs0sK1pvLlu99i5GhHCd/e6ktMWBrsx0/Emk8kWo9QQ==", + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/@google-cloud/common-grpc/-/common-grpc-0.5.5.tgz", + "integrity": "sha512-wgtuBcgTZ7cUMGQV9MSz4y0+FReLqdsOOgzOifu+lsnRh9qsMEZJ9sBDLB6NrRxrvcAHZc4ayiBx7B7i5cDYoA==", "requires": { - "@google-cloud/common": "0.13.6", - "dot-prop": "2.4.0", - "duplexify": "3.5.3", + "@google-cloud/common": "0.16.1", + "dot-prop": "4.2.0", + "duplexify": "3.5.4", "extend": "3.0.1", - "grpc": "1.7.1", + "grpc": "1.7.3", "is": "3.2.1", "modelo": "4.2.3", "retry-request": "3.3.1", "through2": "2.0.3" - }, - "dependencies": { - "@google-cloud/common": { - "version": "0.13.6", - "resolved": "https://registry.npmjs.org/@google-cloud/common/-/common-0.13.6.tgz", - "integrity": "sha1-qdjhN7xCmkSrqWif5qDkMxeE+FM=", - "requires": { - "array-uniq": "1.0.3", - "arrify": "1.0.1", - "concat-stream": "1.6.0", - "create-error-class": "3.0.2", - "duplexify": "3.5.3", - "ent": "2.2.0", - "extend": "3.0.1", - "google-auto-auth": "0.7.2", - "is": "3.2.1", - "log-driver": "1.2.5", - "methmeth": "1.1.0", - "modelo": "4.2.3", - "request": "2.83.0", - "retry-request": "3.3.1", - "split-array-stream": "1.0.3", - "stream-events": "1.0.2", - "string-format-obj": "1.1.1", - "through2": "2.0.3" - } - }, - "google-auth-library": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-0.10.0.tgz", - "integrity": "sha1-bhW6vuhf0d0U2NEoopW2g41SE24=", - "requires": { - "gtoken": "1.2.3", - "jws": "3.1.4", - "lodash.noop": "3.0.1", - "request": "2.83.0" - } - }, - "google-auto-auth": { - "version": "0.7.2", - "resolved": "https://registry.npmjs.org/google-auto-auth/-/google-auto-auth-0.7.2.tgz", - "integrity": "sha512-ux2n2AE2g3+vcLXwL4dP/M12SFMRX5dzCzBfhAEkTeAB7dpyGdOIEj7nmUx0BHKaCcUQrRWg9kT63X/Mmtk1+A==", - "requires": { - "async": "2.6.0", - "gcp-metadata": "0.3.1", - "google-auth-library": "0.10.0", - "request": "2.83.0" - } - } } }, "@google-cloud/firestore": { - "version": "0.10.2", - "resolved": "https://registry.npmjs.org/@google-cloud/firestore/-/firestore-0.10.2.tgz", - "integrity": "sha512-SttuSOqcMA41LOpXAeG78Q9HtHzZio3stjEXIPqDC6edsaVZ4HBjuKYRDYenJx8HMuKNRc+Rar/PtgVPTwBXcQ==", + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/@google-cloud/firestore/-/firestore-0.12.0.tgz", + "integrity": "sha512-sgPAVS+Aax8HNQev4zoXGeMskCzvJ23KWYP0bCVfNabMQ+9UlUfO8Rl5UZSEKI390ORcNyhKCz4Zc3/1t8NhZA==", "requires": { - "@google-cloud/common": "0.15.1", - "@google-cloud/common-grpc": "0.5.3", + "@google-cloud/common": "0.16.1", + "@google-cloud/common-grpc": "0.5.5", "bun": "0.0.12", + "deep-equal": "1.0.1", "extend": "3.0.1", "functional-red-black-tree": "1.0.1", - "google-gax": "0.14.3", - "grpc": "1.7.1", + "google-gax": "0.14.5", "is": "3.2.1", "safe-buffer": "5.1.1", "through2": "2.0.3" } }, "@google-cloud/storage": { - "version": "1.5.2", - "resolved": "https://registry.npmjs.org/@google-cloud/storage/-/storage-1.5.2.tgz", - "integrity": "sha512-E97x2oZr9w0N26H0LtyjR3XLFSLYXH5D8y8HwEZRWQnNVF9sO+x16MEhdHFdFclgdx687eGeCYbDVKpP+dKb6w==", + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/@google-cloud/storage/-/storage-1.6.0.tgz", + "integrity": "sha512-yQ63bJYoiwY220gn/KdTLPoHppAPwFHfG7VFLPwJ+1R5U1eqUN5XV2a7uPj1szGF8/gxlKm2UbE8DgoJJ76DFw==", "requires": { - "@google-cloud/common": "0.15.1", + "@google-cloud/common": "0.16.1", "arrify": "1.0.1", "async": "2.6.0", + "compressible": "2.0.13", "concat-stream": "1.6.0", "create-error-class": "3.0.2", - "duplexify": "3.5.3", + "duplexify": "3.5.4", "extend": "3.0.1", - "gcs-resumable-upload": "0.8.2", + "gcs-resumable-upload": "0.9.0", "hash-stream-validation": "0.2.1", "is": "3.2.1", - "mime-types": "2.1.17", + "mime": "2.2.0", + "mime-types": "2.1.18", "once": "1.4.0", - "pumpify": "1.3.6", + "pumpify": "1.4.0", "request": "2.83.0", "safe-buffer": "5.1.1", "snakeize": "0.1.0", @@ -240,7 +198,7 @@ "resolved": "https://registry.npmjs.org/@types/google-cloud__storage/-/google-cloud__storage-1.1.7.tgz", "integrity": "sha512-010Llp+5ze+XWWmZuLDxs0pZgFjOgtJQVt9icJ0Ed67ZFLq7PnXkYx8x/k9nwDojR5/X4XoLPNqB1F627TScdQ==", "requires": { - "@types/node": "8.5.8" + "@types/node": "8.9.4" } }, "@types/long": { @@ -249,9 +207,9 @@ "integrity": "sha512-ZXyOOm83p7X8p3s0IYM3VeueNmHpkk/yMlP8CLeOnEcu6hIwPH7YjZBvhQkR0ZFS2DqZAxKtJ/M5fcuv3OU5BA==" }, "@types/node": { - "version": "8.5.8", - "resolved": "https://registry.npmjs.org/@types/node/-/node-8.5.8.tgz", - "integrity": "sha512-8KmlRxwbKZfjUHFIt3q8TF5S2B+/E5BaAoo/3mgc5h6FJzqxXkCK/VMetO+IRDtwtU6HUvovHMBn+XRj7SV9Qg==" + "version": "8.9.4", + "resolved": "https://registry.npmjs.org/@types/node/-/node-8.9.4.tgz", + "integrity": "sha512-dSvD36qnQs78G1BPsrZFdPpvLgMW/dnvr5+nTW2csMs5TiP9MOXrjUbnMZOEwnIuBklXtn7b6TPA2Cuq07bDHA==" }, "acorn": { "version": "5.3.0", @@ -259,6 +217,11 @@ "integrity": "sha512-Yej+zOJ1Dm/IMZzzj78OntP/r3zHEaKcyNoU2lAaxPtrseM6rF0xwqoz5Q5ysAiED9hTjI2hgtvLXitlCN1/Ug==", "dev": true }, + "acorn-es7-plugin": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/acorn-es7-plugin/-/acorn-es7-plugin-1.1.7.tgz", + "integrity": "sha1-8u4fMiipDurRJF+asZIusucdM2s=" + }, "acorn-jsx": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", @@ -282,7 +245,7 @@ "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", "requires": { "co": "4.6.0", - "fast-deep-equal": "1.0.0", + "fast-deep-equal": "1.1.0", "fast-json-stable-stringify": "2.0.0", "json-schema-traverse": "0.3.1" } @@ -345,6 +308,11 @@ "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" }, + "array-filter": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-1.0.0.tgz", + "integrity": "sha1-uveeYubvTCpMC4MSMtr/7CUfnYM=" + }, "array-union": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", @@ -425,6 +393,15 @@ "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" }, + "axios": { + "version": "0.17.1", + "resolved": "https://registry.npmjs.org/axios/-/axios-0.17.1.tgz", + "integrity": "sha1-LY4+XQvb1zJ/kbyBT1xXZg+Bgk0=", + "requires": { + "follow-redirects": "1.4.1", + "is-buffer": "1.1.6" + } + }, "babel-cli": { "version": "6.26.0", "resolved": "https://registry.npmjs.org/babel-cli/-/babel-cli-6.26.0.tgz", @@ -1087,7 +1064,7 @@ "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", "requires": { - "hoek": "4.2.0" + "hoek": "4.2.1" } }, "brace-expansion": { @@ -1173,6 +1150,11 @@ "long": "3.2.0" } }, + "call-signature": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/call-signature/-/call-signature-0.0.2.tgz", + "integrity": "sha1-qEq8glpV70yysCi9dOIFpluaSZY=" + }, "caller-path": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", @@ -1287,9 +1269,9 @@ "integrity": "sha1-nLFpkX7F0SwHNtPoaFdG3xyt93g=" }, "combined-stream": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", - "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.6.tgz", + "integrity": "sha1-cj599ugBrFYTETp+RFqbactjKBg=", "requires": { "delayed-stream": "1.0.0" } @@ -1299,6 +1281,14 @@ "resolved": "https://registry.npmjs.org/commander/-/commander-2.13.0.tgz", "integrity": "sha512-MVuS359B+YzaWqjCL/c+22gfryv+mCBPHAv3zyVI2GN8EY6IRP8VwtasXn8jyyhvvq84R4ImN1OKRtcbIasjYA==" }, + "compressible": { + "version": "2.0.13", + "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.13.tgz", + "integrity": "sha1-DRAgq5JLL9tNYnmHXH1tq6a6p6k=", + "requires": { + "mime-db": "1.33.0" + } + }, "concat-map": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", @@ -1321,20 +1311,10 @@ "requires": { "dot-prop": "4.2.0", "graceful-fs": "4.1.11", - "make-dir": "1.1.0", + "make-dir": "1.2.0", "unique-string": "1.0.0", "write-file-atomic": "2.3.0", "xdg-basedir": "3.0.0" - }, - "dependencies": { - "dot-prop": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", - "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", - "requires": { - "is-obj": "1.0.1" - } - } } }, "contains-path": { @@ -1390,7 +1370,7 @@ "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", "requires": { - "hoek": "4.2.0" + "hoek": "4.2.1" } } } @@ -1436,6 +1416,11 @@ "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" }, + "deep-equal": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", + "integrity": "sha1-9dJgKStmDghO/0zbyfCK0yR0SLU=" + }, "deep-is": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", @@ -1446,7 +1431,6 @@ "version": "1.1.2", "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz", "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", - "dev": true, "requires": { "foreach": "2.0.5", "object-keys": "1.0.11" @@ -1510,6 +1494,35 @@ "repeating": "2.0.1" } }, + "diff-match-patch": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/diff-match-patch/-/diff-match-patch-1.0.0.tgz", + "integrity": "sha1-HMPIOkkNZ/ldkeOfatHy4Ia2MEg=" + }, + "dir-glob": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-2.0.0.tgz", + "integrity": "sha512-37qirFDz8cA5fimp9feo43fSuRo2gHwaIn6dXL8Ber1dGwUosDrGZeCCXq57WnIqE4aQ+u3eQZzsk1yOzhdwag==", + "requires": { + "arrify": "1.0.1", + "path-type": "3.0.0" + }, + "dependencies": { + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "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=" + } + } + }, "doctrine": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", @@ -1520,17 +1533,17 @@ } }, "dot-prop": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-2.4.0.tgz", - "integrity": "sha1-hI4o9/HVB0DGdHqzywdnBGK2+Jw=", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", + "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", "requires": { "is-obj": "1.0.1" } }, "duplexify": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.5.3.tgz", - "integrity": "sha512-g8ID9OroF9hKt2POf8YLayy+9594PzmM3scI00/uBXocX3TWNgoB67hjzkFe9ITAbQOne/lLdBxHXvYUM4ZgGA==", + "version": "3.5.4", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.5.4.tgz", + "integrity": "sha512-JzYSLYMhoVVBe8+mbHQ4KgpvHpm0DZpJuL8PY93Vyv1fW7jYJ90LoXa1di/CVbJM+TgMs91rbDapE/RNIfnJsA==", "requires": { "end-of-stream": "1.4.1", "inherits": "2.0.3", @@ -1538,6 +1551,11 @@ "stream-shift": "1.0.0" } }, + "eastasianwidth": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.1.1.tgz", + "integrity": "sha1-RNZW3p2kFWlEZzNTZfsxR7hXK3w=" + }, "ecc-jsbn": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", @@ -1569,6 +1587,24 @@ "electron-releases": "2.1.0" } }, + "empower": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/empower/-/empower-1.2.3.tgz", + "integrity": "sha1-bw2nNEf07dg4/sXGAxOoi6XLhSs=", + "requires": { + "core-js": "2.5.3", + "empower-core": "0.6.2" + } + }, + "empower-core": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/empower-core/-/empower-core-0.6.2.tgz", + "integrity": "sha1-Wt71ZgiOMfuoC6CjbfR9cJQWkUQ=", + "requires": { + "call-signature": "0.0.2", + "core-js": "2.5.3" + } + }, "end-of-stream": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", @@ -1902,6 +1938,14 @@ "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", "dev": true }, + "espurify": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/espurify/-/espurify-1.7.0.tgz", + "integrity": "sha1-HFz2y8zDLm9jk4C9T5kfq5up0iY=", + "requires": { + "core-js": "2.5.3" + } + }, "esquery": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.0.tgz", @@ -1924,8 +1968,7 @@ "estraverse": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", - "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", - "dev": true + "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=" }, "esutils": { "version": "2.0.2", @@ -1998,9 +2041,9 @@ "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" }, "fast-deep-equal": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", - "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=" + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", + "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=" }, "fast-json-stable-stringify": { "version": "2.0.0", @@ -2074,16 +2117,16 @@ } }, "firebase-admin": { - "version": "5.8.0", - "resolved": "https://registry.npmjs.org/firebase-admin/-/firebase-admin-5.8.0.tgz", - "integrity": "sha1-I2NZmtRKSV82c+9YduGMvtazM4U=", - "requires": { - "@firebase/app": "0.1.6", - "@firebase/database": "0.1.7", - "@google-cloud/firestore": "0.10.2", - "@google-cloud/storage": "1.5.2", + "version": "5.9.1", + "resolved": "https://registry.npmjs.org/firebase-admin/-/firebase-admin-5.9.1.tgz", + "integrity": "sha1-Ht9iSNAUBj8ORz+E/p1j3xjlOAc=", + "requires": { + "@firebase/app": "0.1.10", + "@firebase/database": "0.1.11", + "@google-cloud/firestore": "0.12.0", + "@google-cloud/storage": "1.6.0", "@types/google-cloud__storage": "1.1.7", - "@types/node": "8.5.8", + "@types/node": "8.9.4", "faye-websocket": "0.9.3", "jsonwebtoken": "8.1.0", "node-forge": "0.7.1" @@ -2191,6 +2234,24 @@ } } }, + "follow-redirects": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.4.1.tgz", + "integrity": "sha512-uxYePVPogtya1ktGnAAXOacnbIuRMB4dkvqeNz2qTtTQsuzSfbDolV+wMMKxAmCx0bLgAKLbBOkjItMbbkR1vg==", + "requires": { + "debug": "3.1.0" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "requires": { + "ms": "2.0.0" + } + } + } + }, "for-in": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", @@ -2207,8 +2268,7 @@ "foreach": { "version": "2.0.5", "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz", - "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=", - "dev": true + "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=" }, "forever-agent": { "version": "0.6.1", @@ -2216,13 +2276,13 @@ "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" }, "form-data": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", - "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.2.tgz", + "integrity": "sha1-SXBJi+YEwgwAXU9cI67NIda0kJk=", "requires": { "asynckit": "0.4.0", - "combined-stream": "1.0.5", - "mime-types": "2.1.17" + "combined-stream": "1.0.6", + "mime-types": "2.1.18" } }, "fs-extra": { @@ -2258,50 +2318,27 @@ "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=" }, "gcp-metadata": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-0.3.1.tgz", - "integrity": "sha512-5kJPX/RXuqoLmHiOOgkSDk/LI0QaXpEvZ3pvQP4ifjGGDKZKVSOjL/GcDjXA5kLxppFCOjmmsu0Uoop9d1upaQ==", + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-0.6.1.tgz", + "integrity": "sha512-Ju3brkV7kYOBP5s3Z6HS2xd7gyH9MDfuKeB+y51SsI8GPrD37NOB5Re9fWXQQVAkd74zzVOScnNic1lcRsWD9w==", "requires": { + "axios": "0.17.1", "extend": "3.0.1", - "retry-request": "3.3.1" + "retry-axios": "0.3.0" } }, "gcs-resumable-upload": { - "version": "0.8.2", - "resolved": "https://registry.npmjs.org/gcs-resumable-upload/-/gcs-resumable-upload-0.8.2.tgz", - "integrity": "sha512-PBl1OFABYxubxfYPh000I0+JLbQzBRtNqxzgxYboIQk2tdw7BvjJ2dVukk3YH4QM6GiUwqItyNqWBuxjLH8GhA==", + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/gcs-resumable-upload/-/gcs-resumable-upload-0.9.0.tgz", + "integrity": "sha512-+Zrmr0JKO2y/2mg953TW6JLu+NAMHqQsKzqCm7CIT24gMQakolPJCMzDleVpVjXAqB7ZCD276tcUq2ebOfqTug==", "requires": { "buffer-equal": "1.0.0", "configstore": "3.1.1", - "google-auto-auth": "0.7.2", - "pumpify": "1.3.6", + "google-auto-auth": "0.9.5", + "pumpify": "1.4.0", "request": "2.83.0", "stream-events": "1.0.2", "through2": "2.0.3" - }, - "dependencies": { - "google-auth-library": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-0.10.0.tgz", - "integrity": "sha1-bhW6vuhf0d0U2NEoopW2g41SE24=", - "requires": { - "gtoken": "1.2.3", - "jws": "3.1.4", - "lodash.noop": "3.0.1", - "request": "2.83.0" - } - }, - "google-auto-auth": { - "version": "0.7.2", - "resolved": "https://registry.npmjs.org/google-auto-auth/-/google-auto-auth-0.7.2.tgz", - "integrity": "sha512-ux2n2AE2g3+vcLXwL4dP/M12SFMRX5dzCzBfhAEkTeAB7dpyGdOIEj7nmUx0BHKaCcUQrRWg9kT63X/Mmtk1+A==", - "requires": { - "async": "2.6.0", - "gcp-metadata": "0.3.1", - "google-auth-library": "0.10.0", - "request": "2.83.0" - } - } } }, "generate-function": { @@ -2338,838 +2375,135 @@ "dev": true }, "getpass": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", - "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", - "requires": { - "assert-plus": "1.0.0" - } - }, - "glob": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", - "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", - "requires": { - "fs.realpath": "1.0.0", - "inflight": "1.0.6", - "inherits": "2.0.3", - "minimatch": "3.0.4", - "once": "1.4.0", - "path-is-absolute": "1.0.1" - } - }, - "glob-base": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", - "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", - "requires": { - "glob-parent": "2.0.0", - "is-glob": "2.0.1" - } - }, - "glob-parent": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", - "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", - "requires": { - "is-glob": "2.0.1" - } - }, - "globals": { - "version": "9.18.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", - "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==" - }, - "globby": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", - "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", - "requires": { - "array-union": "1.0.2", - "glob": "7.1.2", - "object-assign": "4.1.1", - "pify": "2.3.0", - "pinkie-promise": "2.0.1" - } - }, - "google-auth-library": { - "version": "0.12.0", - "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-0.12.0.tgz", - "integrity": "sha512-79qCXtJ1VweBmmLr4yLq9S4clZB2p5Y+iACvuKk9gu4JitEnPc+bQFmYvtCYehVR44MQzD1J8DVmYW2w677IEw==", - "requires": { - "gtoken": "1.2.3", - "jws": "3.1.4", - "lodash.isstring": "4.0.1", - "lodash.merge": "4.6.0", - "request": "2.83.0" - } - }, - "google-auto-auth": { - "version": "0.8.2", - "resolved": "https://registry.npmjs.org/google-auto-auth/-/google-auto-auth-0.8.2.tgz", - "integrity": "sha512-W91J1paFbyG45gpDWdTu9tKDxbiTDWYkOAxytNVF4oHVVgTCBV/8+lWdjj/6ldjN3eb+sEd9PKJBjm0kmCxvcw==", - "requires": { - "async": "2.6.0", - "gcp-metadata": "0.3.1", - "google-auth-library": "0.12.0", - "request": "2.83.0" - } - }, - "google-gax": { - "version": "0.14.3", - "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-0.14.3.tgz", - "integrity": "sha512-5HpwzDO+Lw2I2PrfU2T07tO6ri7VBpftW4cbefSD89zARII/iPCCDkiItgvzNHWZhlD1UsUC9yJob7twghzlug==", - "requires": { - "extend": "3.0.1", - "globby": "6.1.0", - "google-auto-auth": "0.8.2", - "google-proto-files": "0.13.1", - "grpc": "1.7.3", - "is-stream-ended": "0.1.3", - "lodash": "4.17.4", - "process-nextick-args": "1.0.7", - "protobufjs": "6.8.4", - "readable-stream": "2.3.3", - "through2": "2.0.3" - }, - "dependencies": { - "grpc": { - "version": "1.7.3", - "resolved": "https://registry.npmjs.org/grpc/-/grpc-1.7.3.tgz", - "integrity": "sha512-7zXQJlDXMr/ZaDqdaIchgclViyoWo8GQxZSmFUAxR8GwSr28b6/BTgF221WG+2W693jpp74XJ/+I9DcPXsgt9Q==", - "requires": { - "arguejs": "0.2.3", - "lodash": "4.17.4", - "nan": "2.8.0", - "node-pre-gyp": "0.6.39", - "protobufjs": "5.0.2" - }, - "dependencies": { - "abbrev": { - "version": "1.0.9", - "bundled": true - }, - "ajv": { - "version": "4.11.8", - "bundled": true, - "requires": { - "co": "4.6.0", - "json-stable-stringify": "1.0.1" - } - }, - "ansi-regex": { - "version": "2.1.1", - "bundled": true - }, - "aproba": { - "version": "1.2.0", - "bundled": true - }, - "are-we-there-yet": { - "version": "1.1.4", - "bundled": true, - "requires": { - "delegates": "1.0.0", - "readable-stream": "2.3.3" - } - }, - "asn1": { - "version": "0.2.3", - "bundled": true - }, - "assert-plus": { - "version": "0.2.0", - "bundled": true - }, - "asynckit": { - "version": "0.4.0", - "bundled": true - }, - "aws-sign2": { - "version": "0.6.0", - "bundled": true - }, - "aws4": { - "version": "1.6.0", - "bundled": true - }, - "balanced-match": { - "version": "1.0.0", - "bundled": true - }, - "bcrypt-pbkdf": { - "version": "1.0.1", - "bundled": true, - "optional": true, - "requires": { - "tweetnacl": "0.14.5" - } - }, - "block-stream": { - "version": "0.0.9", - "bundled": true, - "requires": { - "inherits": "2.0.3" - } - }, - "boom": { - "version": "2.10.1", - "bundled": true, - "requires": { - "hoek": "2.16.3" - } - }, - "brace-expansion": { - "version": "1.1.8", - "bundled": true, - "requires": { - "balanced-match": "1.0.0", - "concat-map": "0.0.1" - } - }, - "caseless": { - "version": "0.12.0", - "bundled": true - }, - "co": { - "version": "4.6.0", - "bundled": true - }, - "code-point-at": { - "version": "1.1.0", - "bundled": true - }, - "combined-stream": { - "version": "1.0.5", - "bundled": true, - "requires": { - "delayed-stream": "1.0.0" - } - }, - "concat-map": { - "version": "0.0.1", - "bundled": true - }, - "console-control-strings": { - "version": "1.1.0", - "bundled": true - }, - "core-util-is": { - "version": "1.0.2", - "bundled": true - }, - "cryptiles": { - "version": "2.0.5", - "bundled": true, - "requires": { - "boom": "2.10.1" - } - }, - "dashdash": { - "version": "1.14.1", - "bundled": true, - "requires": { - "assert-plus": "1.0.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true - } - } - }, - "debug": { - "version": "2.6.8", - "bundled": true, - "requires": { - "ms": "2.0.0" - } - }, - "deep-extend": { - "version": "0.4.2", - "bundled": true - }, - "delayed-stream": { - "version": "1.0.0", - "bundled": true - }, - "delegates": { - "version": "1.0.0", - "bundled": true - }, - "detect-libc": { - "version": "1.0.2", - "bundled": true - }, - "ecc-jsbn": { - "version": "0.1.1", - "bundled": true, - "optional": true, - "requires": { - "jsbn": "0.1.1" - } - }, - "extend": { - "version": "3.0.1", - "bundled": true - }, - "extsprintf": { - "version": "1.3.0", - "bundled": true - }, - "forever-agent": { - "version": "0.6.1", - "bundled": true - }, - "form-data": { - "version": "2.1.4", - "bundled": true, - "requires": { - "asynckit": "0.4.0", - "combined-stream": "1.0.5", - "mime-types": "2.1.17" - } - }, - "fs.realpath": { - "version": "1.0.0", - "bundled": true - }, - "fstream": { - "version": "1.0.11", - "bundled": true, - "requires": { - "graceful-fs": "4.1.11", - "inherits": "2.0.3", - "mkdirp": "0.5.1", - "rimraf": "2.6.2" - } - }, - "fstream-ignore": { - "version": "1.0.5", - "bundled": true, - "requires": { - "fstream": "1.0.11", - "inherits": "2.0.3", - "minimatch": "3.0.4" - } - }, - "gauge": { - "version": "2.7.4", - "bundled": true, - "requires": { - "aproba": "1.2.0", - "console-control-strings": "1.1.0", - "has-unicode": "2.0.1", - "object-assign": "4.1.1", - "signal-exit": "3.0.2", - "string-width": "1.0.2", - "strip-ansi": "3.0.1", - "wide-align": "1.1.2" - } - }, - "getpass": { - "version": "0.1.7", - "bundled": true, - "requires": { - "assert-plus": "1.0.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true - } - } - }, - "glob": { - "version": "7.1.1", - "bundled": true, - "requires": { - "fs.realpath": "1.0.0", - "inflight": "1.0.6", - "inherits": "2.0.3", - "minimatch": "3.0.4", - "once": "1.4.0", - "path-is-absolute": "1.0.1" - } - }, - "graceful-fs": { - "version": "4.1.11", - "bundled": true - }, - "har-schema": { - "version": "1.0.5", - "bundled": true - }, - "har-validator": { - "version": "4.2.1", - "bundled": true, - "requires": { - "ajv": "4.11.8", - "har-schema": "1.0.5" - } - }, - "has-unicode": { - "version": "2.0.1", - "bundled": true - }, - "hawk": { - "version": "3.1.3", - "bundled": true, - "requires": { - "boom": "2.10.1", - "cryptiles": "2.0.5", - "hoek": "2.16.3", - "sntp": "1.0.9" - } - }, - "hoek": { - "version": "2.16.3", - "bundled": true - }, - "http-signature": { - "version": "1.1.1", - "bundled": true, - "requires": { - "assert-plus": "0.2.0", - "jsprim": "1.4.1", - "sshpk": "1.13.1" - } - }, - "inflight": { - "version": "1.0.6", - "bundled": true, - "requires": { - "once": "1.4.0", - "wrappy": "1.0.2" - } - }, - "inherits": { - "version": "2.0.3", - "bundled": true - }, - "ini": { - "version": "1.3.4", - "bundled": true - }, - "is-fullwidth-code-point": { - "version": "1.0.0", - "bundled": true, - "requires": { - "number-is-nan": "1.0.1" - } - }, - "is-typedarray": { - "version": "1.0.0", - "bundled": true - }, - "isarray": { - "version": "1.0.0", - "bundled": true - }, - "isstream": { - "version": "0.1.2", - "bundled": true - }, - "jsbn": { - "version": "0.1.1", - "bundled": true, - "optional": true - }, - "json-schema": { - "version": "0.2.3", - "bundled": true - }, - "json-stable-stringify": { - "version": "1.0.1", - "bundled": true, - "requires": { - "jsonify": "0.0.0" - } - }, - "json-stringify-safe": { - "version": "5.0.1", - "bundled": true - }, - "jsonify": { - "version": "0.0.0", - "bundled": true - }, - "jsprim": { - "version": "1.4.1", - "bundled": true, - "requires": { - "assert-plus": "1.0.0", - "extsprintf": "1.3.0", - "json-schema": "0.2.3", - "verror": "1.10.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true - } - } - }, - "mime-db": { - "version": "1.30.0", - "bundled": true - }, - "mime-types": { - "version": "2.1.17", - "bundled": true, - "requires": { - "mime-db": "1.30.0" - } - }, - "minimatch": { - "version": "3.0.4", - "bundled": true, - "requires": { - "brace-expansion": "1.1.8" - } - }, - "minimist": { - "version": "0.0.8", - "bundled": true - }, - "mkdirp": { - "version": "0.5.1", - "bundled": true, - "requires": { - "minimist": "0.0.8" - } - }, - "ms": { - "version": "2.0.0", - "bundled": true - }, - "node-pre-gyp": { - "version": "0.6.39", - "bundled": true, - "requires": { - "detect-libc": "1.0.2", - "hawk": "3.1.3", - "mkdirp": "0.5.1", - "nopt": "4.0.1", - "npmlog": "4.1.2", - "rc": "1.2.2", - "request": "2.81.0", - "rimraf": "2.6.2", - "semver": "5.4.1", - "tar": "2.2.1", - "tar-pack": "3.4.1" - }, - "dependencies": { - "nopt": { - "version": "4.0.1", - "bundled": true, - "requires": { - "abbrev": "1.0.9", - "osenv": "0.1.4" - } - } - } - }, - "npmlog": { - "version": "4.1.2", - "bundled": true, - "requires": { - "are-we-there-yet": "1.1.4", - "console-control-strings": "1.1.0", - "gauge": "2.7.4", - "set-blocking": "2.0.0" - } - }, - "number-is-nan": { - "version": "1.0.1", - "bundled": true - }, - "oauth-sign": { - "version": "0.8.2", - "bundled": true - }, - "object-assign": { - "version": "4.1.1", - "bundled": true - }, - "once": { - "version": "1.4.0", - "bundled": true, - "requires": { - "wrappy": "1.0.2" - } - }, - "os-homedir": { - "version": "1.0.2", - "bundled": true - }, - "os-tmpdir": { - "version": "1.0.2", - "bundled": true - }, - "osenv": { - "version": "0.1.4", - "bundled": true, - "requires": { - "os-homedir": "1.0.2", - "os-tmpdir": "1.0.2" - } - }, - "path-is-absolute": { - "version": "1.0.1", - "bundled": true - }, - "performance-now": { - "version": "0.2.0", - "bundled": true - }, - "process-nextick-args": { - "version": "1.0.7", - "bundled": true - }, - "protobufjs": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-5.0.2.tgz", - "integrity": "sha1-WXSNfc8D0tsiwT2p/rAk4Wq4DJE=", - "requires": { - "ascli": "1.0.1", - "bytebuffer": "5.0.1", - "glob": "7.1.1", - "yargs": "3.32.0" - } - }, - "punycode": { - "version": "1.4.1", - "bundled": true - }, - "qs": { - "version": "6.4.0", - "bundled": true - }, - "rc": { - "version": "1.2.2", - "bundled": true, - "requires": { - "deep-extend": "0.4.2", - "ini": "1.3.4", - "minimist": "1.2.0", - "strip-json-comments": "2.0.1" - }, - "dependencies": { - "minimist": { - "version": "1.2.0", - "bundled": true - } - } - }, - "readable-stream": { - "version": "2.3.3", - "bundled": true, - "requires": { - "core-util-is": "1.0.2", - "inherits": "2.0.3", - "isarray": "1.0.0", - "process-nextick-args": "1.0.7", - "safe-buffer": "5.1.1", - "string_decoder": "1.0.3", - "util-deprecate": "1.0.2" - } - }, - "request": { - "version": "2.81.0", - "bundled": true, - "requires": { - "aws-sign2": "0.6.0", - "aws4": "1.6.0", - "caseless": "0.12.0", - "combined-stream": "1.0.5", - "extend": "3.0.1", - "forever-agent": "0.6.1", - "form-data": "2.1.4", - "har-validator": "4.2.1", - "hawk": "3.1.3", - "http-signature": "1.1.1", - "is-typedarray": "1.0.0", - "isstream": "0.1.2", - "json-stringify-safe": "5.0.1", - "mime-types": "2.1.17", - "oauth-sign": "0.8.2", - "performance-now": "0.2.0", - "qs": "6.4.0", - "safe-buffer": "5.1.1", - "stringstream": "0.0.5", - "tough-cookie": "2.3.3", - "tunnel-agent": "0.6.0", - "uuid": "3.1.0" - } - }, - "rimraf": { - "version": "2.6.2", - "bundled": true, - "requires": { - "glob": "7.1.1" - } - }, - "safe-buffer": { - "version": "5.1.1", - "bundled": true - }, - "semver": { - "version": "5.4.1", - "bundled": true - }, - "set-blocking": { - "version": "2.0.0", - "bundled": true - }, - "signal-exit": { - "version": "3.0.2", - "bundled": true - }, - "sntp": { - "version": "1.0.9", - "bundled": true, - "requires": { - "hoek": "2.16.3" - } - }, - "sshpk": { - "version": "1.13.1", - "bundled": true, - "requires": { - "asn1": "0.2.3", - "assert-plus": "1.0.0", - "bcrypt-pbkdf": "1.0.1", - "dashdash": "1.14.1", - "ecc-jsbn": "0.1.1", - "getpass": "0.1.7", - "jsbn": "0.1.1", - "tweetnacl": "0.14.5" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true - } - } - }, - "string_decoder": { - "version": "1.0.3", - "bundled": true, - "requires": { - "safe-buffer": "5.1.1" - } - }, - "string-width": { - "version": "1.0.2", - "bundled": true, - "requires": { - "code-point-at": "1.1.0", - "is-fullwidth-code-point": "1.0.0", - "strip-ansi": "3.0.1" - } - }, - "stringstream": { - "version": "0.0.5", - "bundled": true - }, - "strip-ansi": { - "version": "3.0.1", - "bundled": true, - "requires": { - "ansi-regex": "2.1.1" - } - }, - "strip-json-comments": { - "version": "2.0.1", - "bundled": true - }, - "tar": { - "version": "2.2.1", - "bundled": true, - "requires": { - "block-stream": "0.0.9", - "fstream": "1.0.11", - "inherits": "2.0.3" - } - }, - "tar-pack": { - "version": "3.4.1", - "bundled": true, - "requires": { - "debug": "2.6.8", - "fstream": "1.0.11", - "fstream-ignore": "1.0.5", - "once": "1.4.0", - "readable-stream": "2.3.3", - "rimraf": "2.6.2", - "tar": "2.2.1", - "uid-number": "0.0.6" - } - }, - "tough-cookie": { - "version": "2.3.3", - "bundled": true, - "requires": { - "punycode": "1.4.1" - } - }, - "tunnel-agent": { - "version": "0.6.0", - "bundled": true, - "requires": { - "safe-buffer": "5.1.1" - } - }, - "tweetnacl": { - "version": "0.14.5", - "bundled": true, - "optional": true - }, - "uid-number": { - "version": "0.0.6", - "bundled": true - }, - "util-deprecate": { - "version": "1.0.2", - "bundled": true - }, - "uuid": { - "version": "3.1.0", - "bundled": true - }, - "verror": { - "version": "1.10.0", - "bundled": true, - "requires": { - "assert-plus": "1.0.0", - "core-util-is": "1.0.2", - "extsprintf": "1.3.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true - } - } - }, - "wide-align": { - "version": "1.1.2", - "bundled": true, - "requires": { - "string-width": "1.0.2" - } - }, - "wrappy": { - "version": "1.0.2", - "bundled": true - } + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "requires": { + "assert-plus": "1.0.0" + } + }, + "glob": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", + "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "glob-base": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", + "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", + "requires": { + "glob-parent": "2.0.0", + "is-glob": "2.0.1" + } + }, + "glob-parent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", + "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", + "requires": { + "is-glob": "2.0.1" + } + }, + "globals": { + "version": "9.18.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", + "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==" + }, + "globby": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/globby/-/globby-7.1.1.tgz", + "integrity": "sha1-+yzP+UAfhgCUXfral0QMypcrhoA=", + "requires": { + "array-union": "1.0.2", + "dir-glob": "2.0.0", + "glob": "7.1.2", + "ignore": "3.3.7", + "pify": "3.0.0", + "slash": "1.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + } + } + }, + "google-auth-library": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-1.3.1.tgz", + "integrity": "sha512-NcAzFY+ScalfjmFTHnCXInuivtbIfib9irJ5H8AHONy3eA56YW1Tu5X1dtbjw5TNBgP+BMu+nIrglJsAlfZ/Hg==", + "requires": { + "axios": "0.18.0", + "gcp-metadata": "0.6.1", + "gtoken": "2.1.0", + "jws": "3.1.4", + "lodash.isstring": "4.0.1", + "lru-cache": "4.1.1", + "retry-axios": "0.3.2" + }, + "dependencies": { + "axios": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/axios/-/axios-0.18.0.tgz", + "integrity": "sha1-MtU+SFHv3AoRmTts0AB4nXDAUQI=", + "requires": { + "follow-redirects": "1.4.1", + "is-buffer": "1.1.6" } }, + "retry-axios": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/retry-axios/-/retry-axios-0.3.2.tgz", + "integrity": "sha512-jp4YlI0qyDFfXiXGhkCOliBN1G7fRH03Nqy8YdShzGqbY5/9S2x/IR6C88ls2DFkbWuL3ASkP7QD3pVrNpPgwQ==" + } + } + }, + "google-auto-auth": { + "version": "0.9.5", + "resolved": "https://registry.npmjs.org/google-auto-auth/-/google-auto-auth-0.9.5.tgz", + "integrity": "sha512-1utCjz63uolG4qAH+i1h7kIXmXaMRZFBsW5AmPNSi9f2ai1zJOayZV2wbi7TJrypA6xnPAi58bnIqg9XLThhow==", + "requires": { + "async": "2.6.0", + "gcp-metadata": "0.6.1", + "google-auth-library": "1.3.1", + "request": "2.83.0" + } + }, + "google-gax": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-0.14.5.tgz", + "integrity": "sha512-3A6KbrtLDavrqZnnzurnSydRIJnyH+2Sm56fAvXciQ/62aEnSDaR43MCgWhtReCLVjeFjBiCEIdX5zV0LVLVBg==", + "requires": { + "extend": "3.0.1", + "globby": "7.1.1", + "google-auto-auth": "0.9.5", + "google-proto-files": "0.14.2", + "grpc": "1.7.3", + "is-stream-ended": "0.1.3", + "lodash": "4.17.4", + "protobufjs": "6.8.6", + "readable-stream": "2.3.3", + "through2": "2.0.3" + }, + "dependencies": { + "long": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", + "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" + }, "protobufjs": { - "version": "6.8.4", - "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.8.4.tgz", - "integrity": "sha512-d+WZqUDXKM+oZhr8yprAtQW07q08p9/V35AJ2J1fds+r903S/aH9P8uO1gmTwozOKugt2XCjdrre3OxuPRGkGg==", + "version": "6.8.6", + "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.8.6.tgz", + "integrity": "sha512-eH2OTP9s55vojr3b7NBaF9i4WhWPkv/nq55nznWNp/FomKrLViprUcqnBjHph2tFQ+7KciGPTPsVWGz0SOhL0Q==", "requires": { "@protobufjs/aspromise": "1.1.2", "@protobufjs/base64": "1.1.2", @@ -3182,24 +2516,65 @@ "@protobufjs/pool": "1.1.0", "@protobufjs/utf8": "1.1.0", "@types/long": "3.0.32", - "@types/node": "8.5.8", - "long": "3.2.0" + "@types/node": "8.9.4", + "long": "4.0.0" } } } }, "google-p12-pem": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-0.1.2.tgz", - "integrity": "sha1-M8RqsCGqc0+gMys5YKmj/8svMXc=", + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-1.0.0.tgz", + "integrity": "sha512-tqu8IJF307iH8vXQEI5ZhuIk89vAf25rmoyoenckm/zY7Elzm4X/x6OPOk4wa3sRzkA/Y2CkubpvLxSEgIEQcg==", "requires": { - "node-forge": "0.7.1" + "node-forge": "0.7.1", + "pify": "3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + } } }, "google-proto-files": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/google-proto-files/-/google-proto-files-0.13.1.tgz", - "integrity": "sha512-CivI3rZ85dMPTCAyxq6lq9s7vDkeWEIFxweopC1vEjjRmFMJwOX/MOmFZ90a0BGal/Dsb63vq7Ael9ryeokz0g==" + "version": "0.14.2", + "resolved": "https://registry.npmjs.org/google-proto-files/-/google-proto-files-0.14.2.tgz", + "integrity": "sha512-wwm2TIlfTgAjDbjrxAb3akznO7vBM0PRLS6Xf2QfR3L7b0p+szD3iwOW0wMSFl3B0UbLv27hUVk+clePqCVmXA==", + "requires": { + "globby": "7.1.1", + "power-assert": "1.4.4", + "prettier": "1.11.1", + "protobufjs": "6.8.6" + }, + "dependencies": { + "long": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", + "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" + }, + "protobufjs": { + "version": "6.8.6", + "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.8.6.tgz", + "integrity": "sha512-eH2OTP9s55vojr3b7NBaF9i4WhWPkv/nq55nznWNp/FomKrLViprUcqnBjHph2tFQ+7KciGPTPsVWGz0SOhL0Q==", + "requires": { + "@protobufjs/aspromise": "1.1.2", + "@protobufjs/base64": "1.1.2", + "@protobufjs/codegen": "2.0.4", + "@protobufjs/eventemitter": "1.1.0", + "@protobufjs/fetch": "1.1.0", + "@protobufjs/float": "1.0.2", + "@protobufjs/inquire": "1.1.0", + "@protobufjs/path": "1.1.2", + "@protobufjs/pool": "1.1.0", + "@protobufjs/utf8": "1.1.0", + "@types/long": "3.0.32", + "@types/node": "8.9.4", + "long": "4.0.0" + } + } + } }, "graceful-fs": { "version": "4.1.11", @@ -3207,13 +2582,13 @@ "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" }, "grpc": { - "version": "1.7.1", - "resolved": "https://registry.npmjs.org/grpc/-/grpc-1.7.1.tgz", - "integrity": "sha512-lMgjZUzJx09VL5iCfs7rFagE5htikdv/9VzX/ji3zuwlzAhijqcU47bi5N5lbVw/UB2fxneeYg8sBTfQfd0c4A==", + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/grpc/-/grpc-1.7.3.tgz", + "integrity": "sha512-7zXQJlDXMr/ZaDqdaIchgclViyoWo8GQxZSmFUAxR8GwSr28b6/BTgF221WG+2W693jpp74XJ/+I9DcPXsgt9Q==", "requires": { "arguejs": "0.2.3", "lodash": "4.17.4", - "nan": "2.8.0", + "nan": "2.9.2", "node-pre-gyp": "0.6.39", "protobufjs": "5.0.2" }, @@ -3815,13 +3190,6 @@ } } }, - "string_decoder": { - "version": "1.0.3", - "bundled": true, - "requires": { - "safe-buffer": "5.1.1" - } - }, "string-width": { "version": "1.0.2", "bundled": true, @@ -3831,6 +3199,13 @@ "strip-ansi": "3.0.1" } }, + "string_decoder": { + "version": "1.0.3", + "bundled": true, + "requires": { + "safe-buffer": "5.1.1" + } + }, "stringstream": { "version": "0.0.5", "bundled": true @@ -3929,14 +3304,22 @@ } }, "gtoken": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-1.2.3.tgz", - "integrity": "sha512-wQAJflfoqSgMWrSBk9Fg86q+sd6s7y6uJhIvvIPz++RElGlMtEqsdAR2oWwZ/WTEtp7P9xFbJRrT976oRgzJ/w==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-2.1.0.tgz", + "integrity": "sha512-r/dh/cVgPBWHcskq03KOSDl+L+0Ac0B8VEhpIbnrcsvHSJHdkEtwbC0lOZNxBIqWbM1+HNig8jpuCwKJzCcilg==", "requires": { - "google-p12-pem": "0.1.2", + "axios": "0.17.1", + "google-p12-pem": "1.0.0", "jws": "3.1.4", - "mime": "1.6.0", - "request": "2.83.0" + "mime": "2.2.0", + "pify": "3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + } } }, "har-schema": { @@ -3991,14 +3374,14 @@ "requires": { "boom": "4.3.1", "cryptiles": "3.1.2", - "hoek": "4.2.0", + "hoek": "4.2.1", "sntp": "2.1.0" } }, "hoek": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.0.tgz", - "integrity": "sha512-v0XCLxICi9nPfYrS9RL8HbYnXi9obYAeLbSP00BmnZwCK9+Ih9WOjoZ8YoHCoav2csqn4FOz4Orldsy2dmDwmQ==" + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.1.tgz", + "integrity": "sha512-QLg82fGkfnJ/4iy1xZ81/9SIJiq1NGFUMGs6ParyjBZr6jW2Ufj/snDqTHixNlHdPNwN2RLVD0Pi3igeK9+JfA==" }, "home-or-tmp": { "version": "2.0.0", @@ -4016,9 +3399,9 @@ "dev": true }, "http-parser-js": { - "version": "0.4.9", - "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.9.tgz", - "integrity": "sha1-6hoE+2St/wJC6ZdPKX3Uw8rSceE=" + "version": "0.4.10", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.10.tgz", + "integrity": "sha1-ksnBN0w1CF912zWexWzCV8u5P6Q=" }, "http-signature": { "version": "1.2.0", @@ -4033,14 +3416,18 @@ "ignore": { "version": "3.3.7", "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.7.tgz", - "integrity": "sha512-YGG3ejvBNHRqu0559EOxxNFihD0AjpvHlC/pdGKd3X3ofe+CoJkYazwNJYTNebqpPKN+VVQbh4ZFn1DivMNuHA==", - "dev": true + "integrity": "sha512-YGG3ejvBNHRqu0559EOxxNFihD0AjpvHlC/pdGKd3X3ofe+CoJkYazwNJYTNebqpPKN+VVQbh4ZFn1DivMNuHA==" }, "imurmurhash": { "version": "0.1.4", "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" }, + "indexof": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", + "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=" + }, "inflight": { "version": "1.0.6", "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", @@ -4548,16 +3935,6 @@ "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" }, - "lodash.merge": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.0.tgz", - "integrity": "sha1-aYhLoUSsM/5plzemCG3v+t0PicU=" - }, - "lodash.noop": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/lodash.noop/-/lodash.noop-3.0.1.tgz", - "integrity": "sha1-OBiPTWUKOkdCWEObluxFsyYXEzw=" - }, "lodash.once": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", @@ -4585,16 +3962,15 @@ "version": "4.1.1", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", - "dev": true, "requires": { "pseudomap": "1.0.2", "yallist": "2.1.2" } }, "make-dir": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.1.0.tgz", - "integrity": "sha512-0Pkui4wLJ7rxvmfUvs87skoEaxmu0hCUApF8nonzpl7q//FWp9zu8W61Scz4sd/kUiqDxvUhtoam2efDyiBzcA==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.2.0.tgz", + "integrity": "sha512-aNUAa4UMg/UougV25bbrU4ZaaKNjJ/3/xnvg/twpmKROPdKZPZ9wGgI0opdZzO8q/zUFawoUuixuOv33eZ61Iw==", "requires": { "pify": "3.0.0" }, @@ -4641,21 +4017,21 @@ } }, "mime": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", - "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.2.0.tgz", + "integrity": "sha512-0Qz9uF1ATtl8RKJG4VRfOymh7PyEor6NbrI/61lRfuRe4vx9SNATrvAeTj2EWVRKjEQGskrzWkJBBY5NbaVHIA==" }, "mime-db": { - "version": "1.30.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", - "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=" + "version": "1.33.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.33.0.tgz", + "integrity": "sha512-BHJ/EKruNIqJf/QahvxwQZXKygOQ256myeN/Ew+THcAa5q+PjyTTMMeNQC4DZw5AwfvelsUrA6B67NKMqXDbzQ==" }, "mime-types": { - "version": "2.1.17", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", - "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", + "version": "2.1.18", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.18.tgz", + "integrity": "sha512-lc/aahn+t4/SWV/qcmumYjymLsWfN3ELhpmVuUFjgsORruuZPVSwAQryq+HHGvO/SI2KVX26bx+En+zhM8g8hQ==", "requires": { - "mime-db": "1.30.0" + "mime-db": "1.33.0" } }, "mimic-fn": { @@ -4702,9 +4078,9 @@ "dev": true }, "nan": { - "version": "2.8.0", - "resolved": "https://registry.npmjs.org/nan/-/nan-2.8.0.tgz", - "integrity": "sha1-7XFfP+neArV6XmJS2QqWZ14fCFo=" + "version": "2.9.2", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.9.2.tgz", + "integrity": "sha512-ltW65co7f3PQWBDbqVvaU1WtFJUsNW7sWWm4HINhbMQIyVyzIeyZ8toX5TC5eeooE6piZoaEh4cZkueSKG3KYw==" }, "natural-compare": { "version": "1.4.0", @@ -4764,8 +4140,7 @@ "object-keys": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", - "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=", - "dev": true + "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=" }, "object.assign": { "version": "4.1.0", @@ -4945,17 +4320,20 @@ "pify": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", + "dev": true }, "pinkie": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", + "dev": true }, "pinkie-promise": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "dev": true, "requires": { "pinkie": "2.0.4" } @@ -5077,6 +4455,122 @@ "integrity": "sha1-0aIUg/0iu0HlihL6NCGCMUCJfEU=", "dev": true }, + "power-assert": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/power-assert/-/power-assert-1.4.4.tgz", + "integrity": "sha1-kpXqdDcZb1pgH95CDwQmMRhtdRc=", + "requires": { + "define-properties": "1.1.2", + "empower": "1.2.3", + "power-assert-formatter": "1.4.1", + "universal-deep-strict-equal": "1.2.2", + "xtend": "4.0.1" + } + }, + "power-assert-context-formatter": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-context-formatter/-/power-assert-context-formatter-1.1.1.tgz", + "integrity": "sha1-7bo1LT7YpgMRTWZyZazOYNaJzN8=", + "requires": { + "core-js": "2.5.3", + "power-assert-context-traversal": "1.1.1" + } + }, + "power-assert-context-reducer-ast": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/power-assert-context-reducer-ast/-/power-assert-context-reducer-ast-1.1.2.tgz", + "integrity": "sha1-SEqZ4m9Jc/+IMuXFzHVnAuYJQXQ=", + "requires": { + "acorn": "4.0.13", + "acorn-es7-plugin": "1.1.7", + "core-js": "2.5.3", + "espurify": "1.7.0", + "estraverse": "4.2.0" + }, + "dependencies": { + "acorn": { + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", + "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" + } + } + }, + "power-assert-context-traversal": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-context-traversal/-/power-assert-context-traversal-1.1.1.tgz", + "integrity": "sha1-iMq8oNE7Y1nwfT0+ivppkmRXftk=", + "requires": { + "core-js": "2.5.3", + "estraverse": "4.2.0" + } + }, + "power-assert-formatter": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/power-assert-formatter/-/power-assert-formatter-1.4.1.tgz", + "integrity": "sha1-XcEl7VCj37HdomwZNH879Y7CiEo=", + "requires": { + "core-js": "2.5.3", + "power-assert-context-formatter": "1.1.1", + "power-assert-context-reducer-ast": "1.1.2", + "power-assert-renderer-assertion": "1.1.1", + "power-assert-renderer-comparison": "1.1.1", + "power-assert-renderer-diagram": "1.1.2", + "power-assert-renderer-file": "1.1.1" + } + }, + "power-assert-renderer-assertion": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-renderer-assertion/-/power-assert-renderer-assertion-1.1.1.tgz", + "integrity": "sha1-y/wOd+AIao+Wrz8djme57n4ozpg=", + "requires": { + "power-assert-renderer-base": "1.1.1", + "power-assert-util-string-width": "1.1.1" + } + }, + "power-assert-renderer-base": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-renderer-base/-/power-assert-renderer-base-1.1.1.tgz", + "integrity": "sha1-lqZQxv0F7hvB9mtUrWFELIs/Y+s=" + }, + "power-assert-renderer-comparison": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-renderer-comparison/-/power-assert-renderer-comparison-1.1.1.tgz", + "integrity": "sha1-10Odl9hRVr5OMKAPL7WnJRTOPAg=", + "requires": { + "core-js": "2.5.3", + "diff-match-patch": "1.0.0", + "power-assert-renderer-base": "1.1.1", + "stringifier": "1.3.0", + "type-name": "2.0.2" + } + }, + "power-assert-renderer-diagram": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/power-assert-renderer-diagram/-/power-assert-renderer-diagram-1.1.2.tgz", + "integrity": "sha1-ZV+PcRk1qbbVQbhjJ2VHF8Y3qYY=", + "requires": { + "core-js": "2.5.3", + "power-assert-renderer-base": "1.1.1", + "power-assert-util-string-width": "1.1.1", + "stringifier": "1.3.0" + } + }, + "power-assert-renderer-file": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-renderer-file/-/power-assert-renderer-file-1.1.1.tgz", + "integrity": "sha1-o34rvReMys0E5427eckv40kzxec=", + "requires": { + "power-assert-renderer-base": "1.1.1" + } + }, + "power-assert-util-string-width": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/power-assert-util-string-width/-/power-assert-util-string-width-1.1.1.tgz", + "integrity": "sha1-vmWet5N/3S5smncmjar2S9W3xZI=", + "requires": { + "eastasianwidth": "0.1.1" + } + }, "prelude-ls": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", @@ -5088,6 +4582,11 @@ "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=" }, + "prettier": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.11.1.tgz", + "integrity": "sha512-T/KD65Ot0PB97xTrG8afQ46x3oiVhnfGjGESSI9NWYcG92+OUPZKkwHqGWXH2t9jK1crnQjubECW0FuOth+hxw==" + }, "private": { "version": "0.1.8", "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", @@ -5118,26 +4617,25 @@ "pseudomap": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", - "dev": true + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" }, "pump": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.0.tgz", - "integrity": "sha512-6MYypjOvtiXhBSTOD0Zs5eNjCGfnqi5mPsCsW+dgKTxrZzQMZQNpBo3XRkLx7id753f3EeyHLBqzqqUymIolgw==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", "requires": { "end-of-stream": "1.4.1", "once": "1.4.0" } }, "pumpify": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.3.6.tgz", - "integrity": "sha512-BurGAcvezsINL5US9T9wGHHcLNrG6MCp//ECtxron3vcR+Rfx5Anqq7HbZXNJvFQli8FGVsWCAvywEJFV5Hx/Q==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.4.0.tgz", + "integrity": "sha512-2kmNR9ry+Pf45opRVirpNuIFotsxUGLaYqxIwuR77AYrYRMuFCz9eryHBS52L360O+NcR383CL4QYlMKPq4zYA==", "requires": { - "duplexify": "3.5.3", + "duplexify": "3.5.4", "inherits": "2.0.3", - "pump": "2.0.0" + "pump": "2.0.1" } }, "punycode": { @@ -5342,25 +4840,25 @@ "aws-sign2": "0.7.0", "aws4": "1.6.0", "caseless": "0.12.0", - "combined-stream": "1.0.5", + "combined-stream": "1.0.6", "extend": "3.0.1", "forever-agent": "0.6.1", - "form-data": "2.3.1", + "form-data": "2.3.2", "har-validator": "5.0.3", "hawk": "6.0.2", "http-signature": "1.2.0", "is-typedarray": "1.0.0", "isstream": "0.1.2", "json-stringify-safe": "5.0.1", - "mime-types": "2.1.17", + "mime-types": "2.1.18", "oauth-sign": "0.8.2", "performance-now": "2.1.0", "qs": "6.5.1", "safe-buffer": "5.1.1", "stringstream": "0.0.5", - "tough-cookie": "2.3.3", + "tough-cookie": "2.3.4", "tunnel-agent": "0.6.0", - "uuid": "3.1.0" + "uuid": "3.2.1" } }, "require-directory": { @@ -5410,6 +4908,11 @@ "onetime": "1.1.0" } }, + "retry-axios": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/retry-axios/-/retry-axios-0.3.0.tgz", + "integrity": "sha512-6vOCghodB5p5N/ZOqug7A3WsT42TULZ7NErUi4lP3KtwtXgz4hE/43LWHsFuHuBfXRmOm/tjXBWAjnObrcy+yg==" + }, "retry-request": { "version": "3.3.1", "resolved": "https://registry.npmjs.org/retry-request/-/retry-request-3.3.1.tgz", @@ -5522,7 +5025,7 @@ "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.1.0.tgz", "integrity": "sha512-FL1b58BDrqS3A11lJ0zEdnJ3UOKqVxawAkF3k7F0CVN7VQ34aZrV+G8BZ1WC9ZL7NyrwsW0oviwsWDgRuVYtJg==", "requires": { - "hoek": "4.2.0" + "hoek": "4.2.1" } }, "source-map": { @@ -5639,14 +5142,6 @@ "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.0.tgz", "integrity": "sha1-1cdSgl5TZ+eG944Y5EXqIjoVWVI=" }, - "string_decoder": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", - "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", - "requires": { - "safe-buffer": "5.1.1" - } - }, "string-format-obj": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/string-format-obj/-/string-format-obj-1.1.1.tgz", @@ -5662,6 +5157,24 @@ "strip-ansi": "3.0.1" } }, + "string_decoder": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", + "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", + "requires": { + "safe-buffer": "5.1.1" + } + }, + "stringifier": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/stringifier/-/stringifier-1.3.0.tgz", + "integrity": "sha1-3vGDQvaTPbDy2/yaoCF1tEjBeVk=", + "requires": { + "core-js": "2.5.3", + "traverse": "0.6.6", + "type-name": "2.0.2" + } + }, "stringstream": { "version": "0.0.5", "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", @@ -5793,18 +5306,28 @@ "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=" }, "tough-cookie": { - "version": "2.3.3", - "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", - "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.4.tgz", + "integrity": "sha512-TZ6TTfI5NtZnuyy/Kecv+CnoROnyXn2DN97LontgQpCwsX2XyLYCC0ENhYkehSOwAp8rTQKc/NUIF7BkQ5rKLA==", "requires": { "punycode": "1.4.1" } }, + "traverse": { + "version": "0.6.6", + "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.6.6.tgz", + "integrity": "sha1-y99WD9e5r2MlAv7UD5GMFX6pcTc=" + }, "trim-right": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=" }, + "tslib": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.0.tgz", + "integrity": "sha512-f/qGG2tUkrISBlQZEjEqoZ3B2+npJjIf04H1wuAv9iA8i04Icp+61KRXxFdha22670NJopsZCIjhC3SnjPRKrQ==" + }, "tunnel-agent": { "version": "0.6.0", "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", @@ -5828,6 +5351,11 @@ "prelude-ls": "1.1.2" } }, + "type-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/type-name/-/type-name-2.0.2.tgz", + "integrity": "sha1-7+fUEj2KxSr/9/QMfk3sUmYAj7Q=" + }, "typedarray": { "version": "0.0.6", "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", @@ -5847,6 +5375,16 @@ "crypto-random-string": "1.0.0" } }, + "universal-deep-strict-equal": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/universal-deep-strict-equal/-/universal-deep-strict-equal-1.2.2.tgz", + "integrity": "sha1-DaSsL3PP95JMgfpN4BjKViyisKc=", + "requires": { + "array-filter": "1.0.0", + "indexof": "0.0.1", + "object-keys": "1.0.11" + } + }, "universalify": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.1.tgz", @@ -5864,9 +5402,9 @@ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" }, "uuid": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", - "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.2.1.tgz", + "integrity": "sha512-jZnMwlb9Iku/O3smGWvZhauCf6cvvpKi4BKRiliS3cxnI+Gz9j5MEpTz2UFuXiKPJocb7gnsLHwiS05ige5BEA==" }, "v8flags": { "version": "2.1.1", @@ -5901,7 +5439,7 @@ "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.0.tgz", "integrity": "sha1-DK+dLXVdk67gSdS90NP+LMoqJOs=", "requires": { - "http-parser-js": "0.4.9", + "http-parser-js": "0.4.10", "websocket-extensions": "0.1.3" } }, @@ -5987,8 +5525,7 @@ "yallist": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", - "dev": true + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" }, "yargs": { "version": "3.32.0", diff --git a/package.json b/package.json index 3a9f078..3d2a161 100644 --- a/package.json +++ b/package.json @@ -16,6 +16,8 @@ "main": "./dist/index.js", "scripts": { "bin": "./bin/firestore-backup.js", + "test": "./bin/firestore-backup.js --accountCredentials $GOOGLE_APPLICATION_CREDENTIALS --backupPath ./backup --prettyPrint", + "pretest": "npm run build", "clean": "rm -rf dist && mkdir dist", "buildSource": "babel lib --out-dir dist", "buildFlow": "flow-copy-source lib dist", From 2b900a35e0ecb3f86c49ac250945dbec681cf119 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 4 Mar 2018 04:19:13 +0000 Subject: [PATCH 02/17] beautify --- lib/index.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lib/index.js b/lib/index.js index 7d3d085..e9baf3e 100644 --- a/lib/index.js +++ b/lib/index.js @@ -36,14 +36,14 @@ export default function(accountCredentials: string | Object, databaseStartPath: const database = Firebase.firestore() const databasePath = (databaseStartPath || ''); - if(isDocumentPath(databasePath)) { + if (isDocumentPath(databasePath)) { const databaseDocument = database.doc(databasePath) return databaseDocument.get() - .then((document)=>{ + .then((document) => { return backupDocument(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON) }) } - if(isCollectionPath(databaseStartPath)) { + if (isCollectionPath(databaseStartPath)) { const databaseCollection = database.collection(databasePath) return backupCollection(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON) } From 56ea08123e9fd9d80be959fb5efb79abf12e835e Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 4 Mar 2018 04:22:41 +0000 Subject: [PATCH 03/17] remove semi based on codacy analysis --- lib/index.js | 2 +- lib/utility.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/index.js b/lib/index.js index e9baf3e..24ee427 100644 --- a/lib/index.js +++ b/lib/index.js @@ -34,7 +34,7 @@ export default function(accountCredentials: string | Object, databaseStartPath: } const database = Firebase.firestore() - const databasePath = (databaseStartPath || ''); + const databasePath = (databaseStartPath || '') if (isDocumentPath(databasePath)) { const databaseDocument = database.doc(databasePath) diff --git a/lib/utility.js b/lib/utility.js index 8ba0b40..496f54c 100644 --- a/lib/utility.js +++ b/lib/utility.js @@ -20,5 +20,5 @@ export const promiseSerial = (funcs) => { export const getSegments = (relativePath) => { // We may have an empty segment at the beginning or end if they had a // leading or trailing slash (which we allow). - return relativePath.split('/').filter(segment => segment.length > 0); + return relativePath.split('/').filter(segment => segment.length > 0) } From 2d509d9d70512b6f93723334142b6a0b51719ebc Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Mon, 5 Mar 2018 05:42:05 +0000 Subject: [PATCH 04/17] add babel class transform and bluebird for concurrency --- .babelrc | 3 +- package-lock.json | 813 ++++++++++++++++++++++++++++++++++++++++++++++ package.json | 4 +- 3 files changed, 818 insertions(+), 2 deletions(-) diff --git a/.babelrc b/.babelrc index aecf955..af3a860 100644 --- a/.babelrc +++ b/.babelrc @@ -2,5 +2,6 @@ "presets": [ "flow", "env" - ] + ], + "plugins": ["transform-class-properties"] } diff --git a/package-lock.json b/package-lock.json index 11e2265..22bc469 100644 --- a/package-lock.json +++ b/package-lock.json @@ -633,6 +633,12 @@ "resolved": "https://registry.npmjs.org/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz", "integrity": "sha1-ytnK0RkbWtY0vzCuCHI5HgZHvpU=" }, + "babel-plugin-syntax-class-properties": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-class-properties/-/babel-plugin-syntax-class-properties-6.13.0.tgz", + "integrity": "sha1-1+sjt5oxf4VDlixQW4J8fWysJ94=", + "dev": true + }, "babel-plugin-syntax-exponentiation-operator": { "version": "6.13.0", "resolved": "https://registry.npmjs.org/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz", @@ -658,6 +664,18 @@ "babel-runtime": "6.26.0" } }, + "babel-plugin-transform-class-properties": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-class-properties/-/babel-plugin-transform-class-properties-6.24.1.tgz", + "integrity": "sha1-anl2PqYdM9NvN7YRqp3vgagbRqw=", + "dev": true, + "requires": { + "babel-helper-function-name": "6.24.1", + "babel-plugin-syntax-class-properties": "6.13.0", + "babel-runtime": "6.26.0", + "babel-template": "6.26.0" + } + }, "babel-plugin-transform-es2015-arrow-functions": { "version": "6.22.0", "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", @@ -1059,6 +1077,11 @@ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=" }, + "bluebird": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", + "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" + }, "boom": { "version": "4.3.1", "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", @@ -1209,6 +1232,7 @@ "requires": { "anymatch": "1.3.2", "async-each": "1.0.1", + "fsevents": "1.1.3", "glob-parent": "2.0.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -2306,6 +2330,795 @@ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" }, + "fsevents": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.1.3.tgz", + "integrity": "sha512-WIr7iDkdmdbxu/Gh6eKEZJL6KPE74/5MEsf2whTOFNxbIoIixogroLdKYqB6FDav4Wavh/lZdzzd3b2KxIXC5Q==", + "optional": true, + "requires": { + "nan": "2.9.2", + "node-pre-gyp": "0.6.39" + }, + "dependencies": { + "abbrev": { + "version": "1.1.0", + "bundled": true, + "optional": true + }, + "ajv": { + "version": "4.11.8", + "bundled": true, + "optional": true, + "requires": { + "co": "4.6.0", + "json-stable-stringify": "1.0.1" + } + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true + }, + "aproba": { + "version": "1.1.1", + "bundled": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.4", + "bundled": true, + "optional": true, + "requires": { + "delegates": "1.0.0", + "readable-stream": "2.2.9" + } + }, + "asn1": { + "version": "0.2.3", + "bundled": true, + "optional": true + }, + "assert-plus": { + "version": "0.2.0", + "bundled": true, + "optional": true + }, + "asynckit": { + "version": "0.4.0", + "bundled": true, + "optional": true + }, + "aws-sign2": { + "version": "0.6.0", + "bundled": true, + "optional": true + }, + "aws4": { + "version": "1.6.0", + "bundled": true, + "optional": true + }, + "balanced-match": { + "version": "0.4.2", + "bundled": true + }, + "bcrypt-pbkdf": { + "version": "1.0.1", + "bundled": true, + "optional": true, + "requires": { + "tweetnacl": "0.14.5" + } + }, + "block-stream": { + "version": "0.0.9", + "bundled": true, + "requires": { + "inherits": "2.0.3" + } + }, + "boom": { + "version": "2.10.1", + "bundled": true, + "requires": { + "hoek": "2.16.3" + } + }, + "brace-expansion": { + "version": "1.1.7", + "bundled": true, + "requires": { + "balanced-match": "0.4.2", + "concat-map": "0.0.1" + } + }, + "buffer-shims": { + "version": "1.0.0", + "bundled": true + }, + "caseless": { + "version": "0.12.0", + "bundled": true, + "optional": true + }, + "co": { + "version": "4.6.0", + "bundled": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true + }, + "combined-stream": { + "version": "1.0.5", + "bundled": true, + "requires": { + "delayed-stream": "1.0.0" + } + }, + "concat-map": { + "version": "0.0.1", + "bundled": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true + }, + "cryptiles": { + "version": "2.0.5", + "bundled": true, + "requires": { + "boom": "2.10.1" + } + }, + "dashdash": { + "version": "1.14.1", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "debug": { + "version": "2.6.8", + "bundled": true, + "optional": true, + "requires": { + "ms": "2.0.0" + } + }, + "deep-extend": { + "version": "0.4.2", + "bundled": true, + "optional": true + }, + "delayed-stream": { + "version": "1.0.0", + "bundled": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "ecc-jsbn": { + "version": "0.1.1", + "bundled": true, + "optional": true, + "requires": { + "jsbn": "0.1.1" + } + }, + "extend": { + "version": "3.0.1", + "bundled": true, + "optional": true + }, + "extsprintf": { + "version": "1.0.2", + "bundled": true + }, + "forever-agent": { + "version": "0.6.1", + "bundled": true, + "optional": true + }, + "form-data": { + "version": "2.1.4", + "bundled": true, + "optional": true, + "requires": { + "asynckit": "0.4.0", + "combined-stream": "1.0.5", + "mime-types": "2.1.15" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true + }, + "fstream": { + "version": "1.0.11", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "inherits": "2.0.3", + "mkdirp": "0.5.1", + "rimraf": "2.6.1" + } + }, + "fstream-ignore": { + "version": "1.0.5", + "bundled": true, + "optional": true, + "requires": { + "fstream": "1.0.11", + "inherits": "2.0.3", + "minimatch": "3.0.4" + } + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "optional": true, + "requires": { + "aproba": "1.1.1", + "console-control-strings": "1.1.0", + "has-unicode": "2.0.1", + "object-assign": "4.1.1", + "signal-exit": "3.0.2", + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wide-align": "1.1.2" + } + }, + "getpass": { + "version": "0.1.7", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "graceful-fs": { + "version": "4.1.11", + "bundled": true + }, + "har-schema": { + "version": "1.0.5", + "bundled": true, + "optional": true + }, + "har-validator": { + "version": "4.2.1", + "bundled": true, + "optional": true, + "requires": { + "ajv": "4.11.8", + "har-schema": "1.0.5" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "hawk": { + "version": "3.1.3", + "bundled": true, + "requires": { + "boom": "2.10.1", + "cryptiles": "2.0.5", + "hoek": "2.16.3", + "sntp": "1.0.9" + } + }, + "hoek": { + "version": "2.16.3", + "bundled": true + }, + "http-signature": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "0.2.0", + "jsprim": "1.4.0", + "sshpk": "1.13.0" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "requires": { + "once": "1.4.0", + "wrappy": "1.0.2" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true + }, + "ini": { + "version": "1.3.4", + "bundled": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "is-typedarray": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "isarray": { + "version": "1.0.0", + "bundled": true + }, + "isstream": { + "version": "0.1.2", + "bundled": true, + "optional": true + }, + "jodid25519": { + "version": "1.0.2", + "bundled": true, + "optional": true, + "requires": { + "jsbn": "0.1.1" + } + }, + "jsbn": { + "version": "0.1.1", + "bundled": true, + "optional": true + }, + "json-schema": { + "version": "0.2.3", + "bundled": true, + "optional": true + }, + "json-stable-stringify": { + "version": "1.0.1", + "bundled": true, + "optional": true, + "requires": { + "jsonify": "0.0.0" + } + }, + "json-stringify-safe": { + "version": "5.0.1", + "bundled": true, + "optional": true + }, + "jsonify": { + "version": "0.0.0", + "bundled": true, + "optional": true + }, + "jsprim": { + "version": "1.4.0", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.0.2", + "json-schema": "0.2.3", + "verror": "1.3.6" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "mime-db": { + "version": "1.27.0", + "bundled": true + }, + "mime-types": { + "version": "2.1.15", + "bundled": true, + "requires": { + "mime-db": "1.27.0" + } + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "requires": { + "brace-expansion": "1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "node-pre-gyp": { + "version": "0.6.39", + "bundled": true, + "optional": true, + "requires": { + "detect-libc": "1.0.2", + "hawk": "3.1.3", + "mkdirp": "0.5.1", + "nopt": "4.0.1", + "npmlog": "4.1.0", + "rc": "1.2.1", + "request": "2.81.0", + "rimraf": "2.6.1", + "semver": "5.3.0", + "tar": "2.2.1", + "tar-pack": "3.4.0" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "optional": true, + "requires": { + "abbrev": "1.1.0", + "osenv": "0.1.4" + } + }, + "npmlog": { + "version": "4.1.0", + "bundled": true, + "optional": true, + "requires": { + "are-we-there-yet": "1.1.4", + "console-control-strings": "1.1.0", + "gauge": "2.7.4", + "set-blocking": "2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true + }, + "oauth-sign": { + "version": "0.8.2", + "bundled": true, + "optional": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "requires": { + "wrappy": "1.0.2" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "osenv": { + "version": "0.1.4", + "bundled": true, + "optional": true, + "requires": { + "os-homedir": "1.0.2", + "os-tmpdir": "1.0.2" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true + }, + "performance-now": { + "version": "0.2.0", + "bundled": true, + "optional": true + }, + "process-nextick-args": { + "version": "1.0.7", + "bundled": true + }, + "punycode": { + "version": "1.4.1", + "bundled": true, + "optional": true + }, + "qs": { + "version": "6.4.0", + "bundled": true, + "optional": true + }, + "rc": { + "version": "1.2.1", + "bundled": true, + "optional": true, + "requires": { + "deep-extend": "0.4.2", + "ini": "1.3.4", + "minimist": "1.2.0", + "strip-json-comments": "2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.2.9", + "bundled": true, + "requires": { + "buffer-shims": "1.0.0", + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "1.0.0", + "process-nextick-args": "1.0.7", + "string_decoder": "1.0.1", + "util-deprecate": "1.0.2" + } + }, + "request": { + "version": "2.81.0", + "bundled": true, + "optional": true, + "requires": { + "aws-sign2": "0.6.0", + "aws4": "1.6.0", + "caseless": "0.12.0", + "combined-stream": "1.0.5", + "extend": "3.0.1", + "forever-agent": "0.6.1", + "form-data": "2.1.4", + "har-validator": "4.2.1", + "hawk": "3.1.3", + "http-signature": "1.1.1", + "is-typedarray": "1.0.0", + "isstream": "0.1.2", + "json-stringify-safe": "5.0.1", + "mime-types": "2.1.15", + "oauth-sign": "0.8.2", + "performance-now": "0.2.0", + "qs": "6.4.0", + "safe-buffer": "5.0.1", + "stringstream": "0.0.5", + "tough-cookie": "2.3.2", + "tunnel-agent": "0.6.0", + "uuid": "3.0.1" + } + }, + "rimraf": { + "version": "2.6.1", + "bundled": true, + "requires": { + "glob": "7.1.2" + } + }, + "safe-buffer": { + "version": "5.0.1", + "bundled": true + }, + "semver": { + "version": "5.3.0", + "bundled": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "optional": true + }, + "sntp": { + "version": "1.0.9", + "bundled": true, + "requires": { + "hoek": "2.16.3" + } + }, + "sshpk": { + "version": "1.13.0", + "bundled": true, + "optional": true, + "requires": { + "asn1": "0.2.3", + "assert-plus": "1.0.0", + "bcrypt-pbkdf": "1.0.1", + "dashdash": "1.14.1", + "ecc-jsbn": "0.1.1", + "getpass": "0.1.7", + "jodid25519": "1.0.2", + "jsbn": "0.1.1", + "tweetnacl": "0.14.5" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "requires": { + "code-point-at": "1.1.0", + "is-fullwidth-code-point": "1.0.0", + "strip-ansi": "3.0.1" + } + }, + "string_decoder": { + "version": "1.0.1", + "bundled": true, + "requires": { + "safe-buffer": "5.0.1" + } + }, + "stringstream": { + "version": "0.0.5", + "bundled": true, + "optional": true + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "tar": { + "version": "2.2.1", + "bundled": true, + "requires": { + "block-stream": "0.0.9", + "fstream": "1.0.11", + "inherits": "2.0.3" + } + }, + "tar-pack": { + "version": "3.4.0", + "bundled": true, + "optional": true, + "requires": { + "debug": "2.6.8", + "fstream": "1.0.11", + "fstream-ignore": "1.0.5", + "once": "1.4.0", + "readable-stream": "2.2.9", + "rimraf": "2.6.1", + "tar": "2.2.1", + "uid-number": "0.0.6" + } + }, + "tough-cookie": { + "version": "2.3.2", + "bundled": true, + "optional": true, + "requires": { + "punycode": "1.4.1" + } + }, + "tunnel-agent": { + "version": "0.6.0", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "bundled": true, + "optional": true + }, + "uid-number": { + "version": "0.0.6", + "bundled": true, + "optional": true + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true + }, + "uuid": { + "version": "3.0.1", + "bundled": true, + "optional": true + }, + "verror": { + "version": "1.3.6", + "bundled": true, + "optional": true, + "requires": { + "extsprintf": "1.0.2" + } + }, + "wide-align": { + "version": "1.1.2", + "bundled": true, + "optional": true, + "requires": { + "string-width": "1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true + } + } + }, "function-bind": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", diff --git a/package.json b/package.json index 3d2a161..3d32fc6 100644 --- a/package.json +++ b/package.json @@ -16,7 +16,7 @@ "main": "./dist/index.js", "scripts": { "bin": "./bin/firestore-backup.js", - "test": "./bin/firestore-backup.js --accountCredentials $GOOGLE_APPLICATION_CREDENTIALS --backupPath ./backup --prettyPrint", + "test": "./bin/firestore-backup.js --accountCredentials $GOOGLE_APPLICATION_CREDENTIALS --backupPath ./backup --prettyPrint --requestCountLimit 20", "pretest": "npm run build", "clean": "rm -rf dist && mkdir dist", "buildSource": "babel lib --out-dir dist", @@ -29,6 +29,7 @@ "babel-cli": "^6.26.0", "babel-preset-env": "^1.6.1", "babel-preset-flow": "^6.23.0", + "bluebird": "^3.5.1", "colors": "^1.1.2", "commander": "^2.11.0", "firebase-admin": "^5.8.1", @@ -36,6 +37,7 @@ }, "devDependencies": { "babel-eslint": "7", + "babel-plugin-transform-class-properties": "^6.24.1", "eslint": "3.x", "eslint-plugin-flowtype": "^2.39.1", "flow-bin": "^0.61.0", From 643b444821d37b2525c6685fb97cc59df5c3b175 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Mon, 5 Mar 2018 05:47:21 +0000 Subject: [PATCH 05/17] add requestCountLimit param to cli. BackupOptions type to reduce func params. consolidated backup functionality into a class to encapsulate the backupStartPath logic and additonal backup logic. --- bin/firestore-backup.js | 16 +++- dist/firestore.js | 201 +++++++++++++++++++++++++++++++--------- dist/firestore.js.flow | 167 ++++++++++++++++++++++++++------- dist/index.js | 46 +++++---- dist/index.js.flow | 44 +++++---- dist/types.js.flow | 11 ++- dist/utility.js | 6 ++ dist/utility.js.flow | 8 +- lib/firestore.js | 172 +++++++++++++++++++++------------- lib/index.js | 41 +++----- lib/types.js | 9 ++ test-results.md | 17 ++++ 12 files changed, 527 insertions(+), 211 deletions(-) create mode 100644 test-results.md diff --git a/bin/firestore-backup.js b/bin/firestore-backup.js index c9cd9e6..d927d92 100755 --- a/bin/firestore-backup.js +++ b/bin/firestore-backup.js @@ -20,11 +20,15 @@ var prettyPrintParamDescription = 'JSON backups done with pretty-printing.' var databaseStartPathParamKey = 'databaseStartPath' var databaseStartPathParamDescription = 'The database collection or document path to begin backup.' +var requestCountLimitParamKey = 'requestCountLimit' +var requestCountLimitParamDescription = 'The maximum number of requests to be made in parallel.' + commander.version('1.0.1') .option('-a, --' + accountCredentialsPathParamKey + ' ', accountCredentialsPathParamDescription) .option('-B, --' + backupPathParamKey + ' ', backupPathParamDescription) .option('-P, --' + prettyPrintParamKey, prettyPrintParamDescription) .option('-S, --' + databaseStartPathParamKey + ' ', databaseStartPathParamDescription) + .option('-L, --' + requestCountLimitParamKey + ' ', requestCountLimitParamDescription) .parse(process.argv) const accountCredentialsPath = commander[accountCredentialsPathParamKey] @@ -51,11 +55,21 @@ const prettyPrint = commander[prettyPrintParamKey] !== undefined && commander[pr const databaseStartPath = (commander[databaseStartPathParamKey] || '').replace(/^\//, '') +const requestCountLimit = parseInt(commander[requestCountLimitParamKey] || '1', 10) + var firestoreBackup = require('../dist/index.js') try { - firestoreBackup.default(accountCredentialsPath, databaseStartPath, backupPath, prettyPrint) + console.time('backuptime') + firestoreBackup.default({ + accountCredentials: accountCredentialsPath, + databaseStartPath, + backupPath, + prettyPrint, + requestCountLimit + }) .then(() => { console.log(colors.bold(colors.green('All done 💫'))) + console.timeEnd('backuptime') }) } catch (error) { console.log(colors.red(error)) diff --git a/dist/firestore.js b/dist/firestore.js index 26c8894..d0755bd 100644 --- a/dist/firestore.js +++ b/dist/firestore.js @@ -3,7 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.backupRootCollections = exports.backupCollection = exports.backupDocument = exports.constructDocumentValue = exports.constructReferenceUrl = undefined; +exports.FirestoreBackup = exports.constructDocumentValue = exports.constructReferenceUrl = undefined; + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _types = require('./types'); @@ -17,10 +19,22 @@ var _mkdirp = require('mkdirp'); var _mkdirp2 = _interopRequireDefault(_mkdirp); +var _bluebird = require('bluebird'); + +var _bluebird2 = _interopRequireDefault(_bluebird); + function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +var backupDocumentConcurrency = 3; // 3 is the max before diminishing returns +var defaultBackupOptions = { + databaseStartPath: '', + requestCountLimit: 1 +}; + var constructReferenceUrl = exports.constructReferenceUrl = function constructReferenceUrl(reference) { var referenceSegments = reference._referencePath.segments; var referencePath = void 0; @@ -104,68 +118,165 @@ var constructDocumentValue = exports.constructDocumentValue = function construct return documentDataToStore; }; -var backupDocument = exports.backupDocument = function backupDocument(document, backupPath, logPath, prettyPrintJSON) { - console.log('Backing up Document \'' + logPath + document.id + '\''); +/*export const backupDocument = (document: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { + console.log('Backing up Document \'' + logPath + document.id + '\'') try { - _mkdirp2.default.sync(backupPath); + mkdirp.sync(backupPath) } catch (error) { - throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error); + throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error) } - var fileContents = void 0; + let fileContents: string try { - var documentData = document.data(); - var keys = Object.keys(documentData); - var documentDataToStore = {}; - documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)); + const documentData = document.data() + const keys = Object.keys(documentData) + var documentDataToStore = {} + documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)) if (prettyPrintJSON === true) { - fileContents = JSON.stringify(documentDataToStore, null, 2); + fileContents = JSON.stringify(documentDataToStore, null, 2) } else { - fileContents = JSON.stringify(documentDataToStore); + fileContents = JSON.stringify(documentDataToStore) } } catch (error) { - throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error); + throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error) } try { - _fs2.default.writeFileSync(backupPath + '/' + document.id + '.json', fileContents); + fs.writeFileSync(backupPath + '/' + document.id + '.json', fileContents) } catch (error) { - throw new Error('Unable to write Document \'' + document.id + '\': ' + error); + throw new Error('Unable to write Document \'' + document.id + '\': ' + error) } - return document.ref.getCollections().then(function (collections) { - return (0, _utility.promiseSerial)(collections.map(function (collection) { - return function () { - return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON); - }; - })); - }); -}; + return Promise.resolve(document.ref.getCollections()) + .map((collection) => { + return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON) + }, { concurrency: backupDocumentConcurrency }) +}*/ -var backupCollection = exports.backupCollection = function backupCollection(collection, backupPath, logPath, prettyPrintJSON) { - console.log('Backing up Collection \'' + logPath + collection.id + '\''); +/*export const backupCollection = (collection: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { + console.log('Backing up Collection \'' + logPath + collection.id + '\'') try { - _mkdirp2.default.sync(backupPath); + mkdirp.sync(backupPath) } catch (error) { - throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error); + throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) + } + + return Promise.resolve(collection.get()) + .then((documentSnapshots) => documentSnapshots.docs) + .map((document) => { + return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON) + }, { concurrency: backupCollectionConcurrency }) +}*/ + +/*export const backupRootCollections = (database: Object, backupPath: string, prettyPrintJSON: boolean) => { + return database.getCollections() + .then((collections) => { + return promiseSerial(collections.map((collection) => { + return () => { + return backupCollection(collection, backupPath + '/' + collection.id, '/', prettyPrintJSON) + } + })) + }) +}*/ + +var FirestoreBackup = exports.FirestoreBackup = function () { + function FirestoreBackup(options) { + _classCallCheck(this, FirestoreBackup); + + this.options = Object.assign({}, defaultBackupOptions, options); + Object.assign(this, this.options); + + // backupCollectionConcurrency = this.requestCountLimit } - return collection.get().then(function (documentSnapshots) { - var backupFunctions = []; - documentSnapshots.forEach(function (document) { - backupFunctions.push(function () { - return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON); + _createClass(FirestoreBackup, [{ + key: 'backup', + value: function backup() { + var _this = this; + + if ((0, _types.isDocumentPath)(this.databaseStartPath)) { + var databaseDocument = this.database.doc(this.databaseStartPath); + return databaseDocument.get().then(function (document) { + return _this.backupDocument(document, _this.backupPath + '/' + document.ref.path, '/', _this.prettyPrintJSON); + }); + } + + if ((0, _types.isCollectionPath)(this.databaseStartPath)) { + var databaseCollection = this.database.collection(this.databaseStartPath); + return this.backupCollection(databaseCollection, this.backupPath + '/' + databaseCollection.path, '/', this.prettyPrintJSON); + } + + return this.backupRootCollections(); + } + }, { + key: 'backupRootCollections', + value: function backupRootCollections() { + var _this2 = this; + + return this.database.getCollections().then(function (collections) { + return (0, _utility.promiseSerial)(collections.map(function (collection) { + return function () { + return _this2.backupCollection(collection, _this2.backupPath + '/' + collection.id, '/'); + }; + })); }); - }); - return (0, _utility.promiseSerial)(backupFunctions); - }); -}; + } + }, { + key: 'backupCollection', + value: function backupCollection(collection, backupPath, logPath) { + var _this3 = this; -var backupRootCollections = exports.backupRootCollections = function backupRootCollections(database, backupPath, prettyPrintJSON) { - return database.getCollections().then(function (collections) { - return (0, _utility.promiseSerial)(collections.map(function (collection) { - return function () { - return backupCollection(collection, backupPath + '/' + collection.id, '/', prettyPrintJSON); - }; - })); - }); -}; \ No newline at end of file + // return backupCollection(collection, backupPath, logPath, this.prettyPrintJSON) + console.log('Backing up Collection \'' + logPath + collection.id + '\''); + try { + _mkdirp2.default.sync(backupPath); + } catch (error) { + throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error); + } + + return _bluebird2.default.resolve(collection.get()).then(function (documentSnapshots) { + return documentSnapshots.docs; + }).map(function (document) { + return _this3.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', _this3.prettyPrintJSON); + }, { concurrency: this.requestCountLimit }); + } + }, { + key: 'backupDocument', + value: function backupDocument(document, backupPath, logPath) { + var _this4 = this; + + // return backupDocument(document, backupPath, logPath, this.prettyPrintJSON) + console.log('Backing up Document \'' + logPath + document.id + '\''); + try { + _mkdirp2.default.sync(backupPath); + } catch (error) { + throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error); + } + + var fileContents = void 0; + try { + var documentData = document.data(); + var keys = Object.keys(documentData); + var documentDataToStore = {}; + documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)); + if (this.prettyPrintJSON === true) { + fileContents = JSON.stringify(documentDataToStore, null, 2); + } else { + fileContents = JSON.stringify(documentDataToStore); + } + } catch (error) { + throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error); + } + try { + _fs2.default.writeFileSync(backupPath + '/' + document.id + '.json', fileContents); + } catch (error) { + throw new Error('Unable to write Document \'' + document.id + '\': ' + error); + } + + return _bluebird2.default.resolve(document.ref.getCollections()).map(function (collection) { + return _this4.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', _this4.prettyPrintJSON); + }, { concurrency: backupDocumentConcurrency }); + } + }]); + + return FirestoreBackup; +}(); \ No newline at end of file diff --git a/dist/firestore.js.flow b/dist/firestore.js.flow index b8db736..291c06e 100644 --- a/dist/firestore.js.flow +++ b/dist/firestore.js.flow @@ -1,15 +1,33 @@ /* @flow */ -import { isString, isNull, isObject, isArray, isNumber, isDate, isBoolean, isReference } from './types' -import type { ValueDescription, Validator } from './types' +import { + isString, + isNull, + isObject, + isArray, + isNumber, + isDate, + isBoolean, + isReference, + isDocumentPath, + isCollectionPath +} from './types' +import type { ValueDescription, Validator, BackupOptions } from './types' import { promiseSerial } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' +import Promise from 'bluebird' + +const backupDocumentConcurrency = 3; // 3 is the max before diminishing returns +const defaultBackupOptions = { + databaseStartPath: '', + requestCountLimit: 1 +} export const constructReferenceUrl = (reference: Object): ValueDescription => { const referenceSegments = reference._referencePath.segments - let referencePath: ?string + let referencePath: ? string if (Array.isArray(referenceSegments)) { referencePath = referenceSegments.join('/') } else if (typeof referenceSegments === 'string') { @@ -30,9 +48,9 @@ export const constructReferenceUrl = (reference: Object): ValueDescription => { } const testValidDocumentValue = ( - key: string, - documentData: Object, - validators: Array) => { + key: string, + documentData: Object, + validators: Array) => { let validValue: ?ValueDescription for (let index = 0; index < validators.length; index++) { @@ -81,25 +99,29 @@ export const constructDocumentValue = (documentDataToStore: Object = {}, keys: A const documentValue = testValidDocumentValue(key, documentData, basicTypeValidators) if (documentValue) { - documentDataToStore = Object.assign({}, documentDataToStore, { [key]: documentValue }) + documentDataToStore = Object.assign({}, documentDataToStore, { + [key]: documentValue + }) } else { const validValue = isReference(documentData[key]) if (validValue) { - documentDataToStore = Object.assign({}, documentDataToStore, { [key]: constructReferenceUrl(documentData[key]) }) + documentDataToStore = Object.assign({}, documentDataToStore, { + [key]: constructReferenceUrl(documentData[key]) + }) } else { documentDataToStore = { value: documentData[key], type: 'unknown' } } - // TODO: stronger validation that we have a reference rather than being our fallback + // TODO: stronger validation that we have a reference rather than being our fallback } } }) return documentDataToStore } -export const backupDocument = (document: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { +/*export const backupDocument = (document: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { console.log('Backing up Document \'' + logPath + document.id + '\'') try { mkdirp.sync(backupPath) @@ -127,17 +149,13 @@ export const backupDocument = (document: Object, backupPath: string, logPath: st throw new Error('Unable to write Document \'' + document.id + '\': ' + error) } - return document.ref.getCollections() - .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON) - } - })) - }) -} + return Promise.resolve(document.ref.getCollections()) + .map((collection) => { + return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON) + }, { concurrency: backupDocumentConcurrency }) +}*/ -export const backupCollection = (collection: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { +/*export const backupCollection = (collection: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { console.log('Backing up Collection \'' + logPath + collection.id + '\'') try { mkdirp.sync(backupPath) @@ -145,19 +163,14 @@ export const backupCollection = (collection: Object, backupPath: string, logPath throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) } - return collection.get() - .then((documentSnapshots) => { - const backupFunctions = [] - documentSnapshots.forEach((document) => { - backupFunctions.push(() => { - return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON) - }) - }) - return promiseSerial(backupFunctions) - }) -} + return Promise.resolve(collection.get()) + .then((documentSnapshots) => documentSnapshots.docs) + .map((document) => { + return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON) + }, { concurrency: backupCollectionConcurrency }) +}*/ -export const backupRootCollections = (database: Object, backupPath: string, prettyPrintJSON: boolean) => { +/*export const backupRootCollections = (database: Object, backupPath: string, prettyPrintJSON: boolean) => { return database.getCollections() .then((collections) => { return promiseSerial(collections.map((collection) => { @@ -166,4 +179,94 @@ export const backupRootCollections = (database: Object, backupPath: string, pret } })) }) +}*/ + +export class FirestoreBackup { + options: BackupOptions; + + constructor(options: BackupOptions) { + this.options = Object.assign({}, defaultBackupOptions, options) + Object.assign(this, this.options) + + // backupCollectionConcurrency = this.requestCountLimit + } + + backup() { + if (isDocumentPath(this.databaseStartPath)) { + const databaseDocument = this.database.doc(this.databaseStartPath) + return databaseDocument.get() + .then((document) => { + return this.backupDocument(document, this.backupPath + '/' + document.ref.path, '/', this.prettyPrintJSON) + }) + } + + if (isCollectionPath(this.databaseStartPath)) { + const databaseCollection = this.database.collection(this.databaseStartPath) + return this.backupCollection(databaseCollection, this.backupPath + '/' + databaseCollection.path, '/', this.prettyPrintJSON) + } + + return this.backupRootCollections() + } + + backupRootCollections() { + return this.database.getCollections() + .then((collections) => { + return promiseSerial(collections.map((collection) => { + return () => { + return this.backupCollection(collection, this.backupPath + '/' + collection.id, '/') + } + })) + }) + } + + backupCollection(collection: Object, backupPath: string, logPath: string) { + // return backupCollection(collection, backupPath, logPath, this.prettyPrintJSON) + console.log('Backing up Collection \'' + logPath + collection.id + '\'') + try { + mkdirp.sync(backupPath) + } catch (error) { + throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) + } + + return Promise.resolve(collection.get()) + .then((documentSnapshots) => documentSnapshots.docs) + .map((document) => { + return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', this.prettyPrintJSON) + }, { concurrency: this.requestCountLimit }) + } + + backupDocument(document: Object, backupPath: string, logPath: string) { + // return backupDocument(document, backupPath, logPath, this.prettyPrintJSON) + console.log('Backing up Document \'' + logPath + document.id + '\'') + try { + mkdirp.sync(backupPath) + } catch (error) { + throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error) + } + + let fileContents: string + try { + const documentData = document.data() + const keys = Object.keys(documentData) + var documentDataToStore = {} + documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)) + if (this.prettyPrintJSON === true) { + fileContents = JSON.stringify(documentDataToStore, null, 2) + } else { + fileContents = JSON.stringify(documentDataToStore) + } + } catch (error) { + throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error) + } + try { + fs.writeFileSync(backupPath + '/' + document.id + '.json', fileContents) + } catch (error) { + throw new Error('Unable to write Document \'' + document.id + '\': ' + error) + } + + return Promise.resolve(document.ref.getCollections()) + .map((collection) => { + return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', this.prettyPrintJSON) + }, { concurrency: backupDocumentConcurrency }) + } } diff --git a/dist/index.js b/dist/index.js index 9369fc3..d246b47 100644 --- a/dist/index.js +++ b/dist/index.js @@ -6,17 +6,22 @@ Object.defineProperty(exports, "__esModule", { var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; -exports.default = function (accountCredentials, databaseStartPath, backupPath, prettyPrintJSON) { +// import { backupRootCollections, backupCollection, backupDocument } from './firestore' + + +exports.default = function (_options) { + var options = Object.assign({}, _options, { databaseStartPath: '' }); + var accountCredentialsContents = void 0; - if (typeof accountCredentials === 'string') { + if (typeof options.accountCredentials === 'string') { try { - var accountCredentialsBuffer = _fs2.default.readFileSync(accountCredentials); + var accountCredentialsBuffer = _fs2.default.readFileSync(options.accountCredentials); accountCredentialsContents = JSON.parse(accountCredentialsBuffer.toString()); } catch (error) { - throw new Error('Unable to read account credential file \'' + accountCredentials + '\': ' + error); + throw new Error('Unable to read account credential file \'' + options.accountCredentials + '\': ' + error); } - } else if ((typeof accountCredentials === 'undefined' ? 'undefined' : _typeof(accountCredentials)) === 'object') { - accountCredentialsContents = accountCredentials; + } else if (_typeof(options.accountCredentials) === 'object') { + accountCredentialsContents = options.accountCredentials; } else { throw new Error('No account credentials provided'); } @@ -26,26 +31,27 @@ exports.default = function (accountCredentials, databaseStartPath, backupPath, p }); try { - _mkdirp2.default.sync(backupPath); + _mkdirp2.default.sync(options.backupPath); } catch (error) { - throw new Error('Unable to create backup path \'' + backupPath + '\': ' + error); + throw new Error('Unable to create backup path \'' + options.backupPath + '\': ' + error); } - var database = _firebaseAdmin2.default.firestore(); - var databasePath = databaseStartPath || ''; + options.database = _firebaseAdmin2.default.firestore(); + var backupClient = new _firestore.FirestoreBackup(options); + return backupClient.backup(); - if ((0, _types.isDocumentPath)(databasePath)) { - var databaseDocument = database.doc(databasePath); - return databaseDocument.get().then(function (document) { - return (0, _firestore.backupDocument)(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON); - }); + /*if (isDocumentPath(options.databaseStartPath)) { + const databaseDocument = options.database.doc(options.databaseStartPath) + return databaseDocument.get() + .then((document) => { + return backupClient.backupDocument(document, options.backupPath + '/' + document.ref.path, '/', options.prettyPrintJSON) + }) } - if ((0, _types.isCollectionPath)(databaseStartPath)) { - var databaseCollection = database.collection(databasePath); - return (0, _firestore.backupCollection)(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON); + if (isCollectionPath(options.databaseStartPath)) { + const databaseCollection = options.database.collection(options.databaseStartPath) + return backupClient.backupCollection(databaseCollection, options.backupPath + '/' + databaseCollection.path, '/', options.prettyPrintJSON) } - - return (0, _firestore.backupRootCollections)(database, backupPath, prettyPrintJSON); + return backupClient.backupRootCollections()*/ }; var _firebaseAdmin = require('firebase-admin'); diff --git a/dist/index.js.flow b/dist/index.js.flow index 7d3d085..b17e5cc 100644 --- a/dist/index.js.flow +++ b/dist/index.js.flow @@ -5,20 +5,23 @@ import Firebase from 'firebase-admin' import fs from 'fs' import mkdirp from 'mkdirp' -import { backupRootCollections, backupCollection, backupDocument } from './firestore' -import { isDocumentPath, isCollectionPath } from './types' +// import { backupRootCollections, backupCollection, backupDocument } from './firestore' +import { FirestoreBackup } from './firestore' +import { isDocumentPath, isCollectionPath, BackupOptions } from './types' + +export default function(_options: BackupOptions) { + const options = Object.assign({}, _options, {databaseStartPath: ''}) -export default function(accountCredentials: string | Object, databaseStartPath: string, backupPath: string, prettyPrintJSON: boolean) { let accountCredentialsContents: Object - if (typeof accountCredentials === 'string') { + if (typeof options.accountCredentials === 'string') { try { - const accountCredentialsBuffer = fs.readFileSync(accountCredentials) + const accountCredentialsBuffer = fs.readFileSync(options.accountCredentials) accountCredentialsContents = JSON.parse(accountCredentialsBuffer.toString()) } catch (error) { - throw new Error('Unable to read account credential file \'' + accountCredentials + '\': ' + error) + throw new Error('Unable to read account credential file \'' + options.accountCredentials + '\': ' + error) } - } else if (typeof accountCredentials === 'object') { - accountCredentialsContents = accountCredentials + } else if (typeof options.accountCredentials === 'object') { + accountCredentialsContents = options.accountCredentials } else { throw new Error('No account credentials provided') } @@ -28,25 +31,26 @@ export default function(accountCredentials: string | Object, databaseStartPath: }) try { - mkdirp.sync(backupPath) + mkdirp.sync(options.backupPath) } catch (error) { - throw new Error('Unable to create backup path \'' + backupPath + '\': ' + error) + throw new Error('Unable to create backup path \'' + options.backupPath + '\': ' + error) } - const database = Firebase.firestore() - const databasePath = (databaseStartPath || ''); + options.database = Firebase.firestore() + const backupClient = new FirestoreBackup(options) + return backupClient.backup() - if(isDocumentPath(databasePath)) { - const databaseDocument = database.doc(databasePath) + /*if (isDocumentPath(options.databaseStartPath)) { + const databaseDocument = options.database.doc(options.databaseStartPath) return databaseDocument.get() - .then((document)=>{ - return backupDocument(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON) + .then((document) => { + return backupClient.backupDocument(document, options.backupPath + '/' + document.ref.path, '/', options.prettyPrintJSON) }) } - if(isCollectionPath(databaseStartPath)) { - const databaseCollection = database.collection(databasePath) - return backupCollection(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON) + if (isCollectionPath(options.databaseStartPath)) { + const databaseCollection = options.database.collection(options.databaseStartPath) + return backupClient.backupCollection(databaseCollection, options.backupPath + '/' + databaseCollection.path, '/', options.prettyPrintJSON) } - return backupRootCollections(database, backupPath, prettyPrintJSON) + return backupClient.backupRootCollections()*/ } diff --git a/dist/types.js.flow b/dist/types.js.flow index f4a7b4d..e2955a7 100644 --- a/dist/types.js.flow +++ b/dist/types.js.flow @@ -11,6 +11,15 @@ export type ValidationResult = ValueDescription | false; export type Validator = (value: any) => ValidationResult; +export type BackupOptions = { + accountCredentials: string | Object, + database: Object, + backupPath: string, + databaseStartPath: string, + prettyPrintJSON: boolean, + requestCountLimit: number +} + // Returns if a value is a string export const isString = (value: any): ValidationResult => { if (typeof value === 'string' || value instanceof String) { @@ -44,7 +53,7 @@ export const isArray = (value: any): ValidationResult => { return false } -const isObjectOfType = (value: any, type: Class < any > , typeName: string): ValidationResult => { +const isObjectOfType = (value: any, type: Class, typeName: string): ValidationResult => { if (value && typeof value === 'object' && value.constructor === type) { return { value, diff --git a/dist/utility.js b/dist/utility.js index 841c793..e4a52b9 100644 --- a/dist/utility.js +++ b/dist/utility.js @@ -15,6 +15,12 @@ var promiseSerial = exports.promiseSerial = function promiseSerial(funcs) { }, Promise.resolve([])); }; +/** + * Splits a string into path segments, using slashes as separators. + * + * @param {string} relativePath - The path to split. + * @returns {Array.} - The split path segments. + */ var getSegments = exports.getSegments = function getSegments(relativePath) { // We may have an empty segment at the beginning or end if they had a // leading or trailing slash (which we allow). diff --git a/dist/utility.js.flow b/dist/utility.js.flow index 3eec3c6..496f54c 100644 --- a/dist/utility.js.flow +++ b/dist/utility.js.flow @@ -11,8 +11,14 @@ export const promiseSerial = (funcs) => { }, Promise.resolve([])) } +/** + * Splits a string into path segments, using slashes as separators. + * + * @param {string} relativePath - The path to split. + * @returns {Array.} - The split path segments. + */ export const getSegments = (relativePath) => { // We may have an empty segment at the beginning or end if they had a // leading or trailing slash (which we allow). - return relativePath.split('/').filter(segment => segment.length > 0); + return relativePath.split('/').filter(segment => segment.length > 0) } diff --git a/lib/firestore.js b/lib/firestore.js index b8db736..a6035bb 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -1,11 +1,23 @@ /* @flow */ -import { isString, isNull, isObject, isArray, isNumber, isDate, isBoolean, isReference } from './types' -import type { ValueDescription, Validator } from './types' +import { + isString, + isNull, + isObject, + isArray, + isNumber, + isDate, + isBoolean, + isReference, + isDocumentPath, + isCollectionPath +} from './types' +import type { ValueDescription, Validator, BackupOptions } from './types' import { promiseSerial } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' +import Promise from 'bluebird' export const constructReferenceUrl = (reference: Object): ValueDescription => { const referenceSegments = reference._referencePath.segments @@ -30,9 +42,9 @@ export const constructReferenceUrl = (reference: Object): ValueDescription => { } const testValidDocumentValue = ( - key: string, - documentData: Object, - validators: Array) => { + key: string, + documentData: Object, + validators: Array) => { let validValue: ?ValueDescription for (let index = 0; index < validators.length; index++) { @@ -81,89 +93,119 @@ export const constructDocumentValue = (documentDataToStore: Object = {}, keys: A const documentValue = testValidDocumentValue(key, documentData, basicTypeValidators) if (documentValue) { - documentDataToStore = Object.assign({}, documentDataToStore, { [key]: documentValue }) + documentDataToStore = Object.assign({}, documentDataToStore, { + [key]: documentValue + }) } else { const validValue = isReference(documentData[key]) if (validValue) { - documentDataToStore = Object.assign({}, documentDataToStore, { [key]: constructReferenceUrl(documentData[key]) }) + documentDataToStore = Object.assign({}, documentDataToStore, { + [key]: constructReferenceUrl(documentData[key]) + }) } else { documentDataToStore = { value: documentData[key], type: 'unknown' } } - // TODO: stronger validation that we have a reference rather than being our fallback + // TODO: stronger validation that we have a reference rather than being our fallback } } }) return documentDataToStore } -export const backupDocument = (document: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { - console.log('Backing up Document \'' + logPath + document.id + '\'') - try { - mkdirp.sync(backupPath) - } catch (error) { - throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error) +const defaultBackupOptions = { + databaseStartPath: '', + requestCountLimit: 1 +} + +export class FirestoreBackup { + options: BackupOptions; + + constructor(options: BackupOptions) { + this.options = Object.assign({}, defaultBackupOptions, options) + Object.assign(this, this.options) + + if(this.requestCountLimit > 1) { + this.documentRequestLimit = 3 // 3 is the max before diminishing returns + } } - let fileContents: string - try { - const documentData = document.data() - const keys = Object.keys(documentData) - var documentDataToStore = {} - documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)) - if (prettyPrintJSON === true) { - fileContents = JSON.stringify(documentDataToStore, null, 2) - } else { - fileContents = JSON.stringify(documentDataToStore) + backup() { + if (isDocumentPath(this.databaseStartPath)) { + const databaseDocument = this.database.doc(this.databaseStartPath) + return databaseDocument.get() + .then((document) => { + return this.backupDocument(document, this.backupPath + '/' + document.ref.path, '/', this.prettyPrintJSON) + }) + } + + if (isCollectionPath(this.databaseStartPath)) { + const databaseCollection = this.database.collection(this.databaseStartPath) + return this.backupCollection(databaseCollection, this.backupPath + '/' + databaseCollection.path, '/', this.prettyPrintJSON) } - } catch (error) { - throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error) + + return this.backupRootCollections() } - try { - fs.writeFileSync(backupPath + '/' + document.id + '.json', fileContents) - } catch (error) { - throw new Error('Unable to write Document \'' + document.id + '\': ' + error) + + backupRootCollections() { + return this.database.getCollections() + .then((collections) => { + return promiseSerial(collections.map((collection) => { + return () => { + return this.backupCollection(collection, this.backupPath + '/' + collection.id, '/') + } + })) + }) } - return document.ref.getCollections() - .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON) - } - })) - }) -} + backupCollection(collection: Object, backupPath: string, logPath: string) { + console.log('Backing up Collection \'' + logPath + collection.id + '\'') + try { + mkdirp.sync(backupPath) + } catch (error) { + throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) + } -export const backupCollection = (collection: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { - console.log('Backing up Collection \'' + logPath + collection.id + '\'') - try { - mkdirp.sync(backupPath) - } catch (error) { - throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) + return Promise.resolve(collection.get()) + .then((documentSnapshots) => documentSnapshots.docs) + .map((document) => { + return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', this.prettyPrintJSON) + }, { concurrency: this.requestCountLimit }) } - return collection.get() - .then((documentSnapshots) => { - const backupFunctions = [] - documentSnapshots.forEach((document) => { - backupFunctions.push(() => { - return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON) - }) - }) - return promiseSerial(backupFunctions) - }) -} + backupDocument(document: Object, backupPath: string, logPath: string) { + console.log('Backing up Document \'' + logPath + document.id + '\'') + try { + mkdirp.sync(backupPath) + } catch (error) { + throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error) + } -export const backupRootCollections = (database: Object, backupPath: string, prettyPrintJSON: boolean) => { - return database.getCollections() - .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return backupCollection(collection, backupPath + '/' + collection.id, '/', prettyPrintJSON) - } - })) - }) + let fileContents: string + try { + const documentData = document.data() + const keys = Object.keys(documentData) + var documentDataToStore = {} + documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)) + if (this.prettyPrintJSON === true) { + fileContents = JSON.stringify(documentDataToStore, null, 2) + } else { + fileContents = JSON.stringify(documentDataToStore) + } + } catch (error) { + throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error) + } + try { + fs.writeFileSync(backupPath + '/' + document.id + '.json', fileContents) + } catch (error) { + throw new Error('Unable to write Document \'' + document.id + '\': ' + error) + } + + return Promise.resolve(document.ref.getCollections()) + .map((collection) => { + return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', this.prettyPrintJSON) + }, { concurrency: this.documentRequestLimit }) + } } diff --git a/lib/index.js b/lib/index.js index 24ee427..525d6f0 100644 --- a/lib/index.js +++ b/lib/index.js @@ -5,20 +5,22 @@ import Firebase from 'firebase-admin' import fs from 'fs' import mkdirp from 'mkdirp' -import { backupRootCollections, backupCollection, backupDocument } from './firestore' -import { isDocumentPath, isCollectionPath } from './types' +import { FirestoreBackup } from './firestore' +import { isDocumentPath, isCollectionPath, BackupOptions } from './types' + +export default function(_options: BackupOptions) { + const options = Object.assign({}, _options, {databaseStartPath: ''}) -export default function(accountCredentials: string | Object, databaseStartPath: string, backupPath: string, prettyPrintJSON: boolean) { let accountCredentialsContents: Object - if (typeof accountCredentials === 'string') { + if (typeof options.accountCredentials === 'string') { try { - const accountCredentialsBuffer = fs.readFileSync(accountCredentials) + const accountCredentialsBuffer = fs.readFileSync(options.accountCredentials) accountCredentialsContents = JSON.parse(accountCredentialsBuffer.toString()) } catch (error) { - throw new Error('Unable to read account credential file \'' + accountCredentials + '\': ' + error) + throw new Error('Unable to read account credential file \'' + options.accountCredentials + '\': ' + error) } - } else if (typeof accountCredentials === 'object') { - accountCredentialsContents = accountCredentials + } else if (typeof options.accountCredentials === 'object') { + accountCredentialsContents = options.accountCredentials } else { throw new Error('No account credentials provided') } @@ -28,25 +30,12 @@ export default function(accountCredentials: string | Object, databaseStartPath: }) try { - mkdirp.sync(backupPath) + mkdirp.sync(options.backupPath) } catch (error) { - throw new Error('Unable to create backup path \'' + backupPath + '\': ' + error) - } - - const database = Firebase.firestore() - const databasePath = (databaseStartPath || '') - - if (isDocumentPath(databasePath)) { - const databaseDocument = database.doc(databasePath) - return databaseDocument.get() - .then((document) => { - return backupDocument(document, backupPath + '/' + document.ref.path, '/', prettyPrintJSON) - }) - } - if (isCollectionPath(databaseStartPath)) { - const databaseCollection = database.collection(databasePath) - return backupCollection(databaseCollection, backupPath + '/' + databaseCollection.path, '/', prettyPrintJSON) + throw new Error('Unable to create backup path \'' + options.backupPath + '\': ' + error) } - return backupRootCollections(database, backupPath, prettyPrintJSON) + options.database = Firebase.firestore() + const backupClient = new FirestoreBackup(options) + return backupClient.backup() } diff --git a/lib/types.js b/lib/types.js index 217d329..e2955a7 100644 --- a/lib/types.js +++ b/lib/types.js @@ -11,6 +11,15 @@ export type ValidationResult = ValueDescription | false; export type Validator = (value: any) => ValidationResult; +export type BackupOptions = { + accountCredentials: string | Object, + database: Object, + backupPath: string, + databaseStartPath: string, + prettyPrintJSON: boolean, + requestCountLimit: number +} + // Returns if a value is a string export const isString = (value: any): ValidationResult => { if (typeof value === 'string' || value instanceof String) { diff --git a/test-results.md b/test-results.md new file mode 100644 index 0000000..cf637d6 --- /dev/null +++ b/test-results.md @@ -0,0 +1,17 @@ +test set of: + * 2 root collections containing 8 "level0" documents each + * each "level0" document has between 3 and 4 subcollections itself + * each subcollection contains a varying amount of "level1" documents ranging from 0 to 12,000 + +`backupDocument` with a concurrency of: + * 1 - backuptime: 479421.435 ms = ~8 mins + * 3 - backuptime: 232267.139 ms = ~3.8 mins + * ~48% reduction of time + * **diminishing return tipping point** + * 20 - backuptime: 238634.216 ms = ~3.9 mins + +`backupDocument` with a concurrency of 3 and `backupCollection` with a concurrency of: + * 3 - backuptime: 87571.663 ms = ~1.4 mins + * ~81% reduction of time + * 20 - backuptime: 28476.332 ms = ~0.4 mins + * ~95% reduction of time From 3ccf82f95b27d2c2151117d5814c017359ceb47e Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Mon, 5 Mar 2018 05:53:22 +0000 Subject: [PATCH 06/17] fix codacy issues --- bin/firestore-backup.js | 20 ++++++++++---------- lib/firestore.js | 2 +- lib/index.js | 2 +- 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/bin/firestore-backup.js b/bin/firestore-backup.js index d927d92..cffd347 100755 --- a/bin/firestore-backup.js +++ b/bin/firestore-backup.js @@ -61,16 +61,16 @@ var firestoreBackup = require('../dist/index.js') try { console.time('backuptime') firestoreBackup.default({ - accountCredentials: accountCredentialsPath, - databaseStartPath, - backupPath, - prettyPrint, - requestCountLimit - }) - .then(() => { - console.log(colors.bold(colors.green('All done 💫'))) - console.timeEnd('backuptime') - }) + accountCredentials: accountCredentialsPath, + databaseStartPath, + backupPath, + prettyPrint, + requestCountLimit + }) + .then(() => { + console.log(colors.bold(colors.green('All done 💫'))) + console.timeEnd('backuptime') + }) } catch (error) { console.log(colors.red(error)) process.exit(1) diff --git a/lib/firestore.js b/lib/firestore.js index a6035bb..2d77b13 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -127,7 +127,7 @@ export class FirestoreBackup { this.options = Object.assign({}, defaultBackupOptions, options) Object.assign(this, this.options) - if(this.requestCountLimit > 1) { + if (this.requestCountLimit > 1) { this.documentRequestLimit = 3 // 3 is the max before diminishing returns } } diff --git a/lib/index.js b/lib/index.js index 525d6f0..42b66c8 100644 --- a/lib/index.js +++ b/lib/index.js @@ -6,7 +6,7 @@ import fs from 'fs' import mkdirp from 'mkdirp' import { FirestoreBackup } from './firestore' -import { isDocumentPath, isCollectionPath, BackupOptions } from './types' +import { BackupOptions } from './types' export default function(_options: BackupOptions) { const options = Object.assign({}, _options, {databaseStartPath: ''}) From 59bcfceed460cb96396d60d3fcf9cc6fe9a49c2e Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Mon, 5 Mar 2018 05:58:41 +0000 Subject: [PATCH 07/17] fix codacy issues --- bin/firestore-backup.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/bin/firestore-backup.js b/bin/firestore-backup.js index cffd347..a19f4cc 100755 --- a/bin/firestore-backup.js +++ b/bin/firestore-backup.js @@ -67,10 +67,10 @@ try { prettyPrint, requestCountLimit }) - .then(() => { - console.log(colors.bold(colors.green('All done 💫'))) - console.timeEnd('backuptime') - }) + .then(() => { + console.log(colors.bold(colors.green('All done 💫'))) + console.timeEnd('backuptime') + }) } catch (error) { console.log(colors.red(error)) process.exit(1) From c00e9f60f20ba54cedf623209029837fcf59bb61 Mon Sep 17 00:00:00 2001 From: Ian G Date: Wed, 7 Mar 2018 13:45:57 -0500 Subject: [PATCH 08/17] Use options member rather than Object.assign to this Pretect against accidental or melicious overwriting --- dist/firestore.js | 100 ++++++++------------------------------- dist/firestore.js.flow | 104 +++++++++-------------------------------- lib/firestore.js | 27 +++++------ 3 files changed, 55 insertions(+), 176 deletions(-) diff --git a/dist/firestore.js b/dist/firestore.js index d0755bd..5724205 100644 --- a/dist/firestore.js +++ b/dist/firestore.js @@ -29,12 +29,6 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } -var backupDocumentConcurrency = 3; // 3 is the max before diminishing returns -var defaultBackupOptions = { - databaseStartPath: '', - requestCountLimit: 1 -}; - var constructReferenceUrl = exports.constructReferenceUrl = function constructReferenceUrl(reference) { var referenceSegments = reference._referencePath.segments; var referencePath = void 0; @@ -118,74 +112,20 @@ var constructDocumentValue = exports.constructDocumentValue = function construct return documentDataToStore; }; -/*export const backupDocument = (document: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { - console.log('Backing up Document \'' + logPath + document.id + '\'') - try { - mkdirp.sync(backupPath) - } catch (error) { - throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error) - } - - let fileContents: string - try { - const documentData = document.data() - const keys = Object.keys(documentData) - var documentDataToStore = {} - documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)) - if (prettyPrintJSON === true) { - fileContents = JSON.stringify(documentDataToStore, null, 2) - } else { - fileContents = JSON.stringify(documentDataToStore) - } - } catch (error) { - throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error) - } - try { - fs.writeFileSync(backupPath + '/' + document.id + '.json', fileContents) - } catch (error) { - throw new Error('Unable to write Document \'' + document.id + '\': ' + error) - } - - return Promise.resolve(document.ref.getCollections()) - .map((collection) => { - return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON) - }, { concurrency: backupDocumentConcurrency }) -}*/ - -/*export const backupCollection = (collection: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { - console.log('Backing up Collection \'' + logPath + collection.id + '\'') - try { - mkdirp.sync(backupPath) - } catch (error) { - throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) - } - - return Promise.resolve(collection.get()) - .then((documentSnapshots) => documentSnapshots.docs) - .map((document) => { - return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON) - }, { concurrency: backupCollectionConcurrency }) -}*/ - -/*export const backupRootCollections = (database: Object, backupPath: string, prettyPrintJSON: boolean) => { - return database.getCollections() - .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return backupCollection(collection, backupPath + '/' + collection.id, '/', prettyPrintJSON) - } - })) - }) -}*/ +var defaultBackupOptions = { + databaseStartPath: '', + requestCountLimit: 1 +}; var FirestoreBackup = exports.FirestoreBackup = function () { function FirestoreBackup(options) { _classCallCheck(this, FirestoreBackup); this.options = Object.assign({}, defaultBackupOptions, options); - Object.assign(this, this.options); - // backupCollectionConcurrency = this.requestCountLimit + if (this.options.requestCountLimit > 1) { + this.documentRequestLimit = 3; // 3 is the max before diminishing returns + } } _createClass(FirestoreBackup, [{ @@ -193,16 +133,16 @@ var FirestoreBackup = exports.FirestoreBackup = function () { value: function backup() { var _this = this; - if ((0, _types.isDocumentPath)(this.databaseStartPath)) { - var databaseDocument = this.database.doc(this.databaseStartPath); + if ((0, _types.isDocumentPath)(this.options.databaseStartPath)) { + var databaseDocument = this.options.database.doc(this.options.databaseStartPath); return databaseDocument.get().then(function (document) { - return _this.backupDocument(document, _this.backupPath + '/' + document.ref.path, '/', _this.prettyPrintJSON); + return _this.backupDocument(document, _this.options.backupPath + '/' + document.ref.path, '/'); }); } - if ((0, _types.isCollectionPath)(this.databaseStartPath)) { - var databaseCollection = this.database.collection(this.databaseStartPath); - return this.backupCollection(databaseCollection, this.backupPath + '/' + databaseCollection.path, '/', this.prettyPrintJSON); + if ((0, _types.isCollectionPath)(this.options.databaseStartPath)) { + var databaseCollection = this.options.database.collection(this.options.databaseStartPath); + return this.backupCollection(databaseCollection, this.options.backupPath + '/' + databaseCollection.path, '/'); } return this.backupRootCollections(); @@ -212,10 +152,10 @@ var FirestoreBackup = exports.FirestoreBackup = function () { value: function backupRootCollections() { var _this2 = this; - return this.database.getCollections().then(function (collections) { + return this.options.database.getCollections().then(function (collections) { return (0, _utility.promiseSerial)(collections.map(function (collection) { return function () { - return _this2.backupCollection(collection, _this2.backupPath + '/' + collection.id, '/'); + return _this2.backupCollection(collection, _this2.options.backupPath + '/' + collection.id, '/'); }; })); }); @@ -225,7 +165,6 @@ var FirestoreBackup = exports.FirestoreBackup = function () { value: function backupCollection(collection, backupPath, logPath) { var _this3 = this; - // return backupCollection(collection, backupPath, logPath, this.prettyPrintJSON) console.log('Backing up Collection \'' + logPath + collection.id + '\''); try { _mkdirp2.default.sync(backupPath); @@ -236,15 +175,14 @@ var FirestoreBackup = exports.FirestoreBackup = function () { return _bluebird2.default.resolve(collection.get()).then(function (documentSnapshots) { return documentSnapshots.docs; }).map(function (document) { - return _this3.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', _this3.prettyPrintJSON); - }, { concurrency: this.requestCountLimit }); + return _this3.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/'); + }, { concurrency: this.options.requestCountLimit }); } }, { key: 'backupDocument', value: function backupDocument(document, backupPath, logPath) { var _this4 = this; - // return backupDocument(document, backupPath, logPath, this.prettyPrintJSON) console.log('Backing up Document \'' + logPath + document.id + '\''); try { _mkdirp2.default.sync(backupPath); @@ -273,8 +211,8 @@ var FirestoreBackup = exports.FirestoreBackup = function () { } return _bluebird2.default.resolve(document.ref.getCollections()).map(function (collection) { - return _this4.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', _this4.prettyPrintJSON); - }, { concurrency: backupDocumentConcurrency }); + return _this4.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/'); + }, { concurrency: this.documentRequestLimit }); } }]); diff --git a/dist/firestore.js.flow b/dist/firestore.js.flow index 291c06e..ffd0fde 100644 --- a/dist/firestore.js.flow +++ b/dist/firestore.js.flow @@ -19,15 +19,9 @@ import fs from 'fs' import mkdirp from 'mkdirp' import Promise from 'bluebird' -const backupDocumentConcurrency = 3; // 3 is the max before diminishing returns -const defaultBackupOptions = { - databaseStartPath: '', - requestCountLimit: 1 -} - export const constructReferenceUrl = (reference: Object): ValueDescription => { const referenceSegments = reference._referencePath.segments - let referencePath: ? string + let referencePath: ?string if (Array.isArray(referenceSegments)) { referencePath = referenceSegments.join('/') } else if (typeof referenceSegments === 'string') { @@ -121,106 +115,53 @@ export const constructDocumentValue = (documentDataToStore: Object = {}, keys: A return documentDataToStore } -/*export const backupDocument = (document: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { - console.log('Backing up Document \'' + logPath + document.id + '\'') - try { - mkdirp.sync(backupPath) - } catch (error) { - throw new Error('Unable to create backup path for Document \'' + document.id + '\': ' + error) - } - - let fileContents: string - try { - const documentData = document.data() - const keys = Object.keys(documentData) - var documentDataToStore = {} - documentDataToStore = Object.assign({}, constructDocumentValue(documentDataToStore, keys, documentData)) - if (prettyPrintJSON === true) { - fileContents = JSON.stringify(documentDataToStore, null, 2) - } else { - fileContents = JSON.stringify(documentDataToStore) - } - } catch (error) { - throw new Error('Unable to serialize Document \'' + document.id + '\': ' + error) - } - try { - fs.writeFileSync(backupPath + '/' + document.id + '.json', fileContents) - } catch (error) { - throw new Error('Unable to write Document \'' + document.id + '\': ' + error) - } - - return Promise.resolve(document.ref.getCollections()) - .map((collection) => { - return backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', prettyPrintJSON) - }, { concurrency: backupDocumentConcurrency }) -}*/ - -/*export const backupCollection = (collection: Object, backupPath: string, logPath: string, prettyPrintJSON: boolean) => { - console.log('Backing up Collection \'' + logPath + collection.id + '\'') - try { - mkdirp.sync(backupPath) - } catch (error) { - throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) - } - - return Promise.resolve(collection.get()) - .then((documentSnapshots) => documentSnapshots.docs) - .map((document) => { - return backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', prettyPrintJSON) - }, { concurrency: backupCollectionConcurrency }) -}*/ - -/*export const backupRootCollections = (database: Object, backupPath: string, prettyPrintJSON: boolean) => { - return database.getCollections() - .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return backupCollection(collection, backupPath + '/' + collection.id, '/', prettyPrintJSON) - } - })) - }) -}*/ +const defaultBackupOptions = { + databaseStartPath: '', + requestCountLimit: 1 +} export class FirestoreBackup { options: BackupOptions; + documentRequestLimit: number; + constructor(options: BackupOptions) { this.options = Object.assign({}, defaultBackupOptions, options) - Object.assign(this, this.options) - // backupCollectionConcurrency = this.requestCountLimit + if (this.options.requestCountLimit > 1) { + this.documentRequestLimit = 3 // 3 is the max before diminishing returns + } } backup() { - if (isDocumentPath(this.databaseStartPath)) { - const databaseDocument = this.database.doc(this.databaseStartPath) + if (isDocumentPath(this.options.databaseStartPath)) { + const databaseDocument = this.options.database.doc(this.options.databaseStartPath) return databaseDocument.get() .then((document) => { - return this.backupDocument(document, this.backupPath + '/' + document.ref.path, '/', this.prettyPrintJSON) + return this.backupDocument(document, this.options.backupPath + '/' + document.ref.path, '/') }) } - if (isCollectionPath(this.databaseStartPath)) { - const databaseCollection = this.database.collection(this.databaseStartPath) - return this.backupCollection(databaseCollection, this.backupPath + '/' + databaseCollection.path, '/', this.prettyPrintJSON) + if (isCollectionPath(this.options.databaseStartPath)) { + const databaseCollection = this.options.database.collection(this.options.databaseStartPath) + return this.backupCollection(databaseCollection, this.options.backupPath + '/' + databaseCollection.path, '/') } return this.backupRootCollections() } backupRootCollections() { - return this.database.getCollections() + return this.options.database.getCollections() .then((collections) => { return promiseSerial(collections.map((collection) => { return () => { - return this.backupCollection(collection, this.backupPath + '/' + collection.id, '/') + return this.backupCollection(collection, this.options.backupPath + '/' + collection.id, '/') } })) }) } backupCollection(collection: Object, backupPath: string, logPath: string) { - // return backupCollection(collection, backupPath, logPath, this.prettyPrintJSON) console.log('Backing up Collection \'' + logPath + collection.id + '\'') try { mkdirp.sync(backupPath) @@ -231,12 +172,11 @@ export class FirestoreBackup { return Promise.resolve(collection.get()) .then((documentSnapshots) => documentSnapshots.docs) .map((document) => { - return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', this.prettyPrintJSON) - }, { concurrency: this.requestCountLimit }) + return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') + }, { concurrency: this.options.requestCountLimit }) } backupDocument(document: Object, backupPath: string, logPath: string) { - // return backupDocument(document, backupPath, logPath, this.prettyPrintJSON) console.log('Backing up Document \'' + logPath + document.id + '\'') try { mkdirp.sync(backupPath) @@ -266,7 +206,7 @@ export class FirestoreBackup { return Promise.resolve(document.ref.getCollections()) .map((collection) => { - return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', this.prettyPrintJSON) - }, { concurrency: backupDocumentConcurrency }) + return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') + }, { concurrency: this.documentRequestLimit }) } } diff --git a/lib/firestore.js b/lib/firestore.js index 2d77b13..ffd0fde 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -123,38 +123,39 @@ const defaultBackupOptions = { export class FirestoreBackup { options: BackupOptions; + documentRequestLimit: number; + constructor(options: BackupOptions) { this.options = Object.assign({}, defaultBackupOptions, options) - Object.assign(this, this.options) - if (this.requestCountLimit > 1) { + if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3 // 3 is the max before diminishing returns } } backup() { - if (isDocumentPath(this.databaseStartPath)) { - const databaseDocument = this.database.doc(this.databaseStartPath) + if (isDocumentPath(this.options.databaseStartPath)) { + const databaseDocument = this.options.database.doc(this.options.databaseStartPath) return databaseDocument.get() .then((document) => { - return this.backupDocument(document, this.backupPath + '/' + document.ref.path, '/', this.prettyPrintJSON) + return this.backupDocument(document, this.options.backupPath + '/' + document.ref.path, '/') }) } - if (isCollectionPath(this.databaseStartPath)) { - const databaseCollection = this.database.collection(this.databaseStartPath) - return this.backupCollection(databaseCollection, this.backupPath + '/' + databaseCollection.path, '/', this.prettyPrintJSON) + if (isCollectionPath(this.options.databaseStartPath)) { + const databaseCollection = this.options.database.collection(this.options.databaseStartPath) + return this.backupCollection(databaseCollection, this.options.backupPath + '/' + databaseCollection.path, '/') } return this.backupRootCollections() } backupRootCollections() { - return this.database.getCollections() + return this.options.database.getCollections() .then((collections) => { return promiseSerial(collections.map((collection) => { return () => { - return this.backupCollection(collection, this.backupPath + '/' + collection.id, '/') + return this.backupCollection(collection, this.options.backupPath + '/' + collection.id, '/') } })) }) @@ -171,8 +172,8 @@ export class FirestoreBackup { return Promise.resolve(collection.get()) .then((documentSnapshots) => documentSnapshots.docs) .map((document) => { - return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/', this.prettyPrintJSON) - }, { concurrency: this.requestCountLimit }) + return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') + }, { concurrency: this.options.requestCountLimit }) } backupDocument(document: Object, backupPath: string, logPath: string) { @@ -205,7 +206,7 @@ export class FirestoreBackup { return Promise.resolve(document.ref.getCollections()) .map((collection) => { - return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/', this.prettyPrintJSON) + return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') }, { concurrency: this.documentRequestLimit }) } } From 606f22fb7e197c3330baab14751b5db601613dbc Mon Sep 17 00:00:00 2001 From: Ian G Date: Wed, 7 Mar 2018 13:47:11 -0500 Subject: [PATCH 09/17] seal BackupOptions definition --- dist/index.js | 18 ------------------ dist/index.js.flow | 17 +---------------- dist/types.js.flow | 4 ++-- lib/index.js | 2 +- lib/types.js | 4 ++-- 5 files changed, 6 insertions(+), 39 deletions(-) diff --git a/dist/index.js b/dist/index.js index d246b47..5963da8 100644 --- a/dist/index.js +++ b/dist/index.js @@ -6,9 +6,6 @@ Object.defineProperty(exports, "__esModule", { var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; -// import { backupRootCollections, backupCollection, backupDocument } from './firestore' - - exports.default = function (_options) { var options = Object.assign({}, _options, { databaseStartPath: '' }); @@ -39,19 +36,6 @@ exports.default = function (_options) { options.database = _firebaseAdmin2.default.firestore(); var backupClient = new _firestore.FirestoreBackup(options); return backupClient.backup(); - - /*if (isDocumentPath(options.databaseStartPath)) { - const databaseDocument = options.database.doc(options.databaseStartPath) - return databaseDocument.get() - .then((document) => { - return backupClient.backupDocument(document, options.backupPath + '/' + document.ref.path, '/', options.prettyPrintJSON) - }) - } - if (isCollectionPath(options.databaseStartPath)) { - const databaseCollection = options.database.collection(options.databaseStartPath) - return backupClient.backupCollection(databaseCollection, options.backupPath + '/' + databaseCollection.path, '/', options.prettyPrintJSON) - } - return backupClient.backupRootCollections()*/ }; var _firebaseAdmin = require('firebase-admin'); @@ -68,6 +52,4 @@ var _mkdirp2 = _interopRequireDefault(_mkdirp); var _firestore = require('./firestore'); -var _types = require('./types'); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } \ No newline at end of file diff --git a/dist/index.js.flow b/dist/index.js.flow index b17e5cc..6a98343 100644 --- a/dist/index.js.flow +++ b/dist/index.js.flow @@ -5,9 +5,8 @@ import Firebase from 'firebase-admin' import fs from 'fs' import mkdirp from 'mkdirp' -// import { backupRootCollections, backupCollection, backupDocument } from './firestore' import { FirestoreBackup } from './firestore' -import { isDocumentPath, isCollectionPath, BackupOptions } from './types' +import type { BackupOptions } from './types' export default function(_options: BackupOptions) { const options = Object.assign({}, _options, {databaseStartPath: ''}) @@ -39,18 +38,4 @@ export default function(_options: BackupOptions) { options.database = Firebase.firestore() const backupClient = new FirestoreBackup(options) return backupClient.backup() - - /*if (isDocumentPath(options.databaseStartPath)) { - const databaseDocument = options.database.doc(options.databaseStartPath) - return databaseDocument.get() - .then((document) => { - return backupClient.backupDocument(document, options.backupPath + '/' + document.ref.path, '/', options.prettyPrintJSON) - }) - } - if (isCollectionPath(options.databaseStartPath)) { - const databaseCollection = options.database.collection(options.databaseStartPath) - return backupClient.backupCollection(databaseCollection, options.backupPath + '/' + databaseCollection.path, '/', options.prettyPrintJSON) - } - - return backupClient.backupRootCollections()*/ } diff --git a/dist/types.js.flow b/dist/types.js.flow index e2955a7..b22f2be 100644 --- a/dist/types.js.flow +++ b/dist/types.js.flow @@ -11,14 +11,14 @@ export type ValidationResult = ValueDescription | false; export type Validator = (value: any) => ValidationResult; -export type BackupOptions = { +export type BackupOptions = {| accountCredentials: string | Object, database: Object, backupPath: string, databaseStartPath: string, prettyPrintJSON: boolean, requestCountLimit: number -} +|} // Returns if a value is a string export const isString = (value: any): ValidationResult => { diff --git a/lib/index.js b/lib/index.js index 42b66c8..6a98343 100644 --- a/lib/index.js +++ b/lib/index.js @@ -6,7 +6,7 @@ import fs from 'fs' import mkdirp from 'mkdirp' import { FirestoreBackup } from './firestore' -import { BackupOptions } from './types' +import type { BackupOptions } from './types' export default function(_options: BackupOptions) { const options = Object.assign({}, _options, {databaseStartPath: ''}) diff --git a/lib/types.js b/lib/types.js index e2955a7..b22f2be 100644 --- a/lib/types.js +++ b/lib/types.js @@ -11,14 +11,14 @@ export type ValidationResult = ValueDescription | false; export type Validator = (value: any) => ValidationResult; -export type BackupOptions = { +export type BackupOptions = {| accountCredentials: string | Object, database: Object, backupPath: string, databaseStartPath: string, prettyPrintJSON: boolean, requestCountLimit: number -} +|} // Returns if a value is a string export const isString = (value: any): ValidationResult => { From 6ec28d727dd809af57611219a15aefe33f7470d9 Mon Sep 17 00:00:00 2001 From: Ian G Date: Wed, 7 Mar 2018 13:47:33 -0500 Subject: [PATCH 10/17] Option misspelling fix --- bin/firestore-backup.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/bin/firestore-backup.js b/bin/firestore-backup.js index a19f4cc..b861df9 100755 --- a/bin/firestore-backup.js +++ b/bin/firestore-backup.js @@ -51,7 +51,7 @@ if (!backupPath) { process.exit(1) } -const prettyPrint = commander[prettyPrintParamKey] !== undefined && commander[prettyPrintParamKey] !== null +const prettyPrintJSON = commander[prettyPrintParamKey] !== undefined && commander[prettyPrintParamKey] !== null const databaseStartPath = (commander[databaseStartPathParamKey] || '').replace(/^\//, '') @@ -64,7 +64,7 @@ try { accountCredentials: accountCredentialsPath, databaseStartPath, backupPath, - prettyPrint, + prettyPrintJSON, requestCountLimit }) .then(() => { From 492aba665db782288929a6f784b969a53fb50dad Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 11 Mar 2018 01:59:03 +0000 Subject: [PATCH 11/17] make prefixed class properties private --- .flowconfig | 1 + 1 file changed, 1 insertion(+) diff --git a/.flowconfig b/.flowconfig index c44fcda..3a2d2dc 100644 --- a/.flowconfig +++ b/.flowconfig @@ -9,5 +9,6 @@ lib/.* [libs] [options] +munge_underscores=true [lints] From 44450a2dd62a26156f590d0d5f6c16a40cd6af48 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 11 Mar 2018 02:04:34 +0000 Subject: [PATCH 12/17] utility to bootstrap an object with a map method. type function to determine if a value is of type Function --- lib/types.js | 5 +++++ lib/utility.js | 28 ++++++++++++++++++++++++++++ 2 files changed, 33 insertions(+) diff --git a/lib/types.js b/lib/types.js index b22f2be..5f35f93 100644 --- a/lib/types.js +++ b/lib/types.js @@ -68,6 +68,11 @@ export const isObject = (value: any): ValidationResult => { return isObjectOfType(value, Object, 'object') } +// Returns if a value is a function +export const isFunction = (value: any): ValidationResult => { + return isObjectOfType(value, Function, 'function') +} + // Returns if a value is null export const isNull = (value: any): ValidationResult => { if (value === null) { diff --git a/lib/utility.js b/lib/utility.js index 496f54c..3f67170 100644 --- a/lib/utility.js +++ b/lib/utility.js @@ -1,4 +1,7 @@ // TODO: Flow coverage + +import { isFunction } from './types' + // from: https://hackernoon.com/functional-javascript-resolving-promises-sequentially-7aac18c4431e export const promiseSerial = (funcs) => { return funcs.reduce( @@ -22,3 +25,28 @@ export const getSegments = (relativePath) => { // leading or trailing slash (which we allow). return relativePath.split('/').filter(segment => segment.length > 0) } + +const map = (basePromise: Object, fn: Function, options: Object) => { + return basePromise.then((value) => { + return promiseSerial(value.map((value) => { + return () => { + return fn(value) + } + })) + }) +} + +/** + * Adds the method 'map' to the prototype of an object. + * + * @param {object} obj - The object to receive the 'map' method. + */ +export const addMapFunction = (obj: Object) => { + if (!isFunction(obj.map)) { + obj.prototype.map = function(fn: Function, options: Object) { + return map(this, fn, options) + } + } + + return obj +} From dcafe188da3c19a824918a626ce411ae4d57ea36 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 11 Mar 2018 02:07:04 +0000 Subject: [PATCH 13/17] add the ability to specify which Promise library the FirestoreBackup will use. removed bluebird from dependencies --- lib/firestore.js | 25 +- package-lock.json | 2670 +++++++++++++++++++++++++++++++++++---------- package.json | 1 - 3 files changed, 2101 insertions(+), 595 deletions(-) diff --git a/lib/firestore.js b/lib/firestore.js index ffd0fde..f36d0de 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -13,11 +13,10 @@ import { isCollectionPath } from './types' import type { ValueDescription, Validator, BackupOptions } from './types' -import { promiseSerial } from './utility' +import { promiseSerial, addMapFunction } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' -import Promise from 'bluebird' export const constructReferenceUrl = (reference: Object): ValueDescription => { const referenceSegments = reference._referencePath.segments @@ -125,12 +124,28 @@ export class FirestoreBackup { documentRequestLimit: number; + _PromiseLibrary: Object; + constructor(options: BackupOptions) { this.options = Object.assign({}, defaultBackupOptions, options) if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3 // 3 is the max before diminishing returns } + + this.Promise = Promise + } + + get Promise() { + return this._PromiseLibrary + } + + /** + * The Promise library used to process asynchronous functions. + */ + set Promise(value: Object) { + // TODO: validate this ia valid Promise-like object + this._PromiseLibrary = addMapFunction(value) } backup() { @@ -169,11 +184,12 @@ export class FirestoreBackup { throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) } - return Promise.resolve(collection.get()) + return this.Promise.resolve(collection.get()) .then((documentSnapshots) => documentSnapshots.docs) .map((document) => { return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') }, { concurrency: this.options.requestCountLimit }) + .catch(err=>console.error(err)) } backupDocument(document: Object, backupPath: string, logPath: string) { @@ -204,9 +220,10 @@ export class FirestoreBackup { throw new Error('Unable to write Document \'' + document.id + '\': ' + error) } - return Promise.resolve(document.ref.getCollections()) + return this.Promise.resolve(document.ref.getCollections()) .map((collection) => { return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') }, { concurrency: this.documentRequestLimit }) + .catch(err=>console.error(err)) } } diff --git a/package-lock.json b/package-lock.json index 22bc469..97b389e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -20,11 +20,12 @@ "integrity": "sha512-bCIZGeMtP0ibrXNNaU214/1tRNw0jHnir/cfiAao1gjUyIS7RzOTQoH+zbwPJNEwUqJ0T3ykw/Tv4/khGqbVBg==" }, "@firebase/database": { - "version": "0.1.11", - "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.1.11.tgz", - "integrity": "sha512-1TX8YlL3BCjgsbe1qvgg/r0SxOvIlJdmaktXXm6fnaPCjSD0Vhm5ln2EX3xGY97ft/Lruy9AA/7TfnAKIYA/+w==", + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.2.0.tgz", + "integrity": "sha512-3IYqpxFv3ZIOc+JmGKqn+Yyg36lsxmw/bzZrmsm2YG0Rk9uJkPCGMXxRI+K5+8RYZmQxotL+USRxGYzk0wKvjw==", "requires": { - "@firebase/database-types": "0.1.2", + "@firebase/database-types": "0.2.0", + "@firebase/logger": "0.1.0", "@firebase/util": "0.1.10", "faye-websocket": "0.11.1", "tslib": "1.9.0" @@ -41,9 +42,14 @@ } }, "@firebase/database-types": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.1.2.tgz", - "integrity": "sha512-WDqyclInvbD6qNtbVlatzXW6SpsV8V1Nz7DaTM8z27CwxRtXakAXxERPnGipA0ZbZV4v+Xs1+6wC7Xc6T4EVaw==" + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.2.0.tgz", + "integrity": "sha512-QFrxlLABVbZAVJqw1XNkSYZK22qPjpE3U5eM1SO7Htx69TrIgX7tb1/+BJnFkb3AKUD33tAr22Z4XVth5Ys46A==" + }, + "@firebase/logger": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.1.0.tgz", + "integrity": "sha512-/abxM9/l0V9WzNXvSonI2imVqORVhyCVS8yJ1O2rsRmNzw3FIPPIt0BuTvmCBH1oh1uDtZIn2Aar1p7zF69KWg==" }, "@firebase/util": { "version": "0.1.10", @@ -60,12 +66,12 @@ "requires": { "array-uniq": "1.0.3", "arrify": "1.0.1", - "concat-stream": "1.6.0", + "concat-stream": "1.6.1", "create-error-class": "3.0.2", "duplexify": "3.5.4", "ent": "2.2.0", "extend": "3.0.1", - "google-auto-auth": "0.9.5", + "google-auto-auth": "0.9.7", "is": "3.2.1", "log-driver": "1.2.5", "methmeth": "1.1.0", @@ -79,15 +85,15 @@ } }, "@google-cloud/common-grpc": { - "version": "0.5.5", - "resolved": "https://registry.npmjs.org/@google-cloud/common-grpc/-/common-grpc-0.5.5.tgz", - "integrity": "sha512-wgtuBcgTZ7cUMGQV9MSz4y0+FReLqdsOOgzOifu+lsnRh9qsMEZJ9sBDLB6NrRxrvcAHZc4ayiBx7B7i5cDYoA==", + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@google-cloud/common-grpc/-/common-grpc-0.6.0.tgz", + "integrity": "sha512-b5i2auMeP+kPPPpWtZVgjbbbIB+3uDGw+Vww1QjG0SEQlahcGrwkCEaNLQit1R77m8ibxs+sTVa+AH/FNILAdQ==", "requires": { "@google-cloud/common": "0.16.1", "dot-prop": "4.2.0", "duplexify": "3.5.4", "extend": "3.0.1", - "grpc": "1.7.3", + "grpc": "1.9.1", "is": "3.2.1", "modelo": "4.2.3", "retry-request": "3.3.1", @@ -95,17 +101,17 @@ } }, "@google-cloud/firestore": { - "version": "0.12.0", - "resolved": "https://registry.npmjs.org/@google-cloud/firestore/-/firestore-0.12.0.tgz", - "integrity": "sha512-sgPAVS+Aax8HNQev4zoXGeMskCzvJ23KWYP0bCVfNabMQ+9UlUfO8Rl5UZSEKI390ORcNyhKCz4Zc3/1t8NhZA==", + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/@google-cloud/firestore/-/firestore-0.13.0.tgz", + "integrity": "sha512-9Aak9O/NBwdhAJWn2ooaHJT0uyU6IN6oHegW4GcAzLwJKwx8nw+c/GwFufSS6PRMLTiXdpV0I/rvdz4nSgO1HA==", "requires": { "@google-cloud/common": "0.16.1", - "@google-cloud/common-grpc": "0.5.5", + "@google-cloud/common-grpc": "0.6.0", "bun": "0.0.12", "deep-equal": "1.0.1", "extend": "3.0.1", "functional-red-black-tree": "1.0.1", - "google-gax": "0.14.5", + "google-gax": "0.15.0", "is": "3.2.1", "safe-buffer": "5.1.1", "through2": "2.0.3" @@ -120,7 +126,7 @@ "arrify": "1.0.1", "async": "2.6.0", "compressible": "2.0.13", - "concat-stream": "1.6.0", + "concat-stream": "1.6.1", "create-error-class": "3.0.2", "duplexify": "3.5.4", "extend": "3.0.1", @@ -139,6 +145,15 @@ "through2": "2.0.3" } }, + "@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz", + "integrity": "sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g==", + "requires": { + "call-me-maybe": "1.0.1", + "glob-to-regexp": "0.3.0" + } + }, "@protobufjs/aspromise": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", @@ -198,7 +213,7 @@ "resolved": "https://registry.npmjs.org/@types/google-cloud__storage/-/google-cloud__storage-1.1.7.tgz", "integrity": "sha512-010Llp+5ze+XWWmZuLDxs0pZgFjOgtJQVt9icJ0Ed67ZFLq7PnXkYx8x/k9nwDojR5/X4XoLPNqB1F627TScdQ==", "requires": { - "@types/node": "8.9.4" + "@types/node": "8.9.5" } }, "@types/long": { @@ -207,15 +222,14 @@ "integrity": "sha512-ZXyOOm83p7X8p3s0IYM3VeueNmHpkk/yMlP8CLeOnEcu6hIwPH7YjZBvhQkR0ZFS2DqZAxKtJ/M5fcuv3OU5BA==" }, "@types/node": { - "version": "8.9.4", - "resolved": "https://registry.npmjs.org/@types/node/-/node-8.9.4.tgz", - "integrity": "sha512-dSvD36qnQs78G1BPsrZFdPpvLgMW/dnvr5+nTW2csMs5TiP9MOXrjUbnMZOEwnIuBklXtn7b6TPA2Cuq07bDHA==" + "version": "8.9.5", + "resolved": "https://registry.npmjs.org/@types/node/-/node-8.9.5.tgz", + "integrity": "sha512-jRHfWsvyMtXdbhnz5CVHxaBgnV6duZnPlQuRSo/dm/GnmikNcmZhxIES4E9OZjUmQ8C+HCl4KJux+cXN/ErGDQ==" }, "acorn": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.3.0.tgz", - "integrity": "sha512-Yej+zOJ1Dm/IMZzzj78OntP/r3zHEaKcyNoU2lAaxPtrseM6rF0xwqoz5Q5ysAiED9hTjI2hgtvLXitlCN1/Ug==", - "dev": true + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", + "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" }, "acorn-es7-plugin": { "version": "1.1.7", @@ -276,29 +290,26 @@ "version": "1.3.2", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", + "optional": true, "requires": { "micromatch": "2.3.11", "normalize-path": "2.1.1" } }, "argparse": { - "version": "1.0.9", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", - "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", + "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.3" } }, - "arguejs": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/arguejs/-/arguejs-0.2.3.tgz", - "integrity": "sha1-tvk59f4OPNHz+T4qqSYkJL8xKvc=" - }, "arr-diff": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", + "optional": true, "requires": { "arr-flatten": "1.1.0" } @@ -308,6 +319,11 @@ "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=" + }, "array-filter": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-1.0.0.tgz", @@ -329,7 +345,8 @@ "array-unique": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", - "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=" + "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", + "optional": true }, "array.prototype.find": { "version": "2.0.4", @@ -365,12 +382,17 @@ "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=" + }, "async": { "version": "2.6.0", "resolved": "https://registry.npmjs.org/async/-/async-2.6.0.tgz", "integrity": "sha512-xAfGg1/NTLBBKlHFmnd7PlmUW9KhVQIUuSrYem9xzFUZy13ScvtyGGejaae9iAVRiRq9+Cx7DPFaAAhCpyxyPw==", "requires": { - "lodash": "4.17.4" + "lodash": "4.17.5" } }, "async-each": { @@ -383,6 +405,11 @@ "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" }, + "atob": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.0.3.tgz", + "integrity": "sha1-GcenYEc3dEaPILLS0DNyrX1Mv10=" + }, "aws-sign2": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", @@ -394,9 +421,9 @@ "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" }, "axios": { - "version": "0.17.1", - "resolved": "https://registry.npmjs.org/axios/-/axios-0.17.1.tgz", - "integrity": "sha1-LY4+XQvb1zJ/kbyBT1xXZg+Bgk0=", + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/axios/-/axios-0.18.0.tgz", + "integrity": "sha1-MtU+SFHv3AoRmTts0AB4nXDAUQI=", "requires": { "follow-redirects": "1.4.1", "is-buffer": "1.1.6" @@ -412,11 +439,11 @@ "babel-register": "6.26.0", "babel-runtime": "6.26.0", "chokidar": "1.7.0", - "commander": "2.13.0", + "commander": "2.15.0", "convert-source-map": "1.5.1", "fs-readdir-recursive": "1.1.0", "glob": "7.1.2", - "lodash": "4.17.4", + "lodash": "4.17.5", "output-file-sync": "1.1.2", "path-is-absolute": "1.0.1", "slash": "1.0.0", @@ -440,7 +467,7 @@ "integrity": "sha1-rzL3izGm/O8RnIew/Y2XU/A6C7g=", "requires": { "babel-code-frame": "6.26.0", - "babel-generator": "6.26.0", + "babel-generator": "6.26.1", "babel-helpers": "6.24.1", "babel-messages": "6.23.0", "babel-register": "6.26.0", @@ -452,7 +479,7 @@ "convert-source-map": "1.5.1", "debug": "2.6.9", "json5": "0.5.1", - "lodash": "4.17.4", + "lodash": "4.17.5", "minimatch": "3.0.4", "path-is-absolute": "1.0.1", "private": "0.1.8", @@ -473,16 +500,16 @@ } }, "babel-generator": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.0.tgz", - "integrity": "sha1-rBriAHC3n248odMmlhMFN3TyDcU=", + "version": "6.26.1", + "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.1.tgz", + "integrity": "sha512-HyfwY6ApZj7BYTcJURpM5tznulaBvyio7/0d4zFOeMPUmfxkCjHocCuoLa2SAGzBI8AREcH3eP3758F672DppA==", "requires": { "babel-messages": "6.23.0", "babel-runtime": "6.26.0", "babel-types": "6.26.0", "detect-indent": "4.0.0", "jsesc": "1.3.0", - "lodash": "4.17.4", + "lodash": "4.17.5", "source-map": "0.5.7", "trim-right": "1.0.1" } @@ -516,7 +543,7 @@ "babel-helper-function-name": "6.24.1", "babel-runtime": "6.26.0", "babel-types": "6.26.0", - "lodash": "4.17.4" + "lodash": "4.17.5" } }, "babel-helper-explode-assignable-expression": { @@ -575,7 +602,7 @@ "requires": { "babel-runtime": "6.26.0", "babel-types": "6.26.0", - "lodash": "4.17.4" + "lodash": "4.17.5" } }, "babel-helper-remap-async-to-generator": { @@ -701,7 +728,7 @@ "babel-template": "6.26.0", "babel-traverse": "6.26.0", "babel-types": "6.26.0", - "lodash": "4.17.4" + "lodash": "4.17.5" } }, "babel-plugin-transform-es2015-classes": { @@ -973,9 +1000,9 @@ "babel-plugin-transform-es2015-unicode-regex": "6.24.1", "babel-plugin-transform-exponentiation-operator": "6.24.1", "babel-plugin-transform-regenerator": "6.26.0", - "browserslist": "2.11.1", - "invariant": "2.2.2", - "semver": "5.4.1" + "browserslist": "2.11.3", + "invariant": "2.2.3", + "semver": "5.5.0" } }, "babel-preset-flow": { @@ -995,7 +1022,7 @@ "babel-runtime": "6.26.0", "core-js": "2.5.3", "home-or-tmp": "2.0.0", - "lodash": "4.17.4", + "lodash": "4.17.5", "mkdirp": "0.5.1", "source-map-support": "0.4.18" } @@ -1018,7 +1045,7 @@ "babel-traverse": "6.26.0", "babel-types": "6.26.0", "babylon": "6.18.0", - "lodash": "4.17.4" + "lodash": "4.17.5" } }, "babel-traverse": { @@ -1033,8 +1060,8 @@ "babylon": "6.18.0", "debug": "2.6.9", "globals": "9.18.0", - "invariant": "2.2.2", - "lodash": "4.17.4" + "invariant": "2.2.3", + "lodash": "4.17.5" } }, "babel-types": { @@ -1044,7 +1071,7 @@ "requires": { "babel-runtime": "6.26.0", "esutils": "2.0.2", - "lodash": "4.17.4", + "lodash": "4.17.5", "to-fast-properties": "1.0.3" } }, @@ -1058,6 +1085,35 @@ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "requires": { + "cache-base": "1.0.1", + "class-utils": "0.3.6", + "component-emitter": "1.2.1", + "define-property": "1.0.0", + "isobject": "3.0.1", + "mixin-deep": "1.3.1", + "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=", + "requires": { + "is-descriptor": "1.0.2" + } + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, "base64url": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/base64url/-/base64url-2.0.0.tgz", @@ -1077,11 +1133,6 @@ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=" }, - "bluebird": { - "version": "3.5.1", - "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", - "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" - }, "boom": { "version": "4.3.1", "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", @@ -1091,9 +1142,9 @@ } }, "brace-expansion": { - "version": "1.1.8", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", - "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", "requires": { "balanced-match": "1.0.0", "concat-map": "0.0.1" @@ -1103,6 +1154,7 @@ "version": "1.8.5", "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", + "optional": true, "requires": { "expand-range": "1.8.2", "preserve": "0.2.0", @@ -1110,12 +1162,12 @@ } }, "browserslist": { - "version": "2.11.1", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-2.11.1.tgz", - "integrity": "sha512-Gp4oJOQOby5TpOJJuUtCrGE0KSJOUYVa/I+/3eD/TRWEK8jqZuJPAK1t+VuG6jp0keudrqtxlH4MbYbmylun9g==", + "version": "2.11.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-2.11.3.tgz", + "integrity": "sha512-yWu5cXT7Av6mVwzWc8lMsJMHWn4xyjSuGYi4IozbVTLUOEYPSagUB8kiMDUHA1fS3zjr8nkxkn9jdvug4BBRmA==", "requires": { - "caniuse-lite": "1.0.30000791", - "electron-to-chromium": "1.3.30" + "caniuse-lite": "1.0.30000813", + "electron-to-chromium": "1.3.37" } }, "buffer-equal": { @@ -1173,6 +1225,34 @@ "long": "3.2.0" } }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "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" + }, + "dependencies": { + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, + "call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=" + }, "call-signature": { "version": "0.0.2", "resolved": "https://registry.npmjs.org/call-signature/-/call-signature-0.0.2.tgz", @@ -1199,9 +1279,9 @@ "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=" }, "caniuse-lite": { - "version": "1.0.30000791", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000791.tgz", - "integrity": "sha1-jjV0Xv1IOj4ju301CZAybSMZ/BY=" + "version": "1.0.30000813", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000813.tgz", + "integrity": "sha512-A8ITSmH5SFdMFdC704ggjg+x2z5PzQmVlG8tavwnfvbC33Q1UYrj0+G+Xm0SNAnd4He36fwUE/KEWytOEchw+A==" }, "capture-stack-trace": { "version": "1.0.0", @@ -1229,6 +1309,7 @@ "version": "1.7.0", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", + "optional": true, "requires": { "anymatch": "1.3.2", "async-each": "1.0.1", @@ -1247,6 +1328,83 @@ "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", "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==", + "requires": { + "arr-union": "3.1.0", + "define-property": "0.2.5", + "isobject": "3.0.1", + "static-extend": "0.1.2" + }, + "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=", + "requires": { + "is-descriptor": "0.1.6" + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "0.1.6", + "is-data-descriptor": "0.1.4", + "kind-of": "5.1.0" + } + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + }, + "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==" + } + } + }, "cli-cursor": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-1.0.2.tgz", @@ -1282,10 +1440,19 @@ "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "requires": { + "map-visit": "1.0.0", + "object-visit": "1.0.1" + } + }, "colors": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", - "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=" + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/colors/-/colors-1.2.0.tgz", + "integrity": "sha512-lweugcX5nailCqZBttArTojZZpHGWhmFJX78KJHlxwhM8tLAy5QCgRgRxrubrksdvA+2Y3inWG5TToyyjL82BQ==" }, "colour": { "version": "0.7.1", @@ -1301,9 +1468,14 @@ } }, "commander": { - "version": "2.13.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.13.0.tgz", - "integrity": "sha512-MVuS359B+YzaWqjCL/c+22gfryv+mCBPHAv3zyVI2GN8EY6IRP8VwtasXn8jyyhvvq84R4ImN1OKRtcbIasjYA==" + "version": "2.15.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.0.tgz", + "integrity": "sha512-7B1ilBwtYSbetCgTY1NJFg+gVpestg0fdA1MhC1Vs4ssyfSXnCAjFr+QcQM9/RedXC0EaUx1sG8Smgw2VfgKEg==" + }, + "component-emitter": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", + "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=" }, "compressible": { "version": "2.0.13", @@ -1319,12 +1491,12 @@ "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" }, "concat-stream": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.0.tgz", - "integrity": "sha1-CqxmL9Ur54lk1VMvaUeE5wEQrPc=", + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.1.tgz", + "integrity": "sha512-gslSSJx03QKa59cIKqeJO9HQ/WZMotvYJCuaUULrLpjj8oG40kV2Z+gz82pVxlTkOADi4PJxQPPfhl1ELYrrXw==", "requires": { "inherits": "2.0.3", - "readable-stream": "2.3.3", + "readable-stream": "2.3.5", "typedarray": "0.0.6" } }, @@ -1352,6 +1524,11 @@ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=" }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=" + }, "core-js": { "version": "2.5.3", "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.3.tgz", @@ -1376,7 +1553,7 @@ "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", "dev": true, "requires": { - "lru-cache": "4.1.1", + "lru-cache": "4.1.2", "shebang-command": "1.2.0", "which": "1.3.0" } @@ -1410,7 +1587,7 @@ "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", "dev": true, "requires": { - "es5-ext": "0.10.37" + "es5-ext": "0.10.40" } }, "dashdash": { @@ -1440,6 +1617,11 @@ "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" }, + "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=" + }, "deep-equal": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", @@ -1460,6 +1642,22 @@ "object-keys": "1.0.11" } }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "requires": { + "is-descriptor": "1.0.2", + "isobject": "3.0.1" + }, + "dependencies": { + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, "deglob": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/deglob/-/deglob-2.1.0.tgz", @@ -1470,7 +1668,7 @@ "glob": "7.1.2", "ignore": "3.3.7", "pkg-config": "1.1.1", - "run-parallel": "1.1.6", + "run-parallel": "1.1.7", "uniq": "1.0.1" } }, @@ -1502,6 +1700,12 @@ "pify": "2.3.0", "pinkie-promise": "2.0.1" } + }, + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", + "dev": true } } }, @@ -1530,21 +1734,6 @@ "requires": { "arrify": "1.0.1", "path-type": "3.0.0" - }, - "dependencies": { - "path-type": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", - "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", - "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=" - } } }, "doctrine": { @@ -1571,7 +1760,7 @@ "requires": { "end-of-stream": "1.4.1", "inherits": "2.0.3", - "readable-stream": "2.3.3", + "readable-stream": "2.3.5", "stream-shift": "1.0.0" } }, @@ -1598,18 +1787,10 @@ "safe-buffer": "5.1.1" } }, - "electron-releases": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/electron-releases/-/electron-releases-2.1.0.tgz", - "integrity": "sha512-cyKFD1bTE/UgULXfaueIN1k5EPFzs+FRc/rvCY5tIynefAPqopQEgjr0EzY+U3Dqrk/G4m9tXSPuZ77v6dL/Rw==" - }, "electron-to-chromium": { - "version": "1.3.30", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.30.tgz", - "integrity": "sha512-zx1Prv7kYLfc4OA60FhxGbSo4qrEjgSzpo1/37i7l9ltXPYOoQBtjQxY9KmsgfHnBxHlBGXwLlsbt/gub1w5lw==", - "requires": { - "electron-releases": "2.1.0" - } + "version": "1.3.37", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.37.tgz", + "integrity": "sha1-SpJzTgBEyM8LFVO+V+riGkxuX6s=" }, "empower": { "version": "1.2.3", @@ -1676,9 +1857,9 @@ } }, "es5-ext": { - "version": "0.10.37", - "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.37.tgz", - "integrity": "sha1-DudB0Ui4AGm6J9AgOTdWryV978M=", + "version": "0.10.40", + "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.40.tgz", + "integrity": "sha512-S9Fh3oya5OOvYSNGvPZJ+vyrs6VYpe1IXPowVe3N1OhaiwVaGlwfn3Zf5P5klYcWOA0toIwYQW8XEv/QqhdHvQ==", "dev": true, "requires": { "es6-iterator": "2.0.3", @@ -1692,7 +1873,7 @@ "dev": true, "requires": { "d": "1.0.0", - "es5-ext": "0.10.37", + "es5-ext": "0.10.40", "es6-symbol": "3.1.1" } }, @@ -1703,7 +1884,7 @@ "dev": true, "requires": { "d": "1.0.0", - "es5-ext": "0.10.37", + "es5-ext": "0.10.40", "es6-iterator": "2.0.3", "es6-set": "0.1.5", "es6-symbol": "3.1.1", @@ -1717,7 +1898,7 @@ "dev": true, "requires": { "d": "1.0.0", - "es5-ext": "0.10.37", + "es5-ext": "0.10.40", "es6-iterator": "2.0.3", "es6-symbol": "3.1.1", "event-emitter": "0.3.5" @@ -1730,7 +1911,7 @@ "dev": true, "requires": { "d": "1.0.0", - "es5-ext": "0.10.37" + "es5-ext": "0.10.40" } }, "es6-weak-map": { @@ -1740,7 +1921,7 @@ "dev": true, "requires": { "d": "1.0.0", - "es5-ext": "0.10.37", + "es5-ext": "0.10.40", "es6-iterator": "2.0.3", "es6-symbol": "3.1.1" } @@ -1758,7 +1939,7 @@ "requires": { "es6-map": "0.1.5", "es6-weak-map": "2.0.2", - "esrecurse": "4.2.0", + "esrecurse": "4.2.1", "estraverse": "4.2.0" } }, @@ -1770,11 +1951,11 @@ "requires": { "babel-code-frame": "6.26.0", "chalk": "1.1.3", - "concat-stream": "1.6.0", + "concat-stream": "1.6.1", "debug": "2.6.9", "doctrine": "2.1.0", "escope": "3.6.0", - "espree": "3.5.2", + "espree": "3.5.4", "esquery": "1.0.0", "estraverse": "4.2.0", "esutils": "2.0.2", @@ -1784,12 +1965,12 @@ "ignore": "3.3.7", "imurmurhash": "0.1.4", "inquirer": "0.12.0", - "is-my-json-valid": "2.17.1", - "is-resolvable": "1.0.1", - "js-yaml": "3.10.0", + "is-my-json-valid": "2.17.2", + "is-resolvable": "1.1.0", + "js-yaml": "3.11.0", "json-stable-stringify": "1.0.1", "levn": "0.3.0", - "lodash": "4.17.4", + "lodash": "4.17.5", "mkdirp": "0.5.1", "natural-compare": "1.4.0", "optionator": "0.8.2", @@ -1850,12 +2031,12 @@ } }, "eslint-plugin-flowtype": { - "version": "2.41.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-flowtype/-/eslint-plugin-flowtype-2.41.0.tgz", - "integrity": "sha512-M5X6qu/zvvXQ7flXp9plyBRlNRMQGNl3c+kQmox+m/jpnCZt0txgauxcrBKAVa9LKE/hBnsItJ9BojdmkefAkA==", + "version": "2.46.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-flowtype/-/eslint-plugin-flowtype-2.46.1.tgz", + "integrity": "sha512-GJzxW7QwiIiW0ZA/+nY+N5TuK3es4Uei0D4xuy14dLZBYEFhM6e7c0J1u4+/iwfPqFtkr5a0oSApnSKF4U6KHw==", "dev": true, "requires": { - "lodash": "4.17.4" + "lodash": "4.17.5" } }, "eslint-plugin-import": { @@ -1947,13 +2128,21 @@ "dev": true }, "espree": { - "version": "3.5.2", - "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.2.tgz", - "integrity": "sha512-sadKeYwaR/aJ3stC2CdvgXu1T16TdYN+qwCpcWbMnGJ8s0zNWemzrvb2GbD4OhmJ/fwpJjudThAlLobGbWZbCQ==", + "version": "3.5.4", + "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.4.tgz", + "integrity": "sha512-yAcIQxtmMiB/jL32dzEp2enBeidsB7xWPLNiw3IIkpVds1P+h7qF9YwJq1yUNzp2OKXgAprs4F61ih66UsoD1A==", "dev": true, "requires": { - "acorn": "5.3.0", + "acorn": "5.5.3", "acorn-jsx": "3.0.1" + }, + "dependencies": { + "acorn": { + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", + "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", + "dev": true + } } }, "esprima": { @@ -1980,13 +2169,12 @@ } }, "esrecurse": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.0.tgz", - "integrity": "sha1-+pVo2Y04I/mkHZHpAtyrnqblsWM=", + "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.2.0", - "object-assign": "4.1.1" + "estraverse": "4.2.0" } }, "estraverse": { @@ -2006,7 +2194,7 @@ "dev": true, "requires": { "d": "1.0.0", - "es5-ext": "0.10.37" + "es5-ext": "0.10.40" } }, "execa": { @@ -2034,6 +2222,7 @@ "version": "0.1.5", "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", + "optional": true, "requires": { "is-posix-bracket": "0.1.1" } @@ -2042,6 +2231,7 @@ "version": "1.8.2", "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", + "optional": true, "requires": { "fill-range": "2.2.3" } @@ -2051,10 +2241,30 @@ "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "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==", + "requires": { + "is-plain-object": "2.0.4" + } + } + } + }, "extglob": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", + "optional": true, "requires": { "is-extglob": "1.0.0" } @@ -2069,122 +2279,402 @@ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=" }, - "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=" - }, - "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.9.3", - "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.9.3.tgz", - "integrity": "sha1-SCpQWw3wrmJrlphm0710DNuWLoM=", - "requires": { - "websocket-driver": "0.7.0" - } - }, - "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.1" - } - }, - "file-entry-cache": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", - "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", - "dev": true, - "requires": { - "flat-cache": "1.3.0", - "object-assign": "4.1.1" - } - }, - "filename-regex": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", - "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=" - }, - "fill-range": { - "version": "2.2.3", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", - "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", - "requires": { - "is-number": "2.1.0", - "isobject": "2.1.0", - "randomatic": "1.1.7", - "repeat-element": "1.1.2", - "repeat-string": "1.6.1" - } - }, - "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": { + "fast-glob": { "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" - } - }, - "firebase-admin": { - "version": "5.9.1", - "resolved": "https://registry.npmjs.org/firebase-admin/-/firebase-admin-5.9.1.tgz", - "integrity": "sha1-Ht9iSNAUBj8ORz+E/p1j3xjlOAc=", - "requires": { - "@firebase/app": "0.1.10", - "@firebase/database": "0.1.11", - "@google-cloud/firestore": "0.12.0", - "@google-cloud/storage": "1.6.0", - "@types/google-cloud__storage": "1.1.7", - "@types/node": "8.9.4", - "faye-websocket": "0.9.3", - "jsonwebtoken": "8.1.0", - "node-forge": "0.7.1" - } - }, - "flat-cache": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", - "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", - "dev": true, - "requires": { - "circular-json": "0.3.3", - "del": "2.2.2", - "graceful-fs": "4.1.11", - "write": "0.2.1" - } - }, - "flow-bin": { - "version": "0.61.0", - "resolved": "https://registry.npmjs.org/flow-bin/-/flow-bin-0.61.0.tgz", - "integrity": "sha512-w6SGi5CDfKLNGzYssRhW6N37qKclDXijsxDQ5M8c3WbivRYta0Horv22bwakegfKBVDnyeS0lRW3OqBC74eq2g==", - "dev": true - }, - "flow-copy-source": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/flow-copy-source/-/flow-copy-source-1.2.1.tgz", - "integrity": "sha512-C3T0OjBOOVd0LWg4wzE3seZOpqddSq5nxMD72iDrGdZ+7WsjbO4rUMEWp4mXErWesD3jPTATxk27HfQdMtZW6g==", - "dev": true, - "requires": { - "chokidar": "1.7.0", - "fs-extra": "3.0.1", - "glob": "7.1.2", - "kefir": "3.8.1", - "yargs": "8.0.2" + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.1.0.tgz", + "integrity": "sha512-QSSKZwDHLznUXdVtWvsfdbojmYI5igtVwfVbKW/LwNsy0JdM1cZ5yyP1kl5npg2ddugdnOk66QlNhbJ1c1hErg==", + "requires": { + "@mrmlnc/readdir-enhanced": "2.2.1", + "glob-parent": "3.1.0", + "is-glob": "4.0.0", + "merge2": "1.2.1", + "micromatch": "3.1.9" + }, + "dependencies": { + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" + }, + "braces": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.1.tgz", + "integrity": "sha512-SO5lYHA3vO6gz66erVvedSCkp7AKWdv6VcQ2N4ysXfPxdAlxAMMAdwegGGcv1Bqwm7naF1hNdk5d6AAIEHV2nQ==", + "requires": { + "arr-flatten": "1.1.0", + "array-unique": "0.3.2", + "define-property": "1.0.0", + "extend-shallow": "2.0.1", + "fill-range": "4.0.0", + "isobject": "3.0.1", + "kind-of": "6.0.2", + "repeat-element": "1.1.2", + "snapdragon": "0.8.1", + "snapdragon-node": "2.1.1", + "split-string": "3.1.0", + "to-regex": "3.0.2" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "1.0.2" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "0.1.1" + } + } + } + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "requires": { + "debug": "2.6.9", + "define-property": "0.2.5", + "extend-shallow": "2.0.1", + "posix-character-classes": "0.1.1", + "regex-not": "1.0.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + }, + "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=", + "requires": { + "is-descriptor": "0.1.6" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "0.1.1" + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "0.1.6", + "is-data-descriptor": "0.1.4", + "kind-of": "5.1.0" + } + }, + "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==" + } + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "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.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "1.0.2" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "0.1.1" + } + } + } + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "requires": { + "extend-shallow": "2.0.1", + "is-number": "3.0.0", + "repeat-string": "1.6.1", + "to-regex-range": "2.1.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "0.1.1" + } + } + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "requires": { + "is-glob": "3.1.0", + "path-dirname": "1.0.2" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "requires": { + "is-extglob": "2.1.1" + } + } + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" + }, + "is-glob": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", + "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + }, + "micromatch": { + "version": "3.1.9", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.9.tgz", + "integrity": "sha512-SlIz6sv5UPaAVVFRKodKjCg48EbNoIhgetzfK/Cy0v5U52Z6zB136M8tp0UC9jM53LYbmIRihJszvvqpKkfm9g==", + "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.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + } + } + } + }, + "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=" + }, + "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.9.3", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.9.3.tgz", + "integrity": "sha1-SCpQWw3wrmJrlphm0710DNuWLoM=", + "requires": { + "websocket-driver": "0.7.0" + } + }, + "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.1" + } + }, + "file-entry-cache": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", + "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", + "dev": true, + "requires": { + "flat-cache": "1.3.0", + "object-assign": "4.1.1" + } + }, + "filename-regex": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", + "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", + "optional": true + }, + "fill-range": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", + "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", + "optional": true, + "requires": { + "is-number": "2.1.0", + "isobject": "2.1.0", + "randomatic": "1.1.7", + "repeat-element": "1.1.2", + "repeat-string": "1.6.1" + } + }, + "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": "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" + } + }, + "firebase-admin": { + "version": "5.10.0", + "resolved": "https://registry.npmjs.org/firebase-admin/-/firebase-admin-5.10.0.tgz", + "integrity": "sha1-dtj85rsdvSwF7HbL+1ncGtOXflY=", + "requires": { + "@firebase/app": "0.1.10", + "@firebase/database": "0.2.0", + "@google-cloud/firestore": "0.13.0", + "@google-cloud/storage": "1.6.0", + "@types/google-cloud__storage": "1.1.7", + "@types/node": "8.9.5", + "faye-websocket": "0.9.3", + "jsonwebtoken": "8.1.0", + "node-forge": "0.7.1" + } + }, + "flat-cache": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", + "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", + "dev": true, + "requires": { + "circular-json": "0.3.3", + "del": "2.2.2", + "graceful-fs": "4.1.11", + "write": "0.2.1" + } + }, + "flow-bin": { + "version": "0.61.0", + "resolved": "https://registry.npmjs.org/flow-bin/-/flow-bin-0.61.0.tgz", + "integrity": "sha512-w6SGi5CDfKLNGzYssRhW6N37qKclDXijsxDQ5M8c3WbivRYta0Horv22bwakegfKBVDnyeS0lRW3OqBC74eq2g==", + "dev": true + }, + "flow-copy-source": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/flow-copy-source/-/flow-copy-source-1.3.0.tgz", + "integrity": "sha512-F8aRmNmtB5l+RFG7LAWj6IYU22K37BrhIXXCcQyxSsYWm0pNubnhBSEk+eoyGCou3+4aI4tReOfLFtgd5wnnYQ==", + "dev": true, + "requires": { + "chokidar": "2.0.2", + "fs-extra": "5.0.0", + "glob": "7.1.2", + "kefir": "3.8.2", + "yargs": "11.0.0" }, "dependencies": { "ansi-regex": { @@ -2193,10 +2683,275 @@ "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", "dev": true }, - "camelcase": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", - "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "dev": true, + "requires": { + "micromatch": "3.1.9", + "normalize-path": "2.1.1" + } + }, + "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 + }, + "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 + }, + "braces": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.1.tgz", + "integrity": "sha512-SO5lYHA3vO6gz66erVvedSCkp7AKWdv6VcQ2N4ysXfPxdAlxAMMAdwegGGcv1Bqwm7naF1hNdk5d6AAIEHV2nQ==", + "dev": true, + "requires": { + "arr-flatten": "1.1.0", + "array-unique": "0.3.2", + "define-property": "1.0.0", + "extend-shallow": "2.0.1", + "fill-range": "4.0.0", + "isobject": "3.0.1", + "kind-of": "6.0.2", + "repeat-element": "1.1.2", + "snapdragon": "0.8.1", + "snapdragon-node": "2.1.1", + "split-string": "3.1.0", + "to-regex": "3.0.2" + }, + "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.2" + } + }, + "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.1" + } + } + } + }, + "chokidar": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.0.2.tgz", + "integrity": "sha512-l32Hw3wqB0L2kGVmSbK/a+xXLDrUEsc84pSgMkmwygHvD7ubRsP/vxxHa5BtB6oix1XLLVCHyYMsckRXxThmZw==", + "dev": true, + "requires": { + "anymatch": "2.0.0", + "async-each": "1.0.1", + "braces": "2.3.1", + "fsevents": "1.1.3", + "glob-parent": "3.1.0", + "inherits": "2.0.3", + "is-binary-path": "1.0.1", + "is-glob": "4.0.0", + "normalize-path": "2.1.1", + "path-is-absolute": "1.0.1", + "readdirp": "2.1.0", + "upath": "1.0.4" + } + }, + "cliui": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.0.0.tgz", + "integrity": "sha512-nY3W5Gu2racvdDk//ELReY+dHjb9PlIcVDFXP72nVIhq2Gy3LuVXYwJoPVudwQnv1shtohpgkdCKT2YaKY0CKw==", + "dev": true, + "requires": { + "string-width": "2.1.1", + "strip-ansi": "4.0.0", + "wrap-ansi": "2.1.0" + } + }, + "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.6.9", + "define-property": "0.2.5", + "extend-shallow": "2.0.1", + "posix-character-classes": "0.1.1", + "regex-not": "1.0.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + }, + "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.6" + } + }, + "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.1" + } + }, + "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.1.0" + } + }, + "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 + } + } + }, + "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.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + }, + "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.2" + } + }, + "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.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.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.1" + } + } + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "3.1.0", + "path-dirname": "1.0.2" + }, + "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, + "requires": { + "is-extglob": "2.1.1" + } + } + } + }, + "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.2.2" + }, + "dependencies": { + "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.6" + } + } + } + }, + "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.2.2" + }, + "dependencies": { + "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.6" + } + } + } + }, + "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-fullwidth-code-point": { @@ -2205,6 +2960,68 @@ "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", "dev": true }, + "is-glob": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", + "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", + "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.2.2" + }, + "dependencies": { + "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.6" + } + } + } + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "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 + }, + "micromatch": { + "version": "3.1.9", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.9.tgz", + "integrity": "sha512-SlIz6sv5UPaAVVFRKodKjCg48EbNoIhgetzfK/Cy0v5U52Z6zB136M8tp0UC9jM53LYbmIRihJszvvqpKkfm9g==", + "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.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + } + }, "os-locale": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-2.1.0.tgz", @@ -2236,24 +3053,23 @@ } }, "yargs": { - "version": "8.0.2", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-8.0.2.tgz", - "integrity": "sha1-YpmpBVsc78lp/355wdkY3Osiw2A=", + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-11.0.0.tgz", + "integrity": "sha512-Rjp+lMYQOWtgqojx1dEWorjCofi1YN7AoFvYV7b1gx/7dAAeuI4kN5SZiEvr0ZmsZTOpDRcCqrpI10L31tFkBw==", "dev": true, "requires": { - "camelcase": "4.1.0", - "cliui": "3.2.0", + "cliui": "4.0.0", "decamelize": "1.2.0", + "find-up": "2.1.0", "get-caller-file": "1.0.2", "os-locale": "2.1.0", - "read-pkg-up": "2.0.0", "require-directory": "2.1.1", "require-main-filename": "1.0.1", "set-blocking": "2.0.0", "string-width": "2.1.1", "which-module": "2.0.0", "y18n": "3.2.1", - "yargs-parser": "7.0.0" + "yargs-parser": "9.0.2" } } } @@ -2285,6 +3101,7 @@ "version": "0.1.5", "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "optional": true, "requires": { "for-in": "1.0.2" } @@ -2309,14 +3126,22 @@ "mime-types": "2.1.18" } }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "requires": { + "map-cache": "0.2.2" + } + }, "fs-extra": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-3.0.1.tgz", - "integrity": "sha1-N5TzeMWLNC6n27sjCVEJxLO2IpE=", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-5.0.0.tgz", + "integrity": "sha512-66Pm4RYbjzdyeuqudYqhFiNBbCIuI9kgRqLPSHIlXHidW8NIQtVdkM1yeZ4lXwuhbTETv3EUGMNHAAw6hiundQ==", "dev": true, "requires": { "graceful-fs": "4.1.11", - "jsonfile": "3.0.1", + "jsonfile": "4.0.0", "universalify": "0.1.1" } }, @@ -3131,13 +3956,13 @@ "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=" }, "gcp-metadata": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-0.6.1.tgz", - "integrity": "sha512-Ju3brkV7kYOBP5s3Z6HS2xd7gyH9MDfuKeB+y51SsI8GPrD37NOB5Re9fWXQQVAkd74zzVOScnNic1lcRsWD9w==", + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/gcp-metadata/-/gcp-metadata-0.6.3.tgz", + "integrity": "sha512-MSmczZctbz91AxCvqp9GHBoZOSbJKAICV7Ow/AIWSJZRrRchUd5NL1b2P4OfP+4m490BEUPhhARfpHdqCxuCvg==", "requires": { - "axios": "0.17.1", + "axios": "0.18.0", "extend": "3.0.1", - "retry-axios": "0.3.0" + "retry-axios": "0.3.2" } }, "gcs-resumable-upload": { @@ -3147,7 +3972,7 @@ "requires": { "buffer-equal": "1.0.0", "configstore": "3.1.1", - "google-auto-auth": "0.9.5", + "google-auto-auth": "0.9.7", "pumpify": "1.4.0", "request": "2.83.0", "stream-events": "1.0.2", @@ -3187,6 +4012,11 @@ "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", "dev": true }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=" + }, "getpass": { "version": "0.1.7", "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", @@ -3212,6 +4042,7 @@ "version": "0.3.0", "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", + "optional": true, "requires": { "glob-parent": "2.0.0", "is-glob": "2.0.1" @@ -3225,29 +4056,28 @@ "is-glob": "2.0.1" } }, + "glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz", + "integrity": "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=" + }, "globals": { "version": "9.18.0", "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==" }, "globby": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/globby/-/globby-7.1.1.tgz", - "integrity": "sha1-+yzP+UAfhgCUXfral0QMypcrhoA=", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/globby/-/globby-8.0.1.tgz", + "integrity": "sha512-oMrYrJERnKBLXNLVTqhm3vPEdJ/b2ZE28xN4YARiix1NOIOBPEpOUnm844K1iu/BkphCaf2WNFwMszv8Soi1pw==", "requires": { "array-union": "1.0.2", "dir-glob": "2.0.0", + "fast-glob": "2.1.0", "glob": "7.1.2", "ignore": "3.3.7", "pify": "3.0.0", "slash": "1.0.0" - }, - "dependencies": { - "pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" - } } }, "google-auth-library": { @@ -3256,55 +4086,39 @@ "integrity": "sha512-NcAzFY+ScalfjmFTHnCXInuivtbIfib9irJ5H8AHONy3eA56YW1Tu5X1dtbjw5TNBgP+BMu+nIrglJsAlfZ/Hg==", "requires": { "axios": "0.18.0", - "gcp-metadata": "0.6.1", - "gtoken": "2.1.0", + "gcp-metadata": "0.6.3", + "gtoken": "2.1.1", "jws": "3.1.4", "lodash.isstring": "4.0.1", - "lru-cache": "4.1.1", + "lru-cache": "4.1.2", "retry-axios": "0.3.2" - }, - "dependencies": { - "axios": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-0.18.0.tgz", - "integrity": "sha1-MtU+SFHv3AoRmTts0AB4nXDAUQI=", - "requires": { - "follow-redirects": "1.4.1", - "is-buffer": "1.1.6" - } - }, - "retry-axios": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/retry-axios/-/retry-axios-0.3.2.tgz", - "integrity": "sha512-jp4YlI0qyDFfXiXGhkCOliBN1G7fRH03Nqy8YdShzGqbY5/9S2x/IR6C88ls2DFkbWuL3ASkP7QD3pVrNpPgwQ==" - } } }, "google-auto-auth": { - "version": "0.9.5", - "resolved": "https://registry.npmjs.org/google-auto-auth/-/google-auto-auth-0.9.5.tgz", - "integrity": "sha512-1utCjz63uolG4qAH+i1h7kIXmXaMRZFBsW5AmPNSi9f2ai1zJOayZV2wbi7TJrypA6xnPAi58bnIqg9XLThhow==", + "version": "0.9.7", + "resolved": "https://registry.npmjs.org/google-auto-auth/-/google-auto-auth-0.9.7.tgz", + "integrity": "sha512-Nro7aIFrL2NP0G7PoGrJqXGMZj8AjdBOcbZXRRm/8T3w08NUHIiNN3dxpuUYzDsZizslH+c8e+7HXL8vh3JXTQ==", "requires": { "async": "2.6.0", - "gcp-metadata": "0.6.1", + "gcp-metadata": "0.6.3", "google-auth-library": "1.3.1", "request": "2.83.0" } }, "google-gax": { - "version": "0.14.5", - "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-0.14.5.tgz", - "integrity": "sha512-3A6KbrtLDavrqZnnzurnSydRIJnyH+2Sm56fAvXciQ/62aEnSDaR43MCgWhtReCLVjeFjBiCEIdX5zV0LVLVBg==", + "version": "0.15.0", + "resolved": "https://registry.npmjs.org/google-gax/-/google-gax-0.15.0.tgz", + "integrity": "sha512-a+WBi3oiV3jQ0eLCIM0GAFe8vYQ10yYuXRnjhEEXFKSNd8nW6XSQ7YWqMLIod2Xnyu6JiSSymMBwCr5YSwQyRQ==", "requires": { "extend": "3.0.1", - "globby": "7.1.1", - "google-auto-auth": "0.9.5", - "google-proto-files": "0.14.2", - "grpc": "1.7.3", + "globby": "8.0.1", + "google-auto-auth": "0.9.7", + "google-proto-files": "0.15.1", + "grpc": "1.9.1", "is-stream-ended": "0.1.3", - "lodash": "4.17.4", + "lodash": "4.17.5", "protobufjs": "6.8.6", - "readable-stream": "2.3.3", + "readable-stream": "2.3.5", "through2": "2.0.3" }, "dependencies": { @@ -3329,39 +4143,51 @@ "@protobufjs/pool": "1.1.0", "@protobufjs/utf8": "1.1.0", "@types/long": "3.0.32", - "@types/node": "8.9.4", + "@types/node": "8.9.5", "long": "4.0.0" } } } }, "google-p12-pem": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-1.0.0.tgz", - "integrity": "sha512-tqu8IJF307iH8vXQEI5ZhuIk89vAf25rmoyoenckm/zY7Elzm4X/x6OPOk4wa3sRzkA/Y2CkubpvLxSEgIEQcg==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-1.0.2.tgz", + "integrity": "sha512-+EuKr4CLlGsnXx4XIJIVkcKYrsa2xkAmCvxRhX2HsazJzUBAJ35wARGeApHUn4nNfPD03Vl057FskNr20VaCyg==", "requires": { - "node-forge": "0.7.1", + "node-forge": "0.7.4", "pify": "3.0.0" }, "dependencies": { - "pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + "node-forge": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.7.4.tgz", + "integrity": "sha512-8Df0906+tq/omxuCZD6PqhPaQDYuyJ1d+VITgxoIA8zvQd1ru+nMJcDChHH324MWitIgbVkAkQoGEEVJNpn/PA==" } } }, "google-proto-files": { - "version": "0.14.2", - "resolved": "https://registry.npmjs.org/google-proto-files/-/google-proto-files-0.14.2.tgz", - "integrity": "sha512-wwm2TIlfTgAjDbjrxAb3akznO7vBM0PRLS6Xf2QfR3L7b0p+szD3iwOW0wMSFl3B0UbLv27hUVk+clePqCVmXA==", + "version": "0.15.1", + "resolved": "https://registry.npmjs.org/google-proto-files/-/google-proto-files-0.15.1.tgz", + "integrity": "sha512-ebtmWgi/ooR5Nl63qRVZZ6VLM6JOb5zTNxTT/ZAU8yfMOdcauoOZNNMOVg0pCmTjqWXeuuVbgPP0CwO5UHHzBQ==", "requires": { "globby": "7.1.1", "power-assert": "1.4.4", - "prettier": "1.11.1", "protobufjs": "6.8.6" }, "dependencies": { + "globby": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/globby/-/globby-7.1.1.tgz", + "integrity": "sha1-+yzP+UAfhgCUXfral0QMypcrhoA=", + "requires": { + "array-union": "1.0.2", + "dir-glob": "2.0.0", + "glob": "7.1.2", + "ignore": "3.3.7", + "pify": "3.0.0", + "slash": "1.0.0" + } + }, "long": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", @@ -3383,7 +4209,7 @@ "@protobufjs/pool": "1.1.0", "@protobufjs/utf8": "1.1.0", "@types/long": "3.0.32", - "@types/node": "8.9.4", + "@types/node": "8.9.5", "long": "4.0.0" } } @@ -3395,19 +4221,18 @@ "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" }, "grpc": { - "version": "1.7.3", - "resolved": "https://registry.npmjs.org/grpc/-/grpc-1.7.3.tgz", - "integrity": "sha512-7zXQJlDXMr/ZaDqdaIchgclViyoWo8GQxZSmFUAxR8GwSr28b6/BTgF221WG+2W693jpp74XJ/+I9DcPXsgt9Q==", + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/grpc/-/grpc-1.9.1.tgz", + "integrity": "sha512-WNW3MWMuAoo63AwIlzFE3T0KzzvNBSvOkg67Hm8WhvHNkXFBlIk1QyJRE3Ocm0O5eIwS7JU8Ssota53QR1zllg==", "requires": { - "arguejs": "0.2.3", - "lodash": "4.17.4", + "lodash": "4.17.5", "nan": "2.9.2", "node-pre-gyp": "0.6.39", "protobufjs": "5.0.2" }, "dependencies": { "abbrev": { - "version": "1.0.9", + "version": "1.1.1", "bundled": true }, "ajv": { @@ -3540,7 +4365,7 @@ } }, "debug": { - "version": "2.6.8", + "version": "2.6.9", "bundled": true, "requires": { "ms": "2.0.0" @@ -3559,7 +4384,7 @@ "bundled": true }, "detect-libc": { - "version": "1.0.2", + "version": "1.0.3", "bundled": true }, "ecc-jsbn": { @@ -3642,7 +4467,7 @@ } }, "glob": { - "version": "7.1.1", + "version": "7.1.2", "bundled": true, "requires": { "fs.realpath": "1.0.0", @@ -3709,7 +4534,7 @@ "bundled": true }, "ini": { - "version": "1.3.4", + "version": "1.3.5", "bundled": true }, "is-fullwidth-code-point": { @@ -3808,27 +4633,25 @@ "version": "0.6.39", "bundled": true, "requires": { - "detect-libc": "1.0.2", + "detect-libc": "1.0.3", "hawk": "3.1.3", "mkdirp": "0.5.1", "nopt": "4.0.1", "npmlog": "4.1.2", - "rc": "1.2.2", + "rc": "1.2.4", "request": "2.81.0", "rimraf": "2.6.2", - "semver": "5.4.1", + "semver": "5.5.0", "tar": "2.2.1", "tar-pack": "3.4.1" - }, - "dependencies": { - "nopt": { - "version": "4.0.1", - "bundled": true, - "requires": { - "abbrev": "1.0.9", - "osenv": "0.1.4" - } - } + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "requires": { + "abbrev": "1.1.1", + "osenv": "0.1.4" } }, "npmlog": { @@ -3897,11 +4720,11 @@ "bundled": true }, "rc": { - "version": "1.2.2", + "version": "1.2.4", "bundled": true, "requires": { "deep-extend": "0.4.2", - "ini": "1.3.4", + "ini": "1.3.5", "minimist": "1.2.0", "strip-json-comments": "2.0.1" }, @@ -3950,14 +4773,14 @@ "stringstream": "0.0.5", "tough-cookie": "2.3.3", "tunnel-agent": "0.6.0", - "uuid": "3.1.0" + "uuid": "3.2.1" } }, "rimraf": { "version": "2.6.2", "bundled": true, "requires": { - "glob": "7.1.1" + "glob": "7.1.2" } }, "safe-buffer": { @@ -3965,7 +4788,7 @@ "bundled": true }, "semver": { - "version": "5.4.1", + "version": "5.5.0", "bundled": true }, "set-blocking": { @@ -4047,7 +4870,7 @@ "version": "3.4.1", "bundled": true, "requires": { - "debug": "2.6.8", + "debug": "2.6.9", "fstream": "1.0.11", "fstream-ignore": "1.0.5", "once": "1.4.0", @@ -4085,7 +4908,7 @@ "bundled": true }, "uuid": { - "version": "3.1.0", + "version": "3.2.1", "bundled": true }, "verror": { @@ -4117,22 +4940,15 @@ } }, "gtoken": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-2.1.0.tgz", - "integrity": "sha512-r/dh/cVgPBWHcskq03KOSDl+L+0Ac0B8VEhpIbnrcsvHSJHdkEtwbC0lOZNxBIqWbM1+HNig8jpuCwKJzCcilg==", + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-2.1.1.tgz", + "integrity": "sha512-9wUP0Gb06lEJxX0w/w+n5Ghxh+/To0rbZSRCOu4Pih2sSDYXJwV4T7q6MPLW31cuKz0wqFQ60mW9nIKc8IgoyA==", "requires": { - "axios": "0.17.1", - "google-p12-pem": "1.0.0", + "axios": "0.18.0", + "google-p12-pem": "1.0.2", "jws": "3.1.4", "mime": "2.2.0", "pify": "3.0.0" - }, - "dependencies": { - "pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" - } } }, "har-schema": { @@ -4166,12 +4982,66 @@ "ansi-regex": "2.1.1" } }, - "has-symbols": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", - "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", - "dev": true - }, + "has-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", + "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=", + "requires": { + "get-value": "2.0.6", + "has-values": "1.0.0", + "isobject": "3.0.1" + }, + "dependencies": { + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, + "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=", + "requires": { + "is-number": "3.0.0", + "kind-of": "4.0.0" + }, + "dependencies": { + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, "hash-stream-validation": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/hash-stream-validation/-/hash-stream-validation-0.2.1.tgz", @@ -4205,16 +5075,10 @@ "os-tmpdir": "1.0.2" } }, - "hosted-git-info": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.5.0.tgz", - "integrity": "sha512-pNgbURSuab90KbTqvRPsseaTxOJCZBD0a7t+haSN33piP9cCM4l0CqdzAif2hUqm716UovKB2ROmiabGAKVXyg==", - "dev": true - }, "http-parser-js": { - "version": "0.4.10", - "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.10.tgz", - "integrity": "sha1-ksnBN0w1CF912zWexWzCV8u5P6Q=" + "version": "0.4.11", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.11.tgz", + "integrity": "sha512-QCR5O2AjjMW8Mo4HyI1ctFcv+O99j/0g367V3YoVnrNw5hkDvAWZD0lWGcc+F4yN3V55USPCVix4efb75HxFfA==" }, "http-signature": { "version": "1.2.0", @@ -4267,7 +5131,7 @@ "cli-cursor": "1.0.2", "cli-width": "2.2.0", "figures": "1.7.0", - "lodash": "4.17.4", + "lodash": "4.17.5", "readline2": "1.0.1", "run-async": "0.1.0", "rx-lite": "3.1.2", @@ -4283,9 +5147,9 @@ "dev": true }, "invariant": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.2.tgz", - "integrity": "sha1-nh9WrArNtr8wMwbzOL47IErmA2A=", + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.3.tgz", + "integrity": "sha512-7Z5PPegwDTyjbaeCnV0efcyS6vdKAU51kpEmS7QFib3P4822l8ICYyMn7qvJnc+WzLoDsuI9gPMKbJ8pCu8XtA==", "requires": { "loose-envify": "1.3.1" } @@ -4300,6 +5164,21 @@ "resolved": "https://registry.npmjs.org/is/-/is-3.2.1.tgz", "integrity": "sha1-0Kwq1V63sL7JJqUmb2xmKqqD3KU=" }, + "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==", + "requires": { + "kind-of": "6.0.2" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, "is-arrayish": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", @@ -4319,36 +5198,61 @@ "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" }, - "is-builtin-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", - "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", - "dev": true, - "requires": { - "builtin-modules": "1.1.1" - } - }, "is-callable": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz", "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=", "dev": true }, + "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==", + "requires": { + "kind-of": "6.0.2" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, "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": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "1.0.0", + "is-data-descriptor": "1.0.0", + "kind-of": "6.0.2" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, "is-dotfile": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", - "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=" + "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", + "optional": true }, "is-equal-shallow": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", + "optional": true, "requires": { "is-primitive": "2.0.0" } @@ -4387,14 +5291,21 @@ "is-extglob": "1.0.0" } }, + "is-my-ip-valid": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-my-ip-valid/-/is-my-ip-valid-1.0.0.tgz", + "integrity": "sha512-gmh/eWXROncUzRnIa1Ubrt5b8ep/MGSnfAUI3aRp+sqTCs1tv1Isl8d8F6JmkN3dXKc3ehZMrtiPN9eL03NuaQ==", + "dev": true + }, "is-my-json-valid": { - "version": "2.17.1", - "resolved": "https://registry.npmjs.org/is-my-json-valid/-/is-my-json-valid-2.17.1.tgz", - "integrity": "sha512-Q2khNw+oBlWuaYvEEHtKSw/pCxD2L5Rc1C+UQme9X6JdRDh7m5D7HkozA0qa3DUkQ6VzCnEm8mVIQPyIRkI5sQ==", + "version": "2.17.2", + "resolved": "https://registry.npmjs.org/is-my-json-valid/-/is-my-json-valid-2.17.2.tgz", + "integrity": "sha512-IBhBslgngMQN8DDSppmgDv7RNrlFotuuDsKcrCP3+HbFaVivIBU7u9oiiErw8sH4ynx3+gOGQ3q2otkgiSi6kg==", "dev": true, "requires": { "generate-function": "2.0.0", "generate-object-property": "1.2.0", + "is-my-ip-valid": "1.0.0", "jsonpointer": "4.0.1", "xtend": "4.0.1" } @@ -4403,6 +5314,7 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", + "optional": true, "requires": { "kind-of": "3.2.2" } @@ -4412,6 +5324,21 @@ "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=" }, + "is-odd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-odd/-/is-odd-2.0.0.tgz", + "integrity": "sha512-OTiixgpZAT1M4NHgS5IguFp/Vz2VI3U7Goh4/HA1adtwyLtSBrxYlcSYkhpAE07s4fKEcjrFxyvtQBND4vFQyQ==", + "requires": { + "is-number": "4.0.0" + }, + "dependencies": { + "is-number": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", + "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==" + } + } + }, "is-path-cwd": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", @@ -4436,15 +5363,32 @@ "path-is-inside": "1.0.2" } }, + "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==", + "requires": { + "isobject": "3.0.1" + }, + "dependencies": { + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, "is-posix-bracket": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", - "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=" + "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", + "optional": true }, "is-primitive": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", - "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=" + "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", + "optional": true }, "is-property": { "version": "1.0.2", @@ -4462,9 +5406,9 @@ } }, "is-resolvable": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.0.1.tgz", - "integrity": "sha512-y5CXYbzvB3jTnWAZH1Nl7ykUWb6T3BcTs56HUruwBf8MhF56n1HWqhDWnVFo8GHrUPDgvUUNVhrc2U8W7iqz5g==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", + "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", "dev": true }, "is-stream": { @@ -4489,6 +5433,11 @@ "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" }, + "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==" + }, "isarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", @@ -4504,6 +5453,7 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "optional": true, "requires": { "isarray": "1.0.0" } @@ -4519,12 +5469,12 @@ "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=" }, "js-yaml": { - "version": "3.10.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.10.0.tgz", - "integrity": "sha512-O2v52ffjLa9VeM43J4XocZE//WT9N0IiwDa3KSHH7Tu8CtH+1qM8SIZvnsTh6v+4yFy5KUY3BHUVwjpfAWsjIA==", + "version": "3.11.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.11.0.tgz", + "integrity": "sha512-saJstZWv7oNeOyBh3+Dx1qWzhW0+e6/8eDzo7p5rDFqxntSztloLtuKu+Ejhtq82jsilwOIZYsCz+lIjthg1Hw==", "dev": true, "requires": { - "argparse": "1.0.9", + "argparse": "1.0.10", "esprima": "4.0.0" } }, @@ -4575,9 +5525,9 @@ "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=" }, "jsonfile": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-3.0.1.tgz", - "integrity": "sha1-pezG9l9T9mLEQVx2daAzHQmS7GY=", + "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.11" @@ -4651,9 +5601,9 @@ } }, "kefir": { - "version": "3.8.1", - "resolved": "https://registry.npmjs.org/kefir/-/kefir-3.8.1.tgz", - "integrity": "sha512-DqeyH7FabWoZTzyRvj9zZMYjekSoEsTFsgRGRGxbt2Ds7OCg8MqSb1PE3xzyZVlBbe5e45oZxfM52IZJZgrjHA==", + "version": "3.8.2", + "resolved": "https://registry.npmjs.org/kefir/-/kefir-3.8.2.tgz", + "integrity": "sha512-sgjlZzkzJOpW0c8OTmnaV0dOJquUgc8fEaxzDhA7HeYVpFEO2BtwT06diU4OA/cyxgKZDvK+h/UkZAXrSej/rQ==", "dev": true, "requires": { "symbol-observable": "1.0.4" @@ -4667,6 +5617,14 @@ "is-buffer": "1.1.6" } }, + "lazy-cache": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-2.0.2.tgz", + "integrity": "sha1-uRkKT5EzVGlIQIWfio9whNiCImQ=", + "requires": { + "set-getter": "0.1.0" + } + }, "lcid": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", @@ -4686,14 +5644,14 @@ } }, "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=", + "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.11", - "parse-json": "2.2.0", - "pify": "2.3.0", + "parse-json": "4.0.0", + "pify": "3.0.0", "strip-bom": "3.0.0" } }, @@ -4708,9 +5666,9 @@ } }, "lodash": { - "version": "4.17.4", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", - "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" + "version": "4.17.5", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.5.tgz", + "integrity": "sha512-svL3uiZf1RwhH+cWrfZn3A4+U58wbP0tGVTLQPbjplZxZ8ROD9VLuNgsRniTlLe7OlSqR79RUehXgpBW/s0IQw==" }, "lodash.cond": { "version": "4.5.2", @@ -4772,9 +5730,9 @@ } }, "lru-cache": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", - "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.2.tgz", + "integrity": "sha512-wgeVXhrDwAWnIF/yZARsFnMBtdFXOg1b8RIrhilp+0iDYN4mdQcNZElDZ0e4B64BhaxeQ5zN7PMyvu7we1kPeQ==", "requires": { "pseudomap": "1.0.2", "yallist": "2.1.2" @@ -4786,13 +5744,19 @@ "integrity": "sha512-aNUAa4UMg/UougV25bbrU4ZaaKNjJ/3/xnvg/twpmKROPdKZPZ9wGgI0opdZzO8q/zUFawoUuixuOv33eZ61Iw==", "requires": { "pify": "3.0.0" - }, - "dependencies": { - "pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" - } + } + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "requires": { + "object-visit": "1.0.1" } }, "mem": { @@ -4801,9 +5765,14 @@ "integrity": "sha1-Xt1StIXKHZAP5kiVUFOZoN+kX3Y=", "dev": true, "requires": { - "mimic-fn": "1.1.0" + "mimic-fn": "1.2.0" } }, + "merge2": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.2.1.tgz", + "integrity": "sha512-wUqcG5pxrAcaFI1lkqkMnk3Q7nUxV/NWfpAFSeWUwG9TRODnBDCUHa75mi3o3vLWQ5N4CQERWCauSlP0I3ZqUg==" + }, "methmeth": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/methmeth/-/methmeth-1.1.0.tgz", @@ -4813,6 +5782,7 @@ "version": "2.3.11", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", + "optional": true, "requires": { "arr-diff": "2.0.0", "array-unique": "0.2.1", @@ -4848,9 +5818,9 @@ } }, "mimic-fn": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.1.0.tgz", - "integrity": "sha1-5md4PZLonb00KBi1IwudYqZyrRg=", + "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 }, "minimatch": { @@ -4858,7 +5828,7 @@ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", "requires": { - "brace-expansion": "1.1.8" + "brace-expansion": "1.1.11" } }, "minimist": { @@ -4866,6 +5836,25 @@ "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" }, + "mixin-deep": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", + "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", + "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==", + "requires": { + "is-plain-object": "2.0.4" + } + } + } + }, "mkdirp": { "version": "0.5.1", "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", @@ -4895,6 +5884,42 @@ "resolved": "https://registry.npmjs.org/nan/-/nan-2.9.2.tgz", "integrity": "sha512-ltW65co7f3PQWBDbqVvaU1WtFJUsNW7sWWm4HINhbMQIyVyzIeyZ8toX5TC5eeooE6piZoaEh4cZkueSKG3KYw==" }, + "nanomatch": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.9.tgz", + "integrity": "sha512-n8R9bS8yQ6eSXaV6jHUpKzD8gLsin02w1HSFiegwrs9E098Ylhw5jdyKPaYqvHknHaSCKTPp7C8dGCQ0q9koXA==", + "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-odd": "2.0.0", + "is-windows": "1.0.2", + "kind-of": "6.0.2", + "object.pick": "1.3.0", + "regex-not": "1.0.2", + "snapdragon": "0.8.1", + "to-regex": "3.0.2" + }, + "dependencies": { + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } + } + }, "natural-compare": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", @@ -4906,18 +5931,6 @@ "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.7.1.tgz", "integrity": "sha1-naYR6giYL0uUIGs760zJZl8gwwA=" }, - "normalize-package-data": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", - "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", - "dev": true, - "requires": { - "hosted-git-info": "2.5.0", - "is-builtin-module": "1.0.0", - "semver": "5.4.1", - "validate-npm-package-license": "3.0.1" - } - }, "normalize-path": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", @@ -4950,11 +5963,79 @@ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "requires": { + "copy-descriptor": "0.1.1", + "define-property": "0.2.5", + "kind-of": "3.2.2" + }, + "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=", + "requires": { + "is-descriptor": "0.1.6" + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "0.1.6", + "is-data-descriptor": "0.1.4", + "kind-of": "5.1.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==" + } + } + } + } + }, "object-keys": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=" }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "requires": { + "isobject": "3.0.1" + }, + "dependencies": { + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, "object.assign": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", @@ -4971,11 +6052,27 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", + "optional": true, "requires": { "for-own": "0.1.5", "is-extendable": "0.1.1" } }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "requires": { + "isobject": "3.0.1" + }, + "dependencies": { + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, "once": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", @@ -5071,6 +6168,7 @@ "version": "3.0.4", "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", + "optional": true, "requires": { "glob-base": "0.3.0", "is-dotfile": "1.0.3", @@ -5079,14 +6177,25 @@ } }, "parse-json": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", - "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", + "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" + "error-ex": "1.3.1", + "json-parse-better-errors": "1.0.1" } }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=" + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=" + }, "path-exists": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", @@ -5117,12 +6226,11 @@ "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, + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", "requires": { - "pify": "2.3.0" + "pify": "3.0.0" } }, "performance-now": { @@ -5131,10 +6239,9 @@ "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" }, "pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", - "dev": true + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" }, "pinkie": { "version": "2.0.4", @@ -5159,36 +6266,6 @@ "requires": { "find-up": "2.1.0", "load-json-file": "4.0.0" - }, - "dependencies": { - "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.11", - "parse-json": "4.0.0", - "pify": "3.0.0", - "strip-bom": "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" - } - }, - "pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", - "dev": true - } } }, "pkg-config": { @@ -5268,6 +6345,11 @@ "integrity": "sha1-0aIUg/0iu0HlihL6NCGCMUCJfEU=", "dev": true }, + "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=" + }, "power-assert": { "version": "1.4.4", "resolved": "https://registry.npmjs.org/power-assert/-/power-assert-1.4.4.tgz", @@ -5299,13 +6381,6 @@ "core-js": "2.5.3", "espurify": "1.7.0", "estraverse": "4.2.0" - }, - "dependencies": { - "acorn": { - "version": "4.0.13", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", - "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" - } } }, "power-assert-context-traversal": { @@ -5393,12 +6468,8 @@ "preserve": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", - "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=" - }, - "prettier": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.11.1.tgz", - "integrity": "sha512-T/KD65Ot0PB97xTrG8afQ46x3oiVhnfGjGESSI9NWYcG92+OUPZKkwHqGWXH2t9jK1crnQjubECW0FuOth+hxw==" + "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", + "optional": true }, "private": { "version": "0.1.8", @@ -5406,9 +6477,9 @@ "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==" }, "process-nextick-args": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", - "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", + "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==" }, "progress": { "version": "1.1.8", @@ -5465,6 +6536,7 @@ "version": "1.1.7", "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", + "optional": true, "requires": { "is-number": "3.0.0", "kind-of": "4.0.0" @@ -5474,6 +6546,7 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "optional": true, "requires": { "kind-of": "3.2.2" }, @@ -5482,6 +6555,7 @@ "version": "3.2.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "optional": true, "requires": { "is-buffer": "1.1.6" } @@ -5492,42 +6566,22 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "optional": true, "requires": { "is-buffer": "1.1.6" } } } }, - "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.4.0", - "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.1.0", - "read-pkg": "2.0.0" - } - }, "readable-stream": { - "version": "2.3.3", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", - "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", + "version": "2.3.5", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.5.tgz", + "integrity": "sha512-tK0yDhrkygt/knjowCUiWP9YdV7c5R+8cR0r/kt9ZhBU906Fs6RpQJCEilamRJj1Nx2rWI6LkW9gKqjTkshhEw==", "requires": { "core-util-is": "1.0.2", "inherits": "2.0.3", "isarray": "1.0.0", - "process-nextick-args": "1.0.7", + "process-nextick-args": "2.0.0", "safe-buffer": "5.1.1", "string_decoder": "1.0.3", "util-deprecate": "1.0.2" @@ -5540,7 +6594,7 @@ "requires": { "graceful-fs": "4.1.11", "minimatch": "3.0.4", - "readable-stream": "2.3.3", + "readable-stream": "2.3.5", "set-immediate-shim": "1.0.1" } }, @@ -5588,10 +6642,20 @@ "version": "0.4.4", "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", + "optional": true, "requires": { "is-equal-shallow": "0.1.3" } }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "requires": { + "extend-shallow": "3.0.2", + "safe-regex": "1.1.0" + } + }, "regexpu-core": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-2.0.0.tgz", @@ -5711,6 +6775,11 @@ "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", "dev": true }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=" + }, "restore-cursor": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-1.0.1.tgz", @@ -5721,10 +6790,15 @@ "onetime": "1.1.0" } }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==" + }, "retry-axios": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/retry-axios/-/retry-axios-0.3.0.tgz", - "integrity": "sha512-6vOCghodB5p5N/ZOqug7A3WsT42TULZ7NErUi4lP3KtwtXgz4hE/43LWHsFuHuBfXRmOm/tjXBWAjnObrcy+yg==" + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/retry-axios/-/retry-axios-0.3.2.tgz", + "integrity": "sha512-jp4YlI0qyDFfXiXGhkCOliBN1G7fRH03Nqy8YdShzGqbY5/9S2x/IR6C88ls2DFkbWuL3ASkP7QD3pVrNpPgwQ==" }, "retry-request": { "version": "3.3.1", @@ -5754,9 +6828,9 @@ } }, "run-parallel": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.6.tgz", - "integrity": "sha1-KQA8miFj4B4tLfyQV18sbB1hoDk=", + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.7.tgz", + "integrity": "sha512-nB641a6enJOh0fdsFHR9SiVCiOlAyjMplImDdjV3kWCzJZw9rwzvGwmpGuPmfX//Yxblh0pkzPcFcxA81iwmxA==", "dev": true }, "rx-lite": { @@ -5770,10 +6844,18 @@ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "requires": { + "ret": "0.1.15" + } + }, "semver": { - "version": "5.4.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", - "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==" + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", + "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==" }, "set-blocking": { "version": "2.0.0", @@ -5781,11 +6863,40 @@ "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", "dev": true }, + "set-getter": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/set-getter/-/set-getter-0.1.0.tgz", + "integrity": "sha1-12nBgsnVpR9AkUXy+6guXoboA3Y=", + "requires": { + "to-object-path": "0.3.0" + } + }, "set-immediate-shim": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=" }, + "set-value": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", + "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", + "requires": { + "extend-shallow": "2.0.1", + "is-extendable": "0.1.1", + "is-plain-object": "2.0.4", + "split-string": "3.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=", + "requires": { + "is-extendable": "0.1.1" + } + } + } + }, "shebang-command": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", @@ -5833,6 +6944,123 @@ "resolved": "https://registry.npmjs.org/snakeize/-/snakeize-0.1.0.tgz", "integrity": "sha1-EMCI2LWOsHazIpu1oE4jLOEmQi0=" }, + "snapdragon": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.1.tgz", + "integrity": "sha1-4StUh/re0+PeoKyR6UAL91tAE3A=", + "requires": { + "base": "0.11.2", + "debug": "2.6.9", + "define-property": "0.2.5", + "extend-shallow": "2.0.1", + "map-cache": "0.2.2", + "source-map": "0.5.7", + "source-map-resolve": "0.5.1", + "use": "2.0.2" + }, + "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=", + "requires": { + "is-descriptor": "0.1.6" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "0.1.1" + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "0.1.6", + "is-data-descriptor": "0.1.4", + "kind-of": "5.1.0" + } + }, + "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==" + } + } + }, + "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==", + "requires": { + "define-property": "1.0.0", + "isobject": "3.0.1", + "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=", + "requires": { + "is-descriptor": "1.0.2" + } + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "requires": { + "kind-of": "3.2.2" + } + }, "sntp": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.1.0.tgz", @@ -5846,6 +7074,18 @@ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" }, + "source-map-resolve": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.1.tgz", + "integrity": "sha512-0KW2wvzfxm8NCTb30z0LMNyPqWCdDGE2viwzUaucqJdkTRXtZiSY3I+2A6nVAjmdOy0I4gU8DwnVVGsk9jvP2A==", + "requires": { + "atob": "2.0.3", + "decode-uri-component": "0.2.0", + "resolve-url": "0.2.1", + "source-map-url": "0.4.0", + "urix": "0.1.0" + } + }, "source-map-support": { "version": "0.4.18", "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", @@ -5854,26 +7094,10 @@ "source-map": "0.5.7" } }, - "spdx-correct": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", - "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", - "dev": true, - "requires": { - "spdx-license-ids": "1.2.2" - } - }, - "spdx-expression-parse": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", - "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=", - "dev": true - }, - "spdx-license-ids": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", - "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=", - "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=" }, "split-array-stream": { "version": "1.0.3", @@ -5884,6 +7108,14 @@ "is-stream-ended": "0.1.3" } }, + "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==", + "requires": { + "extend-shallow": "3.0.2" + } + }, "sprintf-js": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", @@ -5942,6 +7174,76 @@ } } }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "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=", + "requires": { + "is-descriptor": "0.1.6" + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "0.1.6", + "is-data-descriptor": "0.1.4", + "kind-of": "5.1.0" + } + }, + "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==" + } + } + }, "stream-events": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.2.tgz", @@ -6044,7 +7346,7 @@ "ajv": "4.11.8", "ajv-keywords": "1.5.1", "chalk": "1.1.3", - "lodash": "4.17.4", + "lodash": "4.17.5", "slice-ansi": "0.0.4", "string-width": "2.1.1" }, @@ -6109,7 +7411,7 @@ "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", "requires": { - "readable-stream": "2.3.3", + "readable-stream": "2.3.5", "xtend": "4.0.1" } }, @@ -6118,6 +7420,44 @@ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=" }, + "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=", + "requires": { + "kind-of": "3.2.2" + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "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=", + "requires": { + "is-number": "3.0.0", + "repeat-string": "1.6.1" + }, + "dependencies": { + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "requires": { + "kind-of": "3.2.2" + } + } + } + }, "tough-cookie": { "version": "2.3.4", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.4.tgz", @@ -6174,6 +7514,38 @@ "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" }, + "union-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", + "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", + "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=", + "requires": { + "is-extendable": "0.1.1" + } + }, + "set-value": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", + "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", + "requires": { + "extend-shallow": "2.0.1", + "is-extendable": "0.1.1", + "is-plain-object": "2.0.4", + "to-object-path": "0.3.0" + } + } + } + }, "uniq": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", @@ -6204,6 +7576,134 @@ "integrity": "sha1-+nG63UQ3r0wUiEHjs7Fl+enlkLc=", "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=", + "requires": { + "has-value": "0.3.1", + "isobject": "3.0.1" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "requires": { + "get-value": "2.0.6", + "has-values": "0.1.4", + "isobject": "2.1.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "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=" + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + } + } + }, + "upath": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.0.4.tgz", + "integrity": "sha512-d4SJySNBXDaQp+DPrziv3xGS6w3d2Xt69FijJr86zMPBy23JEloMCEOUBBzuN7xCtjLCnmB9tI/z7SBCahHBOw==", + "dev": true + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=" + }, + "use": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/use/-/use-2.0.2.tgz", + "integrity": "sha1-riig1y+TvyJCKhii43mZMRLeyOg=", + "requires": { + "define-property": "0.2.5", + "isobject": "3.0.1", + "lazy-cache": "2.0.2" + }, + "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=", + "requires": { + "is-descriptor": "0.1.6" + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "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=", + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "0.1.6", + "is-data-descriptor": "0.1.4", + "kind-of": "5.1.0" + } + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + }, + "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==" + } + } + }, "user-home": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/user-home/-/user-home-1.1.1.tgz", @@ -6227,16 +7727,6 @@ "user-home": "1.1.1" } }, - "validate-npm-package-license": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", - "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", - "dev": true, - "requires": { - "spdx-correct": "1.0.2", - "spdx-expression-parse": "1.0.4" - } - }, "verror": { "version": "1.10.0", "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", @@ -6252,7 +7742,7 @@ "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.0.tgz", "integrity": "sha1-DK+dLXVdk67gSdS90NP+LMoqJOs=", "requires": { - "http-parser-js": "0.4.10", + "http-parser-js": "0.4.11", "websocket-extensions": "0.1.3" } }, @@ -6355,9 +7845,9 @@ } }, "yargs-parser": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-7.0.0.tgz", - "integrity": "sha1-jQrELxbqVd69MyyvTEA4s+P139k=", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-9.0.2.tgz", + "integrity": "sha1-nM9qQ0YP5O1Aqbto9I1DuKaMwHc=", "dev": true, "requires": { "camelcase": "4.1.0" diff --git a/package.json b/package.json index 3d32fc6..83f7219 100644 --- a/package.json +++ b/package.json @@ -29,7 +29,6 @@ "babel-cli": "^6.26.0", "babel-preset-env": "^1.6.1", "babel-preset-flow": "^6.23.0", - "bluebird": "^3.5.1", "colors": "^1.1.2", "commander": "^2.11.0", "firebase-admin": "^5.8.1", From e7e8a874e2696682e528ba4e8f90c50e60a12e32 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 11 Mar 2018 02:07:38 +0000 Subject: [PATCH 14/17] dist rebuilt --- dist/firestore.js | 32 ++++++++++++++++++++++++-------- dist/firestore.js.flow | 26 ++++++++++++++++++++++---- dist/types.js | 7 ++++++- dist/types.js.flow | 5 +++++ dist/utility.js | 32 +++++++++++++++++++++++++++++++- dist/utility.js.flow | 28 ++++++++++++++++++++++++++++ 6 files changed, 116 insertions(+), 14 deletions(-) diff --git a/dist/firestore.js b/dist/firestore.js index 5724205..3198c51 100644 --- a/dist/firestore.js +++ b/dist/firestore.js @@ -19,10 +19,6 @@ var _mkdirp = require('mkdirp'); var _mkdirp2 = _interopRequireDefault(_mkdirp); -var _bluebird = require('bluebird'); - -var _bluebird2 = _interopRequireDefault(_bluebird); - function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } @@ -126,6 +122,8 @@ var FirestoreBackup = exports.FirestoreBackup = function () { if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3; // 3 is the max before diminishing returns } + + this.Promise = Promise; } _createClass(FirestoreBackup, [{ @@ -172,11 +170,13 @@ var FirestoreBackup = exports.FirestoreBackup = function () { throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error); } - return _bluebird2.default.resolve(collection.get()).then(function (documentSnapshots) { + return this.Promise.resolve(collection.get()).then(function (documentSnapshots) { return documentSnapshots.docs; }).map(function (document) { return _this3.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/'); - }, { concurrency: this.options.requestCountLimit }); + }, { concurrency: this.options.requestCountLimit }).catch(function (err) { + return console.error(err); + }); } }, { key: 'backupDocument', @@ -210,9 +210,25 @@ var FirestoreBackup = exports.FirestoreBackup = function () { throw new Error('Unable to write Document \'' + document.id + '\': ' + error); } - return _bluebird2.default.resolve(document.ref.getCollections()).map(function (collection) { + return this.Promise.resolve(document.ref.getCollections()).map(function (collection) { return _this4.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/'); - }, { concurrency: this.documentRequestLimit }); + }, { concurrency: this.documentRequestLimit }).catch(function (err) { + return console.error(err); + }); + } + }, { + key: 'Promise', + get: function get() { + return this._PromiseLibrary; + } + + /** + * The Promise library used to process asynchronous functions. + */ + , + set: function set(value) { + // TODO: validate this ia valid Promise-like object + this._PromiseLibrary = (0, _utility.addMapFunction)(value); } }]); diff --git a/dist/firestore.js.flow b/dist/firestore.js.flow index ffd0fde..512b095 100644 --- a/dist/firestore.js.flow +++ b/dist/firestore.js.flow @@ -4,6 +4,7 @@ import { isString, isNull, isObject, + isFunction, isArray, isNumber, isDate, @@ -13,11 +14,10 @@ import { isCollectionPath } from './types' import type { ValueDescription, Validator, BackupOptions } from './types' -import { promiseSerial } from './utility' +import { promiseSerial, addMapFunction } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' -import Promise from 'bluebird' export const constructReferenceUrl = (reference: Object): ValueDescription => { const referenceSegments = reference._referencePath.segments @@ -125,12 +125,28 @@ export class FirestoreBackup { documentRequestLimit: number; + _PromiseLibrary: Object; + constructor(options: BackupOptions) { this.options = Object.assign({}, defaultBackupOptions, options) if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3 // 3 is the max before diminishing returns } + + this.Promise = Promise + } + + get Promise() { + return this._PromiseLibrary + } + + /** + * The Promise library used to process asynchronous functions. + */ + set Promise(value: Object) { + // TODO: validate this ia valid Promise-like object + this._PromiseLibrary = addMapFunction(value) } backup() { @@ -169,11 +185,12 @@ export class FirestoreBackup { throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) } - return Promise.resolve(collection.get()) + return this.Promise.resolve(collection.get()) .then((documentSnapshots) => documentSnapshots.docs) .map((document) => { return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') }, { concurrency: this.options.requestCountLimit }) + .catch(err=>console.error(err)) } backupDocument(document: Object, backupPath: string, logPath: string) { @@ -204,9 +221,10 @@ export class FirestoreBackup { throw new Error('Unable to write Document \'' + document.id + '\': ' + error) } - return Promise.resolve(document.ref.getCollections()) + return this.Promise.resolve(document.ref.getCollections()) .map((collection) => { return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') }, { concurrency: this.documentRequestLimit }) + .catch(err=>console.error(err)) } } diff --git a/dist/types.js b/dist/types.js index 8e2710e..c85d305 100644 --- a/dist/types.js +++ b/dist/types.js @@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.isCollectionPath = exports.isDocumentPath = exports.isReference = exports.isDate = exports.isBoolean = exports.isUndefined = exports.isNull = exports.isObject = exports.isArray = exports.isNumber = exports.isString = undefined; +exports.isCollectionPath = exports.isDocumentPath = exports.isReference = exports.isDate = exports.isBoolean = exports.isUndefined = exports.isNull = exports.isFunction = exports.isObject = exports.isArray = exports.isNumber = exports.isString = undefined; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; @@ -57,6 +57,11 @@ var isObject = exports.isObject = function isObject(value) { return isObjectOfType(value, Object, 'object'); }; +// Returns if a value is a function +var isFunction = exports.isFunction = function isFunction(value) { + return isObjectOfType(value, Function, 'function'); +}; + // Returns if a value is null var isNull = exports.isNull = function isNull(value) { if (value === null) { diff --git a/dist/types.js.flow b/dist/types.js.flow index b22f2be..5f35f93 100644 --- a/dist/types.js.flow +++ b/dist/types.js.flow @@ -68,6 +68,11 @@ export const isObject = (value: any): ValidationResult => { return isObjectOfType(value, Object, 'object') } +// Returns if a value is a function +export const isFunction = (value: any): ValidationResult => { + return isObjectOfType(value, Function, 'function') +} + // Returns if a value is null export const isNull = (value: any): ValidationResult => { if (value === null) { diff --git a/dist/utility.js b/dist/utility.js index e4a52b9..a20f993 100644 --- a/dist/utility.js +++ b/dist/utility.js @@ -3,7 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true }); -// TODO: Flow coverage +exports.addMapFunction = exports.getSegments = exports.promiseSerial = undefined; + +var _types = require('./types'); + // from: https://hackernoon.com/functional-javascript-resolving-promises-sequentially-7aac18c4431e var promiseSerial = exports.promiseSerial = function promiseSerial(funcs) { return funcs.reduce(function (promise, func) { @@ -21,10 +24,37 @@ var promiseSerial = exports.promiseSerial = function promiseSerial(funcs) { * @param {string} relativePath - The path to split. * @returns {Array.} - The split path segments. */ +// TODO: Flow coverage + var getSegments = exports.getSegments = function getSegments(relativePath) { // We may have an empty segment at the beginning or end if they had a // leading or trailing slash (which we allow). return relativePath.split('/').filter(function (segment) { return segment.length > 0; }); +}; + +var map = function map(basePromise, fn, options) { + return basePromise.then(function (value) { + return promiseSerial(value.map(function (value) { + return function () { + return fn(value); + }; + })); + }); +}; + +/** + * Adds the method 'map' to the prototype of an object. + * + * @param {object} obj - The object to receive the 'map' method. + */ +var addMapFunction = exports.addMapFunction = function addMapFunction(obj) { + if (!(0, _types.isFunction)(obj.map)) { + obj.prototype.map = function (fn, options) { + return map(this, fn, options); + }; + } + + return obj; }; \ No newline at end of file diff --git a/dist/utility.js.flow b/dist/utility.js.flow index 496f54c..3f67170 100644 --- a/dist/utility.js.flow +++ b/dist/utility.js.flow @@ -1,4 +1,7 @@ // TODO: Flow coverage + +import { isFunction } from './types' + // from: https://hackernoon.com/functional-javascript-resolving-promises-sequentially-7aac18c4431e export const promiseSerial = (funcs) => { return funcs.reduce( @@ -22,3 +25,28 @@ export const getSegments = (relativePath) => { // leading or trailing slash (which we allow). return relativePath.split('/').filter(segment => segment.length > 0) } + +const map = (basePromise: Object, fn: Function, options: Object) => { + return basePromise.then((value) => { + return promiseSerial(value.map((value) => { + return () => { + return fn(value) + } + })) + }) +} + +/** + * Adds the method 'map' to the prototype of an object. + * + * @param {object} obj - The object to receive the 'map' method. + */ +export const addMapFunction = (obj: Object) => { + if (!isFunction(obj.map)) { + obj.prototype.map = function(fn: Function, options: Object) { + return map(this, fn, options) + } + } + + return obj +} From d67346b33474e4edc62ca6226e7ad53fb4283a39 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Sun, 11 Mar 2018 02:11:16 +0000 Subject: [PATCH 15/17] remove Promise.catch statements used during testing --- lib/firestore.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/lib/firestore.js b/lib/firestore.js index f36d0de..217e9d9 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -189,7 +189,6 @@ export class FirestoreBackup { .map((document) => { return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') }, { concurrency: this.options.requestCountLimit }) - .catch(err=>console.error(err)) } backupDocument(document: Object, backupPath: string, logPath: string) { @@ -224,6 +223,5 @@ export class FirestoreBackup { .map((collection) => { return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') }, { concurrency: this.documentRequestLimit }) - .catch(err=>console.error(err)) } } From 654705d031ff54f9db86883c58bbc451883900b6 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Tue, 20 Mar 2018 05:44:10 +0000 Subject: [PATCH 16/17] add promise concurrency utility to use native Promise --- dist/firestore.js | 42 +++++++++-------------------- dist/firestore.js.flow | 49 +++++++++++---------------------- dist/utility.js | 61 +++++++++++++++++++++--------------------- dist/utility.js.flow | 52 +++++++++++++++++------------------ lib/firestore.js | 46 +++++++++++-------------------- lib/utility.js | 52 +++++++++++++++++------------------ package.json | 2 +- 7 files changed, 126 insertions(+), 178 deletions(-) diff --git a/dist/firestore.js b/dist/firestore.js index 3198c51..5d7eecf 100644 --- a/dist/firestore.js +++ b/dist/firestore.js @@ -122,8 +122,6 @@ var FirestoreBackup = exports.FirestoreBackup = function () { if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3; // 3 is the max before diminishing returns } - - this.Promise = Promise; } _createClass(FirestoreBackup, [{ @@ -151,11 +149,9 @@ var FirestoreBackup = exports.FirestoreBackup = function () { var _this2 = this; return this.options.database.getCollections().then(function (collections) { - return (0, _utility.promiseSerial)(collections.map(function (collection) { - return function () { - return _this2.backupCollection(collection, _this2.options.backupPath + '/' + collection.id, '/'); - }; - })); + return (0, _utility.promiseParallel)(collections, function (collection) { + return _this2.backupCollection(collection, _this2.options.backupPath + '/' + collection.id, '/'); + }, 1); }); } }, { @@ -170,12 +166,12 @@ var FirestoreBackup = exports.FirestoreBackup = function () { throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error); } - return this.Promise.resolve(collection.get()).then(function (documentSnapshots) { + return collection.get().then(function (documentSnapshots) { return documentSnapshots.docs; - }).map(function (document) { - return _this3.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/'); - }, { concurrency: this.options.requestCountLimit }).catch(function (err) { - return console.error(err); + }).then(function (docs) { + return (0, _utility.promiseParallel)(docs, function (document) { + return _this3.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/'); + }, _this3.options.requestCountLimit); }); } }, { @@ -210,26 +206,12 @@ var FirestoreBackup = exports.FirestoreBackup = function () { throw new Error('Unable to write Document \'' + document.id + '\': ' + error); } - return this.Promise.resolve(document.ref.getCollections()).map(function (collection) { - return _this4.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/'); - }, { concurrency: this.documentRequestLimit }).catch(function (err) { - return console.error(err); + return document.ref.getCollections().then(function (collections) { + return (0, _utility.promiseParallel)(collections, function (collection) { + return _this4.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/'); + }, _this4.documentRequestLimit); }); } - }, { - key: 'Promise', - get: function get() { - return this._PromiseLibrary; - } - - /** - * The Promise library used to process asynchronous functions. - */ - , - set: function set(value) { - // TODO: validate this ia valid Promise-like object - this._PromiseLibrary = (0, _utility.addMapFunction)(value); - } }]); return FirestoreBackup; diff --git a/dist/firestore.js.flow b/dist/firestore.js.flow index 512b095..853bbc3 100644 --- a/dist/firestore.js.flow +++ b/dist/firestore.js.flow @@ -4,7 +4,6 @@ import { isString, isNull, isObject, - isFunction, isArray, isNumber, isDate, @@ -14,7 +13,7 @@ import { isCollectionPath } from './types' import type { ValueDescription, Validator, BackupOptions } from './types' -import { promiseSerial, addMapFunction } from './utility' +import { promiseSerial, promiseParallel } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' @@ -125,28 +124,12 @@ export class FirestoreBackup { documentRequestLimit: number; - _PromiseLibrary: Object; - constructor(options: BackupOptions) { this.options = Object.assign({}, defaultBackupOptions, options) if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3 // 3 is the max before diminishing returns } - - this.Promise = Promise - } - - get Promise() { - return this._PromiseLibrary - } - - /** - * The Promise library used to process asynchronous functions. - */ - set Promise(value: Object) { - // TODO: validate this ia valid Promise-like object - this._PromiseLibrary = addMapFunction(value) } backup() { @@ -169,11 +152,9 @@ export class FirestoreBackup { backupRootCollections() { return this.options.database.getCollections() .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return this.backupCollection(collection, this.options.backupPath + '/' + collection.id, '/') - } - })) + return promiseParallel(collections, (collection) => { + return this.backupCollection(collection, this.options.backupPath + '/' + collection.id, '/') + }, 1) }) } @@ -185,12 +166,13 @@ export class FirestoreBackup { throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) } - return this.Promise.resolve(collection.get()) + return collection.get() .then((documentSnapshots) => documentSnapshots.docs) - .map((document) => { - return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') - }, { concurrency: this.options.requestCountLimit }) - .catch(err=>console.error(err)) + .then((docs) => { + return promiseParallel(docs, (document) => { + return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') + }, this.options.requestCountLimit) + }) } backupDocument(document: Object, backupPath: string, logPath: string) { @@ -221,10 +203,11 @@ export class FirestoreBackup { throw new Error('Unable to write Document \'' + document.id + '\': ' + error) } - return this.Promise.resolve(document.ref.getCollections()) - .map((collection) => { - return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') - }, { concurrency: this.documentRequestLimit }) - .catch(err=>console.error(err)) + return document.ref.getCollections() + .then((collections) => { + return promiseParallel(collections, (collection) => { + return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') + }, this.documentRequestLimit) + }) } } diff --git a/dist/utility.js b/dist/utility.js index a20f993..78f48af 100644 --- a/dist/utility.js +++ b/dist/utility.js @@ -3,10 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true }); -exports.addMapFunction = exports.getSegments = exports.promiseSerial = undefined; - -var _types = require('./types'); +// TODO: Flow coverage +// TODO: Remove in favor of `promiseParallel` // from: https://hackernoon.com/functional-javascript-resolving-promises-sequentially-7aac18c4431e var promiseSerial = exports.promiseSerial = function promiseSerial(funcs) { return funcs.reduce(function (promise, func) { @@ -18,43 +17,45 @@ var promiseSerial = exports.promiseSerial = function promiseSerial(funcs) { }, Promise.resolve([])); }; +/** + * Iterate over an array using the given mapper function to resolve a list of promises. + * + * @param {Array} input - The array to be mapped. + * @param {function:Promise} mapper - A function to be called on each array element. + * @param {number} [concurrency=1] - Limits the number of Promises created. + * @returns {Promise} + */ +var promiseParallel = exports.promiseParallel = function promiseParallel(input, mapper) { + var concurrency = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1; + + var results = Array.from({ length: input.length }); + var offset = 0; + + function dowork() { + return offset >= input.length ? Promise.resolve() : Promise.resolve(offset++).then(function (ix) { + return mapper(input[ix]).then(function (result) { + results[ix] = result; + }); + }).then(function () { + return dowork(); + }); + } + + return Promise.all(Array.from({ length: concurrency }, dowork)).then(function () { + return results; + }); +}; + /** * Splits a string into path segments, using slashes as separators. * * @param {string} relativePath - The path to split. * @returns {Array.} - The split path segments. */ -// TODO: Flow coverage - var getSegments = exports.getSegments = function getSegments(relativePath) { // We may have an empty segment at the beginning or end if they had a // leading or trailing slash (which we allow). return relativePath.split('/').filter(function (segment) { return segment.length > 0; }); -}; - -var map = function map(basePromise, fn, options) { - return basePromise.then(function (value) { - return promiseSerial(value.map(function (value) { - return function () { - return fn(value); - }; - })); - }); -}; - -/** - * Adds the method 'map' to the prototype of an object. - * - * @param {object} obj - The object to receive the 'map' method. - */ -var addMapFunction = exports.addMapFunction = function addMapFunction(obj) { - if (!(0, _types.isFunction)(obj.map)) { - obj.prototype.map = function (fn, options) { - return map(this, fn, options); - }; - } - - return obj; }; \ No newline at end of file diff --git a/dist/utility.js.flow b/dist/utility.js.flow index 3f67170..6e5bbd6 100644 --- a/dist/utility.js.flow +++ b/dist/utility.js.flow @@ -1,7 +1,6 @@ // TODO: Flow coverage -import { isFunction } from './types' - +// TODO: Remove in favor of `promiseParallel` // from: https://hackernoon.com/functional-javascript-resolving-promises-sequentially-7aac18c4431e export const promiseSerial = (funcs) => { return funcs.reduce( @@ -14,6 +13,30 @@ export const promiseSerial = (funcs) => { }, Promise.resolve([])) } +/** + * Iterate over an array using the given mapper function to resolve a list of promises. + * + * @param {Array} input - The array to be mapped. + * @param {function:Promise} mapper - A function to be called on each array element. + * @param {number} [concurrency=1] - Limits the number of Promises created. + * @returns {Promise} + */ +export const promiseParallel = (input, mapper, concurrency = 1) => { + const results = Array.from({ length: input.length }) + let offset = 0 + + function dowork() { + return (offset >= input.length) ? + Promise.resolve() : + Promise.resolve(offset++) + .then(ix => mapper(input[ix]).then(result => { results[ix] = result })) + .then(() => dowork()) + } + + return Promise.all(Array.from({ length: concurrency }, dowork)) + .then(() => results) +} + /** * Splits a string into path segments, using slashes as separators. * @@ -25,28 +48,3 @@ export const getSegments = (relativePath) => { // leading or trailing slash (which we allow). return relativePath.split('/').filter(segment => segment.length > 0) } - -const map = (basePromise: Object, fn: Function, options: Object) => { - return basePromise.then((value) => { - return promiseSerial(value.map((value) => { - return () => { - return fn(value) - } - })) - }) -} - -/** - * Adds the method 'map' to the prototype of an object. - * - * @param {object} obj - The object to receive the 'map' method. - */ -export const addMapFunction = (obj: Object) => { - if (!isFunction(obj.map)) { - obj.prototype.map = function(fn: Function, options: Object) { - return map(this, fn, options) - } - } - - return obj -} diff --git a/lib/firestore.js b/lib/firestore.js index 217e9d9..853bbc3 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -13,7 +13,7 @@ import { isCollectionPath } from './types' import type { ValueDescription, Validator, BackupOptions } from './types' -import { promiseSerial, addMapFunction } from './utility' +import { promiseSerial, promiseParallel } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' @@ -124,28 +124,12 @@ export class FirestoreBackup { documentRequestLimit: number; - _PromiseLibrary: Object; - constructor(options: BackupOptions) { this.options = Object.assign({}, defaultBackupOptions, options) if (this.options.requestCountLimit > 1) { this.documentRequestLimit = 3 // 3 is the max before diminishing returns } - - this.Promise = Promise - } - - get Promise() { - return this._PromiseLibrary - } - - /** - * The Promise library used to process asynchronous functions. - */ - set Promise(value: Object) { - // TODO: validate this ia valid Promise-like object - this._PromiseLibrary = addMapFunction(value) } backup() { @@ -168,11 +152,9 @@ export class FirestoreBackup { backupRootCollections() { return this.options.database.getCollections() .then((collections) => { - return promiseSerial(collections.map((collection) => { - return () => { - return this.backupCollection(collection, this.options.backupPath + '/' + collection.id, '/') - } - })) + return promiseParallel(collections, (collection) => { + return this.backupCollection(collection, this.options.backupPath + '/' + collection.id, '/') + }, 1) }) } @@ -184,11 +166,13 @@ export class FirestoreBackup { throw new Error('Unable to create backup path for Collection \'' + collection.id + '\': ' + error) } - return this.Promise.resolve(collection.get()) + return collection.get() .then((documentSnapshots) => documentSnapshots.docs) - .map((document) => { - return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') - }, { concurrency: this.options.requestCountLimit }) + .then((docs) => { + return promiseParallel(docs, (document) => { + return this.backupDocument(document, backupPath + '/' + document.id, logPath + collection.id + '/') + }, this.options.requestCountLimit) + }) } backupDocument(document: Object, backupPath: string, logPath: string) { @@ -219,9 +203,11 @@ export class FirestoreBackup { throw new Error('Unable to write Document \'' + document.id + '\': ' + error) } - return this.Promise.resolve(document.ref.getCollections()) - .map((collection) => { - return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') - }, { concurrency: this.documentRequestLimit }) + return document.ref.getCollections() + .then((collections) => { + return promiseParallel(collections, (collection) => { + return this.backupCollection(collection, backupPath + '/' + collection.id, logPath + document.id + '/') + }, this.documentRequestLimit) + }) } } diff --git a/lib/utility.js b/lib/utility.js index 3f67170..6e5bbd6 100644 --- a/lib/utility.js +++ b/lib/utility.js @@ -1,7 +1,6 @@ // TODO: Flow coverage -import { isFunction } from './types' - +// TODO: Remove in favor of `promiseParallel` // from: https://hackernoon.com/functional-javascript-resolving-promises-sequentially-7aac18c4431e export const promiseSerial = (funcs) => { return funcs.reduce( @@ -14,6 +13,30 @@ export const promiseSerial = (funcs) => { }, Promise.resolve([])) } +/** + * Iterate over an array using the given mapper function to resolve a list of promises. + * + * @param {Array} input - The array to be mapped. + * @param {function:Promise} mapper - A function to be called on each array element. + * @param {number} [concurrency=1] - Limits the number of Promises created. + * @returns {Promise} + */ +export const promiseParallel = (input, mapper, concurrency = 1) => { + const results = Array.from({ length: input.length }) + let offset = 0 + + function dowork() { + return (offset >= input.length) ? + Promise.resolve() : + Promise.resolve(offset++) + .then(ix => mapper(input[ix]).then(result => { results[ix] = result })) + .then(() => dowork()) + } + + return Promise.all(Array.from({ length: concurrency }, dowork)) + .then(() => results) +} + /** * Splits a string into path segments, using slashes as separators. * @@ -25,28 +48,3 @@ export const getSegments = (relativePath) => { // leading or trailing slash (which we allow). return relativePath.split('/').filter(segment => segment.length > 0) } - -const map = (basePromise: Object, fn: Function, options: Object) => { - return basePromise.then((value) => { - return promiseSerial(value.map((value) => { - return () => { - return fn(value) - } - })) - }) -} - -/** - * Adds the method 'map' to the prototype of an object. - * - * @param {object} obj - The object to receive the 'map' method. - */ -export const addMapFunction = (obj: Object) => { - if (!isFunction(obj.map)) { - obj.prototype.map = function(fn: Function, options: Object) { - return map(this, fn, options) - } - } - - return obj -} diff --git a/package.json b/package.json index 83f7219..4399c78 100644 --- a/package.json +++ b/package.json @@ -16,7 +16,7 @@ "main": "./dist/index.js", "scripts": { "bin": "./bin/firestore-backup.js", - "test": "./bin/firestore-backup.js --accountCredentials $GOOGLE_APPLICATION_CREDENTIALS --backupPath ./backup --prettyPrint --requestCountLimit 20", + "test": "rm -rf ./backup && ./bin/firestore-backup.js --accountCredentials $GOOGLE_APPLICATION_CREDENTIALS --backupPath ./backup --prettyPrint --requestCountLimit 20", "pretest": "npm run build", "clean": "rm -rf dist && mkdir dist", "buildSource": "babel lib --out-dir dist", From 8927d2e81b3e0de13e26e74de01943ef7995c738 Mon Sep 17 00:00:00 2001 From: "jeremylorino@gmail.com" Date: Tue, 20 Mar 2018 05:51:23 +0000 Subject: [PATCH 17/17] code style fixes. removed unused-vars --- lib/firestore.js | 2 +- lib/utility.js | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/lib/firestore.js b/lib/firestore.js index 853bbc3..424b07c 100644 --- a/lib/firestore.js +++ b/lib/firestore.js @@ -13,7 +13,7 @@ import { isCollectionPath } from './types' import type { ValueDescription, Validator, BackupOptions } from './types' -import { promiseSerial, promiseParallel } from './utility' +import { promiseParallel } from './utility' import fs from 'fs' import mkdirp from 'mkdirp' diff --git a/lib/utility.js b/lib/utility.js index 6e5bbd6..7bee5f2 100644 --- a/lib/utility.js +++ b/lib/utility.js @@ -26,11 +26,11 @@ export const promiseParallel = (input, mapper, concurrency = 1) => { let offset = 0 function dowork() { - return (offset >= input.length) ? - Promise.resolve() : - Promise.resolve(offset++) - .then(ix => mapper(input[ix]).then(result => { results[ix] = result })) - .then(() => dowork()) + return (offset >= input.length) + ? Promise.resolve() + : Promise.resolve(offset++) + .then(ix => mapper(input[ix]).then(result => { results[ix] = result })) + .then(() => dowork()) } return Promise.all(Array.from({ length: concurrency }, dowork))