├── .gitignore ├── LICENSE ├── README.md ├── __mocks__ └── googleapis.js ├── bin └── gapps ├── index.js ├── lib ├── __mocks__ │ ├── defaults.js │ └── miniOAuthServer.js ├── authenticate.js ├── commands │ ├── auth.js │ ├── init.js │ ├── oauthCallbackUrl.js │ └── upload.js ├── defaults.js ├── manifestor.js ├── miniOAuthServer.js └── util.js ├── package-lock.json ├── package.json └── tests └── commands ├── __snapshots__ └── auth.test.js.snap └── auth.test.js /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_STORE 2 | node_modules 3 | *.log -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2015 danthareja, Google, Inc. 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | --- 2 | ### :warning::rotating_light: DEPRECATION NOTICE :rotating_light::warning: 3 | 4 | Google has released [clasp](https://github.com/google/clasp), please use it instead. 5 | 6 | As per the discussion in [issue #86](https://github.com/danthareja/node-google-apps-script/issues/86), it does not make sense for these two projects to co-exist. This project is locked into it's final version and will receive no future updates. 7 | 8 | Happy scripting! 9 | 10 | --- 11 | 12 | # gapps (Google Apps Script) 13 | >The easiest way to develop Google Apps Script projects 14 | 15 | Using **gapps**, you can develop your Apps Script locally and push files to the Apps Script servers. This allows you to use any editor of your choice, version control, and other modern webdev patterns in to Apps Script development. 16 | 17 | ## Requirements 18 | - [node >= 8](https://nodejs.org/download/) 19 | - `npm install -g node-google-apps-script` 20 | 21 | ## Quickstart 22 | 23 | ### 1. Get Google Drive Credentials 24 | To use gapps you need access to your files on your Google Drive through the API provided by Google. To make this happen you have to create a `Developer Console Project`. 25 | 26 | You can do this one of two ways: 27 | 28 | 1. Use the existing 'API Project' in the Developer Console 29 | 1. Create an independent Developer Console Project (choose this when the default project is not available) 30 | 31 | #### 1.1 Use the existing 'API Project' in the Developer Console 32 | This is the easiest approach because you don't need to create a new project. You will use the default Developer Console Project `API Project`, enable Google Drive and get credentials. 33 | 34 | 1. While working in the editor on [script.google.com](https://script.google.com) select `Resources > Cloud Platform Project...` otherwise, go to the [Google Cloud Platform](https://console.cloud.google.com) 35 | 1. Access the automatically created Google Apps Script Project `API Project`: click on the blue button at the top and select (`API Project - api-project-##########`) from the list. 36 | 1. Enable the Google Drive API 37 | 1. Click `APIs & services` in the left nav and then select `Library` 38 | 1. Search for `Drive` and select the Google Drive API listing. 39 | 1. Click `Enable API` 40 | 1. Acquire Google Drive Client Secret Credentials 41 | 1. If you just enabled the Drive API, hit `Create Credentials`, otherwise , go to `Credentials` in the left menu, select `Create credentials` and choose `OAuth client ID` 42 | 1. Select your email address from the dropdown OAuth consent screen and assign your add-on a `Project Name` i.e. `My API access project`. This can always be changed later. 43 | 1. In the menu that appears, choose `Other` for the `Application type`. 44 | 1. Give it any name you like (i.e. Macbook) and click `Create`. 45 | 1. Finally, download your credentials using the `Download as JSON` button to the right. Save these credentials to a location of your choosing; `~/Downloads` is fine. 46 | 1. You may close the Developer Console window. 47 | 48 | #### 1.2 Create an independent Developer Console Project 49 | Use an independent Developer Console Project if the default `API Project` is deleted, in use or if you want to keep permissions separated. 50 | 51 | 1. Create a new Dev Console Project 52 | 1. Use [this link](https://console.developers.google.com/start/api?id=drive&credential=client_key) to create the project. It will auto-activate the Google Drive API. If you have multiple Google Accounts, append `&authuser=1` to the end of the url to choose which account to login with. Note that `authuser` is zero-indexed. 53 | 1. Make sure `Create a New Project` is selected and hit `Continue`. 54 | 1. Once the project has been created, click `Go to Credentials`. 55 | 1. Acquire Google Drive Client Secret Credentials 56 | 1. Click client-ID in the grey paragraph 57 | 1. Select your email address from the dropdown OAuth consent screen and assign your add-on a `Project Name` i.e. `My API access project`. This can always be changed later. 58 | 1. In the menu that appears, choose `Other` for the `Application type`. 59 | 1. Give it any name you like (i.e. Macbook) and click `Create`. 60 | 1. Finally, download your credentials using the `Download as JSON` button to the right. Save these credentials to a location of your choosing; `~/Downloads` is fine. 61 | 1. You may close the Developer Console window. 62 | 63 | To return to this project later, select `Resources` > `Developer Console Project` while editing your script. Then click the link at the top of the dialog to open the Developer Console with this project selected. 64 | 65 | ### 2. Authenticate `gapps` 66 | 67 | This process will set up Google Drive authentication to allow uploading and importing of the Apps Script project. 68 | 69 | 1. Run `gapps auth path/to/client_secret_abcd.json` i.e. `gapps auth ~/Downloads/client_secret_1234567890-abcd.apps.googleusercontent.com.json` 70 | 1. Follow the directions by clicking on the link generated by the script. 71 | 1. After you're successfully authenticated, feel free to delete the `client_secret.json` credentials file. 72 | 73 | You can pass the option `--no-launch-browser` to generate a url that will give you a code to paste back into the console. This is useful if you're using ssh to develop. 74 | 75 | ### 3. Initialize your project 76 | 77 | This proces will create `gapps.config.json` and a sub-directory where all Apps Script project files will be downloaded to. You can either use an existing project or create a new one. 78 | 79 | #### 3.1 An existing Apps Script project 80 | 81 | 1. Navigate to your Apps Script project from Google Drive (must be a [standalone script](https://developers.google.com/apps-script/guides/standalone)) 82 | 1. Get your project ID from the address bar, located after `/d/` and before `/edit` i.e. '//script.google.com/a/google.com/d/__abc123-xyz098__/edit?usp=drive_web' 83 | 1. Navigate to a directory where your Apps Script project will live 84 | 1. Run `gapps init ` within your project directory i.e. `gapps init abc123-xyz098` 85 | 86 | #### 3.2 A new Apps Script project 87 | 88 | 1. Head to [https://script.google.com](https://script.google.com) and create a new blank project. 89 | 1. Save the mostly empty project and give it a name. Saving is important; the project is not in your Google Drive until it is saved. 90 | 1. Get your project ID from the address bar, located after `/d/` and before `/edit` i.e. '//script.google.com/a/google.com/d/__abc123-xyz098__/edit?usp=drive_web' 91 | 1. Navigate to a directory where your Apps Script project will live 92 | 1. Run `gapps init ` within your project directory i.e. example, `gapps init abc123-xyz098` 93 | 94 | 95 | ### 4. Develop locally 96 | 97 | Start scripting and enjoy total freedom of your local dev environment and source control options! Create script files with a `.gs` or `.js` extension and html files with a `.html` extension 98 | 99 | ### 5. Upload New Files 100 | 101 | Run `gapps upload` from within your project directory. You should then be able to reload your Apps Script project in the browser and see the changes. 102 | 103 | 104 | ## Best Practices 105 | 106 | Check out Matt Hessinger's blog post: [Advanced development process with apps](http://googledevelopers.blogspot.com/2015/12/advanced-development-process-with-apps.html) 107 | 108 | ## Docs 109 | 110 | ### gapps auth 111 | 112 | ``` 113 | Usage: gapps auth [options] 114 | 115 | Authorize gapps to use the Google Drive API 116 | 117 | Options: 118 | 119 | -b, --no-launch-browser Do not use a local webserver to capture oauth code 120 | and instead require copy/paste of key returned in 121 | the browser after authorization completes. 122 | -p, --port [port] Port to use for webserver 123 | ``` 124 | 125 | Performs the authentication flow described in the quickstart above. 126 | 127 | ### gapps init 128 | 129 | ``` 130 | Usage: gapps init|clone [options] 131 | 132 | Initialize project locally. The external Apps Script project must exist. 133 | 134 | Options: 135 | -k, --key [key] 136 | -s, --subdir [subdir] 137 | -o, --overwrite 138 | ``` 139 | 140 | Creates `gapps.config.json`, which contains information about your Apps Script project and downloads all project files into a subdirectory (default: `src/`) 141 | 142 | ### gapps upload 143 | 144 | ``` 145 | Usage: gapps upload|push 146 | 147 | Upload back to Google Drive. Run from root of project directory 148 | ``` 149 | 150 | Upload the project to Google Drive. Sources files from `./src` or the 151 | configured subdirectory. 152 | 153 | ### gapps oauth-callback-url 154 | 155 | ``` 156 | Usage: gapps deployment oauth-callback-url 157 | 158 | Get the OAuth Callback URL for a project 159 | ``` 160 | 161 | Returns the OAuth Callback URL required by most 3rd-party OAuth services. 162 | 163 | ## Development 164 | Please submit any bugs to the Issues page. Pull Requests also welcome. 165 | 166 | If you want to develop, clone down the repo and have at it! You can run `npm link` from the root directory of the repo to symlink to your local copy. You'll have to uninstall the production version first `npm uninstall -g node-google-apps-script`. 167 | 168 | ## Limitations 169 | 170 | `gapps` allows you to nest files in folders, but the Apps Script platform expects a flat file structure. Because of this, **no files can have the same name, even if they are in separate directories**. One file will overwrite the other, making debugging difficult. 171 | 172 | Your add-on must be developed as a [standalone script](https://developers.google.com/apps-script/guides/standalone) 173 | and tested within Doc or Sheet. This means that it cannot use certain functions of [bound scripts](https://developers.google.com/apps-script/guides/bound), namely installable triggers. While testing within a Doc, you have access to the 174 | "Special methods" mentioned in [the docs](https://developers.google.com/apps-script/guides/bound), though. If 175 | you followed the quickstart above, you should be set up correctly. 176 | 177 | ## Common Issues 178 | 179 | The Google Drive API frequently returns a *400* error without a helpful error message. Common causes for this are: 180 | 181 | - **javascript formatting errors** 182 | - The server-side javascript code (`.js` or `.gs`) is validated upon upload. 183 | - If there is a syntax error, the upload will fail. 184 | - The project does not exist yet. 185 | - Verify that the project exists in your Google Drive folder. 186 | - If you have been added to an existing project, verify that the owner has shared the file with you with the "can edit" permission. 187 | - Missing server-side libraries 188 | - verify that any required Libraries (frequently `Underscore` or `OAuth2`) have been added to the Apps Script project 189 | - Authentication error 190 | - Verify that `~/.gapps` exists and has 4 values: `client_id`, `client_secret`, `redirect_uri`, and `refresh_token` 191 | - To reset authentication, 'rm ~/.gapps' and then perform the authentication steps in part #2 of the quickstart again. 192 | 193 | ## Acknowledgements 194 | 195 | Huge thanks to [Shrugs](https://github.com/Shrugs) for a massive PR that bumped this project to v1.0 196 | 197 | ## Extra Resources 198 | 199 | - [Google Apps Script Documentation](https://developers.google.com/apps-script/) 200 | -------------------------------------------------------------------------------- /__mocks__/googleapis.js: -------------------------------------------------------------------------------- 1 | // Get the genuine googleapis library: 2 | const googleapis = require.requireActual('googleapis'); 3 | 4 | // Override the getToken with a mock (we don't want to hit Google's servers in our tests) 5 | googleapis.auth.OAuth2.prototype.getToken = (code, cb) => { 6 | console.log("googleapis.auth.OAuth2 getToken called with code " + code); 7 | cb(null, { 8 | refresh_token: "woot_successfully_obtained_refresh_token" 9 | }); 10 | }; 11 | 12 | module.exports = googleapis; 13 | -------------------------------------------------------------------------------- /bin/gapps: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | const _ = require('lodash'); 3 | const path = require('path'); 4 | const program = require('commander'); 5 | const pkg = require('../package.json'); 6 | 7 | const commands = path.join(__dirname, '../lib/commands'); 8 | 9 | program.version(pkg.version); 10 | 11 | program 12 | .command('auth ') 13 | // Multi-word options starting with --no negate the boolean value of the following word 14 | .option( 15 | '-b, --no-launch-browser', 16 | 'Do not use a local webserver to capture oauth code and instead require copy/paste' 17 | ) 18 | .option('-p, --port [port]', 'Port to use for webserver') 19 | .description('Authorize gapps to use the Google Drive API') 20 | .action((clientSecretPath, options) => { 21 | require(commands + '/auth')(clientSecretPath, options.launchBrowser).then( 22 | () => { 23 | process.exit(0); 24 | } 25 | ); 26 | }); 27 | 28 | program 29 | .command('upload') 30 | .description( 31 | 'Upload back to an Apps Script project in Google Drive. Run from root of project directory' 32 | ) 33 | .alias('push') 34 | .action(require(commands + '/upload')); 35 | 36 | program 37 | .command('init ') 38 | .option('-k, --key [key]') 39 | .option('-s, --subdir [subdir]') 40 | .option('-o, --overwrite') 41 | .description( 42 | 'Initialize project. The external Apps Script project must exist.' 43 | ) 44 | .alias('clone') 45 | .action(require(commands + '/init')); 46 | 47 | program 48 | .command('oauth-callback-url') 49 | .description('Get the OAuth Callback URL for a project') 50 | .action(require(commands + '/oauthCallbackUrl')); 51 | 52 | program.parse(process.argv); 53 | 54 | if (program.args.length < 1) { 55 | console.log('No command specified.'); 56 | program.outputHelp(); 57 | process.exit(2); 58 | } 59 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | module.exports.auth = require('./lib/commands/auth'); 2 | module.exports.init = require('./lib/commands/init'); 3 | module.exports.upload = require('./lib/commands/upload'); 4 | module.exports.defaults = require('./lib/defaults'); 5 | -------------------------------------------------------------------------------- /lib/__mocks__/defaults.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | DEFAULT_SUBDIR: 'src', 3 | STORAGE_FILE: '/tmp/.gapps-test', 4 | CONFIG_NAME: 'gapps-test.config.json', 5 | WEBSERVER_PORT: 2386, 6 | DOWNLOAD_URL: 'https://script.google.com/feeds/download/export?format=json&id=' 7 | }; -------------------------------------------------------------------------------- /lib/__mocks__/miniOAuthServer.js: -------------------------------------------------------------------------------- 1 | const url = require('url'); 2 | const http = require('http'); 3 | const Promise = require('bluebird'); 4 | 5 | module.exports = async function createOAuthServerMock(port) { 6 | console.log("createOAuthServerMock with port " + port); 7 | return Promise.resolve("oauth_code_acquired_through_authentication_flow"); 8 | }; 9 | -------------------------------------------------------------------------------- /lib/authenticate.js: -------------------------------------------------------------------------------- 1 | const colors = require('colors'); 2 | const OAuth2Client = require('googleapis').auth.OAuth2; 3 | 4 | const Promise = require('bluebird'); 5 | const fs = Promise.promisifyAll(require('fs'), { multiArgs: true }); 6 | 7 | const defaults = require('./defaults'); 8 | 9 | module.exports = function authenticate() { 10 | return getCredentials() 11 | .then(createAuthClient) 12 | .catch(err => { 13 | console.log('Error in authenticate module', err); 14 | }); 15 | }; 16 | 17 | function getCredentials() { 18 | return fs 19 | .readFileAsync(defaults.STORAGE_FILE) 20 | .then(JSON.parse) 21 | .catch(SyntaxError, e => { 22 | console.log('Could not parse credentials'.red); 23 | }) 24 | .error(e => { 25 | console.log( 26 | 'Could not read path to credentials file. Please check your path and try again' 27 | .red 28 | ); 29 | throw err; 30 | }); 31 | } 32 | 33 | function createAuthClient(credentials) { 34 | const auth = new OAuth2Client( 35 | credentials.client_id, 36 | credentials.client_secret, 37 | credentials.redirect_uri 38 | ); 39 | 40 | // refreshAccessToken requires refresh_token to be set 41 | auth.credentials.refresh_token = credentials.refresh_token; 42 | return new Promise((resolve, reject) => { 43 | auth.refreshAccessToken((err, tokens) => { 44 | if (err) return reject(err); 45 | auth.setCredentials(tokens); 46 | resolve(auth); 47 | }); 48 | }); 49 | } 50 | -------------------------------------------------------------------------------- /lib/commands/auth.js: -------------------------------------------------------------------------------- 1 | const colors = require('colors'); 2 | const readline = require('readline'); 3 | const OAuth2Client = require('googleapis').auth.OAuth2; 4 | 5 | const Promise = require('bluebird'); 6 | const fs = Promise.promisifyAll(require('fs'), { multiArgs: true }); 7 | 8 | const defaults = require('../defaults'); 9 | 10 | const GOOGLE_AUTH_SCOPE = [ 11 | 'https://www.googleapis.com/auth/drive', 12 | 'https://www.googleapis.com/auth/drive.scripts' 13 | ]; 14 | 15 | /** 16 | * Tries to find the storage file. If found, tells the users to remove it, otherwiser runs the 17 | * authentication flow using the provided path the to the clientSecret path 18 | * @param {String} clientSecretPath 19 | * @param {Boolean} withWebServer 20 | * @returns {Promise} 21 | */ 22 | module.exports = function auth(clientSecretPath, withWebServer = true) { 23 | return fs 24 | .lstatAsync(defaults.STORAGE_FILE) 25 | .then(() => { 26 | console.log( 27 | defaults.STORAGE_FILE + 28 | ' already exists. Remove it to re-authenticate node-google-apps-script' 29 | ); 30 | return Promise.resolve(); 31 | }) 32 | .catch(err => { 33 | if (!clientSecretPath) { 34 | throw defaults.STORAGE_FILE + 35 | ' does not exist yet. Specify a credential file with `--auth ~/Downloads/client_secret_abcd.json`'; 36 | } 37 | return performAuthenticationFlow(clientSecretPath, withWebServer); 38 | }); 39 | }; 40 | 41 | /** 42 | * Performs the authentication flow by reading the .json file 43 | * and using it's content to authenticate with Google. When 44 | * done, clean ups the stdin. 45 | * @param {String} clientSecretPath 46 | * @param {Boolean} withWebServer 47 | * @return {Promise} 48 | */ 49 | function performAuthenticationFlow(clientSecretPath, withWebServer) { 50 | return getCredentialsFromFile(clientSecretPath) 51 | .then(credentials => authenticateWithGoogle(credentials, withWebServer)) 52 | .then(saveAuthenticationConfig) 53 | .then(cleanUp) 54 | .then(() => { 55 | console.log('Successfully Authenticated with Google Drive!'.green); 56 | }) 57 | .catch(err => { 58 | console.log('Error running auth command'.underline.red); 59 | console.log(err.red); 60 | throw err; 61 | }); 62 | } 63 | 64 | /** 65 | * The parsed credentials 66 | * @typedef {Object} Credentials 67 | * @property {String} client_id 68 | * @property {String} client_secret 69 | * @property {String} redirect_uri 70 | * @property {String} [refresh_token] 71 | */ 72 | /** 73 | * Reads the content of the credentials file and returns a object 74 | * with the important fields 75 | * @param {String} clientSecretPath 76 | * @returns {Promise} 77 | */ 78 | function getCredentialsFromFile(clientSecretPath) { 79 | return fs 80 | .readFileAsync(clientSecretPath) 81 | .then(JSON.parse) 82 | .then(credentials => { 83 | if (!credentials.installed) { 84 | throw 'Path did not include "OAuth 2.0 client ID" credentials. Please check that you downloaded the right JSON credentials.'; 85 | } 86 | 87 | // Add important auth information to persist 88 | // return credentials 89 | return { 90 | client_id: credentials.installed.client_id, 91 | client_secret: credentials.installed.client_secret, 92 | redirect_uri: credentials.installed.redirect_uris[0] 93 | }; 94 | }) 95 | .catch(SyntaxError, err => { 96 | console.log('Invalid file contents'.red); 97 | }) 98 | .error(err => { 99 | console.log('Unable to read file'.red); 100 | throw err; 101 | }); 102 | } 103 | 104 | /** 105 | * Authenticate with Google using the parsed credentials. 106 | * Uses the OAuth2Client to generate the AuthUrl 107 | * @param {Credentials} credentials 108 | * @param {Boolean} withWebServer 109 | * @returns {Promise} 110 | */ 111 | function authenticateWithGoogle(credentials, withWebServer) { 112 | return new Promise((resolve, reject) => { 113 | let redirect_uri = credentials.redirect_uri; 114 | if (withWebServer) { 115 | redirect_uri = 'http://localhost:' + defaults.WEBSERVER_PORT; 116 | } 117 | 118 | const oauth2Client = new OAuth2Client( 119 | credentials.client_id, 120 | credentials.client_secret, 121 | redirect_uri 122 | ); 123 | const url = oauth2Client.generateAuthUrl({ 124 | access_type: 'offline', // Required to receive a refresh token 125 | approval_prompt: 'force', 126 | scope: GOOGLE_AUTH_SCOPE 127 | }); 128 | 129 | const getToken = code => { 130 | oauth2Client.getToken(code, (err, tokens) => { 131 | if (err) { 132 | reject(err); 133 | return; 134 | } 135 | credentials.refresh_token = tokens.refresh_token; 136 | resolve(credentials); 137 | }); 138 | }; 139 | 140 | console.log( 141 | "\nPlease visit the following url in your browser (you'll only have to do this once):" 142 | .cyan, 143 | url.green 144 | ); 145 | 146 | if (withWebServer) { 147 | require('../miniOAuthServer')(defaults.WEBSERVER_PORT) 148 | .then(getToken) 149 | .catch(err => { 150 | console.log('Something went wrong with the webserver'.red); 151 | throw err; 152 | }); 153 | } else { 154 | const rl = readline.createInterface({ 155 | input: process.stdin, 156 | output: process.stdout 157 | }); 158 | 159 | rl.question('Copy the provided code and paste it here: ', code => { 160 | rl.close(); 161 | 162 | getToken(code); 163 | }); 164 | } 165 | }); 166 | } 167 | 168 | /** 169 | * Write the contents to disk 170 | * @param {Credentials} credentials 171 | */ 172 | function saveAuthenticationConfig(credentials) { 173 | return fs.writeFileAsync( 174 | defaults.STORAGE_FILE, 175 | JSON.stringify(credentials, '', 2) 176 | ); 177 | } 178 | 179 | /** 180 | * Destroys the stdin 181 | * @todo put inline if only used here 182 | */ 183 | function cleanUp() { 184 | process.stdin.destroy(); 185 | } 186 | -------------------------------------------------------------------------------- /lib/commands/init.js: -------------------------------------------------------------------------------- 1 | const colors = require('colors'); 2 | const mkdirp = require('mkdirp'); 3 | 4 | const Promise = require('bluebird'); 5 | const fs = Promise.promisifyAll(require('fs'), { multiArgs: true }); 6 | 7 | const util = require('../util'); 8 | const defaults = require('../defaults'); 9 | const manifestor = require('../manifestor'); 10 | 11 | module.exports = function init(fileId, options) { 12 | const subdir = options.subdir || defaults.DEFAULT_SUBDIR; 13 | 14 | if (!fileIdIsValid(fileId)) { 15 | return; 16 | } 17 | 18 | const config = { 19 | path: subdir, 20 | fileId: fileId, 21 | key: options.key, 22 | }; 23 | 24 | const overwritePromise = options.overwrite 25 | ? Promise.resolve() 26 | : manifestor.throwIfConfig(); 27 | 28 | return overwritePromise 29 | .then(() => manifestor.set(config)) 30 | .then(() => mkdirp(subdir)) 31 | .then(config => manifestor.getExternalFiles(fileId)) 32 | .map(file => writeExternalFile(file, subdir)) 33 | .catch(err => { 34 | console.log('Error running init command'.red); 35 | throw err; 36 | }); 37 | }; 38 | 39 | function writeExternalFile(file, dir) { 40 | const filename = file.name + util.getFileExtension(file); 41 | return fs.writeFileAsync(dir + '/' + filename, file.source).catch(err => { 42 | console.log('Could not write file ' + filename); 43 | throw err; 44 | }); 45 | } 46 | 47 | function fileIdIsValid(fileId) { 48 | if (fileId.charAt(0).toLowerCase() === 'm') { 49 | console.log( 50 | '\nScript file ID error.'.red + 51 | '\n' + 52 | 'It looks like you are passing in a Project Key, from "File --> Project properties",' + 53 | "rather than a Drive File ID.\nYou will find the Drive File ID in the script's URL:\n" + 54 | 'https://script.google.com/a/google.com/d/' + 55 | '__DRIVE_FILE_ID__'.green + 56 | '/edit.\n' 57 | ); 58 | return false; 59 | } else { 60 | return true; 61 | } 62 | } 63 | -------------------------------------------------------------------------------- /lib/commands/oauthCallbackUrl.js: -------------------------------------------------------------------------------- 1 | const defaults = require('../defaults'); 2 | const manifestor = require('../manifestor'); 3 | 4 | module.exports = function() { 5 | return manifestor.get().then(config => { 6 | if (config.key) { 7 | console.log( 8 | 'https://script.google.com/macros/d/' + config.key + '/usercallback' 9 | ); 10 | } else { 11 | console.log('No Project Key provided in ' + defaults.CONFIG_NAME); 12 | } 13 | }); 14 | }; 15 | -------------------------------------------------------------------------------- /lib/commands/upload.js: -------------------------------------------------------------------------------- 1 | const _ = require('lodash'); 2 | const colors = require('colors'); 3 | const google = require('googleapis'); 4 | const Promise = require('bluebird'); 5 | 6 | const defaults = require('../defaults'); 7 | const manifestor = require('../manifestor'); 8 | const authenticate = require('../authenticate'); 9 | 10 | module.exports = function upload() { 11 | console.log('Pushing back up to Google Drive...'); 12 | 13 | let fileId; // Hold in closure to avoid promise nesting 14 | 15 | return manifestor 16 | .get() 17 | .then(config => { 18 | fileId = config.fileId; 19 | return manifestor.getExternalFiles(fileId); 20 | }) 21 | .then(externalFiles => manifestor.build(externalFiles)) 22 | .then(files => sendToGoogle(files, fileId)) 23 | .then(() => { 24 | console.log( 25 | 'The latest files were successfully uploaded to your Apps Script project.' 26 | .green 27 | ); 28 | }) 29 | .catch(err => { 30 | console.log('Upload failed.'.red); 31 | }); 32 | }; 33 | 34 | function sendToGoogle(files, id) { 35 | if (!files.length) { 36 | console.log('No Files to upload.'.red); 37 | throw 'manifest file length is 0'; 38 | } 39 | 40 | return authenticate().then(auth => { 41 | const drive = google.drive({ version: 'v2', auth: auth }); 42 | const options = { 43 | fileId: id, 44 | media: { 45 | mimeType: 'application/vnd.google-apps.script+json', 46 | body: JSON.stringify({ files: files }), 47 | }, 48 | }; 49 | 50 | return Promise.promisify(drive.files.update)(options).catch(err => { 51 | console.log( 52 | 'An error occured while running upload command: '.red + err.message 53 | ); 54 | throw err; 55 | }); 56 | }); 57 | } 58 | -------------------------------------------------------------------------------- /lib/defaults.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | DEFAULT_SUBDIR: 'src', 3 | STORAGE_FILE: getUserHome() + '/.gapps', 4 | CONFIG_NAME: 'gapps.config.json', 5 | WEBSERVER_PORT: 2386, 6 | DOWNLOAD_URL: 7 | 'https://script.google.com/feeds/download/export?format=json&id=', 8 | }; 9 | 10 | function getUserHome() { 11 | return process.env[process.platform == 'win32' ? 'USERPROFILE' : 'HOME']; 12 | } 13 | -------------------------------------------------------------------------------- /lib/manifestor.js: -------------------------------------------------------------------------------- 1 | const _ = require('lodash'); 2 | const path = require('path'); 3 | const colors = require('colors'); 4 | 5 | const Promise = require('bluebird'); 6 | const fs = Promise.promisifyAll(require('fs')); 7 | const request = Promise.promisifyAll(require('request'), { multiArgs: true }); 8 | 9 | const util = require('./util'); 10 | const defaults = require('./defaults'); 11 | const authenticate = require('./authenticate'); 12 | 13 | /** 14 | build generates a manifest to be uploaded to google drive 15 | @param externalFiles {Object} files in the cloud 16 | @return {Object} manifest 17 | */ 18 | const build = function(externalFiles) { 19 | return getConfig() 20 | .get('path') 21 | .then(util.getFilesFromDisk) 22 | .then(files => { 23 | // for each manifest file, if it has an equivalent on disk, keep it 24 | // otherwise trash it 25 | const filesToUpload = _.filter(externalFiles, externalFile => 26 | util.hasFileOnDisk(files, externalFile) 27 | ); 28 | 29 | _.each(files, file => { 30 | // Add new file or update existing record 31 | const manifestFile = getFileInManifest(filesToUpload, file); 32 | if (manifestFile === undefined) { 33 | // add 34 | filesToUpload.push({ 35 | name: file.name, 36 | type: util.getFileType(file), 37 | source: file.content, 38 | }); 39 | } else { 40 | // update 41 | util.updateFileSource(manifestFile, file); 42 | } 43 | }); 44 | 45 | return filesToUpload; 46 | }); 47 | }; 48 | 49 | function getFileInManifest(files, file) { 50 | return _.find(files, { 51 | name: file.name, 52 | type: util.getFileType(file), 53 | }); 54 | } 55 | 56 | function getExternalFiles(fileId) { 57 | return authenticate() 58 | .then(auth => getProjectFiles(fileId, auth)) 59 | .catch(err => { 60 | console.log( 61 | 'Script file ID not found. Please input an ID and try again.'.red 62 | ); 63 | throw err; 64 | }); 65 | } 66 | 67 | function getProjectFiles(fileId, auth) { 68 | const options = { 69 | url: defaults.DOWNLOAD_URL + fileId, 70 | qs: { 71 | access_token: auth.credentials.access_token, 72 | }, 73 | }; 74 | 75 | return request 76 | .getAsync(options) 77 | .spread((res, body) => JSON.parse(body)) 78 | .then(project => { 79 | if (!project.files) { 80 | throw 'Looks like there are no files associated with this project. Check the id and try again.'; 81 | } 82 | return project.files; 83 | }) 84 | .catch(SyntaxError, err => { 85 | console.log('Error parsing project files'.red); 86 | throw err; 87 | }) 88 | .error(err => { 89 | throw err; 90 | }); 91 | } 92 | 93 | function throwIfConfig() { 94 | return fs 95 | .readFileAsync(defaults.CONFIG_NAME) 96 | .then(JSON.parse) 97 | .then(() => { 98 | throw 'Config already exists. Cowardly refusing to overwrite.'; 99 | }) 100 | .error(() => { 101 | // swallow error 102 | }); 103 | } 104 | 105 | function getConfig() { 106 | return fs 107 | .readFileAsync(defaults.CONFIG_NAME) 108 | .then(JSON.parse) 109 | .catch(SyntaxError, err => { 110 | console.log('Error parsing config'.red); 111 | throw err; 112 | }) 113 | .error(err => { 114 | console.log('Config does not exist'.red); 115 | throw err; 116 | }); 117 | } 118 | 119 | function setConfig(config) { 120 | return fs 121 | .writeFileAsync(defaults.CONFIG_NAME, JSON.stringify(config, '', 2)) 122 | .then(() => config); 123 | } 124 | 125 | module.exports.build = build; 126 | module.exports.get = getConfig; 127 | module.exports.set = setConfig; 128 | module.exports.getExternalFiles = getExternalFiles; 129 | module.exports.throwIfConfig = throwIfConfig; 130 | -------------------------------------------------------------------------------- /lib/miniOAuthServer.js: -------------------------------------------------------------------------------- 1 | const url = require('url'); 2 | const http = require('http'); 3 | const Promise = require('bluebird'); 4 | 5 | const AUTH_PAGE = ` 6 | 7 | 8 | 9 | Successfully Authenticated 10 | 11 | 12 | You've been authenticated with Google Drive! You may close this page. 13 | 14 | 15 | `; 16 | 17 | module.exports = function createOAuthServer(port) { 18 | return new Promise((resolve, reject) => { 19 | const server = http.createServer((req, res) => { 20 | const { query } = url.parse(req.url, true); 21 | 22 | if (!query.code) { 23 | return reject('No code in request; did you access this url manually?'); 24 | } 25 | 26 | res.writeHead(200, { 'Content-Type': 'text/html' }); 27 | res.end(AUTH_PAGE); 28 | server.close(); 29 | 30 | return resolve(query.code); 31 | }); 32 | 33 | server.listen(port); 34 | }); 35 | }; 36 | -------------------------------------------------------------------------------- /lib/util.js: -------------------------------------------------------------------------------- 1 | const _ = require('lodash'); 2 | const dir = require('node-dir'); 3 | const path = require('path'); 4 | const Promise = require('bluebird'); 5 | 6 | function getFilesFromDisk(subdir) { 7 | return ( 8 | new Promise((resolve, reject) => { 9 | const filesOnDisk = []; 10 | 11 | // Only iterate through supported .js, .gs and .html files in dir 12 | dir.readFiles( 13 | subdir, 14 | { match: /\.js$|\.gs$|\.html$|^appsscript\.json$/ }, 15 | // Invoke this callback on each file 16 | (err, content, filename, next) => { 17 | if (err) return reject(err); 18 | 19 | // Parse file's absolute path and add its content to result object 20 | file = path.parse(filename); 21 | file.content = content; 22 | 23 | filesOnDisk.push(file); 24 | 25 | // Continue to next file 26 | next(); 27 | }, 28 | // finished callback. 29 | err => { 30 | if (err) return reject(err); 31 | resolve(filesOnDisk); 32 | } 33 | ); 34 | }) 35 | // swallow ENOENT 36 | .error(() => []) 37 | ); 38 | } 39 | 40 | function updateFileSource(existingFile, newFile) { 41 | existingFile.source = newFile.content; 42 | } 43 | 44 | function hasFileOnDisk(filesOnDisk, file) { 45 | return _.some(filesOnDisk, fileOnDisk => { 46 | const sameName = file.name === fileOnDisk.name; 47 | const sameType = file.type === getFileType(fileOnDisk); 48 | return sameName && sameType; 49 | }); 50 | } 51 | 52 | function getFileType(file) { 53 | if (file.ext === '.js') return 'server_js'; 54 | if (file.ext === '.gs') return 'server_js'; 55 | if (file.ext === '.html') return 'html'; 56 | if (file.ext === '.json') return 'json'; 57 | throw new Error( 58 | 'Unsupported file type found. Google Apps Script only allows appscript.json, .js, and .html' 59 | ); 60 | } 61 | 62 | function getFileExtension(file) { 63 | if (file.type === 'server_js') return '.js'; 64 | if (file.type === 'html') return '.html'; 65 | if (file.type === 'json') return '.json'; 66 | throw new Error('Unsupported file type found'); 67 | } 68 | 69 | module.exports.getFilesFromDisk = getFilesFromDisk; 70 | module.exports.updateFileSource = updateFileSource; 71 | module.exports.hasFileOnDisk = hasFileOnDisk; 72 | module.exports.getFileType = getFileType; 73 | module.exports.getFileExtension = getFileExtension; 74 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "node-google-apps-script", 3 | "version": "1.3.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.0.0-beta.36", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0-beta.36.tgz", 10 | "integrity": "sha512-sW77BFwJ48YvQp3Gzz5xtAUiXuYOL2aMJKDwiaY3OcvdqBFurtYfOpSa4QrNyDxmOGRFSYzUpabU2m9QrlWE7w==", 11 | "dev": true, 12 | "requires": { 13 | "chalk": "2.3.0", 14 | "esutils": "2.0.2", 15 | "js-tokens": "3.0.2" 16 | } 17 | }, 18 | "@types/jest": { 19 | "version": "22.0.0", 20 | "resolved": "https://registry.npmjs.org/@types/jest/-/jest-22.0.0.tgz", 21 | "integrity": "sha512-YnvduQPdRtIfvBLqfs6am0iz/07sqd/VYyPoqLzyZAYGyjokJDiE+LCgqX13ef8PNOWG5+Opbcy9gn5ymSIHCg==", 22 | "dev": true 23 | }, 24 | "@types/node": { 25 | "version": "8.5.2", 26 | "resolved": "https://registry.npmjs.org/@types/node/-/node-8.5.2.tgz", 27 | "integrity": "sha512-KA4GKOpgXnrqEH2eCVhiv2CsxgXGQJgV1X0vsGlh+WCnxbeAE1GT44ZsTU1IN5dEeV/gDupKa7gWo08V5IxWVQ==", 28 | "dev": true 29 | }, 30 | "abab": { 31 | "version": "1.0.4", 32 | "resolved": "https://registry.npmjs.org/abab/-/abab-1.0.4.tgz", 33 | "integrity": "sha1-X6rZwsB/YN12dw9xzwJbYqY8/U4=", 34 | "dev": true 35 | }, 36 | "acorn": { 37 | "version": "5.3.0", 38 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.3.0.tgz", 39 | "integrity": "sha512-Yej+zOJ1Dm/IMZzzj78OntP/r3zHEaKcyNoU2lAaxPtrseM6rF0xwqoz5Q5ysAiED9hTjI2hgtvLXitlCN1/Ug==", 40 | "dev": true 41 | }, 42 | "acorn-globals": { 43 | "version": "4.1.0", 44 | "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-4.1.0.tgz", 45 | "integrity": "sha512-KjZwU26uG3u6eZcfGbTULzFcsoz6pegNKtHPksZPOUsiKo5bUmiBPa38FuHZ/Eun+XYh/JCCkS9AS3Lu4McQOQ==", 46 | "dev": true, 47 | "requires": { 48 | "acorn": "5.3.0" 49 | } 50 | }, 51 | "ajv": { 52 | "version": "5.5.1", 53 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.1.tgz", 54 | "integrity": "sha1-s4u4h22ehr7plJVqBOch6IskjrI=", 55 | "requires": { 56 | "co": "4.6.0", 57 | "fast-deep-equal": "1.0.0", 58 | "fast-json-stable-stringify": "2.0.0", 59 | "json-schema-traverse": "0.3.1" 60 | } 61 | }, 62 | "align-text": { 63 | "version": "0.1.4", 64 | "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", 65 | "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", 66 | "dev": true, 67 | "requires": { 68 | "kind-of": "3.2.2", 69 | "longest": "1.0.1", 70 | "repeat-string": "1.6.1" 71 | } 72 | }, 73 | "amdefine": { 74 | "version": "1.0.1", 75 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 76 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", 77 | "dev": true 78 | }, 79 | "ansi-escapes": { 80 | "version": "3.0.0", 81 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.0.0.tgz", 82 | "integrity": "sha512-O/klc27mWNUigtv0F8NJWbLF00OcegQalkqKURWdosW08YZKi4m6CnSUSvIZG1otNJbTWhN01Hhz389DW7mvDQ==", 83 | "dev": true 84 | }, 85 | "ansi-regex": { 86 | "version": "2.1.1", 87 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 88 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 89 | "dev": true 90 | }, 91 | "ansi-styles": { 92 | "version": "3.2.0", 93 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 94 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 95 | "dev": true, 96 | "requires": { 97 | "color-convert": "1.9.1" 98 | } 99 | }, 100 | "anymatch": { 101 | "version": "1.3.2", 102 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", 103 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", 104 | "dev": true, 105 | "requires": { 106 | "micromatch": "2.3.11", 107 | "normalize-path": "2.1.1" 108 | } 109 | }, 110 | "append-transform": { 111 | "version": "0.4.0", 112 | "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-0.4.0.tgz", 113 | "integrity": "sha1-126/jKlNJ24keja61EpLdKthGZE=", 114 | "dev": true, 115 | "requires": { 116 | "default-require-extensions": "1.0.0" 117 | } 118 | }, 119 | "argparse": { 120 | "version": "1.0.9", 121 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", 122 | "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", 123 | "dev": true, 124 | "requires": { 125 | "sprintf-js": "1.0.3" 126 | } 127 | }, 128 | "arr-diff": { 129 | "version": "2.0.0", 130 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 131 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 132 | "dev": true, 133 | "requires": { 134 | "arr-flatten": "1.1.0" 135 | } 136 | }, 137 | "arr-flatten": { 138 | "version": "1.1.0", 139 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 140 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 141 | "dev": true 142 | }, 143 | "array-equal": { 144 | "version": "1.0.0", 145 | "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", 146 | "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=", 147 | "dev": true 148 | }, 149 | "array-unique": { 150 | "version": "0.2.1", 151 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 152 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 153 | "dev": true 154 | }, 155 | "arrify": { 156 | "version": "1.0.1", 157 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 158 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 159 | "dev": true 160 | }, 161 | "asn1": { 162 | "version": "0.2.3", 163 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", 164 | "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=" 165 | }, 166 | "assert-plus": { 167 | "version": "1.0.0", 168 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 169 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 170 | }, 171 | "astral-regex": { 172 | "version": "1.0.0", 173 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 174 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 175 | "dev": true 176 | }, 177 | "async": { 178 | "version": "2.3.0", 179 | "resolved": "https://registry.npmjs.org/async/-/async-2.3.0.tgz", 180 | "integrity": "sha1-EBPRBRBH3TIP4k5JTVxm7K9hR9k=", 181 | "requires": { 182 | "lodash": "4.17.4" 183 | } 184 | }, 185 | "asynckit": { 186 | "version": "0.4.0", 187 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 188 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 189 | }, 190 | "aws-sign2": { 191 | "version": "0.7.0", 192 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 193 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 194 | }, 195 | "aws4": { 196 | "version": "1.6.0", 197 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", 198 | "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" 199 | }, 200 | "babel-code-frame": { 201 | "version": "6.26.0", 202 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 203 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 204 | "dev": true, 205 | "requires": { 206 | "chalk": "1.1.3", 207 | "esutils": "2.0.2", 208 | "js-tokens": "3.0.2" 209 | }, 210 | "dependencies": { 211 | "ansi-styles": { 212 | "version": "2.2.1", 213 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 214 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 215 | "dev": true 216 | }, 217 | "chalk": { 218 | "version": "1.1.3", 219 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 220 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 221 | "dev": true, 222 | "requires": { 223 | "ansi-styles": "2.2.1", 224 | "escape-string-regexp": "1.0.5", 225 | "has-ansi": "2.0.0", 226 | "strip-ansi": "3.0.1", 227 | "supports-color": "2.0.0" 228 | } 229 | }, 230 | "strip-ansi": { 231 | "version": "3.0.1", 232 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 233 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 234 | "dev": true, 235 | "requires": { 236 | "ansi-regex": "2.1.1" 237 | } 238 | }, 239 | "supports-color": { 240 | "version": "2.0.0", 241 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 242 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 243 | "dev": true 244 | } 245 | } 246 | }, 247 | "babel-core": { 248 | "version": "6.26.0", 249 | "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.0.tgz", 250 | "integrity": "sha1-rzL3izGm/O8RnIew/Y2XU/A6C7g=", 251 | "dev": true, 252 | "requires": { 253 | "babel-code-frame": "6.26.0", 254 | "babel-generator": "6.26.0", 255 | "babel-helpers": "6.24.1", 256 | "babel-messages": "6.23.0", 257 | "babel-register": "6.26.0", 258 | "babel-runtime": "6.26.0", 259 | "babel-template": "6.26.0", 260 | "babel-traverse": "6.26.0", 261 | "babel-types": "6.26.0", 262 | "babylon": "6.18.0", 263 | "convert-source-map": "1.5.1", 264 | "debug": "2.6.9", 265 | "json5": "0.5.1", 266 | "lodash": "4.17.4", 267 | "minimatch": "3.0.4", 268 | "path-is-absolute": "1.0.1", 269 | "private": "0.1.8", 270 | "slash": "1.0.0", 271 | "source-map": "0.5.7" 272 | } 273 | }, 274 | "babel-generator": { 275 | "version": "6.26.0", 276 | "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.0.tgz", 277 | "integrity": "sha1-rBriAHC3n248odMmlhMFN3TyDcU=", 278 | "dev": true, 279 | "requires": { 280 | "babel-messages": "6.23.0", 281 | "babel-runtime": "6.26.0", 282 | "babel-types": "6.26.0", 283 | "detect-indent": "4.0.0", 284 | "jsesc": "1.3.0", 285 | "lodash": "4.17.4", 286 | "source-map": "0.5.7", 287 | "trim-right": "1.0.1" 288 | } 289 | }, 290 | "babel-helpers": { 291 | "version": "6.24.1", 292 | "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", 293 | "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", 294 | "dev": true, 295 | "requires": { 296 | "babel-runtime": "6.26.0", 297 | "babel-template": "6.26.0" 298 | } 299 | }, 300 | "babel-jest": { 301 | "version": "22.0.4", 302 | "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-22.0.4.tgz", 303 | "integrity": "sha512-/Yt61fUpdFjetYlnpj280BPKEsPnK4mqzxDdo8DybPvrPNrLurbAF/WBjn2nnoi1Hc2Ippsf12/aOp8ys/Vl1A==", 304 | "dev": true, 305 | "requires": { 306 | "babel-plugin-istanbul": "4.1.5", 307 | "babel-preset-jest": "22.0.3" 308 | } 309 | }, 310 | "babel-messages": { 311 | "version": "6.23.0", 312 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", 313 | "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", 314 | "dev": true, 315 | "requires": { 316 | "babel-runtime": "6.26.0" 317 | } 318 | }, 319 | "babel-plugin-istanbul": { 320 | "version": "4.1.5", 321 | "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-4.1.5.tgz", 322 | "integrity": "sha1-Z2DN2Xf0EdPhdbsGTyvDJ9mbK24=", 323 | "dev": true, 324 | "requires": { 325 | "find-up": "2.1.0", 326 | "istanbul-lib-instrument": "1.9.1", 327 | "test-exclude": "4.1.1" 328 | } 329 | }, 330 | "babel-plugin-jest-hoist": { 331 | "version": "22.0.3", 332 | "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-22.0.3.tgz", 333 | "integrity": "sha512-Z0pOZFs0xDctwF0bPEKrnAzvbbgDi2vDFbQ0EdofnLI2bOa3P1H66gNLb2vMJJaa00VDjfiGhIocsHvBkqtyEQ==", 334 | "dev": true 335 | }, 336 | "babel-plugin-syntax-object-rest-spread": { 337 | "version": "6.13.0", 338 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", 339 | "integrity": "sha1-/WU28rzhODb/o6VFjEkDpZe7O/U=", 340 | "dev": true 341 | }, 342 | "babel-preset-jest": { 343 | "version": "22.0.3", 344 | "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-22.0.3.tgz", 345 | "integrity": "sha512-FbMMniSMXFvkKldCf+e4Tuol/v3XMaIpIp8xiT1WFlEW3ZapTKDW9YgVt3hqcpZXsIGFf6eUF3Owxom7yFlI8w==", 346 | "dev": true, 347 | "requires": { 348 | "babel-plugin-jest-hoist": "22.0.3", 349 | "babel-plugin-syntax-object-rest-spread": "6.13.0" 350 | } 351 | }, 352 | "babel-register": { 353 | "version": "6.26.0", 354 | "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz", 355 | "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=", 356 | "dev": true, 357 | "requires": { 358 | "babel-core": "6.26.0", 359 | "babel-runtime": "6.26.0", 360 | "core-js": "2.5.3", 361 | "home-or-tmp": "2.0.0", 362 | "lodash": "4.17.4", 363 | "mkdirp": "0.5.1", 364 | "source-map-support": "0.4.18" 365 | }, 366 | "dependencies": { 367 | "source-map-support": { 368 | "version": "0.4.18", 369 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", 370 | "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", 371 | "dev": true, 372 | "requires": { 373 | "source-map": "0.5.7" 374 | } 375 | } 376 | } 377 | }, 378 | "babel-runtime": { 379 | "version": "6.26.0", 380 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 381 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 382 | "dev": true, 383 | "requires": { 384 | "core-js": "2.5.3", 385 | "regenerator-runtime": "0.11.1" 386 | } 387 | }, 388 | "babel-template": { 389 | "version": "6.26.0", 390 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz", 391 | "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=", 392 | "dev": true, 393 | "requires": { 394 | "babel-runtime": "6.26.0", 395 | "babel-traverse": "6.26.0", 396 | "babel-types": "6.26.0", 397 | "babylon": "6.18.0", 398 | "lodash": "4.17.4" 399 | } 400 | }, 401 | "babel-traverse": { 402 | "version": "6.26.0", 403 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz", 404 | "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=", 405 | "dev": true, 406 | "requires": { 407 | "babel-code-frame": "6.26.0", 408 | "babel-messages": "6.23.0", 409 | "babel-runtime": "6.26.0", 410 | "babel-types": "6.26.0", 411 | "babylon": "6.18.0", 412 | "debug": "2.6.9", 413 | "globals": "9.18.0", 414 | "invariant": "2.2.2", 415 | "lodash": "4.17.4" 416 | } 417 | }, 418 | "babel-types": { 419 | "version": "6.26.0", 420 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", 421 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", 422 | "dev": true, 423 | "requires": { 424 | "babel-runtime": "6.26.0", 425 | "esutils": "2.0.2", 426 | "lodash": "4.17.4", 427 | "to-fast-properties": "1.0.3" 428 | } 429 | }, 430 | "babylon": { 431 | "version": "6.18.0", 432 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", 433 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==", 434 | "dev": true 435 | }, 436 | "balanced-match": { 437 | "version": "1.0.0", 438 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 439 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 440 | }, 441 | "base64url": { 442 | "version": "2.0.0", 443 | "resolved": "https://registry.npmjs.org/base64url/-/base64url-2.0.0.tgz", 444 | "integrity": "sha1-6sFuA+oUOO/5Qj1puqNiYu0fcLs=" 445 | }, 446 | "bcrypt-pbkdf": { 447 | "version": "1.0.1", 448 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", 449 | "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", 450 | "optional": true, 451 | "requires": { 452 | "tweetnacl": "0.14.5" 453 | } 454 | }, 455 | "bindings": { 456 | "version": "1.3.0", 457 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.3.0.tgz", 458 | "integrity": "sha512-DpLh5EzMR2kzvX1KIlVC0VkC3iZtHKTgdtZ0a3pglBZdaQFjt5S9g9xd1lE+YvXyfd6mtCeRnrUfOLYiTMlNSw==", 459 | "dev": true, 460 | "optional": true 461 | }, 462 | "bluebird": { 463 | "version": "3.5.1", 464 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 465 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 466 | }, 467 | "boom": { 468 | "version": "4.3.1", 469 | "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", 470 | "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", 471 | "requires": { 472 | "hoek": "4.2.0" 473 | } 474 | }, 475 | "brace-expansion": { 476 | "version": "1.1.8", 477 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 478 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 479 | "requires": { 480 | "balanced-match": "1.0.0", 481 | "concat-map": "0.0.1" 482 | } 483 | }, 484 | "braces": { 485 | "version": "1.8.5", 486 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 487 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 488 | "dev": true, 489 | "requires": { 490 | "expand-range": "1.8.2", 491 | "preserve": "0.2.0", 492 | "repeat-element": "1.1.2" 493 | } 494 | }, 495 | "browser-process-hrtime": { 496 | "version": "0.1.2", 497 | "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-0.1.2.tgz", 498 | "integrity": "sha1-Ql1opY00R/AqBKqJQYf86K+Le44=", 499 | "dev": true 500 | }, 501 | "browser-resolve": { 502 | "version": "1.11.2", 503 | "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.2.tgz", 504 | "integrity": "sha1-j/CbCixCFxihBRwmCzLkj0QpOM4=", 505 | "dev": true, 506 | "requires": { 507 | "resolve": "1.1.7" 508 | } 509 | }, 510 | "bser": { 511 | "version": "2.0.0", 512 | "resolved": "https://registry.npmjs.org/bser/-/bser-2.0.0.tgz", 513 | "integrity": "sha1-mseNPtXZFYBP2HrLFYvHlxR6Fxk=", 514 | "dev": true, 515 | "requires": { 516 | "node-int64": "0.4.0" 517 | } 518 | }, 519 | "buffer-equal-constant-time": { 520 | "version": "1.0.1", 521 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 522 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 523 | }, 524 | "builtin-modules": { 525 | "version": "1.1.1", 526 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 527 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 528 | "dev": true 529 | }, 530 | "callsites": { 531 | "version": "2.0.0", 532 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", 533 | "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=", 534 | "dev": true 535 | }, 536 | "camelcase": { 537 | "version": "1.2.1", 538 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", 539 | "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=", 540 | "dev": true, 541 | "optional": true 542 | }, 543 | "caseless": { 544 | "version": "0.12.0", 545 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 546 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 547 | }, 548 | "center-align": { 549 | "version": "0.1.3", 550 | "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", 551 | "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", 552 | "dev": true, 553 | "optional": true, 554 | "requires": { 555 | "align-text": "0.1.4", 556 | "lazy-cache": "1.0.4" 557 | } 558 | }, 559 | "chalk": { 560 | "version": "2.3.0", 561 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 562 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 563 | "dev": true, 564 | "requires": { 565 | "ansi-styles": "3.2.0", 566 | "escape-string-regexp": "1.0.5", 567 | "supports-color": "4.5.0" 568 | } 569 | }, 570 | "ci-info": { 571 | "version": "1.1.2", 572 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.1.2.tgz", 573 | "integrity": "sha512-uTGIPNx/nSpBdsF6xnseRXLLtfr9VLqkz8ZqHXr3Y7b6SftyRxBGjwMtJj1OhNbmlc1wZzLNAlAcvyIiE8a6ZA==", 574 | "dev": true 575 | }, 576 | "cliui": { 577 | "version": "2.1.0", 578 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", 579 | "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", 580 | "dev": true, 581 | "optional": true, 582 | "requires": { 583 | "center-align": "0.1.3", 584 | "right-align": "0.1.3", 585 | "wordwrap": "0.0.2" 586 | }, 587 | "dependencies": { 588 | "wordwrap": { 589 | "version": "0.0.2", 590 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", 591 | "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=", 592 | "dev": true, 593 | "optional": true 594 | } 595 | } 596 | }, 597 | "co": { 598 | "version": "4.6.0", 599 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 600 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" 601 | }, 602 | "code-point-at": { 603 | "version": "1.1.0", 604 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 605 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 606 | "dev": true 607 | }, 608 | "color-convert": { 609 | "version": "1.9.1", 610 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.1.tgz", 611 | "integrity": "sha512-mjGanIiwQJskCC18rPR6OmrZ6fm2Lc7PeGFYwCmy5J34wC6F1PzdGL6xeMfmgicfYcNLGuVFA3WzXtIDCQSZxQ==", 612 | "dev": true, 613 | "requires": { 614 | "color-name": "1.1.3" 615 | } 616 | }, 617 | "color-name": { 618 | "version": "1.1.3", 619 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 620 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 621 | "dev": true 622 | }, 623 | "colors": { 624 | "version": "1.1.2", 625 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", 626 | "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=" 627 | }, 628 | "combined-stream": { 629 | "version": "1.0.5", 630 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 631 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 632 | "requires": { 633 | "delayed-stream": "1.0.0" 634 | } 635 | }, 636 | "commander": { 637 | "version": "2.12.2", 638 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.12.2.tgz", 639 | "integrity": "sha512-BFnaq5ZOGcDN7FlrtBT4xxkgIToalIIxwjxLWVJ8bGTpe1LroqMiqQXdA7ygc7CRvaYS+9zfPGFnJqFSayx+AA==" 640 | }, 641 | "concat-map": { 642 | "version": "0.0.1", 643 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 644 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 645 | }, 646 | "content-type-parser": { 647 | "version": "1.0.2", 648 | "resolved": "https://registry.npmjs.org/content-type-parser/-/content-type-parser-1.0.2.tgz", 649 | "integrity": "sha512-lM4l4CnMEwOLHAHr/P6MEZwZFPJFtAAKgL6pogbXmVZggIqXhdB6RbBtPOTsw2FcXwYhehRGERJmRrjOiIB8pQ==", 650 | "dev": true 651 | }, 652 | "convert-source-map": { 653 | "version": "1.5.1", 654 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", 655 | "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", 656 | "dev": true 657 | }, 658 | "core-js": { 659 | "version": "2.5.3", 660 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.3.tgz", 661 | "integrity": "sha1-isw4NFgk8W2DZbfJtCWRaOjtYD4=", 662 | "dev": true 663 | }, 664 | "core-util-is": { 665 | "version": "1.0.2", 666 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 667 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 668 | }, 669 | "cross-spawn": { 670 | "version": "5.1.0", 671 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 672 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 673 | "dev": true, 674 | "requires": { 675 | "lru-cache": "4.1.1", 676 | "shebang-command": "1.2.0", 677 | "which": "1.3.0" 678 | } 679 | }, 680 | "cryptiles": { 681 | "version": "3.1.2", 682 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-3.1.2.tgz", 683 | "integrity": "sha1-qJ+7Ig9c4l7FboxKqKT9e1sNKf4=", 684 | "requires": { 685 | "boom": "5.2.0" 686 | }, 687 | "dependencies": { 688 | "boom": { 689 | "version": "5.2.0", 690 | "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", 691 | "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", 692 | "requires": { 693 | "hoek": "4.2.0" 694 | } 695 | } 696 | } 697 | }, 698 | "cssom": { 699 | "version": "0.3.2", 700 | "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.2.tgz", 701 | "integrity": "sha1-uANhcMefB6kP8vFuIihAJ6JDhIs=", 702 | "dev": true 703 | }, 704 | "cssstyle": { 705 | "version": "0.2.37", 706 | "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-0.2.37.tgz", 707 | "integrity": "sha1-VBCXI0yyUTyDzu06zdwn/yeYfVQ=", 708 | "dev": true, 709 | "requires": { 710 | "cssom": "0.3.2" 711 | } 712 | }, 713 | "dashdash": { 714 | "version": "1.14.1", 715 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 716 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 717 | "requires": { 718 | "assert-plus": "1.0.0" 719 | } 720 | }, 721 | "debug": { 722 | "version": "2.6.9", 723 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 724 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 725 | "dev": true, 726 | "requires": { 727 | "ms": "2.0.0" 728 | } 729 | }, 730 | "decamelize": { 731 | "version": "1.2.0", 732 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 733 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 734 | "dev": true 735 | }, 736 | "deep-is": { 737 | "version": "0.1.3", 738 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 739 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 740 | "dev": true 741 | }, 742 | "default-require-extensions": { 743 | "version": "1.0.0", 744 | "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-1.0.0.tgz", 745 | "integrity": "sha1-836hXT4T/9m0N9M+GnW1+5eHTLg=", 746 | "dev": true, 747 | "requires": { 748 | "strip-bom": "2.0.0" 749 | } 750 | }, 751 | "define-properties": { 752 | "version": "1.1.2", 753 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz", 754 | "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", 755 | "dev": true, 756 | "requires": { 757 | "foreach": "2.0.5", 758 | "object-keys": "1.0.11" 759 | } 760 | }, 761 | "delayed-stream": { 762 | "version": "1.0.0", 763 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 764 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 765 | }, 766 | "detect-indent": { 767 | "version": "4.0.0", 768 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", 769 | "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", 770 | "dev": true, 771 | "requires": { 772 | "repeating": "2.0.1" 773 | } 774 | }, 775 | "detect-newline": { 776 | "version": "2.1.0", 777 | "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-2.1.0.tgz", 778 | "integrity": "sha1-9B8cEL5LAOh7XxPaaAdZ8sW/0+I=", 779 | "dev": true 780 | }, 781 | "diff": { 782 | "version": "3.4.0", 783 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.4.0.tgz", 784 | "integrity": "sha512-QpVuMTEoJMF7cKzi6bvWhRulU1fZqZnvyVQgNhPaxxuTYwyjn/j1v9falseQ/uXWwPnO56RBfwtg4h/EQXmucA==", 785 | "dev": true 786 | }, 787 | "domexception": { 788 | "version": "1.0.0", 789 | "resolved": "https://registry.npmjs.org/domexception/-/domexception-1.0.0.tgz", 790 | "integrity": "sha512-WpwuBlZ2lQRFa4H/4w49deb9rJLot9KmqrKKjMc9qBl7CID+DdC2swoa34ccRl+anL2B6bLp6TjFdIdnzekMBQ==", 791 | "dev": true 792 | }, 793 | "ecc-jsbn": { 794 | "version": "0.1.1", 795 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", 796 | "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", 797 | "optional": true, 798 | "requires": { 799 | "jsbn": "0.1.1" 800 | } 801 | }, 802 | "ecdsa-sig-formatter": { 803 | "version": "1.0.9", 804 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.9.tgz", 805 | "integrity": "sha1-S8kmJ07Dtau1AW5+HWCSGsJisqE=", 806 | "requires": { 807 | "base64url": "2.0.0", 808 | "safe-buffer": "5.1.1" 809 | } 810 | }, 811 | "error-ex": { 812 | "version": "1.3.1", 813 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", 814 | "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", 815 | "dev": true, 816 | "requires": { 817 | "is-arrayish": "0.2.1" 818 | } 819 | }, 820 | "es-abstract": { 821 | "version": "1.10.0", 822 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.10.0.tgz", 823 | "integrity": "sha512-/uh/DhdqIOSkAWifU+8nG78vlQxdLckUdI/sPgy0VhuXi2qJ7T8czBmqIYtLQVpCIFYafChnsRsB5pyb1JdmCQ==", 824 | "dev": true, 825 | "requires": { 826 | "es-to-primitive": "1.1.1", 827 | "function-bind": "1.1.1", 828 | "has": "1.0.1", 829 | "is-callable": "1.1.3", 830 | "is-regex": "1.0.4" 831 | } 832 | }, 833 | "es-to-primitive": { 834 | "version": "1.1.1", 835 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.1.1.tgz", 836 | "integrity": "sha1-RTVSSKiJeQNLZ5Lhm7gfK3l13Q0=", 837 | "dev": true, 838 | "requires": { 839 | "is-callable": "1.1.3", 840 | "is-date-object": "1.0.1", 841 | "is-symbol": "1.0.1" 842 | } 843 | }, 844 | "escape-string-regexp": { 845 | "version": "1.0.5", 846 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 847 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 848 | "dev": true 849 | }, 850 | "escodegen": { 851 | "version": "1.9.0", 852 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.9.0.tgz", 853 | "integrity": "sha512-v0MYvNQ32bzwoG2OSFzWAkuahDQHK92JBN0pTAALJ4RIxEZe766QJPDR8Hqy7XNUy5K3fnVL76OqYAdc4TZEIw==", 854 | "dev": true, 855 | "requires": { 856 | "esprima": "3.1.3", 857 | "estraverse": "4.2.0", 858 | "esutils": "2.0.2", 859 | "optionator": "0.8.2", 860 | "source-map": "0.5.7" 861 | }, 862 | "dependencies": { 863 | "esprima": { 864 | "version": "3.1.3", 865 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", 866 | "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=", 867 | "dev": true 868 | } 869 | } 870 | }, 871 | "esprima": { 872 | "version": "4.0.0", 873 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz", 874 | "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", 875 | "dev": true 876 | }, 877 | "estraverse": { 878 | "version": "4.2.0", 879 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 880 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 881 | "dev": true 882 | }, 883 | "esutils": { 884 | "version": "2.0.2", 885 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 886 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 887 | "dev": true 888 | }, 889 | "exec-sh": { 890 | "version": "0.2.1", 891 | "resolved": "https://registry.npmjs.org/exec-sh/-/exec-sh-0.2.1.tgz", 892 | "integrity": "sha512-aLt95pexaugVtQerpmE51+4QfWrNc304uez7jvj6fWnN8GeEHpttB8F36n8N7uVhUMbH/1enbxQ9HImZ4w/9qg==", 893 | "dev": true, 894 | "requires": { 895 | "merge": "1.2.0" 896 | } 897 | }, 898 | "execa": { 899 | "version": "0.7.0", 900 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 901 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 902 | "dev": true, 903 | "requires": { 904 | "cross-spawn": "5.1.0", 905 | "get-stream": "3.0.0", 906 | "is-stream": "1.1.0", 907 | "npm-run-path": "2.0.2", 908 | "p-finally": "1.0.0", 909 | "signal-exit": "3.0.2", 910 | "strip-eof": "1.0.0" 911 | } 912 | }, 913 | "expand-brackets": { 914 | "version": "0.1.5", 915 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 916 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 917 | "dev": true, 918 | "requires": { 919 | "is-posix-bracket": "0.1.1" 920 | } 921 | }, 922 | "expand-range": { 923 | "version": "1.8.2", 924 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 925 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 926 | "dev": true, 927 | "requires": { 928 | "fill-range": "2.2.3" 929 | } 930 | }, 931 | "expect": { 932 | "version": "22.0.3", 933 | "resolved": "https://registry.npmjs.org/expect/-/expect-22.0.3.tgz", 934 | "integrity": "sha512-QapzeQkcA3jCx4pDnD07I4SPPxScKbey8TD/WwrnzmpHmL5q0dUtXfUt5OIFOjVBCg+C4zn4Y1zK9Rb9SIDL1g==", 935 | "dev": true, 936 | "requires": { 937 | "ansi-styles": "3.2.0", 938 | "jest-diff": "22.0.3", 939 | "jest-get-type": "22.0.3", 940 | "jest-matcher-utils": "22.0.3", 941 | "jest-message-util": "22.0.3", 942 | "jest-regex-util": "22.0.3" 943 | } 944 | }, 945 | "extend": { 946 | "version": "3.0.1", 947 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 948 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" 949 | }, 950 | "extglob": { 951 | "version": "0.3.2", 952 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 953 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 954 | "dev": true, 955 | "requires": { 956 | "is-extglob": "1.0.0" 957 | } 958 | }, 959 | "extsprintf": { 960 | "version": "1.3.0", 961 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 962 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 963 | }, 964 | "fast-deep-equal": { 965 | "version": "1.0.0", 966 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", 967 | "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=" 968 | }, 969 | "fast-json-stable-stringify": { 970 | "version": "2.0.0", 971 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 972 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 973 | }, 974 | "fast-levenshtein": { 975 | "version": "2.0.6", 976 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 977 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 978 | "dev": true 979 | }, 980 | "fb-watchman": { 981 | "version": "2.0.0", 982 | "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.0.tgz", 983 | "integrity": "sha1-VOmr99+i8mzZsWNsWIwa/AXeXVg=", 984 | "dev": true, 985 | "requires": { 986 | "bser": "2.0.0" 987 | } 988 | }, 989 | "filename-regex": { 990 | "version": "2.0.1", 991 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 992 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 993 | "dev": true 994 | }, 995 | "fileset": { 996 | "version": "2.0.3", 997 | "resolved": "https://registry.npmjs.org/fileset/-/fileset-2.0.3.tgz", 998 | "integrity": "sha1-jnVIqW08wjJ+5eZ0FocjozO7oqA=", 999 | "dev": true, 1000 | "requires": { 1001 | "glob": "7.1.2", 1002 | "minimatch": "3.0.4" 1003 | } 1004 | }, 1005 | "fill-range": { 1006 | "version": "2.2.3", 1007 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", 1008 | "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", 1009 | "dev": true, 1010 | "requires": { 1011 | "is-number": "2.1.0", 1012 | "isobject": "2.1.0", 1013 | "randomatic": "1.1.7", 1014 | "repeat-element": "1.1.2", 1015 | "repeat-string": "1.6.1" 1016 | } 1017 | }, 1018 | "find-up": { 1019 | "version": "2.1.0", 1020 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1021 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1022 | "dev": true, 1023 | "requires": { 1024 | "locate-path": "2.0.0" 1025 | } 1026 | }, 1027 | "for-in": { 1028 | "version": "1.0.2", 1029 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 1030 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 1031 | "dev": true 1032 | }, 1033 | "for-own": { 1034 | "version": "0.1.5", 1035 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 1036 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 1037 | "dev": true, 1038 | "requires": { 1039 | "for-in": "1.0.2" 1040 | } 1041 | }, 1042 | "foreach": { 1043 | "version": "2.0.5", 1044 | "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz", 1045 | "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=", 1046 | "dev": true 1047 | }, 1048 | "forever-agent": { 1049 | "version": "0.6.1", 1050 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 1051 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 1052 | }, 1053 | "form-data": { 1054 | "version": "2.3.1", 1055 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 1056 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 1057 | "requires": { 1058 | "asynckit": "0.4.0", 1059 | "combined-stream": "1.0.5", 1060 | "mime-types": "2.1.17" 1061 | } 1062 | }, 1063 | "fs.realpath": { 1064 | "version": "1.0.0", 1065 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1066 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1067 | "dev": true 1068 | }, 1069 | "fsevents": { 1070 | "version": "1.1.3", 1071 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.1.3.tgz", 1072 | "integrity": "sha512-WIr7iDkdmdbxu/Gh6eKEZJL6KPE74/5MEsf2whTOFNxbIoIixogroLdKYqB6FDav4Wavh/lZdzzd3b2KxIXC5Q==", 1073 | "dev": true, 1074 | "optional": true, 1075 | "requires": { 1076 | "nan": "2.8.0", 1077 | "node-pre-gyp": "0.6.39" 1078 | }, 1079 | "dependencies": { 1080 | "abbrev": { 1081 | "version": "1.1.0", 1082 | "bundled": true, 1083 | "dev": true, 1084 | "optional": true 1085 | }, 1086 | "ajv": { 1087 | "version": "4.11.8", 1088 | "bundled": true, 1089 | "dev": true, 1090 | "optional": true, 1091 | "requires": { 1092 | "co": "4.6.0", 1093 | "json-stable-stringify": "1.0.1" 1094 | } 1095 | }, 1096 | "ansi-regex": { 1097 | "version": "2.1.1", 1098 | "bundled": true, 1099 | "dev": true 1100 | }, 1101 | "aproba": { 1102 | "version": "1.1.1", 1103 | "bundled": true, 1104 | "dev": true, 1105 | "optional": true 1106 | }, 1107 | "are-we-there-yet": { 1108 | "version": "1.1.4", 1109 | "bundled": true, 1110 | "dev": true, 1111 | "optional": true, 1112 | "requires": { 1113 | "delegates": "1.0.0", 1114 | "readable-stream": "2.2.9" 1115 | } 1116 | }, 1117 | "asn1": { 1118 | "version": "0.2.3", 1119 | "bundled": true, 1120 | "dev": true, 1121 | "optional": true 1122 | }, 1123 | "assert-plus": { 1124 | "version": "0.2.0", 1125 | "bundled": true, 1126 | "dev": true, 1127 | "optional": true 1128 | }, 1129 | "asynckit": { 1130 | "version": "0.4.0", 1131 | "bundled": true, 1132 | "dev": true, 1133 | "optional": true 1134 | }, 1135 | "aws-sign2": { 1136 | "version": "0.6.0", 1137 | "bundled": true, 1138 | "dev": true, 1139 | "optional": true 1140 | }, 1141 | "aws4": { 1142 | "version": "1.6.0", 1143 | "bundled": true, 1144 | "dev": true, 1145 | "optional": true 1146 | }, 1147 | "balanced-match": { 1148 | "version": "0.4.2", 1149 | "bundled": true, 1150 | "dev": true 1151 | }, 1152 | "bcrypt-pbkdf": { 1153 | "version": "1.0.1", 1154 | "bundled": true, 1155 | "dev": true, 1156 | "optional": true, 1157 | "requires": { 1158 | "tweetnacl": "0.14.5" 1159 | } 1160 | }, 1161 | "block-stream": { 1162 | "version": "0.0.9", 1163 | "bundled": true, 1164 | "dev": true, 1165 | "requires": { 1166 | "inherits": "2.0.3" 1167 | } 1168 | }, 1169 | "boom": { 1170 | "version": "2.10.1", 1171 | "bundled": true, 1172 | "dev": true, 1173 | "requires": { 1174 | "hoek": "2.16.3" 1175 | } 1176 | }, 1177 | "brace-expansion": { 1178 | "version": "1.1.7", 1179 | "bundled": true, 1180 | "dev": true, 1181 | "requires": { 1182 | "balanced-match": "0.4.2", 1183 | "concat-map": "0.0.1" 1184 | } 1185 | }, 1186 | "buffer-shims": { 1187 | "version": "1.0.0", 1188 | "bundled": true, 1189 | "dev": true 1190 | }, 1191 | "caseless": { 1192 | "version": "0.12.0", 1193 | "bundled": true, 1194 | "dev": true, 1195 | "optional": true 1196 | }, 1197 | "co": { 1198 | "version": "4.6.0", 1199 | "bundled": true, 1200 | "dev": true, 1201 | "optional": true 1202 | }, 1203 | "code-point-at": { 1204 | "version": "1.1.0", 1205 | "bundled": true, 1206 | "dev": true 1207 | }, 1208 | "combined-stream": { 1209 | "version": "1.0.5", 1210 | "bundled": true, 1211 | "dev": true, 1212 | "requires": { 1213 | "delayed-stream": "1.0.0" 1214 | } 1215 | }, 1216 | "concat-map": { 1217 | "version": "0.0.1", 1218 | "bundled": true, 1219 | "dev": true 1220 | }, 1221 | "console-control-strings": { 1222 | "version": "1.1.0", 1223 | "bundled": true, 1224 | "dev": true 1225 | }, 1226 | "core-util-is": { 1227 | "version": "1.0.2", 1228 | "bundled": true, 1229 | "dev": true 1230 | }, 1231 | "cryptiles": { 1232 | "version": "2.0.5", 1233 | "bundled": true, 1234 | "dev": true, 1235 | "requires": { 1236 | "boom": "2.10.1" 1237 | } 1238 | }, 1239 | "dashdash": { 1240 | "version": "1.14.1", 1241 | "bundled": true, 1242 | "dev": true, 1243 | "optional": true, 1244 | "requires": { 1245 | "assert-plus": "1.0.0" 1246 | }, 1247 | "dependencies": { 1248 | "assert-plus": { 1249 | "version": "1.0.0", 1250 | "bundled": true, 1251 | "dev": true, 1252 | "optional": true 1253 | } 1254 | } 1255 | }, 1256 | "debug": { 1257 | "version": "2.6.8", 1258 | "bundled": true, 1259 | "dev": true, 1260 | "optional": true, 1261 | "requires": { 1262 | "ms": "2.0.0" 1263 | } 1264 | }, 1265 | "deep-extend": { 1266 | "version": "0.4.2", 1267 | "bundled": true, 1268 | "dev": true, 1269 | "optional": true 1270 | }, 1271 | "delayed-stream": { 1272 | "version": "1.0.0", 1273 | "bundled": true, 1274 | "dev": true 1275 | }, 1276 | "delegates": { 1277 | "version": "1.0.0", 1278 | "bundled": true, 1279 | "dev": true, 1280 | "optional": true 1281 | }, 1282 | "detect-libc": { 1283 | "version": "1.0.2", 1284 | "bundled": true, 1285 | "dev": true, 1286 | "optional": true 1287 | }, 1288 | "ecc-jsbn": { 1289 | "version": "0.1.1", 1290 | "bundled": true, 1291 | "dev": true, 1292 | "optional": true, 1293 | "requires": { 1294 | "jsbn": "0.1.1" 1295 | } 1296 | }, 1297 | "extend": { 1298 | "version": "3.0.1", 1299 | "bundled": true, 1300 | "dev": true, 1301 | "optional": true 1302 | }, 1303 | "extsprintf": { 1304 | "version": "1.0.2", 1305 | "bundled": true, 1306 | "dev": true 1307 | }, 1308 | "forever-agent": { 1309 | "version": "0.6.1", 1310 | "bundled": true, 1311 | "dev": true, 1312 | "optional": true 1313 | }, 1314 | "form-data": { 1315 | "version": "2.1.4", 1316 | "bundled": true, 1317 | "dev": true, 1318 | "optional": true, 1319 | "requires": { 1320 | "asynckit": "0.4.0", 1321 | "combined-stream": "1.0.5", 1322 | "mime-types": "2.1.15" 1323 | } 1324 | }, 1325 | "fs.realpath": { 1326 | "version": "1.0.0", 1327 | "bundled": true, 1328 | "dev": true 1329 | }, 1330 | "fstream": { 1331 | "version": "1.0.11", 1332 | "bundled": true, 1333 | "dev": true, 1334 | "requires": { 1335 | "graceful-fs": "4.1.11", 1336 | "inherits": "2.0.3", 1337 | "mkdirp": "0.5.1", 1338 | "rimraf": "2.6.1" 1339 | } 1340 | }, 1341 | "fstream-ignore": { 1342 | "version": "1.0.5", 1343 | "bundled": true, 1344 | "dev": true, 1345 | "optional": true, 1346 | "requires": { 1347 | "fstream": "1.0.11", 1348 | "inherits": "2.0.3", 1349 | "minimatch": "3.0.4" 1350 | } 1351 | }, 1352 | "gauge": { 1353 | "version": "2.7.4", 1354 | "bundled": true, 1355 | "dev": true, 1356 | "optional": true, 1357 | "requires": { 1358 | "aproba": "1.1.1", 1359 | "console-control-strings": "1.1.0", 1360 | "has-unicode": "2.0.1", 1361 | "object-assign": "4.1.1", 1362 | "signal-exit": "3.0.2", 1363 | "string-width": "1.0.2", 1364 | "strip-ansi": "3.0.1", 1365 | "wide-align": "1.1.2" 1366 | } 1367 | }, 1368 | "getpass": { 1369 | "version": "0.1.7", 1370 | "bundled": true, 1371 | "dev": true, 1372 | "optional": true, 1373 | "requires": { 1374 | "assert-plus": "1.0.0" 1375 | }, 1376 | "dependencies": { 1377 | "assert-plus": { 1378 | "version": "1.0.0", 1379 | "bundled": true, 1380 | "dev": true, 1381 | "optional": true 1382 | } 1383 | } 1384 | }, 1385 | "glob": { 1386 | "version": "7.1.2", 1387 | "bundled": true, 1388 | "dev": true, 1389 | "requires": { 1390 | "fs.realpath": "1.0.0", 1391 | "inflight": "1.0.6", 1392 | "inherits": "2.0.3", 1393 | "minimatch": "3.0.4", 1394 | "once": "1.4.0", 1395 | "path-is-absolute": "1.0.1" 1396 | } 1397 | }, 1398 | "graceful-fs": { 1399 | "version": "4.1.11", 1400 | "bundled": true, 1401 | "dev": true 1402 | }, 1403 | "har-schema": { 1404 | "version": "1.0.5", 1405 | "bundled": true, 1406 | "dev": true, 1407 | "optional": true 1408 | }, 1409 | "har-validator": { 1410 | "version": "4.2.1", 1411 | "bundled": true, 1412 | "dev": true, 1413 | "optional": true, 1414 | "requires": { 1415 | "ajv": "4.11.8", 1416 | "har-schema": "1.0.5" 1417 | } 1418 | }, 1419 | "has-unicode": { 1420 | "version": "2.0.1", 1421 | "bundled": true, 1422 | "dev": true, 1423 | "optional": true 1424 | }, 1425 | "hawk": { 1426 | "version": "3.1.3", 1427 | "bundled": true, 1428 | "dev": true, 1429 | "requires": { 1430 | "boom": "2.10.1", 1431 | "cryptiles": "2.0.5", 1432 | "hoek": "2.16.3", 1433 | "sntp": "1.0.9" 1434 | } 1435 | }, 1436 | "hoek": { 1437 | "version": "2.16.3", 1438 | "bundled": true, 1439 | "dev": true 1440 | }, 1441 | "http-signature": { 1442 | "version": "1.1.1", 1443 | "bundled": true, 1444 | "dev": true, 1445 | "optional": true, 1446 | "requires": { 1447 | "assert-plus": "0.2.0", 1448 | "jsprim": "1.4.0", 1449 | "sshpk": "1.13.0" 1450 | } 1451 | }, 1452 | "inflight": { 1453 | "version": "1.0.6", 1454 | "bundled": true, 1455 | "dev": true, 1456 | "requires": { 1457 | "once": "1.4.0", 1458 | "wrappy": "1.0.2" 1459 | } 1460 | }, 1461 | "inherits": { 1462 | "version": "2.0.3", 1463 | "bundled": true, 1464 | "dev": true 1465 | }, 1466 | "ini": { 1467 | "version": "1.3.4", 1468 | "bundled": true, 1469 | "dev": true, 1470 | "optional": true 1471 | }, 1472 | "is-fullwidth-code-point": { 1473 | "version": "1.0.0", 1474 | "bundled": true, 1475 | "dev": true, 1476 | "requires": { 1477 | "number-is-nan": "1.0.1" 1478 | } 1479 | }, 1480 | "is-typedarray": { 1481 | "version": "1.0.0", 1482 | "bundled": true, 1483 | "dev": true, 1484 | "optional": true 1485 | }, 1486 | "isarray": { 1487 | "version": "1.0.0", 1488 | "bundled": true, 1489 | "dev": true 1490 | }, 1491 | "isstream": { 1492 | "version": "0.1.2", 1493 | "bundled": true, 1494 | "dev": true, 1495 | "optional": true 1496 | }, 1497 | "jodid25519": { 1498 | "version": "1.0.2", 1499 | "bundled": true, 1500 | "dev": true, 1501 | "optional": true, 1502 | "requires": { 1503 | "jsbn": "0.1.1" 1504 | } 1505 | }, 1506 | "jsbn": { 1507 | "version": "0.1.1", 1508 | "bundled": true, 1509 | "dev": true, 1510 | "optional": true 1511 | }, 1512 | "json-schema": { 1513 | "version": "0.2.3", 1514 | "bundled": true, 1515 | "dev": true, 1516 | "optional": true 1517 | }, 1518 | "json-stable-stringify": { 1519 | "version": "1.0.1", 1520 | "bundled": true, 1521 | "dev": true, 1522 | "optional": true, 1523 | "requires": { 1524 | "jsonify": "0.0.0" 1525 | } 1526 | }, 1527 | "json-stringify-safe": { 1528 | "version": "5.0.1", 1529 | "bundled": true, 1530 | "dev": true, 1531 | "optional": true 1532 | }, 1533 | "jsonify": { 1534 | "version": "0.0.0", 1535 | "bundled": true, 1536 | "dev": true, 1537 | "optional": true 1538 | }, 1539 | "jsprim": { 1540 | "version": "1.4.0", 1541 | "bundled": true, 1542 | "dev": true, 1543 | "optional": true, 1544 | "requires": { 1545 | "assert-plus": "1.0.0", 1546 | "extsprintf": "1.0.2", 1547 | "json-schema": "0.2.3", 1548 | "verror": "1.3.6" 1549 | }, 1550 | "dependencies": { 1551 | "assert-plus": { 1552 | "version": "1.0.0", 1553 | "bundled": true, 1554 | "dev": true, 1555 | "optional": true 1556 | } 1557 | } 1558 | }, 1559 | "mime-db": { 1560 | "version": "1.27.0", 1561 | "bundled": true, 1562 | "dev": true 1563 | }, 1564 | "mime-types": { 1565 | "version": "2.1.15", 1566 | "bundled": true, 1567 | "dev": true, 1568 | "requires": { 1569 | "mime-db": "1.27.0" 1570 | } 1571 | }, 1572 | "minimatch": { 1573 | "version": "3.0.4", 1574 | "bundled": true, 1575 | "dev": true, 1576 | "requires": { 1577 | "brace-expansion": "1.1.7" 1578 | } 1579 | }, 1580 | "minimist": { 1581 | "version": "0.0.8", 1582 | "bundled": true, 1583 | "dev": true 1584 | }, 1585 | "mkdirp": { 1586 | "version": "0.5.1", 1587 | "bundled": true, 1588 | "dev": true, 1589 | "requires": { 1590 | "minimist": "0.0.8" 1591 | } 1592 | }, 1593 | "ms": { 1594 | "version": "2.0.0", 1595 | "bundled": true, 1596 | "dev": true, 1597 | "optional": true 1598 | }, 1599 | "node-pre-gyp": { 1600 | "version": "0.6.39", 1601 | "bundled": true, 1602 | "dev": true, 1603 | "optional": true, 1604 | "requires": { 1605 | "detect-libc": "1.0.2", 1606 | "hawk": "3.1.3", 1607 | "mkdirp": "0.5.1", 1608 | "nopt": "4.0.1", 1609 | "npmlog": "4.1.0", 1610 | "rc": "1.2.1", 1611 | "request": "2.81.0", 1612 | "rimraf": "2.6.1", 1613 | "semver": "5.3.0", 1614 | "tar": "2.2.1", 1615 | "tar-pack": "3.4.0" 1616 | } 1617 | }, 1618 | "nopt": { 1619 | "version": "4.0.1", 1620 | "bundled": true, 1621 | "dev": true, 1622 | "optional": true, 1623 | "requires": { 1624 | "abbrev": "1.1.0", 1625 | "osenv": "0.1.4" 1626 | } 1627 | }, 1628 | "npmlog": { 1629 | "version": "4.1.0", 1630 | "bundled": true, 1631 | "dev": true, 1632 | "optional": true, 1633 | "requires": { 1634 | "are-we-there-yet": "1.1.4", 1635 | "console-control-strings": "1.1.0", 1636 | "gauge": "2.7.4", 1637 | "set-blocking": "2.0.0" 1638 | } 1639 | }, 1640 | "number-is-nan": { 1641 | "version": "1.0.1", 1642 | "bundled": true, 1643 | "dev": true 1644 | }, 1645 | "oauth-sign": { 1646 | "version": "0.8.2", 1647 | "bundled": true, 1648 | "dev": true, 1649 | "optional": true 1650 | }, 1651 | "object-assign": { 1652 | "version": "4.1.1", 1653 | "bundled": true, 1654 | "dev": true, 1655 | "optional": true 1656 | }, 1657 | "once": { 1658 | "version": "1.4.0", 1659 | "bundled": true, 1660 | "dev": true, 1661 | "requires": { 1662 | "wrappy": "1.0.2" 1663 | } 1664 | }, 1665 | "os-homedir": { 1666 | "version": "1.0.2", 1667 | "bundled": true, 1668 | "dev": true, 1669 | "optional": true 1670 | }, 1671 | "os-tmpdir": { 1672 | "version": "1.0.2", 1673 | "bundled": true, 1674 | "dev": true, 1675 | "optional": true 1676 | }, 1677 | "osenv": { 1678 | "version": "0.1.4", 1679 | "bundled": true, 1680 | "dev": true, 1681 | "optional": true, 1682 | "requires": { 1683 | "os-homedir": "1.0.2", 1684 | "os-tmpdir": "1.0.2" 1685 | } 1686 | }, 1687 | "path-is-absolute": { 1688 | "version": "1.0.1", 1689 | "bundled": true, 1690 | "dev": true 1691 | }, 1692 | "performance-now": { 1693 | "version": "0.2.0", 1694 | "bundled": true, 1695 | "dev": true, 1696 | "optional": true 1697 | }, 1698 | "process-nextick-args": { 1699 | "version": "1.0.7", 1700 | "bundled": true, 1701 | "dev": true 1702 | }, 1703 | "punycode": { 1704 | "version": "1.4.1", 1705 | "bundled": true, 1706 | "dev": true, 1707 | "optional": true 1708 | }, 1709 | "qs": { 1710 | "version": "6.4.0", 1711 | "bundled": true, 1712 | "dev": true, 1713 | "optional": true 1714 | }, 1715 | "rc": { 1716 | "version": "1.2.1", 1717 | "bundled": true, 1718 | "dev": true, 1719 | "optional": true, 1720 | "requires": { 1721 | "deep-extend": "0.4.2", 1722 | "ini": "1.3.4", 1723 | "minimist": "1.2.0", 1724 | "strip-json-comments": "2.0.1" 1725 | }, 1726 | "dependencies": { 1727 | "minimist": { 1728 | "version": "1.2.0", 1729 | "bundled": true, 1730 | "dev": true, 1731 | "optional": true 1732 | } 1733 | } 1734 | }, 1735 | "readable-stream": { 1736 | "version": "2.2.9", 1737 | "bundled": true, 1738 | "dev": true, 1739 | "requires": { 1740 | "buffer-shims": "1.0.0", 1741 | "core-util-is": "1.0.2", 1742 | "inherits": "2.0.3", 1743 | "isarray": "1.0.0", 1744 | "process-nextick-args": "1.0.7", 1745 | "string_decoder": "1.0.1", 1746 | "util-deprecate": "1.0.2" 1747 | } 1748 | }, 1749 | "request": { 1750 | "version": "2.81.0", 1751 | "bundled": true, 1752 | "dev": true, 1753 | "optional": true, 1754 | "requires": { 1755 | "aws-sign2": "0.6.0", 1756 | "aws4": "1.6.0", 1757 | "caseless": "0.12.0", 1758 | "combined-stream": "1.0.5", 1759 | "extend": "3.0.1", 1760 | "forever-agent": "0.6.1", 1761 | "form-data": "2.1.4", 1762 | "har-validator": "4.2.1", 1763 | "hawk": "3.1.3", 1764 | "http-signature": "1.1.1", 1765 | "is-typedarray": "1.0.0", 1766 | "isstream": "0.1.2", 1767 | "json-stringify-safe": "5.0.1", 1768 | "mime-types": "2.1.15", 1769 | "oauth-sign": "0.8.2", 1770 | "performance-now": "0.2.0", 1771 | "qs": "6.4.0", 1772 | "safe-buffer": "5.0.1", 1773 | "stringstream": "0.0.5", 1774 | "tough-cookie": "2.3.2", 1775 | "tunnel-agent": "0.6.0", 1776 | "uuid": "3.0.1" 1777 | } 1778 | }, 1779 | "rimraf": { 1780 | "version": "2.6.1", 1781 | "bundled": true, 1782 | "dev": true, 1783 | "requires": { 1784 | "glob": "7.1.2" 1785 | } 1786 | }, 1787 | "safe-buffer": { 1788 | "version": "5.0.1", 1789 | "bundled": true, 1790 | "dev": true 1791 | }, 1792 | "semver": { 1793 | "version": "5.3.0", 1794 | "bundled": true, 1795 | "dev": true, 1796 | "optional": true 1797 | }, 1798 | "set-blocking": { 1799 | "version": "2.0.0", 1800 | "bundled": true, 1801 | "dev": true, 1802 | "optional": true 1803 | }, 1804 | "signal-exit": { 1805 | "version": "3.0.2", 1806 | "bundled": true, 1807 | "dev": true, 1808 | "optional": true 1809 | }, 1810 | "sntp": { 1811 | "version": "1.0.9", 1812 | "bundled": true, 1813 | "dev": true, 1814 | "requires": { 1815 | "hoek": "2.16.3" 1816 | } 1817 | }, 1818 | "sshpk": { 1819 | "version": "1.13.0", 1820 | "bundled": true, 1821 | "dev": true, 1822 | "optional": true, 1823 | "requires": { 1824 | "asn1": "0.2.3", 1825 | "assert-plus": "1.0.0", 1826 | "bcrypt-pbkdf": "1.0.1", 1827 | "dashdash": "1.14.1", 1828 | "ecc-jsbn": "0.1.1", 1829 | "getpass": "0.1.7", 1830 | "jodid25519": "1.0.2", 1831 | "jsbn": "0.1.1", 1832 | "tweetnacl": "0.14.5" 1833 | }, 1834 | "dependencies": { 1835 | "assert-plus": { 1836 | "version": "1.0.0", 1837 | "bundled": true, 1838 | "dev": true, 1839 | "optional": true 1840 | } 1841 | } 1842 | }, 1843 | "string-width": { 1844 | "version": "1.0.2", 1845 | "bundled": true, 1846 | "dev": true, 1847 | "requires": { 1848 | "code-point-at": "1.1.0", 1849 | "is-fullwidth-code-point": "1.0.0", 1850 | "strip-ansi": "3.0.1" 1851 | } 1852 | }, 1853 | "string_decoder": { 1854 | "version": "1.0.1", 1855 | "bundled": true, 1856 | "dev": true, 1857 | "requires": { 1858 | "safe-buffer": "5.0.1" 1859 | } 1860 | }, 1861 | "stringstream": { 1862 | "version": "0.0.5", 1863 | "bundled": true, 1864 | "dev": true, 1865 | "optional": true 1866 | }, 1867 | "strip-ansi": { 1868 | "version": "3.0.1", 1869 | "bundled": true, 1870 | "dev": true, 1871 | "requires": { 1872 | "ansi-regex": "2.1.1" 1873 | } 1874 | }, 1875 | "strip-json-comments": { 1876 | "version": "2.0.1", 1877 | "bundled": true, 1878 | "dev": true, 1879 | "optional": true 1880 | }, 1881 | "tar": { 1882 | "version": "2.2.1", 1883 | "bundled": true, 1884 | "dev": true, 1885 | "requires": { 1886 | "block-stream": "0.0.9", 1887 | "fstream": "1.0.11", 1888 | "inherits": "2.0.3" 1889 | } 1890 | }, 1891 | "tar-pack": { 1892 | "version": "3.4.0", 1893 | "bundled": true, 1894 | "dev": true, 1895 | "optional": true, 1896 | "requires": { 1897 | "debug": "2.6.8", 1898 | "fstream": "1.0.11", 1899 | "fstream-ignore": "1.0.5", 1900 | "once": "1.4.0", 1901 | "readable-stream": "2.2.9", 1902 | "rimraf": "2.6.1", 1903 | "tar": "2.2.1", 1904 | "uid-number": "0.0.6" 1905 | } 1906 | }, 1907 | "tough-cookie": { 1908 | "version": "2.3.2", 1909 | "bundled": true, 1910 | "dev": true, 1911 | "optional": true, 1912 | "requires": { 1913 | "punycode": "1.4.1" 1914 | } 1915 | }, 1916 | "tunnel-agent": { 1917 | "version": "0.6.0", 1918 | "bundled": true, 1919 | "dev": true, 1920 | "optional": true, 1921 | "requires": { 1922 | "safe-buffer": "5.0.1" 1923 | } 1924 | }, 1925 | "tweetnacl": { 1926 | "version": "0.14.5", 1927 | "bundled": true, 1928 | "dev": true, 1929 | "optional": true 1930 | }, 1931 | "uid-number": { 1932 | "version": "0.0.6", 1933 | "bundled": true, 1934 | "dev": true, 1935 | "optional": true 1936 | }, 1937 | "util-deprecate": { 1938 | "version": "1.0.2", 1939 | "bundled": true, 1940 | "dev": true 1941 | }, 1942 | "uuid": { 1943 | "version": "3.0.1", 1944 | "bundled": true, 1945 | "dev": true, 1946 | "optional": true 1947 | }, 1948 | "verror": { 1949 | "version": "1.3.6", 1950 | "bundled": true, 1951 | "dev": true, 1952 | "optional": true, 1953 | "requires": { 1954 | "extsprintf": "1.0.2" 1955 | } 1956 | }, 1957 | "wide-align": { 1958 | "version": "1.1.2", 1959 | "bundled": true, 1960 | "dev": true, 1961 | "optional": true, 1962 | "requires": { 1963 | "string-width": "1.0.2" 1964 | } 1965 | }, 1966 | "wrappy": { 1967 | "version": "1.0.2", 1968 | "bundled": true, 1969 | "dev": true 1970 | } 1971 | } 1972 | }, 1973 | "function-bind": { 1974 | "version": "1.1.1", 1975 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1976 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1977 | "dev": true 1978 | }, 1979 | "get-caller-file": { 1980 | "version": "1.0.2", 1981 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.2.tgz", 1982 | "integrity": "sha1-9wLmMSfn4jHBYKgMFVSstw1QR+U=", 1983 | "dev": true 1984 | }, 1985 | "get-stream": { 1986 | "version": "3.0.0", 1987 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 1988 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", 1989 | "dev": true 1990 | }, 1991 | "getpass": { 1992 | "version": "0.1.7", 1993 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 1994 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 1995 | "requires": { 1996 | "assert-plus": "1.0.0" 1997 | } 1998 | }, 1999 | "glob": { 2000 | "version": "7.1.2", 2001 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 2002 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 2003 | "dev": true, 2004 | "requires": { 2005 | "fs.realpath": "1.0.0", 2006 | "inflight": "1.0.6", 2007 | "inherits": "2.0.3", 2008 | "minimatch": "3.0.4", 2009 | "once": "1.4.0", 2010 | "path-is-absolute": "1.0.1" 2011 | } 2012 | }, 2013 | "glob-base": { 2014 | "version": "0.3.0", 2015 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 2016 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 2017 | "dev": true, 2018 | "requires": { 2019 | "glob-parent": "2.0.0", 2020 | "is-glob": "2.0.1" 2021 | } 2022 | }, 2023 | "glob-parent": { 2024 | "version": "2.0.0", 2025 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 2026 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 2027 | "dev": true, 2028 | "requires": { 2029 | "is-glob": "2.0.1" 2030 | } 2031 | }, 2032 | "globals": { 2033 | "version": "9.18.0", 2034 | "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", 2035 | "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", 2036 | "dev": true 2037 | }, 2038 | "google-auth-library": { 2039 | "version": "0.10.0", 2040 | "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-0.10.0.tgz", 2041 | "integrity": "sha1-bhW6vuhf0d0U2NEoopW2g41SE24=", 2042 | "requires": { 2043 | "gtoken": "1.2.3", 2044 | "jws": "3.1.4", 2045 | "lodash.noop": "3.0.1", 2046 | "request": "2.83.0" 2047 | }, 2048 | "dependencies": { 2049 | "request": { 2050 | "version": "2.83.0", 2051 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 2052 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 2053 | "requires": { 2054 | "aws-sign2": "0.7.0", 2055 | "aws4": "1.6.0", 2056 | "caseless": "0.12.0", 2057 | "combined-stream": "1.0.5", 2058 | "extend": "3.0.1", 2059 | "forever-agent": "0.6.1", 2060 | "form-data": "2.3.1", 2061 | "har-validator": "5.0.3", 2062 | "hawk": "6.0.2", 2063 | "http-signature": "1.2.0", 2064 | "is-typedarray": "1.0.0", 2065 | "isstream": "0.1.2", 2066 | "json-stringify-safe": "5.0.1", 2067 | "mime-types": "2.1.17", 2068 | "oauth-sign": "0.8.2", 2069 | "performance-now": "2.1.0", 2070 | "qs": "6.5.1", 2071 | "safe-buffer": "5.1.1", 2072 | "stringstream": "0.0.5", 2073 | "tough-cookie": "2.3.3", 2074 | "tunnel-agent": "0.6.0", 2075 | "uuid": "3.1.0" 2076 | } 2077 | } 2078 | } 2079 | }, 2080 | "google-p12-pem": { 2081 | "version": "0.1.2", 2082 | "resolved": "https://registry.npmjs.org/google-p12-pem/-/google-p12-pem-0.1.2.tgz", 2083 | "integrity": "sha1-M8RqsCGqc0+gMys5YKmj/8svMXc=", 2084 | "requires": { 2085 | "node-forge": "0.7.1" 2086 | } 2087 | }, 2088 | "googleapis": { 2089 | "version": "20.1.0", 2090 | "resolved": "https://registry.npmjs.org/googleapis/-/googleapis-20.1.0.tgz", 2091 | "integrity": "sha512-UZYpUKPcwt28tZIvC+sT7yHtl56bMxnePNJBtZ3tG0OrQ1KegukirKRRuIxPavNCOcVC/ka5j/RRDhEIrYf5UA==", 2092 | "requires": { 2093 | "async": "2.3.0", 2094 | "google-auth-library": "0.10.0", 2095 | "string-template": "1.0.0" 2096 | } 2097 | }, 2098 | "graceful-fs": { 2099 | "version": "4.1.11", 2100 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 2101 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 2102 | "dev": true 2103 | }, 2104 | "growly": { 2105 | "version": "1.3.0", 2106 | "resolved": "https://registry.npmjs.org/growly/-/growly-1.3.0.tgz", 2107 | "integrity": "sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=", 2108 | "dev": true 2109 | }, 2110 | "gtoken": { 2111 | "version": "1.2.3", 2112 | "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-1.2.3.tgz", 2113 | "integrity": "sha512-wQAJflfoqSgMWrSBk9Fg86q+sd6s7y6uJhIvvIPz++RElGlMtEqsdAR2oWwZ/WTEtp7P9xFbJRrT976oRgzJ/w==", 2114 | "requires": { 2115 | "google-p12-pem": "0.1.2", 2116 | "jws": "3.1.4", 2117 | "mime": "1.6.0", 2118 | "request": "2.83.0" 2119 | }, 2120 | "dependencies": { 2121 | "request": { 2122 | "version": "2.83.0", 2123 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 2124 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 2125 | "requires": { 2126 | "aws-sign2": "0.7.0", 2127 | "aws4": "1.6.0", 2128 | "caseless": "0.12.0", 2129 | "combined-stream": "1.0.5", 2130 | "extend": "3.0.1", 2131 | "forever-agent": "0.6.1", 2132 | "form-data": "2.3.1", 2133 | "har-validator": "5.0.3", 2134 | "hawk": "6.0.2", 2135 | "http-signature": "1.2.0", 2136 | "is-typedarray": "1.0.0", 2137 | "isstream": "0.1.2", 2138 | "json-stringify-safe": "5.0.1", 2139 | "mime-types": "2.1.17", 2140 | "oauth-sign": "0.8.2", 2141 | "performance-now": "2.1.0", 2142 | "qs": "6.5.1", 2143 | "safe-buffer": "5.1.1", 2144 | "stringstream": "0.0.5", 2145 | "tough-cookie": "2.3.3", 2146 | "tunnel-agent": "0.6.0", 2147 | "uuid": "3.1.0" 2148 | } 2149 | } 2150 | } 2151 | }, 2152 | "handlebars": { 2153 | "version": "4.0.11", 2154 | "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.0.11.tgz", 2155 | "integrity": "sha1-Ywo13+ApS8KB7a5v/F0yn8eYLcw=", 2156 | "dev": true, 2157 | "requires": { 2158 | "async": "1.5.2", 2159 | "optimist": "0.6.1", 2160 | "source-map": "0.4.4", 2161 | "uglify-js": "2.8.29" 2162 | }, 2163 | "dependencies": { 2164 | "async": { 2165 | "version": "1.5.2", 2166 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 2167 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", 2168 | "dev": true 2169 | }, 2170 | "source-map": { 2171 | "version": "0.4.4", 2172 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", 2173 | "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", 2174 | "dev": true, 2175 | "requires": { 2176 | "amdefine": "1.0.1" 2177 | } 2178 | } 2179 | } 2180 | }, 2181 | "har-schema": { 2182 | "version": "2.0.0", 2183 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 2184 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 2185 | }, 2186 | "har-validator": { 2187 | "version": "5.0.3", 2188 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 2189 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 2190 | "requires": { 2191 | "ajv": "5.5.1", 2192 | "har-schema": "2.0.0" 2193 | } 2194 | }, 2195 | "has": { 2196 | "version": "1.0.1", 2197 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", 2198 | "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=", 2199 | "dev": true, 2200 | "requires": { 2201 | "function-bind": "1.1.1" 2202 | } 2203 | }, 2204 | "has-ansi": { 2205 | "version": "2.0.0", 2206 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 2207 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 2208 | "dev": true, 2209 | "requires": { 2210 | "ansi-regex": "2.1.1" 2211 | } 2212 | }, 2213 | "has-flag": { 2214 | "version": "2.0.0", 2215 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 2216 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 2217 | "dev": true 2218 | }, 2219 | "hawk": { 2220 | "version": "6.0.2", 2221 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-6.0.2.tgz", 2222 | "integrity": "sha512-miowhl2+U7Qle4vdLqDdPt9m09K6yZhkLDTWGoUiUzrQCn+mHHSmfJgAyGaLRZbPmTqfFFjRV1QWCW0VWUJBbQ==", 2223 | "requires": { 2224 | "boom": "4.3.1", 2225 | "cryptiles": "3.1.2", 2226 | "hoek": "4.2.0", 2227 | "sntp": "2.1.0" 2228 | } 2229 | }, 2230 | "hoek": { 2231 | "version": "4.2.0", 2232 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.0.tgz", 2233 | "integrity": "sha512-v0XCLxICi9nPfYrS9RL8HbYnXi9obYAeLbSP00BmnZwCK9+Ih9WOjoZ8YoHCoav2csqn4FOz4Orldsy2dmDwmQ==" 2234 | }, 2235 | "home-or-tmp": { 2236 | "version": "2.0.0", 2237 | "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", 2238 | "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", 2239 | "dev": true, 2240 | "requires": { 2241 | "os-homedir": "1.0.2", 2242 | "os-tmpdir": "1.0.2" 2243 | } 2244 | }, 2245 | "hosted-git-info": { 2246 | "version": "2.5.0", 2247 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.5.0.tgz", 2248 | "integrity": "sha512-pNgbURSuab90KbTqvRPsseaTxOJCZBD0a7t+haSN33piP9cCM4l0CqdzAif2hUqm716UovKB2ROmiabGAKVXyg==", 2249 | "dev": true 2250 | }, 2251 | "html-encoding-sniffer": { 2252 | "version": "1.0.2", 2253 | "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-1.0.2.tgz", 2254 | "integrity": "sha512-71lZziiDnsuabfdYiUeWdCVyKuqwWi23L8YeIgV9jSSZHCtb6wB1BKWooH7L3tn4/FuZJMVWyNaIDr4RGmaSYw==", 2255 | "dev": true, 2256 | "requires": { 2257 | "whatwg-encoding": "1.0.3" 2258 | } 2259 | }, 2260 | "http-signature": { 2261 | "version": "1.2.0", 2262 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 2263 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 2264 | "requires": { 2265 | "assert-plus": "1.0.0", 2266 | "jsprim": "1.4.1", 2267 | "sshpk": "1.13.1" 2268 | } 2269 | }, 2270 | "iconv-lite": { 2271 | "version": "0.4.19", 2272 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 2273 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==", 2274 | "dev": true 2275 | }, 2276 | "imurmurhash": { 2277 | "version": "0.1.4", 2278 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2279 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2280 | "dev": true 2281 | }, 2282 | "inflight": { 2283 | "version": "1.0.6", 2284 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2285 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2286 | "dev": true, 2287 | "requires": { 2288 | "once": "1.4.0", 2289 | "wrappy": "1.0.2" 2290 | } 2291 | }, 2292 | "inherits": { 2293 | "version": "2.0.3", 2294 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 2295 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 2296 | "dev": true 2297 | }, 2298 | "invariant": { 2299 | "version": "2.2.2", 2300 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.2.tgz", 2301 | "integrity": "sha1-nh9WrArNtr8wMwbzOL47IErmA2A=", 2302 | "dev": true, 2303 | "requires": { 2304 | "loose-envify": "1.3.1" 2305 | } 2306 | }, 2307 | "invert-kv": { 2308 | "version": "1.0.0", 2309 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", 2310 | "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=", 2311 | "dev": true 2312 | }, 2313 | "is-arrayish": { 2314 | "version": "0.2.1", 2315 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2316 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 2317 | "dev": true 2318 | }, 2319 | "is-buffer": { 2320 | "version": "1.1.6", 2321 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 2322 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 2323 | "dev": true 2324 | }, 2325 | "is-builtin-module": { 2326 | "version": "1.0.0", 2327 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 2328 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 2329 | "dev": true, 2330 | "requires": { 2331 | "builtin-modules": "1.1.1" 2332 | } 2333 | }, 2334 | "is-callable": { 2335 | "version": "1.1.3", 2336 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz", 2337 | "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=", 2338 | "dev": true 2339 | }, 2340 | "is-ci": { 2341 | "version": "1.0.10", 2342 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.0.10.tgz", 2343 | "integrity": "sha1-9zkzayYyNlBhqdSCcM1WrjNpMY4=", 2344 | "dev": true, 2345 | "requires": { 2346 | "ci-info": "1.1.2" 2347 | } 2348 | }, 2349 | "is-date-object": { 2350 | "version": "1.0.1", 2351 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 2352 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 2353 | "dev": true 2354 | }, 2355 | "is-dotfile": { 2356 | "version": "1.0.3", 2357 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 2358 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 2359 | "dev": true 2360 | }, 2361 | "is-equal-shallow": { 2362 | "version": "0.1.3", 2363 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 2364 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 2365 | "dev": true, 2366 | "requires": { 2367 | "is-primitive": "2.0.0" 2368 | } 2369 | }, 2370 | "is-extendable": { 2371 | "version": "0.1.1", 2372 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 2373 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 2374 | "dev": true 2375 | }, 2376 | "is-extglob": { 2377 | "version": "1.0.0", 2378 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 2379 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 2380 | "dev": true 2381 | }, 2382 | "is-finite": { 2383 | "version": "1.0.2", 2384 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", 2385 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", 2386 | "dev": true, 2387 | "requires": { 2388 | "number-is-nan": "1.0.1" 2389 | } 2390 | }, 2391 | "is-fullwidth-code-point": { 2392 | "version": "1.0.0", 2393 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 2394 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 2395 | "dev": true, 2396 | "requires": { 2397 | "number-is-nan": "1.0.1" 2398 | } 2399 | }, 2400 | "is-glob": { 2401 | "version": "2.0.1", 2402 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 2403 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 2404 | "dev": true, 2405 | "requires": { 2406 | "is-extglob": "1.0.0" 2407 | } 2408 | }, 2409 | "is-number": { 2410 | "version": "2.1.0", 2411 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 2412 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 2413 | "dev": true, 2414 | "requires": { 2415 | "kind-of": "3.2.2" 2416 | } 2417 | }, 2418 | "is-posix-bracket": { 2419 | "version": "0.1.1", 2420 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 2421 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 2422 | "dev": true 2423 | }, 2424 | "is-primitive": { 2425 | "version": "2.0.0", 2426 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 2427 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 2428 | "dev": true 2429 | }, 2430 | "is-regex": { 2431 | "version": "1.0.4", 2432 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 2433 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 2434 | "dev": true, 2435 | "requires": { 2436 | "has": "1.0.1" 2437 | } 2438 | }, 2439 | "is-stream": { 2440 | "version": "1.1.0", 2441 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 2442 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 2443 | "dev": true 2444 | }, 2445 | "is-symbol": { 2446 | "version": "1.0.1", 2447 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.1.tgz", 2448 | "integrity": "sha1-PMWfAAJRlLarLjjbrmaJJWtmBXI=", 2449 | "dev": true 2450 | }, 2451 | "is-typedarray": { 2452 | "version": "1.0.0", 2453 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 2454 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 2455 | }, 2456 | "is-utf8": { 2457 | "version": "0.2.1", 2458 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 2459 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", 2460 | "dev": true 2461 | }, 2462 | "isarray": { 2463 | "version": "1.0.0", 2464 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2465 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 2466 | "dev": true 2467 | }, 2468 | "isexe": { 2469 | "version": "2.0.0", 2470 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2471 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2472 | "dev": true 2473 | }, 2474 | "isobject": { 2475 | "version": "2.1.0", 2476 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 2477 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 2478 | "dev": true, 2479 | "requires": { 2480 | "isarray": "1.0.0" 2481 | } 2482 | }, 2483 | "isstream": { 2484 | "version": "0.1.2", 2485 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 2486 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 2487 | }, 2488 | "istanbul-api": { 2489 | "version": "1.2.1", 2490 | "resolved": "https://registry.npmjs.org/istanbul-api/-/istanbul-api-1.2.1.tgz", 2491 | "integrity": "sha512-oFCwXvd65amgaPCzqrR+a2XjanS1MvpXN6l/MlMUTv6uiA1NOgGX+I0uyq8Lg3GDxsxPsaP1049krz3hIJ5+KA==", 2492 | "dev": true, 2493 | "requires": { 2494 | "async": "2.3.0", 2495 | "fileset": "2.0.3", 2496 | "istanbul-lib-coverage": "1.1.1", 2497 | "istanbul-lib-hook": "1.1.0", 2498 | "istanbul-lib-instrument": "1.9.1", 2499 | "istanbul-lib-report": "1.1.2", 2500 | "istanbul-lib-source-maps": "1.2.2", 2501 | "istanbul-reports": "1.1.3", 2502 | "js-yaml": "3.10.0", 2503 | "mkdirp": "0.5.1", 2504 | "once": "1.4.0" 2505 | } 2506 | }, 2507 | "istanbul-lib-coverage": { 2508 | "version": "1.1.1", 2509 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-1.1.1.tgz", 2510 | "integrity": "sha512-0+1vDkmzxqJIn5rcoEqapSB4DmPxE31EtI2dF2aCkV5esN9EWHxZ0dwgDClivMXJqE7zaYQxq30hj5L0nlTN5Q==", 2511 | "dev": true 2512 | }, 2513 | "istanbul-lib-hook": { 2514 | "version": "1.1.0", 2515 | "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-1.1.0.tgz", 2516 | "integrity": "sha512-U3qEgwVDUerZ0bt8cfl3dSP3S6opBoOtk3ROO5f2EfBr/SRiD9FQqzwaZBqFORu8W7O0EXpai+k7kxHK13beRg==", 2517 | "dev": true, 2518 | "requires": { 2519 | "append-transform": "0.4.0" 2520 | } 2521 | }, 2522 | "istanbul-lib-instrument": { 2523 | "version": "1.9.1", 2524 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-1.9.1.tgz", 2525 | "integrity": "sha512-RQmXeQ7sphar7k7O1wTNzVczF9igKpaeGQAG9qR2L+BS4DCJNTI9nytRmIVYevwO0bbq+2CXvJmYDuz0gMrywA==", 2526 | "dev": true, 2527 | "requires": { 2528 | "babel-generator": "6.26.0", 2529 | "babel-template": "6.26.0", 2530 | "babel-traverse": "6.26.0", 2531 | "babel-types": "6.26.0", 2532 | "babylon": "6.18.0", 2533 | "istanbul-lib-coverage": "1.1.1", 2534 | "semver": "5.4.1" 2535 | } 2536 | }, 2537 | "istanbul-lib-report": { 2538 | "version": "1.1.2", 2539 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-1.1.2.tgz", 2540 | "integrity": "sha512-UTv4VGx+HZivJQwAo1wnRwe1KTvFpfi/NYwN7DcsrdzMXwpRT/Yb6r4SBPoHWj4VuQPakR32g4PUUeyKkdDkBA==", 2541 | "dev": true, 2542 | "requires": { 2543 | "istanbul-lib-coverage": "1.1.1", 2544 | "mkdirp": "0.5.1", 2545 | "path-parse": "1.0.5", 2546 | "supports-color": "3.2.3" 2547 | }, 2548 | "dependencies": { 2549 | "has-flag": { 2550 | "version": "1.0.0", 2551 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", 2552 | "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", 2553 | "dev": true 2554 | }, 2555 | "supports-color": { 2556 | "version": "3.2.3", 2557 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", 2558 | "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", 2559 | "dev": true, 2560 | "requires": { 2561 | "has-flag": "1.0.0" 2562 | } 2563 | } 2564 | } 2565 | }, 2566 | "istanbul-lib-source-maps": { 2567 | "version": "1.2.2", 2568 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-1.2.2.tgz", 2569 | "integrity": "sha512-8BfdqSfEdtip7/wo1RnrvLpHVEd8zMZEDmOFEnpC6dg0vXflHt9nvoAyQUzig2uMSXfF2OBEYBV3CVjIL9JvaQ==", 2570 | "dev": true, 2571 | "requires": { 2572 | "debug": "3.1.0", 2573 | "istanbul-lib-coverage": "1.1.1", 2574 | "mkdirp": "0.5.1", 2575 | "rimraf": "2.6.2", 2576 | "source-map": "0.5.7" 2577 | }, 2578 | "dependencies": { 2579 | "debug": { 2580 | "version": "3.1.0", 2581 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2582 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2583 | "dev": true, 2584 | "requires": { 2585 | "ms": "2.0.0" 2586 | } 2587 | } 2588 | } 2589 | }, 2590 | "istanbul-reports": { 2591 | "version": "1.1.3", 2592 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-1.1.3.tgz", 2593 | "integrity": "sha512-ZEelkHh8hrZNI5xDaKwPMFwDsUf5wIEI2bXAFGp1e6deR2mnEKBPhLJEgr4ZBt8Gi6Mj38E/C8kcy9XLggVO2Q==", 2594 | "dev": true, 2595 | "requires": { 2596 | "handlebars": "4.0.11" 2597 | } 2598 | }, 2599 | "jest": { 2600 | "version": "22.0.4", 2601 | "resolved": "https://registry.npmjs.org/jest/-/jest-22.0.4.tgz", 2602 | "integrity": "sha512-S0tmgK5psULvt/11QzgAZWGpY5y5TkMRzd3T21Q13JzTx37Vx6F0Nw022c9Kc/IbEy+AHkKkGFVO5QafE8MrDg==", 2603 | "dev": true, 2604 | "requires": { 2605 | "jest-cli": "22.0.4" 2606 | }, 2607 | "dependencies": { 2608 | "jest-cli": { 2609 | "version": "22.0.4", 2610 | "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-22.0.4.tgz", 2611 | "integrity": "sha512-f1lZRM13IwIINzjE3RebXQKtQLiKncpSrbJZ/aTZJXmzEWGdgSayW4ESyhU+xK3uGiJEUSzbHjwPY6nGJ8VbUA==", 2612 | "dev": true, 2613 | "requires": { 2614 | "ansi-escapes": "3.0.0", 2615 | "chalk": "2.3.0", 2616 | "glob": "7.1.2", 2617 | "graceful-fs": "4.1.11", 2618 | "is-ci": "1.0.10", 2619 | "istanbul-api": "1.2.1", 2620 | "istanbul-lib-coverage": "1.1.1", 2621 | "istanbul-lib-instrument": "1.9.1", 2622 | "istanbul-lib-source-maps": "1.2.2", 2623 | "jest-changed-files": "22.0.3", 2624 | "jest-config": "22.0.4", 2625 | "jest-environment-jsdom": "22.0.4", 2626 | "jest-get-type": "22.0.3", 2627 | "jest-haste-map": "22.0.3", 2628 | "jest-message-util": "22.0.3", 2629 | "jest-regex-util": "22.0.3", 2630 | "jest-resolve-dependencies": "22.0.3", 2631 | "jest-runner": "22.0.4", 2632 | "jest-runtime": "22.0.4", 2633 | "jest-snapshot": "22.0.3", 2634 | "jest-util": "22.0.4", 2635 | "jest-worker": "22.0.3", 2636 | "micromatch": "2.3.11", 2637 | "node-notifier": "5.1.2", 2638 | "realpath-native": "1.0.0", 2639 | "rimraf": "2.6.2", 2640 | "slash": "1.0.0", 2641 | "string-length": "2.0.0", 2642 | "strip-ansi": "4.0.0", 2643 | "which": "1.3.0", 2644 | "yargs": "10.0.3" 2645 | } 2646 | } 2647 | } 2648 | }, 2649 | "jest-changed-files": { 2650 | "version": "22.0.3", 2651 | "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-22.0.3.tgz", 2652 | "integrity": "sha512-CG7eNJNO9x1O/3J4Uhe2QXra1MnC9+KS1f2NeOg+7iQ+8dDCgxCtpusmKfu44TnEyKwkIDhDr6htPfPaI+Fwbw==", 2653 | "dev": true, 2654 | "requires": { 2655 | "throat": "4.1.0" 2656 | } 2657 | }, 2658 | "jest-config": { 2659 | "version": "22.0.4", 2660 | "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-22.0.4.tgz", 2661 | "integrity": "sha512-NcBeixqHjHDZO9+pUj+365LQV2s65d2f0/IrwlUyv0xaJovRNc6eDvoJ/r2UUlHnqjP3Go+R0ECUsXPXjk4SHw==", 2662 | "dev": true, 2663 | "requires": { 2664 | "chalk": "2.3.0", 2665 | "glob": "7.1.2", 2666 | "jest-environment-jsdom": "22.0.4", 2667 | "jest-environment-node": "22.0.4", 2668 | "jest-get-type": "22.0.3", 2669 | "jest-jasmine2": "22.0.4", 2670 | "jest-regex-util": "22.0.3", 2671 | "jest-resolve": "22.0.4", 2672 | "jest-util": "22.0.4", 2673 | "jest-validate": "22.0.3", 2674 | "pretty-format": "22.0.3" 2675 | } 2676 | }, 2677 | "jest-diff": { 2678 | "version": "22.0.3", 2679 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-22.0.3.tgz", 2680 | "integrity": "sha512-Y7xN9Lc/NgFvR14lvjrJXB6x2x1LLe5NnMyzLvilBSSOyjy9uAVnR2Bt1YgzdfRrfaxsx7xFUVcqXLUnPkrJcA==", 2681 | "dev": true, 2682 | "requires": { 2683 | "chalk": "2.3.0", 2684 | "diff": "3.4.0", 2685 | "jest-get-type": "22.0.3", 2686 | "pretty-format": "22.0.3" 2687 | } 2688 | }, 2689 | "jest-docblock": { 2690 | "version": "22.0.3", 2691 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-22.0.3.tgz", 2692 | "integrity": "sha512-LhviP2rqIg2IzS6m97W7T032oMrT699Tr6Njjhhl4FCLj+75BUy9CsSmGgfoVEql1uc+myBkssvcbn7T9xDR+A==", 2693 | "dev": true, 2694 | "requires": { 2695 | "detect-newline": "2.1.0" 2696 | } 2697 | }, 2698 | "jest-environment-jsdom": { 2699 | "version": "22.0.4", 2700 | "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-22.0.4.tgz", 2701 | "integrity": "sha512-vnjefLZlsNsmnjKcaXkx2IxTBNG40vfRVOdMfcfkPkq85JxFB7wzNtjLx+RIfiNpIZd04C1PXbF0aJIenY85Ng==", 2702 | "dev": true, 2703 | "requires": { 2704 | "jest-mock": "22.0.3", 2705 | "jest-util": "22.0.4", 2706 | "jsdom": "11.5.1" 2707 | } 2708 | }, 2709 | "jest-environment-node": { 2710 | "version": "22.0.4", 2711 | "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-22.0.4.tgz", 2712 | "integrity": "sha512-9vjNKb86UivvKCZCudMNixQgdMnOG7ql6iVYnaiK0CmvZ0WQD+mlM10NvgiWpRv4HstcnRL1pY/GSIHXAD6qXw==", 2713 | "dev": true, 2714 | "requires": { 2715 | "jest-mock": "22.0.3", 2716 | "jest-util": "22.0.4" 2717 | } 2718 | }, 2719 | "jest-get-type": { 2720 | "version": "22.0.3", 2721 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-22.0.3.tgz", 2722 | "integrity": "sha512-TaJnc/lnJQ3jwry+NUWkqaJmKrM/Ut3XdK89HfiqdI3DMRLd6Zb4wyKjwuNP37MEQqlNg0YWH4sbBR8D4exjCA==", 2723 | "dev": true 2724 | }, 2725 | "jest-haste-map": { 2726 | "version": "22.0.3", 2727 | "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-22.0.3.tgz", 2728 | "integrity": "sha512-VosIMOFQFu1rTF+MvOWVuv2KVmZ9eTkRgfwW2yUAs6/AhwmIfXRl/tih+fIOYcHzU4Auu1G8Fvl2kkF5g0k6/A==", 2729 | "dev": true, 2730 | "requires": { 2731 | "fb-watchman": "2.0.0", 2732 | "graceful-fs": "4.1.11", 2733 | "jest-docblock": "22.0.3", 2734 | "jest-worker": "22.0.3", 2735 | "micromatch": "2.3.11", 2736 | "sane": "2.2.0" 2737 | } 2738 | }, 2739 | "jest-jasmine2": { 2740 | "version": "22.0.4", 2741 | "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-22.0.4.tgz", 2742 | "integrity": "sha512-pn1XPHUkffHK6oNY1Dfl/+Rg0UuTdlg3aGDnjyK6dZzGEBeiH1uKuSgZEjy3Lj461l3atpzsQyw7ilXPyjFnUw==", 2743 | "dev": true, 2744 | "requires": { 2745 | "callsites": "2.0.0", 2746 | "chalk": "2.3.0", 2747 | "expect": "22.0.3", 2748 | "graceful-fs": "4.1.11", 2749 | "jest-diff": "22.0.3", 2750 | "jest-matcher-utils": "22.0.3", 2751 | "jest-message-util": "22.0.3", 2752 | "jest-snapshot": "22.0.3", 2753 | "source-map-support": "0.5.0" 2754 | } 2755 | }, 2756 | "jest-leak-detector": { 2757 | "version": "22.0.3", 2758 | "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-22.0.3.tgz", 2759 | "integrity": "sha512-xyVdAmcG8M3jWtVeadDUU6MAHLBrjkP4clz2UtTZ1gpe5bRLk27VjQOpzTwK20MkV/6iZQhSuRVuzHS5kD0HpA==", 2760 | "dev": true, 2761 | "requires": { 2762 | "pretty-format": "22.0.3", 2763 | "weak": "1.0.1" 2764 | } 2765 | }, 2766 | "jest-matcher-utils": { 2767 | "version": "22.0.3", 2768 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-22.0.3.tgz", 2769 | "integrity": "sha512-FJbKpCR3K7YYE/Pnvy5OrLFgPEswpYWIfVtdwT2NC6pBARbYGX39KF3bTxS9yg2mv0YL2zHe3UbwzFsi9nFpVA==", 2770 | "dev": true, 2771 | "requires": { 2772 | "chalk": "2.3.0", 2773 | "jest-get-type": "22.0.3", 2774 | "pretty-format": "22.0.3" 2775 | } 2776 | }, 2777 | "jest-message-util": { 2778 | "version": "22.0.3", 2779 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-22.0.3.tgz", 2780 | "integrity": "sha512-AVBdCx7Oj5wBpMOH089lx7Zgwpdz9HbReA82HuVAlIT4kEQRvCy6Sl9yVWDGJwHTgB/OYQGkgmbv/P/K8TkWNw==", 2781 | "dev": true, 2782 | "requires": { 2783 | "@babel/code-frame": "7.0.0-beta.36", 2784 | "chalk": "2.3.0", 2785 | "micromatch": "2.3.11", 2786 | "slash": "1.0.0", 2787 | "stack-utils": "1.0.1" 2788 | } 2789 | }, 2790 | "jest-mock": { 2791 | "version": "22.0.3", 2792 | "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-22.0.3.tgz", 2793 | "integrity": "sha512-donODXcDG03EAEavc9xfJ7fBF/LNVjoZYkmj9DLrQ1B9YcT6wh8Xx7IYg25b8V/8F/eXPMAE0KK5q6Fqe6yAeg==", 2794 | "dev": true 2795 | }, 2796 | "jest-regex-util": { 2797 | "version": "22.0.3", 2798 | "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-22.0.3.tgz", 2799 | "integrity": "sha512-mplC9chiAotES3ClzNhy0SJcfHB2DivooKJZW+2hDdvP8LLB+OUI+D6bJd7sncbKUsyFcmblEvpm/zz/hef7HA==", 2800 | "dev": true 2801 | }, 2802 | "jest-resolve": { 2803 | "version": "22.0.4", 2804 | "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-22.0.4.tgz", 2805 | "integrity": "sha512-yoxHsX4MTT2Ra/dFia9VCunzsA/4jMBENMmLjREIUkCIP1edk/PZUOGVVf680Gw04CtmT5stETylcbmbL7hJBw==", 2806 | "dev": true, 2807 | "requires": { 2808 | "browser-resolve": "1.11.2", 2809 | "chalk": "2.3.0" 2810 | } 2811 | }, 2812 | "jest-resolve-dependencies": { 2813 | "version": "22.0.3", 2814 | "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-22.0.3.tgz", 2815 | "integrity": "sha512-u9MUNJIa9GJ0YFhvM0+Scr4tyX84nC42d3w18Cly1doY7pTT+9momm+TncpuDlFyB2aNmS8SfdEbiLr1e6tBwg==", 2816 | "dev": true, 2817 | "requires": { 2818 | "jest-regex-util": "22.0.3" 2819 | } 2820 | }, 2821 | "jest-runner": { 2822 | "version": "22.0.4", 2823 | "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-22.0.4.tgz", 2824 | "integrity": "sha512-srBkbqmiSB+jzSaG652fmi3kS6rV6wS/4fOG8dxxBg3dCqNQcM2/L3TI3ZK0SwIAcdGJh5Gybs8aDboT8K9Cdw==", 2825 | "dev": true, 2826 | "requires": { 2827 | "jest-config": "22.0.4", 2828 | "jest-docblock": "22.0.3", 2829 | "jest-haste-map": "22.0.3", 2830 | "jest-jasmine2": "22.0.4", 2831 | "jest-leak-detector": "22.0.3", 2832 | "jest-message-util": "22.0.3", 2833 | "jest-runtime": "22.0.4", 2834 | "jest-util": "22.0.4", 2835 | "jest-worker": "22.0.3", 2836 | "throat": "4.1.0" 2837 | } 2838 | }, 2839 | "jest-runtime": { 2840 | "version": "22.0.4", 2841 | "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-22.0.4.tgz", 2842 | "integrity": "sha512-+7uEwf/4f8k1E/eViyGK6/M5yA4O3f6TdWViuqF9MV7vXwG2OVJu8YEZa5239nEnHJiwinXp4eZXX+HB4pQRPg==", 2843 | "dev": true, 2844 | "requires": { 2845 | "babel-core": "6.26.0", 2846 | "babel-jest": "22.0.4", 2847 | "babel-plugin-istanbul": "4.1.5", 2848 | "chalk": "2.3.0", 2849 | "convert-source-map": "1.5.1", 2850 | "graceful-fs": "4.1.11", 2851 | "jest-config": "22.0.4", 2852 | "jest-haste-map": "22.0.3", 2853 | "jest-regex-util": "22.0.3", 2854 | "jest-resolve": "22.0.4", 2855 | "jest-util": "22.0.4", 2856 | "json-stable-stringify": "1.0.1", 2857 | "micromatch": "2.3.11", 2858 | "realpath-native": "1.0.0", 2859 | "slash": "1.0.0", 2860 | "strip-bom": "3.0.0", 2861 | "write-file-atomic": "2.3.0", 2862 | "yargs": "10.0.3" 2863 | }, 2864 | "dependencies": { 2865 | "strip-bom": { 2866 | "version": "3.0.0", 2867 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2868 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2869 | "dev": true 2870 | } 2871 | } 2872 | }, 2873 | "jest-snapshot": { 2874 | "version": "22.0.3", 2875 | "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-22.0.3.tgz", 2876 | "integrity": "sha512-e/a/EvMsY5XROWy4QWX6PvYziuJ8ttD6+QcnbogODWtx2LGhvVQOb7pmqGTo0tL/p0vzFetZA9GlZSh/EfMepg==", 2877 | "dev": true, 2878 | "requires": { 2879 | "chalk": "2.3.0", 2880 | "jest-diff": "22.0.3", 2881 | "jest-matcher-utils": "22.0.3", 2882 | "mkdirp": "0.5.1", 2883 | "natural-compare": "1.4.0", 2884 | "pretty-format": "22.0.3" 2885 | } 2886 | }, 2887 | "jest-util": { 2888 | "version": "22.0.4", 2889 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-22.0.4.tgz", 2890 | "integrity": "sha512-gNNPtcCFkVh7daKIl3/06eoQ90QXGXCyDOfyZ3IEyTWmHBdX3GvklcOtyGcdOvrYEubaZTfMcMKmEeo/6sRTog==", 2891 | "dev": true, 2892 | "requires": { 2893 | "callsites": "2.0.0", 2894 | "chalk": "2.3.0", 2895 | "graceful-fs": "4.1.11", 2896 | "is-ci": "1.0.10", 2897 | "jest-message-util": "22.0.3", 2898 | "jest-validate": "22.0.3", 2899 | "mkdirp": "0.5.1" 2900 | } 2901 | }, 2902 | "jest-validate": { 2903 | "version": "22.0.3", 2904 | "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-22.0.3.tgz", 2905 | "integrity": "sha512-GmlLmPCtrSQ3iB4A1uxcfjawaaQnwESCDcUg5tMxJKeBbmPdcWPAb6EWzvANxULPUV7hfPKLwg4xIPpi7cx1/g==", 2906 | "dev": true, 2907 | "requires": { 2908 | "chalk": "2.3.0", 2909 | "jest-get-type": "22.0.3", 2910 | "leven": "2.1.0", 2911 | "pretty-format": "22.0.3" 2912 | } 2913 | }, 2914 | "jest-worker": { 2915 | "version": "22.0.3", 2916 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-22.0.3.tgz", 2917 | "integrity": "sha512-fPdCTnogFQiR0CP6whEsIly2RfcHxvalqyLjhui6qa1SnOmHiX7L8k4Umo8CBIp5ndWY0+ej1o7OTE5MlzPabg==", 2918 | "dev": true, 2919 | "requires": { 2920 | "merge-stream": "1.0.1" 2921 | } 2922 | }, 2923 | "js-tokens": { 2924 | "version": "3.0.2", 2925 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 2926 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 2927 | "dev": true 2928 | }, 2929 | "js-yaml": { 2930 | "version": "3.10.0", 2931 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.10.0.tgz", 2932 | "integrity": "sha512-O2v52ffjLa9VeM43J4XocZE//WT9N0IiwDa3KSHH7Tu8CtH+1qM8SIZvnsTh6v+4yFy5KUY3BHUVwjpfAWsjIA==", 2933 | "dev": true, 2934 | "requires": { 2935 | "argparse": "1.0.9", 2936 | "esprima": "4.0.0" 2937 | } 2938 | }, 2939 | "jsbn": { 2940 | "version": "0.1.1", 2941 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 2942 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 2943 | "optional": true 2944 | }, 2945 | "jsdom": { 2946 | "version": "11.5.1", 2947 | "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-11.5.1.tgz", 2948 | "integrity": "sha512-89ztIZ03aYK9f1uUrLXLsZndRge/JnZjzjpaN+lrse3coqz+8PR/dX4WLHpbF5fIKTXhDjFODOJw2328lPJ90g==", 2949 | "dev": true, 2950 | "requires": { 2951 | "abab": "1.0.4", 2952 | "acorn": "5.3.0", 2953 | "acorn-globals": "4.1.0", 2954 | "array-equal": "1.0.0", 2955 | "browser-process-hrtime": "0.1.2", 2956 | "content-type-parser": "1.0.2", 2957 | "cssom": "0.3.2", 2958 | "cssstyle": "0.2.37", 2959 | "domexception": "1.0.0", 2960 | "escodegen": "1.9.0", 2961 | "html-encoding-sniffer": "1.0.2", 2962 | "left-pad": "1.2.0", 2963 | "nwmatcher": "1.4.3", 2964 | "parse5": "3.0.3", 2965 | "pn": "1.0.0", 2966 | "request": "2.83.0", 2967 | "request-promise-native": "1.0.5", 2968 | "sax": "1.2.4", 2969 | "symbol-tree": "3.2.2", 2970 | "tough-cookie": "2.3.3", 2971 | "webidl-conversions": "4.0.2", 2972 | "whatwg-encoding": "1.0.3", 2973 | "whatwg-url": "6.4.0", 2974 | "xml-name-validator": "2.0.1" 2975 | } 2976 | }, 2977 | "jsesc": { 2978 | "version": "1.3.0", 2979 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", 2980 | "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=", 2981 | "dev": true 2982 | }, 2983 | "json-schema": { 2984 | "version": "0.2.3", 2985 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 2986 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 2987 | }, 2988 | "json-schema-traverse": { 2989 | "version": "0.3.1", 2990 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 2991 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=" 2992 | }, 2993 | "json-stable-stringify": { 2994 | "version": "1.0.1", 2995 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 2996 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 2997 | "dev": true, 2998 | "requires": { 2999 | "jsonify": "0.0.0" 3000 | } 3001 | }, 3002 | "json-stringify-safe": { 3003 | "version": "5.0.1", 3004 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 3005 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 3006 | }, 3007 | "json5": { 3008 | "version": "0.5.1", 3009 | "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", 3010 | "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", 3011 | "dev": true 3012 | }, 3013 | "jsonify": { 3014 | "version": "0.0.0", 3015 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 3016 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 3017 | "dev": true 3018 | }, 3019 | "jsprim": { 3020 | "version": "1.4.1", 3021 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 3022 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 3023 | "requires": { 3024 | "assert-plus": "1.0.0", 3025 | "extsprintf": "1.3.0", 3026 | "json-schema": "0.2.3", 3027 | "verror": "1.10.0" 3028 | } 3029 | }, 3030 | "jwa": { 3031 | "version": "1.1.5", 3032 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.1.5.tgz", 3033 | "integrity": "sha1-oFUs4CIHQs1S4VN3SjKQXDDnVuU=", 3034 | "requires": { 3035 | "base64url": "2.0.0", 3036 | "buffer-equal-constant-time": "1.0.1", 3037 | "ecdsa-sig-formatter": "1.0.9", 3038 | "safe-buffer": "5.1.1" 3039 | } 3040 | }, 3041 | "jws": { 3042 | "version": "3.1.4", 3043 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.1.4.tgz", 3044 | "integrity": "sha1-+ei5M46KhHJ31kRLFGT2GIDgUKI=", 3045 | "requires": { 3046 | "base64url": "2.0.0", 3047 | "jwa": "1.1.5", 3048 | "safe-buffer": "5.1.1" 3049 | } 3050 | }, 3051 | "kind-of": { 3052 | "version": "3.2.2", 3053 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 3054 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 3055 | "dev": true, 3056 | "requires": { 3057 | "is-buffer": "1.1.6" 3058 | } 3059 | }, 3060 | "lazy-cache": { 3061 | "version": "1.0.4", 3062 | "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", 3063 | "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=", 3064 | "dev": true, 3065 | "optional": true 3066 | }, 3067 | "lcid": { 3068 | "version": "1.0.0", 3069 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", 3070 | "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", 3071 | "dev": true, 3072 | "requires": { 3073 | "invert-kv": "1.0.0" 3074 | } 3075 | }, 3076 | "left-pad": { 3077 | "version": "1.2.0", 3078 | "resolved": "https://registry.npmjs.org/left-pad/-/left-pad-1.2.0.tgz", 3079 | "integrity": "sha1-0wpzxrggHY99jnlWupYWCHpo4O4=", 3080 | "dev": true 3081 | }, 3082 | "leven": { 3083 | "version": "2.1.0", 3084 | "resolved": "https://registry.npmjs.org/leven/-/leven-2.1.0.tgz", 3085 | "integrity": "sha1-wuep93IJTe6dNCAq6KzORoeHVYA=", 3086 | "dev": true 3087 | }, 3088 | "levn": { 3089 | "version": "0.3.0", 3090 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 3091 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 3092 | "dev": true, 3093 | "requires": { 3094 | "prelude-ls": "1.1.2", 3095 | "type-check": "0.3.2" 3096 | } 3097 | }, 3098 | "load-json-file": { 3099 | "version": "1.1.0", 3100 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", 3101 | "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", 3102 | "dev": true, 3103 | "requires": { 3104 | "graceful-fs": "4.1.11", 3105 | "parse-json": "2.2.0", 3106 | "pify": "2.3.0", 3107 | "pinkie-promise": "2.0.1", 3108 | "strip-bom": "2.0.0" 3109 | } 3110 | }, 3111 | "locate-path": { 3112 | "version": "2.0.0", 3113 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 3114 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 3115 | "dev": true, 3116 | "requires": { 3117 | "p-locate": "2.0.0", 3118 | "path-exists": "3.0.0" 3119 | } 3120 | }, 3121 | "lodash": { 3122 | "version": "4.17.4", 3123 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 3124 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" 3125 | }, 3126 | "lodash.noop": { 3127 | "version": "3.0.1", 3128 | "resolved": "https://registry.npmjs.org/lodash.noop/-/lodash.noop-3.0.1.tgz", 3129 | "integrity": "sha1-OBiPTWUKOkdCWEObluxFsyYXEzw=" 3130 | }, 3131 | "lodash.sortby": { 3132 | "version": "4.7.0", 3133 | "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", 3134 | "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=", 3135 | "dev": true 3136 | }, 3137 | "longest": { 3138 | "version": "1.0.1", 3139 | "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", 3140 | "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=", 3141 | "dev": true 3142 | }, 3143 | "loose-envify": { 3144 | "version": "1.3.1", 3145 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.3.1.tgz", 3146 | "integrity": "sha1-0aitM/qc4OcT1l/dCsi3SNR4yEg=", 3147 | "dev": true, 3148 | "requires": { 3149 | "js-tokens": "3.0.2" 3150 | } 3151 | }, 3152 | "lru-cache": { 3153 | "version": "4.1.1", 3154 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", 3155 | "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", 3156 | "dev": true, 3157 | "requires": { 3158 | "pseudomap": "1.0.2", 3159 | "yallist": "2.1.2" 3160 | } 3161 | }, 3162 | "makeerror": { 3163 | "version": "1.0.11", 3164 | "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.11.tgz", 3165 | "integrity": "sha1-4BpckQnyr3lmDk6LlYd5AYT1qWw=", 3166 | "dev": true, 3167 | "requires": { 3168 | "tmpl": "1.0.4" 3169 | } 3170 | }, 3171 | "mem": { 3172 | "version": "1.1.0", 3173 | "resolved": "https://registry.npmjs.org/mem/-/mem-1.1.0.tgz", 3174 | "integrity": "sha1-Xt1StIXKHZAP5kiVUFOZoN+kX3Y=", 3175 | "dev": true, 3176 | "requires": { 3177 | "mimic-fn": "1.1.0" 3178 | } 3179 | }, 3180 | "merge": { 3181 | "version": "1.2.0", 3182 | "resolved": "https://registry.npmjs.org/merge/-/merge-1.2.0.tgz", 3183 | "integrity": "sha1-dTHjnUlJwoGma4xabgJl6LBYlNo=", 3184 | "dev": true 3185 | }, 3186 | "merge-stream": { 3187 | "version": "1.0.1", 3188 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-1.0.1.tgz", 3189 | "integrity": "sha1-QEEgLVCKNCugAXQAjfDCUbjBNeE=", 3190 | "dev": true, 3191 | "requires": { 3192 | "readable-stream": "2.3.3" 3193 | } 3194 | }, 3195 | "micromatch": { 3196 | "version": "2.3.11", 3197 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 3198 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 3199 | "dev": true, 3200 | "requires": { 3201 | "arr-diff": "2.0.0", 3202 | "array-unique": "0.2.1", 3203 | "braces": "1.8.5", 3204 | "expand-brackets": "0.1.5", 3205 | "extglob": "0.3.2", 3206 | "filename-regex": "2.0.1", 3207 | "is-extglob": "1.0.0", 3208 | "is-glob": "2.0.1", 3209 | "kind-of": "3.2.2", 3210 | "normalize-path": "2.1.1", 3211 | "object.omit": "2.0.1", 3212 | "parse-glob": "3.0.4", 3213 | "regex-cache": "0.4.4" 3214 | } 3215 | }, 3216 | "mime": { 3217 | "version": "1.6.0", 3218 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 3219 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 3220 | }, 3221 | "mime-db": { 3222 | "version": "1.30.0", 3223 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", 3224 | "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=" 3225 | }, 3226 | "mime-types": { 3227 | "version": "2.1.17", 3228 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", 3229 | "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", 3230 | "requires": { 3231 | "mime-db": "1.30.0" 3232 | } 3233 | }, 3234 | "mimic-fn": { 3235 | "version": "1.1.0", 3236 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.1.0.tgz", 3237 | "integrity": "sha1-5md4PZLonb00KBi1IwudYqZyrRg=", 3238 | "dev": true 3239 | }, 3240 | "minimatch": { 3241 | "version": "3.0.4", 3242 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 3243 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 3244 | "requires": { 3245 | "brace-expansion": "1.1.8" 3246 | } 3247 | }, 3248 | "minimist": { 3249 | "version": "0.0.8", 3250 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 3251 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 3252 | }, 3253 | "mkdirp": { 3254 | "version": "0.5.1", 3255 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 3256 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 3257 | "requires": { 3258 | "minimist": "0.0.8" 3259 | } 3260 | }, 3261 | "ms": { 3262 | "version": "2.0.0", 3263 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 3264 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 3265 | "dev": true 3266 | }, 3267 | "nan": { 3268 | "version": "2.8.0", 3269 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.8.0.tgz", 3270 | "integrity": "sha1-7XFfP+neArV6XmJS2QqWZ14fCFo=", 3271 | "dev": true, 3272 | "optional": true 3273 | }, 3274 | "natural-compare": { 3275 | "version": "1.4.0", 3276 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3277 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 3278 | "dev": true 3279 | }, 3280 | "node-dir": { 3281 | "version": "0.1.17", 3282 | "resolved": "https://registry.npmjs.org/node-dir/-/node-dir-0.1.17.tgz", 3283 | "integrity": "sha1-X1Zl2TNRM1yqvvjxxVRRbPXx5OU=", 3284 | "requires": { 3285 | "minimatch": "3.0.4" 3286 | } 3287 | }, 3288 | "node-forge": { 3289 | "version": "0.7.1", 3290 | "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.7.1.tgz", 3291 | "integrity": "sha1-naYR6giYL0uUIGs760zJZl8gwwA=" 3292 | }, 3293 | "node-int64": { 3294 | "version": "0.4.0", 3295 | "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", 3296 | "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=", 3297 | "dev": true 3298 | }, 3299 | "node-notifier": { 3300 | "version": "5.1.2", 3301 | "resolved": "https://registry.npmjs.org/node-notifier/-/node-notifier-5.1.2.tgz", 3302 | "integrity": "sha1-L6nhJgX6EACdRFSdb82KY93g5P8=", 3303 | "dev": true, 3304 | "requires": { 3305 | "growly": "1.3.0", 3306 | "semver": "5.4.1", 3307 | "shellwords": "0.1.1", 3308 | "which": "1.3.0" 3309 | } 3310 | }, 3311 | "normalize-package-data": { 3312 | "version": "2.4.0", 3313 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 3314 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 3315 | "dev": true, 3316 | "requires": { 3317 | "hosted-git-info": "2.5.0", 3318 | "is-builtin-module": "1.0.0", 3319 | "semver": "5.4.1", 3320 | "validate-npm-package-license": "3.0.1" 3321 | } 3322 | }, 3323 | "normalize-path": { 3324 | "version": "2.1.1", 3325 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 3326 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 3327 | "dev": true, 3328 | "requires": { 3329 | "remove-trailing-separator": "1.1.0" 3330 | } 3331 | }, 3332 | "npm-run-path": { 3333 | "version": "2.0.2", 3334 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 3335 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 3336 | "dev": true, 3337 | "requires": { 3338 | "path-key": "2.0.1" 3339 | } 3340 | }, 3341 | "number-is-nan": { 3342 | "version": "1.0.1", 3343 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 3344 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 3345 | "dev": true 3346 | }, 3347 | "nwmatcher": { 3348 | "version": "1.4.3", 3349 | "resolved": "https://registry.npmjs.org/nwmatcher/-/nwmatcher-1.4.3.tgz", 3350 | "integrity": "sha512-IKdSTiDWCarf2JTS5e9e2+5tPZGdkRJ79XjYV0pzK8Q9BpsFyBq1RGKxzs7Q8UBushGw7m6TzVKz6fcY99iSWw==", 3351 | "dev": true 3352 | }, 3353 | "oauth-sign": { 3354 | "version": "0.8.2", 3355 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 3356 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=" 3357 | }, 3358 | "object-assign": { 3359 | "version": "4.1.1", 3360 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 3361 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 3362 | "dev": true 3363 | }, 3364 | "object-keys": { 3365 | "version": "1.0.11", 3366 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", 3367 | "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=", 3368 | "dev": true 3369 | }, 3370 | "object.getownpropertydescriptors": { 3371 | "version": "2.0.3", 3372 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", 3373 | "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", 3374 | "dev": true, 3375 | "requires": { 3376 | "define-properties": "1.1.2", 3377 | "es-abstract": "1.10.0" 3378 | } 3379 | }, 3380 | "object.omit": { 3381 | "version": "2.0.1", 3382 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 3383 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 3384 | "dev": true, 3385 | "requires": { 3386 | "for-own": "0.1.5", 3387 | "is-extendable": "0.1.1" 3388 | } 3389 | }, 3390 | "once": { 3391 | "version": "1.4.0", 3392 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3393 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 3394 | "dev": true, 3395 | "requires": { 3396 | "wrappy": "1.0.2" 3397 | } 3398 | }, 3399 | "optimist": { 3400 | "version": "0.6.1", 3401 | "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", 3402 | "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", 3403 | "dev": true, 3404 | "requires": { 3405 | "minimist": "0.0.8", 3406 | "wordwrap": "0.0.3" 3407 | } 3408 | }, 3409 | "optionator": { 3410 | "version": "0.8.2", 3411 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 3412 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 3413 | "dev": true, 3414 | "requires": { 3415 | "deep-is": "0.1.3", 3416 | "fast-levenshtein": "2.0.6", 3417 | "levn": "0.3.0", 3418 | "prelude-ls": "1.1.2", 3419 | "type-check": "0.3.2", 3420 | "wordwrap": "1.0.0" 3421 | }, 3422 | "dependencies": { 3423 | "wordwrap": { 3424 | "version": "1.0.0", 3425 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3426 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3427 | "dev": true 3428 | } 3429 | } 3430 | }, 3431 | "os-homedir": { 3432 | "version": "1.0.2", 3433 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 3434 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 3435 | "dev": true 3436 | }, 3437 | "os-locale": { 3438 | "version": "2.1.0", 3439 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-2.1.0.tgz", 3440 | "integrity": "sha512-3sslG3zJbEYcaC4YVAvDorjGxc7tv6KVATnLPZONiljsUncvihe9BQoVCEs0RZ1kmf4Hk9OBqlZfJZWI4GanKA==", 3441 | "dev": true, 3442 | "requires": { 3443 | "execa": "0.7.0", 3444 | "lcid": "1.0.0", 3445 | "mem": "1.1.0" 3446 | } 3447 | }, 3448 | "os-tmpdir": { 3449 | "version": "1.0.2", 3450 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 3451 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 3452 | "dev": true 3453 | }, 3454 | "p-finally": { 3455 | "version": "1.0.0", 3456 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 3457 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 3458 | "dev": true 3459 | }, 3460 | "p-limit": { 3461 | "version": "1.1.0", 3462 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.1.0.tgz", 3463 | "integrity": "sha1-sH/y2aXYi+yAYDWJWiurZqJ5iLw=", 3464 | "dev": true 3465 | }, 3466 | "p-locate": { 3467 | "version": "2.0.0", 3468 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 3469 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 3470 | "dev": true, 3471 | "requires": { 3472 | "p-limit": "1.1.0" 3473 | } 3474 | }, 3475 | "parse-glob": { 3476 | "version": "3.0.4", 3477 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 3478 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 3479 | "dev": true, 3480 | "requires": { 3481 | "glob-base": "0.3.0", 3482 | "is-dotfile": "1.0.3", 3483 | "is-extglob": "1.0.0", 3484 | "is-glob": "2.0.1" 3485 | } 3486 | }, 3487 | "parse-json": { 3488 | "version": "2.2.0", 3489 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 3490 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 3491 | "dev": true, 3492 | "requires": { 3493 | "error-ex": "1.3.1" 3494 | } 3495 | }, 3496 | "parse5": { 3497 | "version": "3.0.3", 3498 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-3.0.3.tgz", 3499 | "integrity": "sha512-rgO9Zg5LLLkfJF9E6CCmXlSE4UVceloys8JrFqCcHloC3usd/kJCyPDwH2SOlzix2j3xaP9sUX3e8+kvkuleAA==", 3500 | "dev": true, 3501 | "requires": { 3502 | "@types/node": "8.5.2" 3503 | } 3504 | }, 3505 | "path-exists": { 3506 | "version": "3.0.0", 3507 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 3508 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 3509 | "dev": true 3510 | }, 3511 | "path-is-absolute": { 3512 | "version": "1.0.1", 3513 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3514 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 3515 | "dev": true 3516 | }, 3517 | "path-key": { 3518 | "version": "2.0.1", 3519 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 3520 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 3521 | "dev": true 3522 | }, 3523 | "path-parse": { 3524 | "version": "1.0.5", 3525 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", 3526 | "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=", 3527 | "dev": true 3528 | }, 3529 | "path-type": { 3530 | "version": "1.1.0", 3531 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", 3532 | "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", 3533 | "dev": true, 3534 | "requires": { 3535 | "graceful-fs": "4.1.11", 3536 | "pify": "2.3.0", 3537 | "pinkie-promise": "2.0.1" 3538 | } 3539 | }, 3540 | "performance-now": { 3541 | "version": "2.1.0", 3542 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 3543 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 3544 | }, 3545 | "pify": { 3546 | "version": "2.3.0", 3547 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 3548 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 3549 | "dev": true 3550 | }, 3551 | "pinkie": { 3552 | "version": "2.0.4", 3553 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 3554 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 3555 | "dev": true 3556 | }, 3557 | "pinkie-promise": { 3558 | "version": "2.0.1", 3559 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 3560 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 3561 | "dev": true, 3562 | "requires": { 3563 | "pinkie": "2.0.4" 3564 | } 3565 | }, 3566 | "pn": { 3567 | "version": "1.0.0", 3568 | "resolved": "https://registry.npmjs.org/pn/-/pn-1.0.0.tgz", 3569 | "integrity": "sha1-HPWjCw2AbNGPiPxBprXUrWFbO6k=", 3570 | "dev": true 3571 | }, 3572 | "prelude-ls": { 3573 | "version": "1.1.2", 3574 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 3575 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 3576 | "dev": true 3577 | }, 3578 | "preserve": { 3579 | "version": "0.2.0", 3580 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 3581 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 3582 | "dev": true 3583 | }, 3584 | "pretty-format": { 3585 | "version": "22.0.3", 3586 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-22.0.3.tgz", 3587 | "integrity": "sha512-qXbDFJ2/Kk3HFIaLdOblbsCKQ09kZu4MKbXB+m/EaqD7PZ/wXe2XcRREmQleMh4wmerxlma6eJTh3nxCXYUmmA==", 3588 | "dev": true, 3589 | "requires": { 3590 | "ansi-regex": "3.0.0", 3591 | "ansi-styles": "3.2.0" 3592 | }, 3593 | "dependencies": { 3594 | "ansi-regex": { 3595 | "version": "3.0.0", 3596 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 3597 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 3598 | "dev": true 3599 | } 3600 | } 3601 | }, 3602 | "private": { 3603 | "version": "0.1.8", 3604 | "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", 3605 | "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", 3606 | "dev": true 3607 | }, 3608 | "process-nextick-args": { 3609 | "version": "1.0.7", 3610 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 3611 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", 3612 | "dev": true 3613 | }, 3614 | "pseudomap": { 3615 | "version": "1.0.2", 3616 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 3617 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 3618 | "dev": true 3619 | }, 3620 | "punycode": { 3621 | "version": "1.4.1", 3622 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 3623 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 3624 | }, 3625 | "qs": { 3626 | "version": "6.5.1", 3627 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 3628 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 3629 | }, 3630 | "randomatic": { 3631 | "version": "1.1.7", 3632 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", 3633 | "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", 3634 | "dev": true, 3635 | "requires": { 3636 | "is-number": "3.0.0", 3637 | "kind-of": "4.0.0" 3638 | }, 3639 | "dependencies": { 3640 | "is-number": { 3641 | "version": "3.0.0", 3642 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 3643 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 3644 | "dev": true, 3645 | "requires": { 3646 | "kind-of": "3.2.2" 3647 | }, 3648 | "dependencies": { 3649 | "kind-of": { 3650 | "version": "3.2.2", 3651 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 3652 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 3653 | "dev": true, 3654 | "requires": { 3655 | "is-buffer": "1.1.6" 3656 | } 3657 | } 3658 | } 3659 | }, 3660 | "kind-of": { 3661 | "version": "4.0.0", 3662 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 3663 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 3664 | "dev": true, 3665 | "requires": { 3666 | "is-buffer": "1.1.6" 3667 | } 3668 | } 3669 | } 3670 | }, 3671 | "read-pkg": { 3672 | "version": "1.1.0", 3673 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", 3674 | "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", 3675 | "dev": true, 3676 | "requires": { 3677 | "load-json-file": "1.1.0", 3678 | "normalize-package-data": "2.4.0", 3679 | "path-type": "1.1.0" 3680 | } 3681 | }, 3682 | "read-pkg-up": { 3683 | "version": "1.0.1", 3684 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", 3685 | "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", 3686 | "dev": true, 3687 | "requires": { 3688 | "find-up": "1.1.2", 3689 | "read-pkg": "1.1.0" 3690 | }, 3691 | "dependencies": { 3692 | "find-up": { 3693 | "version": "1.1.2", 3694 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 3695 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 3696 | "dev": true, 3697 | "requires": { 3698 | "path-exists": "2.1.0", 3699 | "pinkie-promise": "2.0.1" 3700 | } 3701 | }, 3702 | "path-exists": { 3703 | "version": "2.1.0", 3704 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 3705 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 3706 | "dev": true, 3707 | "requires": { 3708 | "pinkie-promise": "2.0.1" 3709 | } 3710 | } 3711 | } 3712 | }, 3713 | "readable-stream": { 3714 | "version": "2.3.3", 3715 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 3716 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 3717 | "dev": true, 3718 | "requires": { 3719 | "core-util-is": "1.0.2", 3720 | "inherits": "2.0.3", 3721 | "isarray": "1.0.0", 3722 | "process-nextick-args": "1.0.7", 3723 | "safe-buffer": "5.1.1", 3724 | "string_decoder": "1.0.3", 3725 | "util-deprecate": "1.0.2" 3726 | } 3727 | }, 3728 | "realpath-native": { 3729 | "version": "1.0.0", 3730 | "resolved": "https://registry.npmjs.org/realpath-native/-/realpath-native-1.0.0.tgz", 3731 | "integrity": "sha512-XJtlRJ9jf0E1H1SLeJyQ9PGzQD7S65h1pRXEcAeK48doKOnKxcgPeNohJvD5u/2sI9J1oke6E8bZHS/fmW1UiQ==", 3732 | "dev": true, 3733 | "requires": { 3734 | "util.promisify": "1.0.0" 3735 | } 3736 | }, 3737 | "regenerator-runtime": { 3738 | "version": "0.11.1", 3739 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", 3740 | "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", 3741 | "dev": true 3742 | }, 3743 | "regex-cache": { 3744 | "version": "0.4.4", 3745 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 3746 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 3747 | "dev": true, 3748 | "requires": { 3749 | "is-equal-shallow": "0.1.3" 3750 | } 3751 | }, 3752 | "remove-trailing-separator": { 3753 | "version": "1.1.0", 3754 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 3755 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 3756 | "dev": true 3757 | }, 3758 | "repeat-element": { 3759 | "version": "1.1.2", 3760 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 3761 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 3762 | "dev": true 3763 | }, 3764 | "repeat-string": { 3765 | "version": "1.6.1", 3766 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 3767 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 3768 | "dev": true 3769 | }, 3770 | "repeating": { 3771 | "version": "2.0.1", 3772 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 3773 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 3774 | "dev": true, 3775 | "requires": { 3776 | "is-finite": "1.0.2" 3777 | } 3778 | }, 3779 | "request": { 3780 | "version": "2.83.0", 3781 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 3782 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 3783 | "requires": { 3784 | "aws-sign2": "0.7.0", 3785 | "aws4": "1.6.0", 3786 | "caseless": "0.12.0", 3787 | "combined-stream": "1.0.5", 3788 | "extend": "3.0.1", 3789 | "forever-agent": "0.6.1", 3790 | "form-data": "2.3.1", 3791 | "har-validator": "5.0.3", 3792 | "hawk": "6.0.2", 3793 | "http-signature": "1.2.0", 3794 | "is-typedarray": "1.0.0", 3795 | "isstream": "0.1.2", 3796 | "json-stringify-safe": "5.0.1", 3797 | "mime-types": "2.1.17", 3798 | "oauth-sign": "0.8.2", 3799 | "performance-now": "2.1.0", 3800 | "qs": "6.5.1", 3801 | "safe-buffer": "5.1.1", 3802 | "stringstream": "0.0.5", 3803 | "tough-cookie": "2.3.3", 3804 | "tunnel-agent": "0.6.0", 3805 | "uuid": "3.1.0" 3806 | } 3807 | }, 3808 | "request-promise-core": { 3809 | "version": "1.1.1", 3810 | "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.1.tgz", 3811 | "integrity": "sha1-Pu4AssWqgyOc+wTFcA2jb4HNCLY=", 3812 | "dev": true, 3813 | "requires": { 3814 | "lodash": "4.17.4" 3815 | } 3816 | }, 3817 | "request-promise-native": { 3818 | "version": "1.0.5", 3819 | "resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.5.tgz", 3820 | "integrity": "sha1-UoF3D2jgyXGeUWP9P6tIIhX0/aU=", 3821 | "dev": true, 3822 | "requires": { 3823 | "request-promise-core": "1.1.1", 3824 | "stealthy-require": "1.1.1", 3825 | "tough-cookie": "2.3.3" 3826 | } 3827 | }, 3828 | "require-directory": { 3829 | "version": "2.1.1", 3830 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3831 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3832 | "dev": true 3833 | }, 3834 | "require-main-filename": { 3835 | "version": "1.0.1", 3836 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 3837 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", 3838 | "dev": true 3839 | }, 3840 | "resolve": { 3841 | "version": "1.1.7", 3842 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", 3843 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", 3844 | "dev": true 3845 | }, 3846 | "right-align": { 3847 | "version": "0.1.3", 3848 | "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", 3849 | "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", 3850 | "dev": true, 3851 | "optional": true, 3852 | "requires": { 3853 | "align-text": "0.1.4" 3854 | } 3855 | }, 3856 | "rimraf": { 3857 | "version": "2.6.2", 3858 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 3859 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 3860 | "dev": true, 3861 | "requires": { 3862 | "glob": "7.1.2" 3863 | } 3864 | }, 3865 | "safe-buffer": { 3866 | "version": "5.1.1", 3867 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 3868 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 3869 | }, 3870 | "sane": { 3871 | "version": "2.2.0", 3872 | "resolved": "https://registry.npmjs.org/sane/-/sane-2.2.0.tgz", 3873 | "integrity": "sha512-OSJxhHO0CgPUw3lUm3GhfREAfza45smvEI9ozuFrxKG10GHVo0ryW9FK5VYlLvxj0SV7HVKHW0voYJIRu27GWg==", 3874 | "dev": true, 3875 | "requires": { 3876 | "anymatch": "1.3.2", 3877 | "exec-sh": "0.2.1", 3878 | "fb-watchman": "2.0.0", 3879 | "fsevents": "1.1.3", 3880 | "minimatch": "3.0.4", 3881 | "minimist": "1.2.0", 3882 | "walker": "1.0.7", 3883 | "watch": "0.18.0" 3884 | }, 3885 | "dependencies": { 3886 | "minimist": { 3887 | "version": "1.2.0", 3888 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 3889 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 3890 | "dev": true 3891 | } 3892 | } 3893 | }, 3894 | "sax": { 3895 | "version": "1.2.4", 3896 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 3897 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", 3898 | "dev": true 3899 | }, 3900 | "semver": { 3901 | "version": "5.4.1", 3902 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", 3903 | "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==", 3904 | "dev": true 3905 | }, 3906 | "set-blocking": { 3907 | "version": "2.0.0", 3908 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 3909 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 3910 | "dev": true 3911 | }, 3912 | "shebang-command": { 3913 | "version": "1.2.0", 3914 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 3915 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 3916 | "dev": true, 3917 | "requires": { 3918 | "shebang-regex": "1.0.0" 3919 | } 3920 | }, 3921 | "shebang-regex": { 3922 | "version": "1.0.0", 3923 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 3924 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 3925 | "dev": true 3926 | }, 3927 | "shellwords": { 3928 | "version": "0.1.1", 3929 | "resolved": "https://registry.npmjs.org/shellwords/-/shellwords-0.1.1.tgz", 3930 | "integrity": "sha512-vFwSUfQvqybiICwZY5+DAWIPLKsWO31Q91JSKl3UYv+K5c2QRPzn0qzec6QPu1Qc9eHYItiP3NdJqNVqetYAww==", 3931 | "dev": true 3932 | }, 3933 | "signal-exit": { 3934 | "version": "3.0.2", 3935 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 3936 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 3937 | "dev": true 3938 | }, 3939 | "slash": { 3940 | "version": "1.0.0", 3941 | "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", 3942 | "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", 3943 | "dev": true 3944 | }, 3945 | "sntp": { 3946 | "version": "2.1.0", 3947 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.1.0.tgz", 3948 | "integrity": "sha512-FL1b58BDrqS3A11lJ0zEdnJ3UOKqVxawAkF3k7F0CVN7VQ34aZrV+G8BZ1WC9ZL7NyrwsW0oviwsWDgRuVYtJg==", 3949 | "requires": { 3950 | "hoek": "4.2.0" 3951 | } 3952 | }, 3953 | "source-map": { 3954 | "version": "0.5.7", 3955 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 3956 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 3957 | "dev": true 3958 | }, 3959 | "source-map-support": { 3960 | "version": "0.5.0", 3961 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.0.tgz", 3962 | "integrity": "sha512-vUoN3I7fHQe0R/SJLKRdKYuEdRGogsviXFkHHo17AWaTGv17VLnxw+CFXvqy+y4ORZ3doWLQcxRYfwKrsd/H7Q==", 3963 | "dev": true, 3964 | "requires": { 3965 | "source-map": "0.6.1" 3966 | }, 3967 | "dependencies": { 3968 | "source-map": { 3969 | "version": "0.6.1", 3970 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3971 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3972 | "dev": true 3973 | } 3974 | } 3975 | }, 3976 | "spdx-correct": { 3977 | "version": "1.0.2", 3978 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", 3979 | "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", 3980 | "dev": true, 3981 | "requires": { 3982 | "spdx-license-ids": "1.2.2" 3983 | } 3984 | }, 3985 | "spdx-expression-parse": { 3986 | "version": "1.0.4", 3987 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", 3988 | "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=", 3989 | "dev": true 3990 | }, 3991 | "spdx-license-ids": { 3992 | "version": "1.2.2", 3993 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", 3994 | "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=", 3995 | "dev": true 3996 | }, 3997 | "sprintf-js": { 3998 | "version": "1.0.3", 3999 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 4000 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 4001 | "dev": true 4002 | }, 4003 | "sshpk": { 4004 | "version": "1.13.1", 4005 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", 4006 | "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", 4007 | "requires": { 4008 | "asn1": "0.2.3", 4009 | "assert-plus": "1.0.0", 4010 | "bcrypt-pbkdf": "1.0.1", 4011 | "dashdash": "1.14.1", 4012 | "ecc-jsbn": "0.1.1", 4013 | "getpass": "0.1.7", 4014 | "jsbn": "0.1.1", 4015 | "tweetnacl": "0.14.5" 4016 | } 4017 | }, 4018 | "stack-utils": { 4019 | "version": "1.0.1", 4020 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.1.tgz", 4021 | "integrity": "sha1-1PM6tU6OOHeLDKXP07OvsS22hiA=", 4022 | "dev": true 4023 | }, 4024 | "stealthy-require": { 4025 | "version": "1.1.1", 4026 | "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", 4027 | "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=", 4028 | "dev": true 4029 | }, 4030 | "string-length": { 4031 | "version": "2.0.0", 4032 | "resolved": "https://registry.npmjs.org/string-length/-/string-length-2.0.0.tgz", 4033 | "integrity": "sha1-1A27aGo6zpYMHP/KVivyxF+DY+0=", 4034 | "dev": true, 4035 | "requires": { 4036 | "astral-regex": "1.0.0", 4037 | "strip-ansi": "4.0.0" 4038 | } 4039 | }, 4040 | "string-template": { 4041 | "version": "1.0.0", 4042 | "resolved": "https://registry.npmjs.org/string-template/-/string-template-1.0.0.tgz", 4043 | "integrity": "sha1-np8iM9wA8hhxjsN5oopWc+zKi5Y=" 4044 | }, 4045 | "string-width": { 4046 | "version": "2.1.1", 4047 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 4048 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 4049 | "dev": true, 4050 | "requires": { 4051 | "is-fullwidth-code-point": "2.0.0", 4052 | "strip-ansi": "4.0.0" 4053 | }, 4054 | "dependencies": { 4055 | "is-fullwidth-code-point": { 4056 | "version": "2.0.0", 4057 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 4058 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 4059 | "dev": true 4060 | } 4061 | } 4062 | }, 4063 | "string_decoder": { 4064 | "version": "1.0.3", 4065 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 4066 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 4067 | "dev": true, 4068 | "requires": { 4069 | "safe-buffer": "5.1.1" 4070 | } 4071 | }, 4072 | "stringstream": { 4073 | "version": "0.0.5", 4074 | "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", 4075 | "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=" 4076 | }, 4077 | "strip-ansi": { 4078 | "version": "4.0.0", 4079 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 4080 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 4081 | "dev": true, 4082 | "requires": { 4083 | "ansi-regex": "3.0.0" 4084 | }, 4085 | "dependencies": { 4086 | "ansi-regex": { 4087 | "version": "3.0.0", 4088 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 4089 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 4090 | "dev": true 4091 | } 4092 | } 4093 | }, 4094 | "strip-bom": { 4095 | "version": "2.0.0", 4096 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", 4097 | "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", 4098 | "dev": true, 4099 | "requires": { 4100 | "is-utf8": "0.2.1" 4101 | } 4102 | }, 4103 | "strip-eof": { 4104 | "version": "1.0.0", 4105 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 4106 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 4107 | "dev": true 4108 | }, 4109 | "supports-color": { 4110 | "version": "4.5.0", 4111 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 4112 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 4113 | "dev": true, 4114 | "requires": { 4115 | "has-flag": "2.0.0" 4116 | } 4117 | }, 4118 | "symbol-tree": { 4119 | "version": "3.2.2", 4120 | "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.2.tgz", 4121 | "integrity": "sha1-rifbOPZgp64uHDt9G8KQgZuFGeY=", 4122 | "dev": true 4123 | }, 4124 | "test-exclude": { 4125 | "version": "4.1.1", 4126 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-4.1.1.tgz", 4127 | "integrity": "sha512-35+Asrsk3XHJDBgf/VRFexPgh3UyETv8IAn/LRTiZjVy6rjPVqdEk8dJcJYBzl1w0XCJM48lvTy8SfEsCWS4nA==", 4128 | "dev": true, 4129 | "requires": { 4130 | "arrify": "1.0.1", 4131 | "micromatch": "2.3.11", 4132 | "object-assign": "4.1.1", 4133 | "read-pkg-up": "1.0.1", 4134 | "require-main-filename": "1.0.1" 4135 | } 4136 | }, 4137 | "throat": { 4138 | "version": "4.1.0", 4139 | "resolved": "https://registry.npmjs.org/throat/-/throat-4.1.0.tgz", 4140 | "integrity": "sha1-iQN8vJLFarGJJua6TLsgDhVnKmo=", 4141 | "dev": true 4142 | }, 4143 | "tmpl": { 4144 | "version": "1.0.4", 4145 | "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.4.tgz", 4146 | "integrity": "sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE=", 4147 | "dev": true 4148 | }, 4149 | "to-fast-properties": { 4150 | "version": "1.0.3", 4151 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", 4152 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=", 4153 | "dev": true 4154 | }, 4155 | "tough-cookie": { 4156 | "version": "2.3.3", 4157 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", 4158 | "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", 4159 | "requires": { 4160 | "punycode": "1.4.1" 4161 | } 4162 | }, 4163 | "tr46": { 4164 | "version": "1.0.1", 4165 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-1.0.1.tgz", 4166 | "integrity": "sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk=", 4167 | "dev": true, 4168 | "requires": { 4169 | "punycode": "2.1.0" 4170 | }, 4171 | "dependencies": { 4172 | "punycode": { 4173 | "version": "2.1.0", 4174 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.0.tgz", 4175 | "integrity": "sha1-X4Y+3Im5bbCQdLrXlHvwkFbKTn0=", 4176 | "dev": true 4177 | } 4178 | } 4179 | }, 4180 | "trim-right": { 4181 | "version": "1.0.1", 4182 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 4183 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", 4184 | "dev": true 4185 | }, 4186 | "tunnel-agent": { 4187 | "version": "0.6.0", 4188 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 4189 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 4190 | "requires": { 4191 | "safe-buffer": "5.1.1" 4192 | } 4193 | }, 4194 | "tweetnacl": { 4195 | "version": "0.14.5", 4196 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 4197 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 4198 | "optional": true 4199 | }, 4200 | "type-check": { 4201 | "version": "0.3.2", 4202 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 4203 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 4204 | "dev": true, 4205 | "requires": { 4206 | "prelude-ls": "1.1.2" 4207 | } 4208 | }, 4209 | "uglify-js": { 4210 | "version": "2.8.29", 4211 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", 4212 | "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", 4213 | "dev": true, 4214 | "optional": true, 4215 | "requires": { 4216 | "source-map": "0.5.7", 4217 | "uglify-to-browserify": "1.0.2", 4218 | "yargs": "3.10.0" 4219 | }, 4220 | "dependencies": { 4221 | "yargs": { 4222 | "version": "3.10.0", 4223 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", 4224 | "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", 4225 | "dev": true, 4226 | "optional": true, 4227 | "requires": { 4228 | "camelcase": "1.2.1", 4229 | "cliui": "2.1.0", 4230 | "decamelize": "1.2.0", 4231 | "window-size": "0.1.0" 4232 | } 4233 | } 4234 | } 4235 | }, 4236 | "uglify-to-browserify": { 4237 | "version": "1.0.2", 4238 | "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", 4239 | "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", 4240 | "dev": true, 4241 | "optional": true 4242 | }, 4243 | "util-deprecate": { 4244 | "version": "1.0.2", 4245 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 4246 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 4247 | "dev": true 4248 | }, 4249 | "util.promisify": { 4250 | "version": "1.0.0", 4251 | "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", 4252 | "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", 4253 | "dev": true, 4254 | "requires": { 4255 | "define-properties": "1.1.2", 4256 | "object.getownpropertydescriptors": "2.0.3" 4257 | } 4258 | }, 4259 | "uuid": { 4260 | "version": "3.1.0", 4261 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 4262 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 4263 | }, 4264 | "validate-npm-package-license": { 4265 | "version": "3.0.1", 4266 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", 4267 | "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", 4268 | "dev": true, 4269 | "requires": { 4270 | "spdx-correct": "1.0.2", 4271 | "spdx-expression-parse": "1.0.4" 4272 | } 4273 | }, 4274 | "verror": { 4275 | "version": "1.10.0", 4276 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 4277 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 4278 | "requires": { 4279 | "assert-plus": "1.0.0", 4280 | "core-util-is": "1.0.2", 4281 | "extsprintf": "1.3.0" 4282 | } 4283 | }, 4284 | "walker": { 4285 | "version": "1.0.7", 4286 | "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.7.tgz", 4287 | "integrity": "sha1-L3+bj9ENZ3JisYqITijRlhjgKPs=", 4288 | "dev": true, 4289 | "requires": { 4290 | "makeerror": "1.0.11" 4291 | } 4292 | }, 4293 | "watch": { 4294 | "version": "0.18.0", 4295 | "resolved": "https://registry.npmjs.org/watch/-/watch-0.18.0.tgz", 4296 | "integrity": "sha1-KAlUdsbffJDJYxOJkMClQj60uYY=", 4297 | "dev": true, 4298 | "requires": { 4299 | "exec-sh": "0.2.1", 4300 | "minimist": "1.2.0" 4301 | }, 4302 | "dependencies": { 4303 | "minimist": { 4304 | "version": "1.2.0", 4305 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 4306 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 4307 | "dev": true 4308 | } 4309 | } 4310 | }, 4311 | "weak": { 4312 | "version": "1.0.1", 4313 | "resolved": "https://registry.npmjs.org/weak/-/weak-1.0.1.tgz", 4314 | "integrity": "sha1-q5mqswcGlZqgIAy4z1RbucszuZ4=", 4315 | "dev": true, 4316 | "optional": true, 4317 | "requires": { 4318 | "bindings": "1.3.0", 4319 | "nan": "2.8.0" 4320 | } 4321 | }, 4322 | "webidl-conversions": { 4323 | "version": "4.0.2", 4324 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz", 4325 | "integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg==", 4326 | "dev": true 4327 | }, 4328 | "whatwg-encoding": { 4329 | "version": "1.0.3", 4330 | "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.3.tgz", 4331 | "integrity": "sha512-jLBwwKUhi8WtBfsMQlL4bUUcT8sMkAtQinscJAe/M4KHCkHuUJAF6vuB0tueNIw4c8ziO6AkRmgY+jL3a0iiPw==", 4332 | "dev": true, 4333 | "requires": { 4334 | "iconv-lite": "0.4.19" 4335 | } 4336 | }, 4337 | "whatwg-url": { 4338 | "version": "6.4.0", 4339 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-6.4.0.tgz", 4340 | "integrity": "sha512-Z0CVh/YE217Foyb488eo+iBv+r7eAQ0wSTyApi9n06jhcA3z6Nidg/EGvl0UFkg7kMdKxfBzzr+o9JF+cevgMg==", 4341 | "dev": true, 4342 | "requires": { 4343 | "lodash.sortby": "4.7.0", 4344 | "tr46": "1.0.1", 4345 | "webidl-conversions": "4.0.2" 4346 | } 4347 | }, 4348 | "which": { 4349 | "version": "1.3.0", 4350 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 4351 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 4352 | "dev": true, 4353 | "requires": { 4354 | "isexe": "2.0.0" 4355 | } 4356 | }, 4357 | "which-module": { 4358 | "version": "2.0.0", 4359 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 4360 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 4361 | "dev": true 4362 | }, 4363 | "window-size": { 4364 | "version": "0.1.0", 4365 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", 4366 | "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=", 4367 | "dev": true, 4368 | "optional": true 4369 | }, 4370 | "wordwrap": { 4371 | "version": "0.0.3", 4372 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", 4373 | "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", 4374 | "dev": true 4375 | }, 4376 | "wrap-ansi": { 4377 | "version": "2.1.0", 4378 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 4379 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 4380 | "dev": true, 4381 | "requires": { 4382 | "string-width": "1.0.2", 4383 | "strip-ansi": "3.0.1" 4384 | }, 4385 | "dependencies": { 4386 | "string-width": { 4387 | "version": "1.0.2", 4388 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 4389 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 4390 | "dev": true, 4391 | "requires": { 4392 | "code-point-at": "1.1.0", 4393 | "is-fullwidth-code-point": "1.0.0", 4394 | "strip-ansi": "3.0.1" 4395 | } 4396 | }, 4397 | "strip-ansi": { 4398 | "version": "3.0.1", 4399 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 4400 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 4401 | "dev": true, 4402 | "requires": { 4403 | "ansi-regex": "2.1.1" 4404 | } 4405 | } 4406 | } 4407 | }, 4408 | "wrappy": { 4409 | "version": "1.0.2", 4410 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4411 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 4412 | "dev": true 4413 | }, 4414 | "write-file-atomic": { 4415 | "version": "2.3.0", 4416 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.3.0.tgz", 4417 | "integrity": "sha512-xuPeK4OdjWqtfi59ylvVL0Yn35SF3zgcAcv7rBPFHVaEapaDr4GdGgm3j7ckTwH9wHL7fGmgfAnb0+THrHb8tA==", 4418 | "dev": true, 4419 | "requires": { 4420 | "graceful-fs": "4.1.11", 4421 | "imurmurhash": "0.1.4", 4422 | "signal-exit": "3.0.2" 4423 | } 4424 | }, 4425 | "xml-name-validator": { 4426 | "version": "2.0.1", 4427 | "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-2.0.1.tgz", 4428 | "integrity": "sha1-TYuPHszTQZqjYgYb7O9RXh5VljU=", 4429 | "dev": true 4430 | }, 4431 | "y18n": { 4432 | "version": "3.2.1", 4433 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", 4434 | "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", 4435 | "dev": true 4436 | }, 4437 | "yallist": { 4438 | "version": "2.1.2", 4439 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 4440 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 4441 | "dev": true 4442 | }, 4443 | "yargs": { 4444 | "version": "10.0.3", 4445 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-10.0.3.tgz", 4446 | "integrity": "sha512-DqBpQ8NAUX4GyPP/ijDGHsJya4tYqLQrjPr95HNsr1YwL3+daCfvBwg7+gIC6IdJhR2kATh3hb61vjzMWEtjdw==", 4447 | "dev": true, 4448 | "requires": { 4449 | "cliui": "3.2.0", 4450 | "decamelize": "1.2.0", 4451 | "find-up": "2.1.0", 4452 | "get-caller-file": "1.0.2", 4453 | "os-locale": "2.1.0", 4454 | "require-directory": "2.1.1", 4455 | "require-main-filename": "1.0.1", 4456 | "set-blocking": "2.0.0", 4457 | "string-width": "2.1.1", 4458 | "which-module": "2.0.0", 4459 | "y18n": "3.2.1", 4460 | "yargs-parser": "8.1.0" 4461 | }, 4462 | "dependencies": { 4463 | "cliui": { 4464 | "version": "3.2.0", 4465 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", 4466 | "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", 4467 | "dev": true, 4468 | "requires": { 4469 | "string-width": "1.0.2", 4470 | "strip-ansi": "3.0.1", 4471 | "wrap-ansi": "2.1.0" 4472 | }, 4473 | "dependencies": { 4474 | "string-width": { 4475 | "version": "1.0.2", 4476 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 4477 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 4478 | "dev": true, 4479 | "requires": { 4480 | "code-point-at": "1.1.0", 4481 | "is-fullwidth-code-point": "1.0.0", 4482 | "strip-ansi": "3.0.1" 4483 | } 4484 | } 4485 | } 4486 | }, 4487 | "strip-ansi": { 4488 | "version": "3.0.1", 4489 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 4490 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 4491 | "dev": true, 4492 | "requires": { 4493 | "ansi-regex": "2.1.1" 4494 | } 4495 | } 4496 | } 4497 | }, 4498 | "yargs-parser": { 4499 | "version": "8.1.0", 4500 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-8.1.0.tgz", 4501 | "integrity": "sha512-yP+6QqN8BmrgW2ggLtTbdrOyBNSI7zBa4IykmiV5R1wl1JWNxQvWhMfMdmzIYtKU7oP3OOInY/tl2ov3BDjnJQ==", 4502 | "dev": true, 4503 | "requires": { 4504 | "camelcase": "4.1.0" 4505 | }, 4506 | "dependencies": { 4507 | "camelcase": { 4508 | "version": "4.1.0", 4509 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 4510 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", 4511 | "dev": true 4512 | } 4513 | } 4514 | } 4515 | } 4516 | } 4517 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "node-google-apps-script", 3 | "version": "1.3.1", 4 | "description": "The easiest way to develop Google Apps Script projects", 5 | "repository": { 6 | "type": "git", 7 | "url": "https://github.com/danthareja/node-google-apps-script.git" 8 | }, 9 | "bin": { 10 | "gapps": "./bin/gapps" 11 | }, 12 | "main": "index", 13 | "preferGlobal": true, 14 | "keywords": [ 15 | "google", 16 | "apps", 17 | "script", 18 | "drive", 19 | "github", 20 | "source", 21 | "version", 22 | "control", 23 | "import", 24 | "export", 25 | "download", 26 | "upload", 27 | "push", 28 | "clone" 29 | ], 30 | "author": "Dan Thareja (danthareja@gmail.com)", 31 | "license": "MIT", 32 | "bugs": { 33 | "url": "https://github.com/danthareja/node-google-apps-script/issues" 34 | }, 35 | "homepage": "https://github.com/danthareja/node-google-apps-script", 36 | "dependencies": { 37 | "bluebird": "^3.5.1", 38 | "colors": "^1.1.2", 39 | "commander": "^2.12.2", 40 | "googleapis": "^20.1.0", 41 | "lodash": "^4.17.4", 42 | "mkdirp": "^0.5.1", 43 | "node-dir": "^0.1.x", 44 | "request": "^2.83.0" 45 | }, 46 | "scripts": { 47 | "test": "jest" 48 | }, 49 | "engines": { 50 | "node": ">= 8" 51 | }, 52 | "devDependencies": { 53 | "@types/jest": "^22.0.0", 54 | "jest": "^22.0.4" 55 | } 56 | } 57 | -------------------------------------------------------------------------------- /tests/commands/__snapshots__/auth.test.js.snap: -------------------------------------------------------------------------------- 1 | // Jest Snapshot v1, https://goo.gl/fbAQLP 2 | 3 | exports[`should complain if credentials are not in the OAuth 2.0 format 1`] = `"Path did not include \\"OAuth 2.0 client ID\\" credentials. Please check that you downloaded the right JSON credentials."`; 4 | 5 | exports[`should reject the promise when a previous file does not exists and a credential path is not provided 1`] = `"/tmp/.gapps-test does not exist yet. Specify a credential file with \`--auth ~/Downloads/client_secret_abcd.json\`"`; 6 | 7 | exports[`should resolve the promise when a file already exists 1`] = `"/tmp/.gapps-test already exists. Remove it to re-authenticate node-google-apps-script"`; 8 | 9 | exports[`should start a authentication flow and print the oauth url when a clientSecret is provided 1`] = ` 10 | " 11 | Please visit the following url in your browser (you'll only have to do this once):" 12 | `; 13 | -------------------------------------------------------------------------------- /tests/commands/auth.test.js: -------------------------------------------------------------------------------- 1 | const fs = require("fs"); 2 | const { promisify } = require("util"); 3 | const unlinkAsync = promisify(fs.unlink); 4 | 5 | jest.mock("../../lib/defaults"); 6 | jest.mock("../../lib/miniOAuthServer"); 7 | 8 | jest.mock("googleapis"); 9 | 10 | const fakeClientSecretPath = "/tmp/.fakeClientSecret"; 11 | const defaults = require("../../lib/defaults"); 12 | 13 | const removeFile = () => unlinkAsync(defaults.STORAGE_FILE).catch(() => {}); 14 | const writeFakeFile = () => fs.writeFileSync(defaults.STORAGE_FILE, "f4k3"); 15 | 16 | let spiedConsole = jest.spyOn(console, "log").mockImplementation(() => {}); 17 | 18 | const cleanUp = () => { 19 | jest.resetAllMocks(); 20 | removeFile(); 21 | }; 22 | 23 | const clientSecret = { 24 | installed: { 25 | client_id: "424242424242-f4k3h4ck15h.apps.googleusercontent.com", 26 | project_id: "project-id-424242424242", 27 | auth_uri: "https://accounts.google.com/o/oauth2/auth", 28 | token_uri: "https://accounts.google.com/o/oauth2/token", 29 | auth_provider_x509_cert_url: "https://www.googleapis.com/oauth2/v1/certs", 30 | client_secret: "client_secret_fake", 31 | redirect_uris: ["urn:ietf:wg:oauth:2.0:oob", "http://localhost"] 32 | } 33 | }; 34 | 35 | 36 | afterEach(cleanUp); 37 | 38 | test("should resolve the promise when a file already exists", async () => { 39 | writeFakeFile(); 40 | 41 | const auth = await require("../../lib/commands/auth")(); 42 | 43 | expect(auth).toBeUndefined(); 44 | expect(spiedConsole.mock.calls[0][0]).toMatchSnapshot(); 45 | }); 46 | 47 | test("should reject the promise when a previous file does not exists and a credential path is not provided", async () => { 48 | try { 49 | await require("../../lib/commands/auth")(); 50 | } catch (e) { 51 | expect(e).toMatchSnapshot(); 52 | } 53 | }); 54 | 55 | test("should start a authentication flow and print the oauth url when a clientSecret is provided", async () => { 56 | fs.writeFileSync(fakeClientSecretPath, JSON.stringify(clientSecret), "utf-8"); 57 | 58 | const auth = require("../../lib/commands/auth"); 59 | await auth(fakeClientSecretPath); 60 | 61 | expect(spiedConsole.mock.calls[0][0]).toMatchSnapshot(); 62 | expect(spiedConsole.mock.calls[0][1]).toContain("https://"); 63 | 64 | const obtainedCredentials = JSON.parse(fs.readFileSync(defaults.STORAGE_FILE)); 65 | expect(obtainedCredentials.refresh_token).toEqual("woot_successfully_obtained_refresh_token"); 66 | }); 67 | 68 | test("should complain if credentials are not in the OAuth 2.0 format", async done => { 69 | const wrongFormatSecret = { 70 | client_id: "424242424242-f4k3h4ck15h.apps.googleusercontent.com", 71 | project_id: "project-id-424242424242" 72 | }; 73 | fs.writeFileSync( 74 | fakeClientSecretPath, 75 | JSON.stringify(wrongFormatSecret), 76 | "utf-8" 77 | ); 78 | 79 | try { 80 | await require("../../lib/commands/auth")(fakeClientSecretPath); 81 | } catch (e) { 82 | expect(e).toMatchSnapshot(); 83 | done(); 84 | } 85 | }); 86 | --------------------------------------------------------------------------------