├── .editorconfig ├── .gitignore ├── README.md ├── package-lock.json ├── package.json └── src ├── index.js ├── websocket-client.js └── websocket.js /.editorconfig: -------------------------------------------------------------------------------- 1 | # http://editorconfig.org 2 | 3 | # A special property that should be specified at the top of the file outside of 4 | # any sections. Set to true to stop .editor config file search on current file 5 | root = true 6 | 7 | [*] 8 | # Indentation style 9 | # Possible values - tab, space 10 | indent_style = tab 11 | 12 | # Indentation size in single-spaced characters 13 | # Possible values - an integer, tab 14 | indent_size = 4 15 | 16 | # Line ending file format 17 | # Possible values - lf, crlf, cr 18 | end_of_line = lf 19 | 20 | # File character encoding 21 | # Possible values - latin1, utf-8, utf-16be, utf-16le 22 | charset = utf-8 23 | 24 | # Denotes whether to trim whitespace at the end of lines 25 | # Possible values - true, false 26 | trim_trailing_whitespace = true 27 | 28 | # Denotes whether file should end with a newline 29 | # Possible values - true, false 30 | insert_final_newline = true 31 | 32 | 33 | [*.{yaml,yml,yml.sh}] 34 | indent_style = space 35 | indent_size = 2 36 | 37 | [.eslintrc] 38 | indent_size = 2 39 | 40 | [package.json] 41 | indent_size = 2 42 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules 3 | dist 4 | npm-debug.log 5 | yarn.lock 6 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![npm version](https://badge.fury.io/js/paul-revere.svg)](https://badge.fury.io/js/paul-revere) 2 | 3 | # Paul Revere 4 | 5 | Paul Revere is a lightweight wrapper for server-client WebSocket communication. It uses [schemapack](https://github.com/phretaddin/schemapack) to encode buffers from JavaScript objects and delivers a smaller payload and faster parsing than traditional JSON messaging. On the browser, it wraps a vanilla WebSocket object, and on the server it wraps the [ws](https://github.com/websockets/ws) package. 6 | 7 | Paul Revere also accepts pub/sub adapters to allows for horizontal server scaling. 8 | 9 | ## Server Usage 10 | 11 | Paul Revere can be used with any Node server, though this example shows Express. 12 | 13 | ```JavaScript 14 | const express = require('express'), 15 | PaulRevere = require('paul-revere'), 16 | schemas = require('../shared/schemas'); // same module as client 17 | 18 | /** 19 | * Example schemas.js 20 | * Follow schema rules found at https://github.com/phretaddin/schemapack 21 | 22 | exports.chat = { 23 | payload: { 24 | message: 'string', 25 | user: 'string' 26 | }, 27 | meta: { 28 | timestamp: 'string' 29 | } 30 | }; 31 | */ 32 | 33 | const app = express(); 34 | 35 | // Get Node server instance 36 | const server = app.listen(3000, () => app.log.info('Paul Revere App listening on port 3000')); 37 | 38 | // Pass your schemas and a Node server to start a Paul Revere WebSocket server 39 | const paul = new PaulRevere(schemas, {server}); 40 | 41 | // Bind a client connection handler 42 | paul.onConnection(client => { 43 | 44 | // The server exposes your schemas to broadcast messages to all clients 45 | // Pass a client as the second argument to exclude it from the broadcast 46 | paul.chat.broadcast({ 47 | payload: { 48 | message: 'New user joined!', 49 | user: 'ChatBot' 50 | }, 51 | meta: { 52 | timestamp: String(Date.now()) 53 | } 54 | }, client); // Don't send this message to the client that just joined 55 | 56 | // Each client has its own schema instance to send messages directly to that client... 57 | client.chat.send({ 58 | payload: { 59 | message: 'Welcome to Chat!', 60 | user: 'ChatBot' 61 | }, 62 | meta: { 63 | timestamp: String(Date.now()) 64 | } 65 | }); 66 | 67 | // And also listen for messages from that client 68 | client.chat.onMessage(message => { 69 | // Broadcasting the message to all clients simplifies front end rendering and listeners 70 | // and is fast enough for non-optimistic updates 71 | paul.chat.broadcast(message); 72 | }); 73 | }); 74 | ``` 75 | 76 | 77 | ## Client Usage 78 | 79 | Paul Revere is supported on all browsers that support native WebSockets. http://caniuse.com/#feat=websockets 80 | 81 | ```JavaScript 82 | import PaulRevere from 'paul-revere'; 83 | import schemas from '../shared/schemas'; // same module as server 84 | 85 | // Pass your schemas and a WebSocket address to connect to a Paul Revere server 86 | const paul = new PaulRevere(schemas, {url: 'ws://localhost:3000'}), 87 | 88 | // The client exposes your schemas to send messages to the server 89 | paul.chat.send({ 90 | payload: { 91 | message: 'Hello!', 92 | user: 'ClientBot' 93 | }, 94 | meta: { 95 | timestamp: String(Date.now()) 96 | } 97 | }); 98 | 99 | 100 | // And also listen to messages from the server 101 | paul.chat.onMessage(m => { 102 | console.log(m); 103 | }); 104 | ``` 105 | 106 | ## Server Adapters 107 | 108 | In order to support horizontal server scaling, Paul Revere servers internally run off a pub/sub model for broadcasting messages. The default is nothing more than a stub function firing callbacks (see below). Custom adapters can be written and passed as the option `pubSub` when instantiating a server, and Paul Revere will use that instead. There is an official NATS adapter at [paul-revere-nats-adapter](https://github.com/the-control-group/paul-revere-nats-adapter). 109 | 110 | ### Adapter API 111 | 112 | Paul Revere servers need publicly accessible `publish(subject, msg, exclude)` and `subscribe(subject, cb)` methods. Nothing else is required to be exposed. 113 | 114 | ```JavaScript 115 | const pubSubAdapter = { 116 | // subject will always be an integer unique to a schema type, msg will always be a plain object, and exclude may be undefined or a string id 117 | publish(subject, msg, exclude) { 118 | // listeners are namespaced with 'paulrevere' just to ensure string keys 119 | // Your subject can be anything, so long as it is unique for every schema 120 | if(!this.listeners[`paulrevere.${subject}`]) return; 121 | 122 | this.listeners[`paulrevere.${subject}`].forEach(cb => cb(msg, exclude)); 123 | }, 124 | 125 | // subscriber callbacks expect a plain object msg, and also an exclude string id if passed in the schema.broadcast() method 126 | subscribe(subject, cb) { 127 | if(!this.listeners[`paulrevere.${subject}`]) this.listeners[`paulrevere.${subject}`] = []; 128 | 129 | this.listeners[`paulrevere.${subject}`].push(cb); 130 | }, 131 | 132 | listeners: {} 133 | }; 134 | 135 | const paul = new PaulRevere(schemas, {server, pubSub: pubSubAdapter}); 136 | ``` 137 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "paul-revere", 3 | "version": "2.2.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "acorn": { 8 | "version": "5.5.3", 9 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.5.3.tgz", 10 | "integrity": "sha512-jd5MkIUlbbmb07nXH0DT3y7rDVtkzDi4XZOUVWAer8ajmF/DTSSbl5oNFyDOl/OXA33Bl79+ypHhl2pN20VeOQ==", 11 | "dev": true 12 | }, 13 | "acorn-jsx": { 14 | "version": "3.0.1", 15 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", 16 | "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", 17 | "dev": true, 18 | "requires": { 19 | "acorn": "^3.0.4" 20 | }, 21 | "dependencies": { 22 | "acorn": { 23 | "version": "3.3.0", 24 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", 25 | "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", 26 | "dev": true 27 | } 28 | } 29 | }, 30 | "ajv": { 31 | "version": "5.5.2", 32 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", 33 | "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", 34 | "dev": true, 35 | "requires": { 36 | "co": "^4.6.0", 37 | "fast-deep-equal": "^1.0.0", 38 | "fast-json-stable-stringify": "^2.0.0", 39 | "json-schema-traverse": "^0.3.0" 40 | } 41 | }, 42 | "ajv-keywords": { 43 | "version": "2.1.1", 44 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-2.1.1.tgz", 45 | "integrity": "sha1-YXmX/F9gV2iUxDX5QNgZ4TW4B2I=", 46 | "dev": true 47 | }, 48 | "ansi-escapes": { 49 | "version": "3.1.0", 50 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", 51 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", 52 | "dev": true 53 | }, 54 | "ansi-regex": { 55 | "version": "2.1.1", 56 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 57 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 58 | "dev": true 59 | }, 60 | "ansi-styles": { 61 | "version": "2.2.1", 62 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 63 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 64 | "dev": true 65 | }, 66 | "anymatch": { 67 | "version": "1.3.2", 68 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", 69 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", 70 | "dev": true, 71 | "optional": true, 72 | "requires": { 73 | "micromatch": "^2.1.5", 74 | "normalize-path": "^2.0.0" 75 | } 76 | }, 77 | "argparse": { 78 | "version": "1.0.10", 79 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 80 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 81 | "dev": true, 82 | "requires": { 83 | "sprintf-js": "~1.0.2" 84 | } 85 | }, 86 | "arr-diff": { 87 | "version": "2.0.0", 88 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 89 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 90 | "dev": true, 91 | "optional": true, 92 | "requires": { 93 | "arr-flatten": "^1.0.1" 94 | } 95 | }, 96 | "arr-flatten": { 97 | "version": "1.1.0", 98 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 99 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 100 | "dev": true, 101 | "optional": true 102 | }, 103 | "array-union": { 104 | "version": "1.0.2", 105 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 106 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 107 | "dev": true, 108 | "requires": { 109 | "array-uniq": "^1.0.1" 110 | } 111 | }, 112 | "array-uniq": { 113 | "version": "1.0.3", 114 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 115 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 116 | "dev": true 117 | }, 118 | "array-unique": { 119 | "version": "0.2.1", 120 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 121 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 122 | "dev": true, 123 | "optional": true 124 | }, 125 | "arrify": { 126 | "version": "1.0.1", 127 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 128 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 129 | "dev": true 130 | }, 131 | "async-each": { 132 | "version": "1.0.1", 133 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 134 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", 135 | "dev": true, 136 | "optional": true 137 | }, 138 | "async-limiter": { 139 | "version": "1.0.0", 140 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz", 141 | "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg==" 142 | }, 143 | "babel-cli": { 144 | "version": "6.26.0", 145 | "resolved": "https://registry.npmjs.org/babel-cli/-/babel-cli-6.26.0.tgz", 146 | "integrity": "sha1-UCq1SHTX24itALiHoGODzgPQAvE=", 147 | "dev": true, 148 | "requires": { 149 | "babel-core": "^6.26.0", 150 | "babel-polyfill": "^6.26.0", 151 | "babel-register": "^6.26.0", 152 | "babel-runtime": "^6.26.0", 153 | "chokidar": "^1.6.1", 154 | "commander": "^2.11.0", 155 | "convert-source-map": "^1.5.0", 156 | "fs-readdir-recursive": "^1.0.0", 157 | "glob": "^7.1.2", 158 | "lodash": "^4.17.4", 159 | "output-file-sync": "^1.1.2", 160 | "path-is-absolute": "^1.0.1", 161 | "slash": "^1.0.0", 162 | "source-map": "^0.5.6", 163 | "v8flags": "^2.1.1" 164 | } 165 | }, 166 | "babel-code-frame": { 167 | "version": "6.26.0", 168 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 169 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 170 | "dev": true, 171 | "requires": { 172 | "chalk": "^1.1.3", 173 | "esutils": "^2.0.2", 174 | "js-tokens": "^3.0.2" 175 | } 176 | }, 177 | "babel-core": { 178 | "version": "6.26.3", 179 | "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.3.tgz", 180 | "integrity": "sha512-6jyFLuDmeidKmUEb3NM+/yawG0M2bDZ9Z1qbZP59cyHLz8kYGKYwpJP0UwUKKUiTRNvxfLesJnTedqczP7cTDA==", 181 | "dev": true, 182 | "requires": { 183 | "babel-code-frame": "^6.26.0", 184 | "babel-generator": "^6.26.0", 185 | "babel-helpers": "^6.24.1", 186 | "babel-messages": "^6.23.0", 187 | "babel-register": "^6.26.0", 188 | "babel-runtime": "^6.26.0", 189 | "babel-template": "^6.26.0", 190 | "babel-traverse": "^6.26.0", 191 | "babel-types": "^6.26.0", 192 | "babylon": "^6.18.0", 193 | "convert-source-map": "^1.5.1", 194 | "debug": "^2.6.9", 195 | "json5": "^0.5.1", 196 | "lodash": "^4.17.4", 197 | "minimatch": "^3.0.4", 198 | "path-is-absolute": "^1.0.1", 199 | "private": "^0.1.8", 200 | "slash": "^1.0.0", 201 | "source-map": "^0.5.7" 202 | } 203 | }, 204 | "babel-generator": { 205 | "version": "6.26.1", 206 | "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.1.tgz", 207 | "integrity": "sha512-HyfwY6ApZj7BYTcJURpM5tznulaBvyio7/0d4zFOeMPUmfxkCjHocCuoLa2SAGzBI8AREcH3eP3758F672DppA==", 208 | "dev": true, 209 | "requires": { 210 | "babel-messages": "^6.23.0", 211 | "babel-runtime": "^6.26.0", 212 | "babel-types": "^6.26.0", 213 | "detect-indent": "^4.0.0", 214 | "jsesc": "^1.3.0", 215 | "lodash": "^4.17.4", 216 | "source-map": "^0.5.7", 217 | "trim-right": "^1.0.1" 218 | } 219 | }, 220 | "babel-helper-call-delegate": { 221 | "version": "6.24.1", 222 | "resolved": "https://registry.npmjs.org/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz", 223 | "integrity": "sha1-7Oaqzdx25Bw0YfiL/Fdb0Nqi340=", 224 | "dev": true, 225 | "requires": { 226 | "babel-helper-hoist-variables": "^6.24.1", 227 | "babel-runtime": "^6.22.0", 228 | "babel-traverse": "^6.24.1", 229 | "babel-types": "^6.24.1" 230 | } 231 | }, 232 | "babel-helper-define-map": { 233 | "version": "6.26.0", 234 | "resolved": "https://registry.npmjs.org/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz", 235 | "integrity": "sha1-pfVtq0GiX5fstJjH66ypgZ+Vvl8=", 236 | "dev": true, 237 | "requires": { 238 | "babel-helper-function-name": "^6.24.1", 239 | "babel-runtime": "^6.26.0", 240 | "babel-types": "^6.26.0", 241 | "lodash": "^4.17.4" 242 | } 243 | }, 244 | "babel-helper-function-name": { 245 | "version": "6.24.1", 246 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 247 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 248 | "dev": true, 249 | "requires": { 250 | "babel-helper-get-function-arity": "^6.24.1", 251 | "babel-runtime": "^6.22.0", 252 | "babel-template": "^6.24.1", 253 | "babel-traverse": "^6.24.1", 254 | "babel-types": "^6.24.1" 255 | } 256 | }, 257 | "babel-helper-get-function-arity": { 258 | "version": "6.24.1", 259 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 260 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 261 | "dev": true, 262 | "requires": { 263 | "babel-runtime": "^6.22.0", 264 | "babel-types": "^6.24.1" 265 | } 266 | }, 267 | "babel-helper-hoist-variables": { 268 | "version": "6.24.1", 269 | "resolved": "https://registry.npmjs.org/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz", 270 | "integrity": "sha1-HssnaJydJVE+rbyZFKc/VAi+enY=", 271 | "dev": true, 272 | "requires": { 273 | "babel-runtime": "^6.22.0", 274 | "babel-types": "^6.24.1" 275 | } 276 | }, 277 | "babel-helper-optimise-call-expression": { 278 | "version": "6.24.1", 279 | "resolved": "https://registry.npmjs.org/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz", 280 | "integrity": "sha1-96E0J7qfc/j0+pk8VKl4gtEkQlc=", 281 | "dev": true, 282 | "requires": { 283 | "babel-runtime": "^6.22.0", 284 | "babel-types": "^6.24.1" 285 | } 286 | }, 287 | "babel-helper-regex": { 288 | "version": "6.26.0", 289 | "resolved": "https://registry.npmjs.org/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz", 290 | "integrity": "sha1-MlxZ+QL4LyS3T6zu0DY5VPZJXnI=", 291 | "dev": true, 292 | "requires": { 293 | "babel-runtime": "^6.26.0", 294 | "babel-types": "^6.26.0", 295 | "lodash": "^4.17.4" 296 | } 297 | }, 298 | "babel-helper-replace-supers": { 299 | "version": "6.24.1", 300 | "resolved": "https://registry.npmjs.org/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz", 301 | "integrity": "sha1-v22/5Dk40XNpohPKiov3S2qQqxo=", 302 | "dev": true, 303 | "requires": { 304 | "babel-helper-optimise-call-expression": "^6.24.1", 305 | "babel-messages": "^6.23.0", 306 | "babel-runtime": "^6.22.0", 307 | "babel-template": "^6.24.1", 308 | "babel-traverse": "^6.24.1", 309 | "babel-types": "^6.24.1" 310 | } 311 | }, 312 | "babel-helpers": { 313 | "version": "6.24.1", 314 | "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", 315 | "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", 316 | "dev": true, 317 | "requires": { 318 | "babel-runtime": "^6.22.0", 319 | "babel-template": "^6.24.1" 320 | } 321 | }, 322 | "babel-messages": { 323 | "version": "6.23.0", 324 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", 325 | "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", 326 | "dev": true, 327 | "requires": { 328 | "babel-runtime": "^6.22.0" 329 | } 330 | }, 331 | "babel-plugin-check-es2015-constants": { 332 | "version": "6.22.0", 333 | "resolved": "https://registry.npmjs.org/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz", 334 | "integrity": "sha1-NRV7EBQm/S/9PaP3XH0ekYNbv4o=", 335 | "dev": true, 336 | "requires": { 337 | "babel-runtime": "^6.22.0" 338 | } 339 | }, 340 | "babel-plugin-transform-es2015-arrow-functions": { 341 | "version": "6.22.0", 342 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", 343 | "integrity": "sha1-RSaSy3EdX3ncf4XkQM5BufJE0iE=", 344 | "dev": true, 345 | "requires": { 346 | "babel-runtime": "^6.22.0" 347 | } 348 | }, 349 | "babel-plugin-transform-es2015-block-scoped-functions": { 350 | "version": "6.22.0", 351 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz", 352 | "integrity": "sha1-u8UbSflk1wy42OC5ToICRs46YUE=", 353 | "dev": true, 354 | "requires": { 355 | "babel-runtime": "^6.22.0" 356 | } 357 | }, 358 | "babel-plugin-transform-es2015-block-scoping": { 359 | "version": "6.26.0", 360 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz", 361 | "integrity": "sha1-1w9SmcEwjQXBL0Y4E7CgnnOxiV8=", 362 | "dev": true, 363 | "requires": { 364 | "babel-runtime": "^6.26.0", 365 | "babel-template": "^6.26.0", 366 | "babel-traverse": "^6.26.0", 367 | "babel-types": "^6.26.0", 368 | "lodash": "^4.17.4" 369 | } 370 | }, 371 | "babel-plugin-transform-es2015-classes": { 372 | "version": "6.24.1", 373 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz", 374 | "integrity": "sha1-WkxYpQyclGHlZLSyo7+ryXolhNs=", 375 | "dev": true, 376 | "requires": { 377 | "babel-helper-define-map": "^6.24.1", 378 | "babel-helper-function-name": "^6.24.1", 379 | "babel-helper-optimise-call-expression": "^6.24.1", 380 | "babel-helper-replace-supers": "^6.24.1", 381 | "babel-messages": "^6.23.0", 382 | "babel-runtime": "^6.22.0", 383 | "babel-template": "^6.24.1", 384 | "babel-traverse": "^6.24.1", 385 | "babel-types": "^6.24.1" 386 | } 387 | }, 388 | "babel-plugin-transform-es2015-computed-properties": { 389 | "version": "6.24.1", 390 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz", 391 | "integrity": "sha1-b+Ko0WiV1WNPTNmZttNICjCBWbM=", 392 | "dev": true, 393 | "requires": { 394 | "babel-runtime": "^6.22.0", 395 | "babel-template": "^6.24.1" 396 | } 397 | }, 398 | "babel-plugin-transform-es2015-destructuring": { 399 | "version": "6.23.0", 400 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz", 401 | "integrity": "sha1-mXux8auWf2gtKwh2/jWNYOdlxW0=", 402 | "dev": true, 403 | "requires": { 404 | "babel-runtime": "^6.22.0" 405 | } 406 | }, 407 | "babel-plugin-transform-es2015-duplicate-keys": { 408 | "version": "6.24.1", 409 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz", 410 | "integrity": "sha1-c+s9MQypaePvnskcU3QabxV2Qj4=", 411 | "dev": true, 412 | "requires": { 413 | "babel-runtime": "^6.22.0", 414 | "babel-types": "^6.24.1" 415 | } 416 | }, 417 | "babel-plugin-transform-es2015-for-of": { 418 | "version": "6.23.0", 419 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz", 420 | "integrity": "sha1-9HyVsrYT3x0+zC/bdXNiPHUkhpE=", 421 | "dev": true, 422 | "requires": { 423 | "babel-runtime": "^6.22.0" 424 | } 425 | }, 426 | "babel-plugin-transform-es2015-function-name": { 427 | "version": "6.24.1", 428 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz", 429 | "integrity": "sha1-g0yJhTvDaxrw86TF26qU/Y6sqos=", 430 | "dev": true, 431 | "requires": { 432 | "babel-helper-function-name": "^6.24.1", 433 | "babel-runtime": "^6.22.0", 434 | "babel-types": "^6.24.1" 435 | } 436 | }, 437 | "babel-plugin-transform-es2015-literals": { 438 | "version": "6.22.0", 439 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz", 440 | "integrity": "sha1-T1SgLWzWbPkVKAAZox0xklN3yi4=", 441 | "dev": true, 442 | "requires": { 443 | "babel-runtime": "^6.22.0" 444 | } 445 | }, 446 | "babel-plugin-transform-es2015-modules-amd": { 447 | "version": "6.24.1", 448 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz", 449 | "integrity": "sha1-Oz5UAXI5hC1tGcMBHEvS8AoA0VQ=", 450 | "dev": true, 451 | "requires": { 452 | "babel-plugin-transform-es2015-modules-commonjs": "^6.24.1", 453 | "babel-runtime": "^6.22.0", 454 | "babel-template": "^6.24.1" 455 | } 456 | }, 457 | "babel-plugin-transform-es2015-modules-commonjs": { 458 | "version": "6.26.2", 459 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.2.tgz", 460 | "integrity": "sha512-CV9ROOHEdrjcwhIaJNBGMBCodN+1cfkwtM1SbUHmvyy35KGT7fohbpOxkE2uLz1o6odKK2Ck/tz47z+VqQfi9Q==", 461 | "dev": true, 462 | "requires": { 463 | "babel-plugin-transform-strict-mode": "^6.24.1", 464 | "babel-runtime": "^6.26.0", 465 | "babel-template": "^6.26.0", 466 | "babel-types": "^6.26.0" 467 | } 468 | }, 469 | "babel-plugin-transform-es2015-modules-systemjs": { 470 | "version": "6.24.1", 471 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz", 472 | "integrity": "sha1-/4mhQrkRmpBhlfXxBuzzBdlAfSM=", 473 | "dev": true, 474 | "requires": { 475 | "babel-helper-hoist-variables": "^6.24.1", 476 | "babel-runtime": "^6.22.0", 477 | "babel-template": "^6.24.1" 478 | } 479 | }, 480 | "babel-plugin-transform-es2015-modules-umd": { 481 | "version": "6.24.1", 482 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz", 483 | "integrity": "sha1-rJl+YoXNGO1hdq22B9YCNErThGg=", 484 | "dev": true, 485 | "requires": { 486 | "babel-plugin-transform-es2015-modules-amd": "^6.24.1", 487 | "babel-runtime": "^6.22.0", 488 | "babel-template": "^6.24.1" 489 | } 490 | }, 491 | "babel-plugin-transform-es2015-object-super": { 492 | "version": "6.24.1", 493 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz", 494 | "integrity": "sha1-JM72muIcuDp/hgPa0CH1cusnj40=", 495 | "dev": true, 496 | "requires": { 497 | "babel-helper-replace-supers": "^6.24.1", 498 | "babel-runtime": "^6.22.0" 499 | } 500 | }, 501 | "babel-plugin-transform-es2015-parameters": { 502 | "version": "6.24.1", 503 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz", 504 | "integrity": "sha1-V6w1GrScrxSpfNE7CfZv3wpiXys=", 505 | "dev": true, 506 | "requires": { 507 | "babel-helper-call-delegate": "^6.24.1", 508 | "babel-helper-get-function-arity": "^6.24.1", 509 | "babel-runtime": "^6.22.0", 510 | "babel-template": "^6.24.1", 511 | "babel-traverse": "^6.24.1", 512 | "babel-types": "^6.24.1" 513 | } 514 | }, 515 | "babel-plugin-transform-es2015-shorthand-properties": { 516 | "version": "6.24.1", 517 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz", 518 | "integrity": "sha1-JPh11nIch2YbvZmkYi5R8U3jiqA=", 519 | "dev": true, 520 | "requires": { 521 | "babel-runtime": "^6.22.0", 522 | "babel-types": "^6.24.1" 523 | } 524 | }, 525 | "babel-plugin-transform-es2015-spread": { 526 | "version": "6.22.0", 527 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz", 528 | "integrity": "sha1-1taKmfia7cRTbIGlQujdnxdG+NE=", 529 | "dev": true, 530 | "requires": { 531 | "babel-runtime": "^6.22.0" 532 | } 533 | }, 534 | "babel-plugin-transform-es2015-sticky-regex": { 535 | "version": "6.24.1", 536 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz", 537 | "integrity": "sha1-AMHNsaynERLN8M9hJsLta0V8zbw=", 538 | "dev": true, 539 | "requires": { 540 | "babel-helper-regex": "^6.24.1", 541 | "babel-runtime": "^6.22.0", 542 | "babel-types": "^6.24.1" 543 | } 544 | }, 545 | "babel-plugin-transform-es2015-template-literals": { 546 | "version": "6.22.0", 547 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz", 548 | "integrity": "sha1-qEs0UPfp+PH2g51taH2oS7EjbY0=", 549 | "dev": true, 550 | "requires": { 551 | "babel-runtime": "^6.22.0" 552 | } 553 | }, 554 | "babel-plugin-transform-es2015-typeof-symbol": { 555 | "version": "6.23.0", 556 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz", 557 | "integrity": "sha1-3sCfHN3/lLUqxz1QXITfWdzOs3I=", 558 | "dev": true, 559 | "requires": { 560 | "babel-runtime": "^6.22.0" 561 | } 562 | }, 563 | "babel-plugin-transform-es2015-unicode-regex": { 564 | "version": "6.24.1", 565 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz", 566 | "integrity": "sha1-04sS9C6nMj9yk4fxinxa4frrNek=", 567 | "dev": true, 568 | "requires": { 569 | "babel-helper-regex": "^6.24.1", 570 | "babel-runtime": "^6.22.0", 571 | "regexpu-core": "^2.0.0" 572 | } 573 | }, 574 | "babel-plugin-transform-regenerator": { 575 | "version": "6.26.0", 576 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz", 577 | "integrity": "sha1-4HA2lvveJ/Cj78rPi03KL3s6jy8=", 578 | "dev": true, 579 | "requires": { 580 | "regenerator-transform": "^0.10.0" 581 | } 582 | }, 583 | "babel-plugin-transform-strict-mode": { 584 | "version": "6.24.1", 585 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz", 586 | "integrity": "sha1-1fr3qleKZbvlkc9e2uBKDGcCB1g=", 587 | "dev": true, 588 | "requires": { 589 | "babel-runtime": "^6.22.0", 590 | "babel-types": "^6.24.1" 591 | } 592 | }, 593 | "babel-polyfill": { 594 | "version": "6.26.0", 595 | "resolved": "https://registry.npmjs.org/babel-polyfill/-/babel-polyfill-6.26.0.tgz", 596 | "integrity": "sha1-N5k3q8Z9eJWXCtxiHyhM2WbPIVM=", 597 | "dev": true, 598 | "requires": { 599 | "babel-runtime": "^6.26.0", 600 | "core-js": "^2.5.0", 601 | "regenerator-runtime": "^0.10.5" 602 | }, 603 | "dependencies": { 604 | "regenerator-runtime": { 605 | "version": "0.10.5", 606 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz", 607 | "integrity": "sha1-M2w+/BIgrc7dosn6tntaeVWjNlg=", 608 | "dev": true 609 | } 610 | } 611 | }, 612 | "babel-preset-es2015": { 613 | "version": "6.24.1", 614 | "resolved": "https://registry.npmjs.org/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz", 615 | "integrity": "sha1-1EBQ1rwsn+6nAqrzjXJ6AhBTiTk=", 616 | "dev": true, 617 | "requires": { 618 | "babel-plugin-check-es2015-constants": "^6.22.0", 619 | "babel-plugin-transform-es2015-arrow-functions": "^6.22.0", 620 | "babel-plugin-transform-es2015-block-scoped-functions": "^6.22.0", 621 | "babel-plugin-transform-es2015-block-scoping": "^6.24.1", 622 | "babel-plugin-transform-es2015-classes": "^6.24.1", 623 | "babel-plugin-transform-es2015-computed-properties": "^6.24.1", 624 | "babel-plugin-transform-es2015-destructuring": "^6.22.0", 625 | "babel-plugin-transform-es2015-duplicate-keys": "^6.24.1", 626 | "babel-plugin-transform-es2015-for-of": "^6.22.0", 627 | "babel-plugin-transform-es2015-function-name": "^6.24.1", 628 | "babel-plugin-transform-es2015-literals": "^6.22.0", 629 | "babel-plugin-transform-es2015-modules-amd": "^6.24.1", 630 | "babel-plugin-transform-es2015-modules-commonjs": "^6.24.1", 631 | "babel-plugin-transform-es2015-modules-systemjs": "^6.24.1", 632 | "babel-plugin-transform-es2015-modules-umd": "^6.24.1", 633 | "babel-plugin-transform-es2015-object-super": "^6.24.1", 634 | "babel-plugin-transform-es2015-parameters": "^6.24.1", 635 | "babel-plugin-transform-es2015-shorthand-properties": "^6.24.1", 636 | "babel-plugin-transform-es2015-spread": "^6.22.0", 637 | "babel-plugin-transform-es2015-sticky-regex": "^6.24.1", 638 | "babel-plugin-transform-es2015-template-literals": "^6.22.0", 639 | "babel-plugin-transform-es2015-typeof-symbol": "^6.22.0", 640 | "babel-plugin-transform-es2015-unicode-regex": "^6.24.1", 641 | "babel-plugin-transform-regenerator": "^6.24.1" 642 | } 643 | }, 644 | "babel-register": { 645 | "version": "6.26.0", 646 | "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz", 647 | "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=", 648 | "dev": true, 649 | "requires": { 650 | "babel-core": "^6.26.0", 651 | "babel-runtime": "^6.26.0", 652 | "core-js": "^2.5.0", 653 | "home-or-tmp": "^2.0.0", 654 | "lodash": "^4.17.4", 655 | "mkdirp": "^0.5.1", 656 | "source-map-support": "^0.4.15" 657 | } 658 | }, 659 | "babel-runtime": { 660 | "version": "6.26.0", 661 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 662 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 663 | "dev": true, 664 | "requires": { 665 | "core-js": "^2.4.0", 666 | "regenerator-runtime": "^0.11.0" 667 | } 668 | }, 669 | "babel-template": { 670 | "version": "6.26.0", 671 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz", 672 | "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=", 673 | "dev": true, 674 | "requires": { 675 | "babel-runtime": "^6.26.0", 676 | "babel-traverse": "^6.26.0", 677 | "babel-types": "^6.26.0", 678 | "babylon": "^6.18.0", 679 | "lodash": "^4.17.4" 680 | } 681 | }, 682 | "babel-traverse": { 683 | "version": "6.26.0", 684 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz", 685 | "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=", 686 | "dev": true, 687 | "requires": { 688 | "babel-code-frame": "^6.26.0", 689 | "babel-messages": "^6.23.0", 690 | "babel-runtime": "^6.26.0", 691 | "babel-types": "^6.26.0", 692 | "babylon": "^6.18.0", 693 | "debug": "^2.6.8", 694 | "globals": "^9.18.0", 695 | "invariant": "^2.2.2", 696 | "lodash": "^4.17.4" 697 | } 698 | }, 699 | "babel-types": { 700 | "version": "6.26.0", 701 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", 702 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", 703 | "dev": true, 704 | "requires": { 705 | "babel-runtime": "^6.26.0", 706 | "esutils": "^2.0.2", 707 | "lodash": "^4.17.4", 708 | "to-fast-properties": "^1.0.3" 709 | } 710 | }, 711 | "babylon": { 712 | "version": "6.18.0", 713 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", 714 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==", 715 | "dev": true 716 | }, 717 | "balanced-match": { 718 | "version": "1.0.0", 719 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 720 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 721 | "dev": true 722 | }, 723 | "binary-extensions": { 724 | "version": "1.11.0", 725 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", 726 | "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=", 727 | "dev": true, 728 | "optional": true 729 | }, 730 | "blob-to-buffer": { 731 | "version": "1.2.7", 732 | "resolved": "https://registry.npmjs.org/blob-to-buffer/-/blob-to-buffer-1.2.7.tgz", 733 | "integrity": "sha512-IxU6RVzH4cekdAiLbsUIC3fd11fA1c+FoD/+7PTTGejYe3Q8Y++TcR8tXt+1CYG4veMzGI2uMeIismNgqIMq9w==" 734 | }, 735 | "brace-expansion": { 736 | "version": "1.1.11", 737 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 738 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 739 | "dev": true, 740 | "requires": { 741 | "balanced-match": "^1.0.0", 742 | "concat-map": "0.0.1" 743 | } 744 | }, 745 | "braces": { 746 | "version": "1.8.5", 747 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 748 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 749 | "dev": true, 750 | "optional": true, 751 | "requires": { 752 | "expand-range": "^1.8.1", 753 | "preserve": "^0.2.0", 754 | "repeat-element": "^1.1.2" 755 | } 756 | }, 757 | "buffer-from": { 758 | "version": "1.0.0", 759 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.0.0.tgz", 760 | "integrity": "sha512-83apNb8KK0Se60UE1+4Ukbe3HbfELJ6UlI4ldtOGs7So4KD26orJM8hIY9lxdzP+UpItH1Yh/Y8GUvNFWFFRxA==", 761 | "dev": true 762 | }, 763 | "caller-path": { 764 | "version": "0.1.0", 765 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 766 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 767 | "dev": true, 768 | "requires": { 769 | "callsites": "^0.2.0" 770 | } 771 | }, 772 | "callsites": { 773 | "version": "0.2.0", 774 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 775 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 776 | "dev": true 777 | }, 778 | "chalk": { 779 | "version": "1.1.3", 780 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 781 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 782 | "dev": true, 783 | "requires": { 784 | "ansi-styles": "^2.2.1", 785 | "escape-string-regexp": "^1.0.2", 786 | "has-ansi": "^2.0.0", 787 | "strip-ansi": "^3.0.0", 788 | "supports-color": "^2.0.0" 789 | } 790 | }, 791 | "chardet": { 792 | "version": "0.4.2", 793 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.4.2.tgz", 794 | "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", 795 | "dev": true 796 | }, 797 | "chokidar": { 798 | "version": "1.7.0", 799 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", 800 | "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", 801 | "dev": true, 802 | "optional": true, 803 | "requires": { 804 | "anymatch": "^1.3.0", 805 | "async-each": "^1.0.0", 806 | "fsevents": "^1.0.0", 807 | "glob-parent": "^2.0.0", 808 | "inherits": "^2.0.1", 809 | "is-binary-path": "^1.0.0", 810 | "is-glob": "^2.0.0", 811 | "path-is-absolute": "^1.0.0", 812 | "readdirp": "^2.0.0" 813 | } 814 | }, 815 | "circular-json": { 816 | "version": "0.3.3", 817 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 818 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 819 | "dev": true 820 | }, 821 | "cli-cursor": { 822 | "version": "2.1.0", 823 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 824 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 825 | "dev": true, 826 | "requires": { 827 | "restore-cursor": "^2.0.0" 828 | } 829 | }, 830 | "cli-width": { 831 | "version": "2.2.0", 832 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 833 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 834 | "dev": true 835 | }, 836 | "co": { 837 | "version": "4.6.0", 838 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 839 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 840 | "dev": true 841 | }, 842 | "color-convert": { 843 | "version": "1.9.1", 844 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.1.tgz", 845 | "integrity": "sha512-mjGanIiwQJskCC18rPR6OmrZ6fm2Lc7PeGFYwCmy5J34wC6F1PzdGL6xeMfmgicfYcNLGuVFA3WzXtIDCQSZxQ==", 846 | "dev": true, 847 | "requires": { 848 | "color-name": "^1.1.1" 849 | } 850 | }, 851 | "color-name": { 852 | "version": "1.1.3", 853 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 854 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 855 | "dev": true 856 | }, 857 | "commander": { 858 | "version": "2.15.1", 859 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.1.tgz", 860 | "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==", 861 | "dev": true 862 | }, 863 | "concat-map": { 864 | "version": "0.0.1", 865 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 866 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 867 | "dev": true 868 | }, 869 | "concat-stream": { 870 | "version": "1.6.2", 871 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 872 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 873 | "dev": true, 874 | "requires": { 875 | "buffer-from": "^1.0.0", 876 | "inherits": "^2.0.3", 877 | "readable-stream": "^2.2.2", 878 | "typedarray": "^0.0.6" 879 | } 880 | }, 881 | "convert-source-map": { 882 | "version": "1.5.1", 883 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", 884 | "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", 885 | "dev": true 886 | }, 887 | "core-js": { 888 | "version": "2.5.6", 889 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.6.tgz", 890 | "integrity": "sha512-lQUVfQi0aLix2xpyjrrJEvfuYCqPc/HwmTKsC/VNf8q0zsjX7SQZtp4+oRONN5Tsur9GDETPjj+Ub2iDiGZfSQ==", 891 | "dev": true 892 | }, 893 | "core-util-is": { 894 | "version": "1.0.2", 895 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 896 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 897 | "dev": true 898 | }, 899 | "cross-spawn": { 900 | "version": "5.1.0", 901 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 902 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 903 | "dev": true, 904 | "requires": { 905 | "lru-cache": "^4.0.1", 906 | "shebang-command": "^1.2.0", 907 | "which": "^1.2.9" 908 | } 909 | }, 910 | "debug": { 911 | "version": "2.6.9", 912 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 913 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 914 | "dev": true, 915 | "requires": { 916 | "ms": "2.0.0" 917 | } 918 | }, 919 | "deep-is": { 920 | "version": "0.1.3", 921 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 922 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 923 | "dev": true 924 | }, 925 | "del": { 926 | "version": "2.2.2", 927 | "resolved": "https://registry.npmjs.org/del/-/del-2.2.2.tgz", 928 | "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", 929 | "dev": true, 930 | "requires": { 931 | "globby": "^5.0.0", 932 | "is-path-cwd": "^1.0.0", 933 | "is-path-in-cwd": "^1.0.0", 934 | "object-assign": "^4.0.1", 935 | "pify": "^2.0.0", 936 | "pinkie-promise": "^2.0.0", 937 | "rimraf": "^2.2.8" 938 | } 939 | }, 940 | "detect-indent": { 941 | "version": "4.0.0", 942 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", 943 | "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", 944 | "dev": true, 945 | "requires": { 946 | "repeating": "^2.0.0" 947 | } 948 | }, 949 | "detect-node": { 950 | "version": "2.0.3", 951 | "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.0.3.tgz", 952 | "integrity": "sha1-ogM8CcyOFY03dI+951B4Mr1s4Sc=" 953 | }, 954 | "doctrine": { 955 | "version": "2.1.0", 956 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 957 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 958 | "dev": true, 959 | "requires": { 960 | "esutils": "^2.0.2" 961 | } 962 | }, 963 | "escape-string-regexp": { 964 | "version": "1.0.5", 965 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 966 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 967 | "dev": true 968 | }, 969 | "eslint": { 970 | "version": "4.19.1", 971 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-4.19.1.tgz", 972 | "integrity": "sha512-bT3/1x1EbZB7phzYu7vCr1v3ONuzDtX8WjuM9c0iYxe+cq+pwcKEoQjl7zd3RpC6YOLgnSy3cTN58M2jcoPDIQ==", 973 | "dev": true, 974 | "requires": { 975 | "ajv": "^5.3.0", 976 | "babel-code-frame": "^6.22.0", 977 | "chalk": "^2.1.0", 978 | "concat-stream": "^1.6.0", 979 | "cross-spawn": "^5.1.0", 980 | "debug": "^3.1.0", 981 | "doctrine": "^2.1.0", 982 | "eslint-scope": "^3.7.1", 983 | "eslint-visitor-keys": "^1.0.0", 984 | "espree": "^3.5.4", 985 | "esquery": "^1.0.0", 986 | "esutils": "^2.0.2", 987 | "file-entry-cache": "^2.0.0", 988 | "functional-red-black-tree": "^1.0.1", 989 | "glob": "^7.1.2", 990 | "globals": "^11.0.1", 991 | "ignore": "^3.3.3", 992 | "imurmurhash": "^0.1.4", 993 | "inquirer": "^3.0.6", 994 | "is-resolvable": "^1.0.0", 995 | "js-yaml": "^3.9.1", 996 | "json-stable-stringify-without-jsonify": "^1.0.1", 997 | "levn": "^0.3.0", 998 | "lodash": "^4.17.4", 999 | "minimatch": "^3.0.2", 1000 | "mkdirp": "^0.5.1", 1001 | "natural-compare": "^1.4.0", 1002 | "optionator": "^0.8.2", 1003 | "path-is-inside": "^1.0.2", 1004 | "pluralize": "^7.0.0", 1005 | "progress": "^2.0.0", 1006 | "regexpp": "^1.0.1", 1007 | "require-uncached": "^1.0.3", 1008 | "semver": "^5.3.0", 1009 | "strip-ansi": "^4.0.0", 1010 | "strip-json-comments": "~2.0.1", 1011 | "table": "4.0.2", 1012 | "text-table": "~0.2.0" 1013 | }, 1014 | "dependencies": { 1015 | "ansi-regex": { 1016 | "version": "3.0.0", 1017 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1018 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1019 | "dev": true 1020 | }, 1021 | "ansi-styles": { 1022 | "version": "3.2.1", 1023 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1024 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1025 | "dev": true, 1026 | "requires": { 1027 | "color-convert": "^1.9.0" 1028 | } 1029 | }, 1030 | "chalk": { 1031 | "version": "2.4.1", 1032 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 1033 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 1034 | "dev": true, 1035 | "requires": { 1036 | "ansi-styles": "^3.2.1", 1037 | "escape-string-regexp": "^1.0.5", 1038 | "supports-color": "^5.3.0" 1039 | } 1040 | }, 1041 | "debug": { 1042 | "version": "3.1.0", 1043 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1044 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1045 | "dev": true, 1046 | "requires": { 1047 | "ms": "2.0.0" 1048 | } 1049 | }, 1050 | "globals": { 1051 | "version": "11.5.0", 1052 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.5.0.tgz", 1053 | "integrity": "sha512-hYyf+kI8dm3nORsiiXUQigOU62hDLfJ9G01uyGMxhc6BKsircrUhC4uJPQPUSuq2GrTmiiEt7ewxlMdBewfmKQ==", 1054 | "dev": true 1055 | }, 1056 | "strip-ansi": { 1057 | "version": "4.0.0", 1058 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1059 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1060 | "dev": true, 1061 | "requires": { 1062 | "ansi-regex": "^3.0.0" 1063 | } 1064 | }, 1065 | "supports-color": { 1066 | "version": "5.4.0", 1067 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz", 1068 | "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", 1069 | "dev": true, 1070 | "requires": { 1071 | "has-flag": "^3.0.0" 1072 | } 1073 | } 1074 | } 1075 | }, 1076 | "eslint-scope": { 1077 | "version": "3.7.1", 1078 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", 1079 | "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", 1080 | "dev": true, 1081 | "requires": { 1082 | "esrecurse": "^4.1.0", 1083 | "estraverse": "^4.1.1" 1084 | } 1085 | }, 1086 | "eslint-visitor-keys": { 1087 | "version": "1.0.0", 1088 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 1089 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 1090 | "dev": true 1091 | }, 1092 | "espree": { 1093 | "version": "3.5.4", 1094 | "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.4.tgz", 1095 | "integrity": "sha512-yAcIQxtmMiB/jL32dzEp2enBeidsB7xWPLNiw3IIkpVds1P+h7qF9YwJq1yUNzp2OKXgAprs4F61ih66UsoD1A==", 1096 | "dev": true, 1097 | "requires": { 1098 | "acorn": "^5.5.0", 1099 | "acorn-jsx": "^3.0.0" 1100 | } 1101 | }, 1102 | "esprima": { 1103 | "version": "4.0.0", 1104 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz", 1105 | "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", 1106 | "dev": true 1107 | }, 1108 | "esquery": { 1109 | "version": "1.0.1", 1110 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 1111 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 1112 | "dev": true, 1113 | "requires": { 1114 | "estraverse": "^4.0.0" 1115 | } 1116 | }, 1117 | "esrecurse": { 1118 | "version": "4.2.1", 1119 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1120 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1121 | "dev": true, 1122 | "requires": { 1123 | "estraverse": "^4.1.0" 1124 | } 1125 | }, 1126 | "estraverse": { 1127 | "version": "4.2.0", 1128 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 1129 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 1130 | "dev": true 1131 | }, 1132 | "esutils": { 1133 | "version": "2.0.2", 1134 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 1135 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 1136 | "dev": true 1137 | }, 1138 | "expand-brackets": { 1139 | "version": "0.1.5", 1140 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 1141 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 1142 | "dev": true, 1143 | "optional": true, 1144 | "requires": { 1145 | "is-posix-bracket": "^0.1.0" 1146 | } 1147 | }, 1148 | "expand-range": { 1149 | "version": "1.8.2", 1150 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 1151 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 1152 | "dev": true, 1153 | "optional": true, 1154 | "requires": { 1155 | "fill-range": "^2.1.0" 1156 | } 1157 | }, 1158 | "external-editor": { 1159 | "version": "2.2.0", 1160 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.2.0.tgz", 1161 | "integrity": "sha512-bSn6gvGxKt+b7+6TKEv1ZycHleA7aHhRHyAqJyp5pbUFuYYNIzpZnQDk7AsYckyWdEnTeAnay0aCy2aV6iTk9A==", 1162 | "dev": true, 1163 | "requires": { 1164 | "chardet": "^0.4.0", 1165 | "iconv-lite": "^0.4.17", 1166 | "tmp": "^0.0.33" 1167 | } 1168 | }, 1169 | "extglob": { 1170 | "version": "0.3.2", 1171 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 1172 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 1173 | "dev": true, 1174 | "optional": true, 1175 | "requires": { 1176 | "is-extglob": "^1.0.0" 1177 | } 1178 | }, 1179 | "fast-deep-equal": { 1180 | "version": "1.1.0", 1181 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", 1182 | "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", 1183 | "dev": true 1184 | }, 1185 | "fast-json-stable-stringify": { 1186 | "version": "2.0.0", 1187 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 1188 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 1189 | "dev": true 1190 | }, 1191 | "fast-levenshtein": { 1192 | "version": "2.0.6", 1193 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1194 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1195 | "dev": true 1196 | }, 1197 | "figures": { 1198 | "version": "2.0.0", 1199 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 1200 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 1201 | "dev": true, 1202 | "requires": { 1203 | "escape-string-regexp": "^1.0.5" 1204 | } 1205 | }, 1206 | "file-entry-cache": { 1207 | "version": "2.0.0", 1208 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 1209 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 1210 | "dev": true, 1211 | "requires": { 1212 | "flat-cache": "^1.2.1", 1213 | "object-assign": "^4.0.1" 1214 | } 1215 | }, 1216 | "filename-regex": { 1217 | "version": "2.0.1", 1218 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 1219 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 1220 | "dev": true, 1221 | "optional": true 1222 | }, 1223 | "fill-range": { 1224 | "version": "2.2.4", 1225 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.4.tgz", 1226 | "integrity": "sha512-cnrcCbj01+j2gTG921VZPnHbjmdAf8oQV/iGeV2kZxGSyfYjjTyY79ErsK1WJWMpw6DaApEX72binqJE+/d+5Q==", 1227 | "dev": true, 1228 | "optional": true, 1229 | "requires": { 1230 | "is-number": "^2.1.0", 1231 | "isobject": "^2.0.0", 1232 | "randomatic": "^3.0.0", 1233 | "repeat-element": "^1.1.2", 1234 | "repeat-string": "^1.5.2" 1235 | } 1236 | }, 1237 | "flat-cache": { 1238 | "version": "1.3.0", 1239 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", 1240 | "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", 1241 | "dev": true, 1242 | "requires": { 1243 | "circular-json": "^0.3.1", 1244 | "del": "^2.0.2", 1245 | "graceful-fs": "^4.1.2", 1246 | "write": "^0.2.1" 1247 | } 1248 | }, 1249 | "for-in": { 1250 | "version": "1.0.2", 1251 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 1252 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 1253 | "dev": true, 1254 | "optional": true 1255 | }, 1256 | "for-own": { 1257 | "version": "0.1.5", 1258 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 1259 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 1260 | "dev": true, 1261 | "optional": true, 1262 | "requires": { 1263 | "for-in": "^1.0.1" 1264 | } 1265 | }, 1266 | "fs-readdir-recursive": { 1267 | "version": "1.1.0", 1268 | "resolved": "https://registry.npmjs.org/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz", 1269 | "integrity": "sha512-GNanXlVr2pf02+sPN40XN8HG+ePaNcvM0q5mZBd668Obwb0yD5GiUbZOFgwn8kGMY6I3mdyDJzieUy3PTYyTRA==", 1270 | "dev": true 1271 | }, 1272 | "fs.realpath": { 1273 | "version": "1.0.0", 1274 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1275 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1276 | "dev": true 1277 | }, 1278 | "fsevents": { 1279 | "version": "1.2.3", 1280 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.3.tgz", 1281 | "integrity": "sha512-X+57O5YkDTiEQGiw8i7wYc2nQgweIekqkepI8Q3y4wVlurgBt2SuwxTeYUYMZIGpLZH3r/TsMjczCMXE5ZOt7Q==", 1282 | "dev": true, 1283 | "optional": true, 1284 | "requires": { 1285 | "nan": "^2.9.2", 1286 | "node-pre-gyp": "^0.9.0" 1287 | }, 1288 | "dependencies": { 1289 | "abbrev": { 1290 | "version": "1.1.1", 1291 | "bundled": true, 1292 | "dev": true, 1293 | "optional": true 1294 | }, 1295 | "ansi-regex": { 1296 | "version": "2.1.1", 1297 | "bundled": true, 1298 | "dev": true 1299 | }, 1300 | "aproba": { 1301 | "version": "1.2.0", 1302 | "bundled": true, 1303 | "dev": true, 1304 | "optional": true 1305 | }, 1306 | "are-we-there-yet": { 1307 | "version": "1.1.4", 1308 | "bundled": true, 1309 | "dev": true, 1310 | "optional": true, 1311 | "requires": { 1312 | "delegates": "^1.0.0", 1313 | "readable-stream": "^2.0.6" 1314 | } 1315 | }, 1316 | "balanced-match": { 1317 | "version": "1.0.0", 1318 | "bundled": true, 1319 | "dev": true 1320 | }, 1321 | "brace-expansion": { 1322 | "version": "1.1.11", 1323 | "bundled": true, 1324 | "dev": true, 1325 | "requires": { 1326 | "balanced-match": "^1.0.0", 1327 | "concat-map": "0.0.1" 1328 | } 1329 | }, 1330 | "chownr": { 1331 | "version": "1.0.1", 1332 | "bundled": true, 1333 | "dev": true, 1334 | "optional": true 1335 | }, 1336 | "code-point-at": { 1337 | "version": "1.1.0", 1338 | "bundled": true, 1339 | "dev": true 1340 | }, 1341 | "concat-map": { 1342 | "version": "0.0.1", 1343 | "bundled": true, 1344 | "dev": true 1345 | }, 1346 | "console-control-strings": { 1347 | "version": "1.1.0", 1348 | "bundled": true, 1349 | "dev": true 1350 | }, 1351 | "core-util-is": { 1352 | "version": "1.0.2", 1353 | "bundled": true, 1354 | "dev": true, 1355 | "optional": true 1356 | }, 1357 | "debug": { 1358 | "version": "2.6.9", 1359 | "bundled": true, 1360 | "dev": true, 1361 | "optional": true, 1362 | "requires": { 1363 | "ms": "2.0.0" 1364 | } 1365 | }, 1366 | "deep-extend": { 1367 | "version": "0.4.2", 1368 | "bundled": true, 1369 | "dev": true, 1370 | "optional": true 1371 | }, 1372 | "delegates": { 1373 | "version": "1.0.0", 1374 | "bundled": true, 1375 | "dev": true, 1376 | "optional": true 1377 | }, 1378 | "detect-libc": { 1379 | "version": "1.0.3", 1380 | "bundled": true, 1381 | "dev": true, 1382 | "optional": true 1383 | }, 1384 | "fs-minipass": { 1385 | "version": "1.2.5", 1386 | "bundled": true, 1387 | "dev": true, 1388 | "optional": true, 1389 | "requires": { 1390 | "minipass": "^2.2.1" 1391 | } 1392 | }, 1393 | "fs.realpath": { 1394 | "version": "1.0.0", 1395 | "bundled": true, 1396 | "dev": true, 1397 | "optional": true 1398 | }, 1399 | "gauge": { 1400 | "version": "2.7.4", 1401 | "bundled": true, 1402 | "dev": true, 1403 | "optional": true, 1404 | "requires": { 1405 | "aproba": "^1.0.3", 1406 | "console-control-strings": "^1.0.0", 1407 | "has-unicode": "^2.0.0", 1408 | "object-assign": "^4.1.0", 1409 | "signal-exit": "^3.0.0", 1410 | "string-width": "^1.0.1", 1411 | "strip-ansi": "^3.0.1", 1412 | "wide-align": "^1.1.0" 1413 | } 1414 | }, 1415 | "glob": { 1416 | "version": "7.1.2", 1417 | "bundled": true, 1418 | "dev": true, 1419 | "optional": true, 1420 | "requires": { 1421 | "fs.realpath": "^1.0.0", 1422 | "inflight": "^1.0.4", 1423 | "inherits": "2", 1424 | "minimatch": "^3.0.4", 1425 | "once": "^1.3.0", 1426 | "path-is-absolute": "^1.0.0" 1427 | } 1428 | }, 1429 | "has-unicode": { 1430 | "version": "2.0.1", 1431 | "bundled": true, 1432 | "dev": true, 1433 | "optional": true 1434 | }, 1435 | "iconv-lite": { 1436 | "version": "0.4.21", 1437 | "bundled": true, 1438 | "dev": true, 1439 | "optional": true, 1440 | "requires": { 1441 | "safer-buffer": "^2.1.0" 1442 | } 1443 | }, 1444 | "ignore-walk": { 1445 | "version": "3.0.1", 1446 | "bundled": true, 1447 | "dev": true, 1448 | "optional": true, 1449 | "requires": { 1450 | "minimatch": "^3.0.4" 1451 | } 1452 | }, 1453 | "inflight": { 1454 | "version": "1.0.6", 1455 | "bundled": true, 1456 | "dev": true, 1457 | "optional": true, 1458 | "requires": { 1459 | "once": "^1.3.0", 1460 | "wrappy": "1" 1461 | } 1462 | }, 1463 | "inherits": { 1464 | "version": "2.0.3", 1465 | "bundled": true, 1466 | "dev": true 1467 | }, 1468 | "ini": { 1469 | "version": "1.3.5", 1470 | "bundled": true, 1471 | "dev": true, 1472 | "optional": true 1473 | }, 1474 | "is-fullwidth-code-point": { 1475 | "version": "1.0.0", 1476 | "bundled": true, 1477 | "dev": true, 1478 | "requires": { 1479 | "number-is-nan": "^1.0.0" 1480 | } 1481 | }, 1482 | "isarray": { 1483 | "version": "1.0.0", 1484 | "bundled": true, 1485 | "dev": true, 1486 | "optional": true 1487 | }, 1488 | "minimatch": { 1489 | "version": "3.0.4", 1490 | "bundled": true, 1491 | "dev": true, 1492 | "requires": { 1493 | "brace-expansion": "^1.1.7" 1494 | } 1495 | }, 1496 | "minimist": { 1497 | "version": "0.0.8", 1498 | "bundled": true, 1499 | "dev": true 1500 | }, 1501 | "minipass": { 1502 | "version": "2.2.4", 1503 | "bundled": true, 1504 | "dev": true, 1505 | "requires": { 1506 | "safe-buffer": "^5.1.1", 1507 | "yallist": "^3.0.0" 1508 | } 1509 | }, 1510 | "minizlib": { 1511 | "version": "1.1.0", 1512 | "bundled": true, 1513 | "dev": true, 1514 | "optional": true, 1515 | "requires": { 1516 | "minipass": "^2.2.1" 1517 | } 1518 | }, 1519 | "mkdirp": { 1520 | "version": "0.5.1", 1521 | "bundled": true, 1522 | "dev": true, 1523 | "requires": { 1524 | "minimist": "0.0.8" 1525 | } 1526 | }, 1527 | "ms": { 1528 | "version": "2.0.0", 1529 | "bundled": true, 1530 | "dev": true, 1531 | "optional": true 1532 | }, 1533 | "needle": { 1534 | "version": "2.2.0", 1535 | "bundled": true, 1536 | "dev": true, 1537 | "optional": true, 1538 | "requires": { 1539 | "debug": "^2.1.2", 1540 | "iconv-lite": "^0.4.4", 1541 | "sax": "^1.2.4" 1542 | } 1543 | }, 1544 | "node-pre-gyp": { 1545 | "version": "0.9.1", 1546 | "bundled": true, 1547 | "dev": true, 1548 | "optional": true, 1549 | "requires": { 1550 | "detect-libc": "^1.0.2", 1551 | "mkdirp": "^0.5.1", 1552 | "needle": "^2.2.0", 1553 | "nopt": "^4.0.1", 1554 | "npm-packlist": "^1.1.6", 1555 | "npmlog": "^4.0.2", 1556 | "rc": "^1.1.7", 1557 | "rimraf": "^2.6.1", 1558 | "semver": "^5.3.0", 1559 | "tar": "^4" 1560 | } 1561 | }, 1562 | "nopt": { 1563 | "version": "4.0.1", 1564 | "bundled": true, 1565 | "dev": true, 1566 | "optional": true, 1567 | "requires": { 1568 | "abbrev": "1", 1569 | "osenv": "^0.1.4" 1570 | } 1571 | }, 1572 | "npm-bundled": { 1573 | "version": "1.0.3", 1574 | "bundled": true, 1575 | "dev": true, 1576 | "optional": true 1577 | }, 1578 | "npm-packlist": { 1579 | "version": "1.1.10", 1580 | "bundled": true, 1581 | "dev": true, 1582 | "optional": true, 1583 | "requires": { 1584 | "ignore-walk": "^3.0.1", 1585 | "npm-bundled": "^1.0.1" 1586 | } 1587 | }, 1588 | "npmlog": { 1589 | "version": "4.1.2", 1590 | "bundled": true, 1591 | "dev": true, 1592 | "optional": true, 1593 | "requires": { 1594 | "are-we-there-yet": "~1.1.2", 1595 | "console-control-strings": "~1.1.0", 1596 | "gauge": "~2.7.3", 1597 | "set-blocking": "~2.0.0" 1598 | } 1599 | }, 1600 | "number-is-nan": { 1601 | "version": "1.0.1", 1602 | "bundled": true, 1603 | "dev": true 1604 | }, 1605 | "object-assign": { 1606 | "version": "4.1.1", 1607 | "bundled": true, 1608 | "dev": true, 1609 | "optional": true 1610 | }, 1611 | "once": { 1612 | "version": "1.4.0", 1613 | "bundled": true, 1614 | "dev": true, 1615 | "requires": { 1616 | "wrappy": "1" 1617 | } 1618 | }, 1619 | "os-homedir": { 1620 | "version": "1.0.2", 1621 | "bundled": true, 1622 | "dev": true, 1623 | "optional": true 1624 | }, 1625 | "os-tmpdir": { 1626 | "version": "1.0.2", 1627 | "bundled": true, 1628 | "dev": true, 1629 | "optional": true 1630 | }, 1631 | "osenv": { 1632 | "version": "0.1.5", 1633 | "bundled": true, 1634 | "dev": true, 1635 | "optional": true, 1636 | "requires": { 1637 | "os-homedir": "^1.0.0", 1638 | "os-tmpdir": "^1.0.0" 1639 | } 1640 | }, 1641 | "path-is-absolute": { 1642 | "version": "1.0.1", 1643 | "bundled": true, 1644 | "dev": true, 1645 | "optional": true 1646 | }, 1647 | "process-nextick-args": { 1648 | "version": "2.0.0", 1649 | "bundled": true, 1650 | "dev": true, 1651 | "optional": true 1652 | }, 1653 | "rc": { 1654 | "version": "1.2.6", 1655 | "bundled": true, 1656 | "dev": true, 1657 | "optional": true, 1658 | "requires": { 1659 | "deep-extend": "~0.4.0", 1660 | "ini": "~1.3.0", 1661 | "minimist": "^1.2.0", 1662 | "strip-json-comments": "~2.0.1" 1663 | }, 1664 | "dependencies": { 1665 | "minimist": { 1666 | "version": "1.2.0", 1667 | "bundled": true, 1668 | "dev": true, 1669 | "optional": true 1670 | } 1671 | } 1672 | }, 1673 | "readable-stream": { 1674 | "version": "2.3.6", 1675 | "bundled": true, 1676 | "dev": true, 1677 | "optional": true, 1678 | "requires": { 1679 | "core-util-is": "~1.0.0", 1680 | "inherits": "~2.0.3", 1681 | "isarray": "~1.0.0", 1682 | "process-nextick-args": "~2.0.0", 1683 | "safe-buffer": "~5.1.1", 1684 | "string_decoder": "~1.1.1", 1685 | "util-deprecate": "~1.0.1" 1686 | } 1687 | }, 1688 | "rimraf": { 1689 | "version": "2.6.2", 1690 | "bundled": true, 1691 | "dev": true, 1692 | "optional": true, 1693 | "requires": { 1694 | "glob": "^7.0.5" 1695 | } 1696 | }, 1697 | "safe-buffer": { 1698 | "version": "5.1.1", 1699 | "bundled": true, 1700 | "dev": true 1701 | }, 1702 | "safer-buffer": { 1703 | "version": "2.1.2", 1704 | "bundled": true, 1705 | "dev": true, 1706 | "optional": true 1707 | }, 1708 | "sax": { 1709 | "version": "1.2.4", 1710 | "bundled": true, 1711 | "dev": true, 1712 | "optional": true 1713 | }, 1714 | "semver": { 1715 | "version": "5.5.0", 1716 | "bundled": true, 1717 | "dev": true, 1718 | "optional": true 1719 | }, 1720 | "set-blocking": { 1721 | "version": "2.0.0", 1722 | "bundled": true, 1723 | "dev": true, 1724 | "optional": true 1725 | }, 1726 | "signal-exit": { 1727 | "version": "3.0.2", 1728 | "bundled": true, 1729 | "dev": true, 1730 | "optional": true 1731 | }, 1732 | "string-width": { 1733 | "version": "1.0.2", 1734 | "bundled": true, 1735 | "dev": true, 1736 | "requires": { 1737 | "code-point-at": "^1.0.0", 1738 | "is-fullwidth-code-point": "^1.0.0", 1739 | "strip-ansi": "^3.0.0" 1740 | } 1741 | }, 1742 | "string_decoder": { 1743 | "version": "1.1.1", 1744 | "bundled": true, 1745 | "dev": true, 1746 | "optional": true, 1747 | "requires": { 1748 | "safe-buffer": "~5.1.0" 1749 | } 1750 | }, 1751 | "strip-ansi": { 1752 | "version": "3.0.1", 1753 | "bundled": true, 1754 | "dev": true, 1755 | "requires": { 1756 | "ansi-regex": "^2.0.0" 1757 | } 1758 | }, 1759 | "strip-json-comments": { 1760 | "version": "2.0.1", 1761 | "bundled": true, 1762 | "dev": true, 1763 | "optional": true 1764 | }, 1765 | "tar": { 1766 | "version": "4.4.1", 1767 | "bundled": true, 1768 | "dev": true, 1769 | "optional": true, 1770 | "requires": { 1771 | "chownr": "^1.0.1", 1772 | "fs-minipass": "^1.2.5", 1773 | "minipass": "^2.2.4", 1774 | "minizlib": "^1.1.0", 1775 | "mkdirp": "^0.5.0", 1776 | "safe-buffer": "^5.1.1", 1777 | "yallist": "^3.0.2" 1778 | } 1779 | }, 1780 | "util-deprecate": { 1781 | "version": "1.0.2", 1782 | "bundled": true, 1783 | "dev": true, 1784 | "optional": true 1785 | }, 1786 | "wide-align": { 1787 | "version": "1.1.2", 1788 | "bundled": true, 1789 | "dev": true, 1790 | "optional": true, 1791 | "requires": { 1792 | "string-width": "^1.0.2" 1793 | } 1794 | }, 1795 | "wrappy": { 1796 | "version": "1.0.2", 1797 | "bundled": true, 1798 | "dev": true 1799 | }, 1800 | "yallist": { 1801 | "version": "3.0.2", 1802 | "bundled": true, 1803 | "dev": true 1804 | } 1805 | } 1806 | }, 1807 | "functional-red-black-tree": { 1808 | "version": "1.0.1", 1809 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1810 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1811 | "dev": true 1812 | }, 1813 | "glob": { 1814 | "version": "7.1.2", 1815 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 1816 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 1817 | "dev": true, 1818 | "requires": { 1819 | "fs.realpath": "^1.0.0", 1820 | "inflight": "^1.0.4", 1821 | "inherits": "2", 1822 | "minimatch": "^3.0.4", 1823 | "once": "^1.3.0", 1824 | "path-is-absolute": "^1.0.0" 1825 | } 1826 | }, 1827 | "glob-base": { 1828 | "version": "0.3.0", 1829 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 1830 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 1831 | "dev": true, 1832 | "optional": true, 1833 | "requires": { 1834 | "glob-parent": "^2.0.0", 1835 | "is-glob": "^2.0.0" 1836 | } 1837 | }, 1838 | "glob-parent": { 1839 | "version": "2.0.0", 1840 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 1841 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 1842 | "dev": true, 1843 | "requires": { 1844 | "is-glob": "^2.0.0" 1845 | } 1846 | }, 1847 | "globals": { 1848 | "version": "9.18.0", 1849 | "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", 1850 | "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", 1851 | "dev": true 1852 | }, 1853 | "globby": { 1854 | "version": "5.0.0", 1855 | "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", 1856 | "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", 1857 | "dev": true, 1858 | "requires": { 1859 | "array-union": "^1.0.1", 1860 | "arrify": "^1.0.0", 1861 | "glob": "^7.0.3", 1862 | "object-assign": "^4.0.1", 1863 | "pify": "^2.0.0", 1864 | "pinkie-promise": "^2.0.0" 1865 | } 1866 | }, 1867 | "graceful-fs": { 1868 | "version": "4.1.11", 1869 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1870 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 1871 | "dev": true 1872 | }, 1873 | "has-ansi": { 1874 | "version": "2.0.0", 1875 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1876 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1877 | "dev": true, 1878 | "requires": { 1879 | "ansi-regex": "^2.0.0" 1880 | } 1881 | }, 1882 | "has-flag": { 1883 | "version": "3.0.0", 1884 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1885 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1886 | "dev": true 1887 | }, 1888 | "home-or-tmp": { 1889 | "version": "2.0.0", 1890 | "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", 1891 | "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", 1892 | "dev": true, 1893 | "requires": { 1894 | "os-homedir": "^1.0.0", 1895 | "os-tmpdir": "^1.0.1" 1896 | } 1897 | }, 1898 | "iconv-lite": { 1899 | "version": "0.4.23", 1900 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 1901 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 1902 | "dev": true, 1903 | "requires": { 1904 | "safer-buffer": ">= 2.1.2 < 3" 1905 | } 1906 | }, 1907 | "ignore": { 1908 | "version": "3.3.8", 1909 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.8.tgz", 1910 | "integrity": "sha512-pUh+xUQQhQzevjRHHFqqcTy0/dP/kS9I8HSrUydhihjuD09W6ldVWFtIrwhXdUJHis3i2rZNqEHpZH/cbinFbg==", 1911 | "dev": true 1912 | }, 1913 | "imurmurhash": { 1914 | "version": "0.1.4", 1915 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1916 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1917 | "dev": true 1918 | }, 1919 | "inflight": { 1920 | "version": "1.0.6", 1921 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1922 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1923 | "dev": true, 1924 | "requires": { 1925 | "once": "^1.3.0", 1926 | "wrappy": "1" 1927 | } 1928 | }, 1929 | "inherits": { 1930 | "version": "2.0.3", 1931 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1932 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1933 | "dev": true 1934 | }, 1935 | "inquirer": { 1936 | "version": "3.3.0", 1937 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-3.3.0.tgz", 1938 | "integrity": "sha512-h+xtnyk4EwKvFWHrUYsWErEVR+igKtLdchu+o0Z1RL7VU/jVMFbYir2bp6bAj8efFNxWqHX0dIss6fJQ+/+qeQ==", 1939 | "dev": true, 1940 | "requires": { 1941 | "ansi-escapes": "^3.0.0", 1942 | "chalk": "^2.0.0", 1943 | "cli-cursor": "^2.1.0", 1944 | "cli-width": "^2.0.0", 1945 | "external-editor": "^2.0.4", 1946 | "figures": "^2.0.0", 1947 | "lodash": "^4.3.0", 1948 | "mute-stream": "0.0.7", 1949 | "run-async": "^2.2.0", 1950 | "rx-lite": "^4.0.8", 1951 | "rx-lite-aggregates": "^4.0.8", 1952 | "string-width": "^2.1.0", 1953 | "strip-ansi": "^4.0.0", 1954 | "through": "^2.3.6" 1955 | }, 1956 | "dependencies": { 1957 | "ansi-regex": { 1958 | "version": "3.0.0", 1959 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1960 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1961 | "dev": true 1962 | }, 1963 | "ansi-styles": { 1964 | "version": "3.2.1", 1965 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1966 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1967 | "dev": true, 1968 | "requires": { 1969 | "color-convert": "^1.9.0" 1970 | } 1971 | }, 1972 | "chalk": { 1973 | "version": "2.4.1", 1974 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 1975 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 1976 | "dev": true, 1977 | "requires": { 1978 | "ansi-styles": "^3.2.1", 1979 | "escape-string-regexp": "^1.0.5", 1980 | "supports-color": "^5.3.0" 1981 | } 1982 | }, 1983 | "strip-ansi": { 1984 | "version": "4.0.0", 1985 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1986 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1987 | "dev": true, 1988 | "requires": { 1989 | "ansi-regex": "^3.0.0" 1990 | } 1991 | }, 1992 | "supports-color": { 1993 | "version": "5.4.0", 1994 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz", 1995 | "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", 1996 | "dev": true, 1997 | "requires": { 1998 | "has-flag": "^3.0.0" 1999 | } 2000 | } 2001 | } 2002 | }, 2003 | "invariant": { 2004 | "version": "2.2.4", 2005 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", 2006 | "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", 2007 | "dev": true, 2008 | "requires": { 2009 | "loose-envify": "^1.0.0" 2010 | } 2011 | }, 2012 | "is-binary-path": { 2013 | "version": "1.0.1", 2014 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 2015 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 2016 | "dev": true, 2017 | "optional": true, 2018 | "requires": { 2019 | "binary-extensions": "^1.0.0" 2020 | } 2021 | }, 2022 | "is-buffer": { 2023 | "version": "1.1.6", 2024 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 2025 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 2026 | "dev": true 2027 | }, 2028 | "is-dotfile": { 2029 | "version": "1.0.3", 2030 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 2031 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 2032 | "dev": true, 2033 | "optional": true 2034 | }, 2035 | "is-equal-shallow": { 2036 | "version": "0.1.3", 2037 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 2038 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 2039 | "dev": true, 2040 | "optional": true, 2041 | "requires": { 2042 | "is-primitive": "^2.0.0" 2043 | } 2044 | }, 2045 | "is-extendable": { 2046 | "version": "0.1.1", 2047 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 2048 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 2049 | "dev": true, 2050 | "optional": true 2051 | }, 2052 | "is-extglob": { 2053 | "version": "1.0.0", 2054 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 2055 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 2056 | "dev": true 2057 | }, 2058 | "is-finite": { 2059 | "version": "1.0.2", 2060 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", 2061 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", 2062 | "dev": true, 2063 | "requires": { 2064 | "number-is-nan": "^1.0.0" 2065 | } 2066 | }, 2067 | "is-fullwidth-code-point": { 2068 | "version": "2.0.0", 2069 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2070 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2071 | "dev": true 2072 | }, 2073 | "is-glob": { 2074 | "version": "2.0.1", 2075 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 2076 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 2077 | "dev": true, 2078 | "requires": { 2079 | "is-extglob": "^1.0.0" 2080 | } 2081 | }, 2082 | "is-number": { 2083 | "version": "2.1.0", 2084 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 2085 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 2086 | "dev": true, 2087 | "optional": true, 2088 | "requires": { 2089 | "kind-of": "^3.0.2" 2090 | } 2091 | }, 2092 | "is-path-cwd": { 2093 | "version": "1.0.0", 2094 | "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", 2095 | "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", 2096 | "dev": true 2097 | }, 2098 | "is-path-in-cwd": { 2099 | "version": "1.0.1", 2100 | "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz", 2101 | "integrity": "sha512-FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ==", 2102 | "dev": true, 2103 | "requires": { 2104 | "is-path-inside": "^1.0.0" 2105 | } 2106 | }, 2107 | "is-path-inside": { 2108 | "version": "1.0.1", 2109 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 2110 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 2111 | "dev": true, 2112 | "requires": { 2113 | "path-is-inside": "^1.0.1" 2114 | } 2115 | }, 2116 | "is-posix-bracket": { 2117 | "version": "0.1.1", 2118 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 2119 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 2120 | "dev": true, 2121 | "optional": true 2122 | }, 2123 | "is-primitive": { 2124 | "version": "2.0.0", 2125 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 2126 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 2127 | "dev": true, 2128 | "optional": true 2129 | }, 2130 | "is-promise": { 2131 | "version": "2.1.0", 2132 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 2133 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 2134 | "dev": true 2135 | }, 2136 | "is-resolvable": { 2137 | "version": "1.1.0", 2138 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", 2139 | "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", 2140 | "dev": true 2141 | }, 2142 | "isarray": { 2143 | "version": "1.0.0", 2144 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2145 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 2146 | "dev": true 2147 | }, 2148 | "isexe": { 2149 | "version": "2.0.0", 2150 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2151 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2152 | "dev": true 2153 | }, 2154 | "isobject": { 2155 | "version": "2.1.0", 2156 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 2157 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 2158 | "dev": true, 2159 | "optional": true, 2160 | "requires": { 2161 | "isarray": "1.0.0" 2162 | } 2163 | }, 2164 | "js-tokens": { 2165 | "version": "3.0.2", 2166 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 2167 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 2168 | "dev": true 2169 | }, 2170 | "js-yaml": { 2171 | "version": "3.11.0", 2172 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.11.0.tgz", 2173 | "integrity": "sha512-saJstZWv7oNeOyBh3+Dx1qWzhW0+e6/8eDzo7p5rDFqxntSztloLtuKu+Ejhtq82jsilwOIZYsCz+lIjthg1Hw==", 2174 | "dev": true, 2175 | "requires": { 2176 | "argparse": "^1.0.7", 2177 | "esprima": "^4.0.0" 2178 | } 2179 | }, 2180 | "jsesc": { 2181 | "version": "1.3.0", 2182 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", 2183 | "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=", 2184 | "dev": true 2185 | }, 2186 | "json-schema-traverse": { 2187 | "version": "0.3.1", 2188 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 2189 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 2190 | "dev": true 2191 | }, 2192 | "json-stable-stringify-without-jsonify": { 2193 | "version": "1.0.1", 2194 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2195 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2196 | "dev": true 2197 | }, 2198 | "json5": { 2199 | "version": "0.5.1", 2200 | "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", 2201 | "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", 2202 | "dev": true 2203 | }, 2204 | "kind-of": { 2205 | "version": "3.2.2", 2206 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2207 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2208 | "dev": true, 2209 | "requires": { 2210 | "is-buffer": "^1.1.5" 2211 | } 2212 | }, 2213 | "levn": { 2214 | "version": "0.3.0", 2215 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 2216 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 2217 | "dev": true, 2218 | "requires": { 2219 | "prelude-ls": "~1.1.2", 2220 | "type-check": "~0.3.2" 2221 | } 2222 | }, 2223 | "lodash": { 2224 | "version": "4.17.10", 2225 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.10.tgz", 2226 | "integrity": "sha512-UejweD1pDoXu+AD825lWwp4ZGtSwgnpZxb3JDViD7StjQz+Nb/6l093lx4OQ0foGWNRoc19mWy7BzL+UAK2iVg==", 2227 | "dev": true 2228 | }, 2229 | "loose-envify": { 2230 | "version": "1.3.1", 2231 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.3.1.tgz", 2232 | "integrity": "sha1-0aitM/qc4OcT1l/dCsi3SNR4yEg=", 2233 | "dev": true, 2234 | "requires": { 2235 | "js-tokens": "^3.0.0" 2236 | } 2237 | }, 2238 | "lru-cache": { 2239 | "version": "4.1.3", 2240 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.3.tgz", 2241 | "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", 2242 | "dev": true, 2243 | "requires": { 2244 | "pseudomap": "^1.0.2", 2245 | "yallist": "^2.1.2" 2246 | } 2247 | }, 2248 | "math-random": { 2249 | "version": "1.0.1", 2250 | "resolved": "https://registry.npmjs.org/math-random/-/math-random-1.0.1.tgz", 2251 | "integrity": "sha1-izqsWIuKZuSXXjzepn97sylgH6w=", 2252 | "dev": true, 2253 | "optional": true 2254 | }, 2255 | "micromatch": { 2256 | "version": "2.3.11", 2257 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 2258 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 2259 | "dev": true, 2260 | "optional": true, 2261 | "requires": { 2262 | "arr-diff": "^2.0.0", 2263 | "array-unique": "^0.2.1", 2264 | "braces": "^1.8.2", 2265 | "expand-brackets": "^0.1.4", 2266 | "extglob": "^0.3.1", 2267 | "filename-regex": "^2.0.0", 2268 | "is-extglob": "^1.0.0", 2269 | "is-glob": "^2.0.1", 2270 | "kind-of": "^3.0.2", 2271 | "normalize-path": "^2.0.1", 2272 | "object.omit": "^2.0.0", 2273 | "parse-glob": "^3.0.4", 2274 | "regex-cache": "^0.4.2" 2275 | } 2276 | }, 2277 | "mimic-fn": { 2278 | "version": "1.2.0", 2279 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 2280 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 2281 | "dev": true 2282 | }, 2283 | "minimatch": { 2284 | "version": "3.0.4", 2285 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2286 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2287 | "dev": true, 2288 | "requires": { 2289 | "brace-expansion": "^1.1.7" 2290 | } 2291 | }, 2292 | "minimist": { 2293 | "version": "0.0.8", 2294 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 2295 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 2296 | "dev": true 2297 | }, 2298 | "mkdirp": { 2299 | "version": "0.5.1", 2300 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 2301 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 2302 | "dev": true, 2303 | "requires": { 2304 | "minimist": "0.0.8" 2305 | } 2306 | }, 2307 | "ms": { 2308 | "version": "2.0.0", 2309 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2310 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 2311 | "dev": true 2312 | }, 2313 | "mute-stream": { 2314 | "version": "0.0.7", 2315 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 2316 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 2317 | "dev": true 2318 | }, 2319 | "nan": { 2320 | "version": "2.10.0", 2321 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", 2322 | "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", 2323 | "dev": true, 2324 | "optional": true 2325 | }, 2326 | "natural-compare": { 2327 | "version": "1.4.0", 2328 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2329 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2330 | "dev": true 2331 | }, 2332 | "normalize-path": { 2333 | "version": "2.1.1", 2334 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 2335 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 2336 | "dev": true, 2337 | "requires": { 2338 | "remove-trailing-separator": "^1.0.1" 2339 | } 2340 | }, 2341 | "number-is-nan": { 2342 | "version": "1.0.1", 2343 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 2344 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 2345 | "dev": true 2346 | }, 2347 | "object-assign": { 2348 | "version": "4.1.1", 2349 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2350 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 2351 | "dev": true 2352 | }, 2353 | "object.omit": { 2354 | "version": "2.0.1", 2355 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 2356 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 2357 | "dev": true, 2358 | "optional": true, 2359 | "requires": { 2360 | "for-own": "^0.1.4", 2361 | "is-extendable": "^0.1.1" 2362 | } 2363 | }, 2364 | "once": { 2365 | "version": "1.4.0", 2366 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2367 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2368 | "dev": true, 2369 | "requires": { 2370 | "wrappy": "1" 2371 | } 2372 | }, 2373 | "onetime": { 2374 | "version": "2.0.1", 2375 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 2376 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 2377 | "dev": true, 2378 | "requires": { 2379 | "mimic-fn": "^1.0.0" 2380 | } 2381 | }, 2382 | "optionator": { 2383 | "version": "0.8.2", 2384 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 2385 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 2386 | "dev": true, 2387 | "requires": { 2388 | "deep-is": "~0.1.3", 2389 | "fast-levenshtein": "~2.0.4", 2390 | "levn": "~0.3.0", 2391 | "prelude-ls": "~1.1.2", 2392 | "type-check": "~0.3.2", 2393 | "wordwrap": "~1.0.0" 2394 | } 2395 | }, 2396 | "os-homedir": { 2397 | "version": "1.0.2", 2398 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 2399 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 2400 | "dev": true 2401 | }, 2402 | "os-tmpdir": { 2403 | "version": "1.0.2", 2404 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2405 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 2406 | "dev": true 2407 | }, 2408 | "output-file-sync": { 2409 | "version": "1.1.2", 2410 | "resolved": "https://registry.npmjs.org/output-file-sync/-/output-file-sync-1.1.2.tgz", 2411 | "integrity": "sha1-0KM+7+YaIF+suQCS6CZZjVJFznY=", 2412 | "dev": true, 2413 | "requires": { 2414 | "graceful-fs": "^4.1.4", 2415 | "mkdirp": "^0.5.1", 2416 | "object-assign": "^4.1.0" 2417 | } 2418 | }, 2419 | "parse-glob": { 2420 | "version": "3.0.4", 2421 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 2422 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 2423 | "dev": true, 2424 | "optional": true, 2425 | "requires": { 2426 | "glob-base": "^0.3.0", 2427 | "is-dotfile": "^1.0.0", 2428 | "is-extglob": "^1.0.0", 2429 | "is-glob": "^2.0.0" 2430 | } 2431 | }, 2432 | "path-is-absolute": { 2433 | "version": "1.0.1", 2434 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2435 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2436 | "dev": true 2437 | }, 2438 | "path-is-inside": { 2439 | "version": "1.0.2", 2440 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2441 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 2442 | "dev": true 2443 | }, 2444 | "pify": { 2445 | "version": "2.3.0", 2446 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2447 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 2448 | "dev": true 2449 | }, 2450 | "pinkie": { 2451 | "version": "2.0.4", 2452 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 2453 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 2454 | "dev": true 2455 | }, 2456 | "pinkie-promise": { 2457 | "version": "2.0.1", 2458 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 2459 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 2460 | "dev": true, 2461 | "requires": { 2462 | "pinkie": "^2.0.0" 2463 | } 2464 | }, 2465 | "pluralize": { 2466 | "version": "7.0.0", 2467 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 2468 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 2469 | "dev": true 2470 | }, 2471 | "prelude-ls": { 2472 | "version": "1.1.2", 2473 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2474 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2475 | "dev": true 2476 | }, 2477 | "preserve": { 2478 | "version": "0.2.0", 2479 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 2480 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 2481 | "dev": true, 2482 | "optional": true 2483 | }, 2484 | "private": { 2485 | "version": "0.1.8", 2486 | "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", 2487 | "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", 2488 | "dev": true 2489 | }, 2490 | "process-nextick-args": { 2491 | "version": "2.0.0", 2492 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 2493 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 2494 | "dev": true 2495 | }, 2496 | "progress": { 2497 | "version": "2.0.0", 2498 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.0.tgz", 2499 | "integrity": "sha1-ihvjZr+Pwj2yvSPxDG/pILQ4nR8=", 2500 | "dev": true 2501 | }, 2502 | "pseudomap": { 2503 | "version": "1.0.2", 2504 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2505 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 2506 | "dev": true 2507 | }, 2508 | "randomatic": { 2509 | "version": "3.0.0", 2510 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-3.0.0.tgz", 2511 | "integrity": "sha512-VdxFOIEY3mNO5PtSRkkle/hPJDHvQhK21oa73K4yAc9qmp6N429gAyF1gZMOTMeS0/AYzaV/2Trcef+NaIonSA==", 2512 | "dev": true, 2513 | "optional": true, 2514 | "requires": { 2515 | "is-number": "^4.0.0", 2516 | "kind-of": "^6.0.0", 2517 | "math-random": "^1.0.1" 2518 | }, 2519 | "dependencies": { 2520 | "is-number": { 2521 | "version": "4.0.0", 2522 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", 2523 | "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", 2524 | "dev": true, 2525 | "optional": true 2526 | }, 2527 | "kind-of": { 2528 | "version": "6.0.2", 2529 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 2530 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 2531 | "dev": true, 2532 | "optional": true 2533 | } 2534 | } 2535 | }, 2536 | "readable-stream": { 2537 | "version": "2.3.6", 2538 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2539 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2540 | "dev": true, 2541 | "requires": { 2542 | "core-util-is": "~1.0.0", 2543 | "inherits": "~2.0.3", 2544 | "isarray": "~1.0.0", 2545 | "process-nextick-args": "~2.0.0", 2546 | "safe-buffer": "~5.1.1", 2547 | "string_decoder": "~1.1.1", 2548 | "util-deprecate": "~1.0.1" 2549 | } 2550 | }, 2551 | "readdirp": { 2552 | "version": "2.1.0", 2553 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", 2554 | "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", 2555 | "dev": true, 2556 | "optional": true, 2557 | "requires": { 2558 | "graceful-fs": "^4.1.2", 2559 | "minimatch": "^3.0.2", 2560 | "readable-stream": "^2.0.2", 2561 | "set-immediate-shim": "^1.0.1" 2562 | } 2563 | }, 2564 | "regenerate": { 2565 | "version": "1.4.0", 2566 | "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz", 2567 | "integrity": "sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg==", 2568 | "dev": true 2569 | }, 2570 | "regenerator-runtime": { 2571 | "version": "0.11.1", 2572 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", 2573 | "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", 2574 | "dev": true 2575 | }, 2576 | "regenerator-transform": { 2577 | "version": "0.10.1", 2578 | "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.10.1.tgz", 2579 | "integrity": "sha512-PJepbvDbuK1xgIgnau7Y90cwaAmO/LCLMI2mPvaXq2heGMR3aWW5/BQvYrhJ8jgmQjXewXvBjzfqKcVOmhjZ6Q==", 2580 | "dev": true, 2581 | "requires": { 2582 | "babel-runtime": "^6.18.0", 2583 | "babel-types": "^6.19.0", 2584 | "private": "^0.1.6" 2585 | } 2586 | }, 2587 | "regex-cache": { 2588 | "version": "0.4.4", 2589 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 2590 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 2591 | "dev": true, 2592 | "optional": true, 2593 | "requires": { 2594 | "is-equal-shallow": "^0.1.3" 2595 | } 2596 | }, 2597 | "regexpp": { 2598 | "version": "1.1.0", 2599 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-1.1.0.tgz", 2600 | "integrity": "sha512-LOPw8FpgdQF9etWMaAfG/WRthIdXJGYp4mJ2Jgn/2lpkbod9jPn0t9UqN7AxBOKNfzRbYyVfgc7Vk4t/MpnXgw==", 2601 | "dev": true 2602 | }, 2603 | "regexpu-core": { 2604 | "version": "2.0.0", 2605 | "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-2.0.0.tgz", 2606 | "integrity": "sha1-SdA4g3uNz4v6W5pCE5k45uoq4kA=", 2607 | "dev": true, 2608 | "requires": { 2609 | "regenerate": "^1.2.1", 2610 | "regjsgen": "^0.2.0", 2611 | "regjsparser": "^0.1.4" 2612 | } 2613 | }, 2614 | "regjsgen": { 2615 | "version": "0.2.0", 2616 | "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.2.0.tgz", 2617 | "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=", 2618 | "dev": true 2619 | }, 2620 | "regjsparser": { 2621 | "version": "0.1.5", 2622 | "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz", 2623 | "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=", 2624 | "dev": true, 2625 | "requires": { 2626 | "jsesc": "~0.5.0" 2627 | }, 2628 | "dependencies": { 2629 | "jsesc": { 2630 | "version": "0.5.0", 2631 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", 2632 | "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", 2633 | "dev": true 2634 | } 2635 | } 2636 | }, 2637 | "remove-trailing-separator": { 2638 | "version": "1.1.0", 2639 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2640 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2641 | "dev": true 2642 | }, 2643 | "repeat-element": { 2644 | "version": "1.1.2", 2645 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 2646 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 2647 | "dev": true 2648 | }, 2649 | "repeat-string": { 2650 | "version": "1.6.1", 2651 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2652 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2653 | "dev": true, 2654 | "optional": true 2655 | }, 2656 | "repeating": { 2657 | "version": "2.0.1", 2658 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 2659 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 2660 | "dev": true, 2661 | "requires": { 2662 | "is-finite": "^1.0.0" 2663 | } 2664 | }, 2665 | "require-uncached": { 2666 | "version": "1.0.3", 2667 | "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 2668 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 2669 | "dev": true, 2670 | "requires": { 2671 | "caller-path": "^0.1.0", 2672 | "resolve-from": "^1.0.0" 2673 | } 2674 | }, 2675 | "resolve-from": { 2676 | "version": "1.0.1", 2677 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 2678 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 2679 | "dev": true 2680 | }, 2681 | "restore-cursor": { 2682 | "version": "2.0.0", 2683 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 2684 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 2685 | "dev": true, 2686 | "requires": { 2687 | "onetime": "^2.0.0", 2688 | "signal-exit": "^3.0.2" 2689 | } 2690 | }, 2691 | "rimraf": { 2692 | "version": "2.6.2", 2693 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 2694 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 2695 | "dev": true, 2696 | "requires": { 2697 | "glob": "^7.0.5" 2698 | } 2699 | }, 2700 | "run-async": { 2701 | "version": "2.3.0", 2702 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 2703 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 2704 | "dev": true, 2705 | "requires": { 2706 | "is-promise": "^2.1.0" 2707 | } 2708 | }, 2709 | "rx-lite": { 2710 | "version": "4.0.8", 2711 | "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-4.0.8.tgz", 2712 | "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=", 2713 | "dev": true 2714 | }, 2715 | "rx-lite-aggregates": { 2716 | "version": "4.0.8", 2717 | "resolved": "https://registry.npmjs.org/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", 2718 | "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", 2719 | "dev": true, 2720 | "requires": { 2721 | "rx-lite": "*" 2722 | } 2723 | }, 2724 | "safe-buffer": { 2725 | "version": "5.1.2", 2726 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2727 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2728 | "dev": true 2729 | }, 2730 | "safer-buffer": { 2731 | "version": "2.1.2", 2732 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2733 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2734 | "dev": true 2735 | }, 2736 | "schemapack": { 2737 | "version": "1.4.2", 2738 | "resolved": "https://registry.npmjs.org/schemapack/-/schemapack-1.4.2.tgz", 2739 | "integrity": "sha1-i1gqVeEo40WFTOP7OANxxYJk80k=" 2740 | }, 2741 | "semver": { 2742 | "version": "5.5.0", 2743 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.0.tgz", 2744 | "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", 2745 | "dev": true 2746 | }, 2747 | "set-immediate-shim": { 2748 | "version": "1.0.1", 2749 | "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", 2750 | "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", 2751 | "dev": true, 2752 | "optional": true 2753 | }, 2754 | "shebang-command": { 2755 | "version": "1.2.0", 2756 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2757 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2758 | "dev": true, 2759 | "requires": { 2760 | "shebang-regex": "^1.0.0" 2761 | } 2762 | }, 2763 | "shebang-regex": { 2764 | "version": "1.0.0", 2765 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2766 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2767 | "dev": true 2768 | }, 2769 | "signal-exit": { 2770 | "version": "3.0.2", 2771 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2772 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2773 | "dev": true 2774 | }, 2775 | "slash": { 2776 | "version": "1.0.0", 2777 | "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", 2778 | "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", 2779 | "dev": true 2780 | }, 2781 | "slice-ansi": { 2782 | "version": "1.0.0", 2783 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 2784 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 2785 | "dev": true, 2786 | "requires": { 2787 | "is-fullwidth-code-point": "^2.0.0" 2788 | } 2789 | }, 2790 | "source-map": { 2791 | "version": "0.5.7", 2792 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2793 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2794 | "dev": true 2795 | }, 2796 | "source-map-support": { 2797 | "version": "0.4.18", 2798 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", 2799 | "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", 2800 | "dev": true, 2801 | "requires": { 2802 | "source-map": "^0.5.6" 2803 | } 2804 | }, 2805 | "sprintf-js": { 2806 | "version": "1.0.3", 2807 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2808 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2809 | "dev": true 2810 | }, 2811 | "string-width": { 2812 | "version": "2.1.1", 2813 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2814 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2815 | "dev": true, 2816 | "requires": { 2817 | "is-fullwidth-code-point": "^2.0.0", 2818 | "strip-ansi": "^4.0.0" 2819 | }, 2820 | "dependencies": { 2821 | "ansi-regex": { 2822 | "version": "3.0.0", 2823 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2824 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 2825 | "dev": true 2826 | }, 2827 | "strip-ansi": { 2828 | "version": "4.0.0", 2829 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2830 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2831 | "dev": true, 2832 | "requires": { 2833 | "ansi-regex": "^3.0.0" 2834 | } 2835 | } 2836 | } 2837 | }, 2838 | "string_decoder": { 2839 | "version": "1.1.1", 2840 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2841 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2842 | "dev": true, 2843 | "requires": { 2844 | "safe-buffer": "~5.1.0" 2845 | } 2846 | }, 2847 | "strip-ansi": { 2848 | "version": "3.0.1", 2849 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2850 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2851 | "dev": true, 2852 | "requires": { 2853 | "ansi-regex": "^2.0.0" 2854 | } 2855 | }, 2856 | "strip-json-comments": { 2857 | "version": "2.0.1", 2858 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2859 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2860 | "dev": true 2861 | }, 2862 | "supports-color": { 2863 | "version": "2.0.0", 2864 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 2865 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 2866 | "dev": true 2867 | }, 2868 | "table": { 2869 | "version": "4.0.2", 2870 | "resolved": "https://registry.npmjs.org/table/-/table-4.0.2.tgz", 2871 | "integrity": "sha512-UUkEAPdSGxtRpiV9ozJ5cMTtYiqz7Ni1OGqLXRCynrvzdtR1p+cfOWe2RJLwvUG8hNanaSRjecIqwOjqeatDsA==", 2872 | "dev": true, 2873 | "requires": { 2874 | "ajv": "^5.2.3", 2875 | "ajv-keywords": "^2.1.0", 2876 | "chalk": "^2.1.0", 2877 | "lodash": "^4.17.4", 2878 | "slice-ansi": "1.0.0", 2879 | "string-width": "^2.1.1" 2880 | }, 2881 | "dependencies": { 2882 | "ansi-styles": { 2883 | "version": "3.2.1", 2884 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2885 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2886 | "dev": true, 2887 | "requires": { 2888 | "color-convert": "^1.9.0" 2889 | } 2890 | }, 2891 | "chalk": { 2892 | "version": "2.4.1", 2893 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 2894 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 2895 | "dev": true, 2896 | "requires": { 2897 | "ansi-styles": "^3.2.1", 2898 | "escape-string-regexp": "^1.0.5", 2899 | "supports-color": "^5.3.0" 2900 | } 2901 | }, 2902 | "supports-color": { 2903 | "version": "5.4.0", 2904 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz", 2905 | "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", 2906 | "dev": true, 2907 | "requires": { 2908 | "has-flag": "^3.0.0" 2909 | } 2910 | } 2911 | } 2912 | }, 2913 | "text-table": { 2914 | "version": "0.2.0", 2915 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2916 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2917 | "dev": true 2918 | }, 2919 | "through": { 2920 | "version": "2.3.8", 2921 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2922 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2923 | "dev": true 2924 | }, 2925 | "tmp": { 2926 | "version": "0.0.33", 2927 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2928 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2929 | "dev": true, 2930 | "requires": { 2931 | "os-tmpdir": "~1.0.2" 2932 | } 2933 | }, 2934 | "to-fast-properties": { 2935 | "version": "1.0.3", 2936 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", 2937 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=", 2938 | "dev": true 2939 | }, 2940 | "trim-right": { 2941 | "version": "1.0.1", 2942 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 2943 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", 2944 | "dev": true 2945 | }, 2946 | "type-check": { 2947 | "version": "0.3.2", 2948 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2949 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2950 | "dev": true, 2951 | "requires": { 2952 | "prelude-ls": "~1.1.2" 2953 | } 2954 | }, 2955 | "typedarray": { 2956 | "version": "0.0.6", 2957 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2958 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 2959 | "dev": true 2960 | }, 2961 | "user-home": { 2962 | "version": "1.1.1", 2963 | "resolved": "https://registry.npmjs.org/user-home/-/user-home-1.1.1.tgz", 2964 | "integrity": "sha1-K1viOjK2Onyd640PKNSFcko98ZA=", 2965 | "dev": true 2966 | }, 2967 | "util-deprecate": { 2968 | "version": "1.0.2", 2969 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2970 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2971 | "dev": true 2972 | }, 2973 | "uuid": { 2974 | "version": "3.2.1", 2975 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.2.1.tgz", 2976 | "integrity": "sha512-jZnMwlb9Iku/O3smGWvZhauCf6cvvpKi4BKRiliS3cxnI+Gz9j5MEpTz2UFuXiKPJocb7gnsLHwiS05ige5BEA==" 2977 | }, 2978 | "v8flags": { 2979 | "version": "2.1.1", 2980 | "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-2.1.1.tgz", 2981 | "integrity": "sha1-qrGh+jDUX4jdMhFIh1rALAtV5bQ=", 2982 | "dev": true, 2983 | "requires": { 2984 | "user-home": "^1.1.1" 2985 | } 2986 | }, 2987 | "which": { 2988 | "version": "1.3.0", 2989 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 2990 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 2991 | "dev": true, 2992 | "requires": { 2993 | "isexe": "^2.0.0" 2994 | } 2995 | }, 2996 | "wordwrap": { 2997 | "version": "1.0.0", 2998 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2999 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3000 | "dev": true 3001 | }, 3002 | "wrappy": { 3003 | "version": "1.0.2", 3004 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3005 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3006 | "dev": true 3007 | }, 3008 | "write": { 3009 | "version": "0.2.1", 3010 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 3011 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 3012 | "dev": true, 3013 | "requires": { 3014 | "mkdirp": "^0.5.1" 3015 | } 3016 | }, 3017 | "ws": { 3018 | "version": "5.1.1", 3019 | "resolved": "https://registry.npmjs.org/ws/-/ws-5.1.1.tgz", 3020 | "integrity": "sha512-bOusvpCb09TOBLbpMKszd45WKC2KPtxiyiHanv+H2DE3Az+1db5a/L7sVJZVDPUC1Br8f0SKRr1KjLpD1U/IAw==", 3021 | "requires": { 3022 | "async-limiter": "~1.0.0" 3023 | } 3024 | }, 3025 | "yallist": { 3026 | "version": "2.1.2", 3027 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3028 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 3029 | "dev": true 3030 | } 3031 | } 3032 | } 3033 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "paul-revere", 3 | "version": "2.2.1", 4 | "description": "Lightweight WebSocket messaging between browsers and Node", 5 | "main": "dist/index.js", 6 | "scripts": { 7 | "prepublish": "babel src -d dist", 8 | "build": "babel src -d dist", 9 | "test": "echo \"Error: no test specified\" && exit 1" 10 | }, 11 | "keywords": [ 12 | "websockets", 13 | "schemapack", 14 | "uws" 15 | ], 16 | "engines": { 17 | "node": ">=7.0" 18 | }, 19 | "repository": { 20 | "type": "git", 21 | "url": "https://github.com/the-control-group/paul-revere.git" 22 | }, 23 | "devDependencies": { 24 | "babel-cli": "^6.26.0", 25 | "babel-preset-es2015": "^6.24.1", 26 | "eslint": "^4.19.1" 27 | }, 28 | "babel": { 29 | "presets": [ 30 | "es2015" 31 | ] 32 | }, 33 | "browser": { 34 | "./dist/websocket.js": "./dist/websocket-client.js" 35 | }, 36 | "files": [ 37 | "dist" 38 | ], 39 | "eslintConfig": { 40 | "extends": [ 41 | "eslint:recommended" 42 | ], 43 | "env": { 44 | "browser": true, 45 | "node": true, 46 | "es6": true 47 | }, 48 | "rules": { 49 | "strict": 0, 50 | "indent": [ 51 | 2, 52 | "tab", 53 | { 54 | "SwitchCase": 1 55 | } 56 | ], 57 | "comma-dangle": 2, 58 | "no-unused-vars": [ 59 | 2, 60 | { 61 | "args": "none" 62 | } 63 | ], 64 | "no-console": 0, 65 | "no-var": 2, 66 | "space-before-function-paren": [ 67 | 2, 68 | { 69 | "anonymous": "always", 70 | "named": "never" 71 | } 72 | ], 73 | "semi": [ 74 | 2, 75 | "always" 76 | ], 77 | "space-infix-ops": 0, 78 | "max-len": [ 79 | 2, 80 | 200, 81 | 2 82 | ], 83 | "padded-blocks": 0, 84 | "no-multiple-empty-lines": 0 85 | } 86 | }, 87 | "author": "Joe Furfaro", 88 | "license": "MIT", 89 | "dependencies": { 90 | "blob-to-buffer": "^1.2.7", 91 | "detect-node": "^2.0.3", 92 | "schemapack": "^1.4.2", 93 | "uuid": "^3.2.1", 94 | "ws": "^5.1.1" 95 | } 96 | } 97 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | const urlUtil = require('url'), 2 | { build } = require('schemapack'), 3 | toBuffer = require('blob-to-buffer'), 4 | uuid = require('uuid'), 5 | WebSocket = require('./websocket'), 6 | isNode = require('detect-node'); 7 | 8 | // Symbols to keep the class properties somewhat private 9 | const schemaMap = Symbol('schemaMap'), 10 | ws = Symbol('websocket'), 11 | wsc = Symbol('wsClient'), 12 | id = Symbol('id'), 13 | ci = Symbol('ci'), 14 | ps = Symbol('pubSub'), 15 | bs = Symbol('builtSchema'), 16 | si = Symbol('schemaIndex'), 17 | rb = Symbol('receiveBuffer'), 18 | om = Symbol('onMessage'); 19 | 20 | /** 21 | * Universal message parser 22 | * @param {(Blob|Buffer|ArrayBuffer)} b - Schemapack message 23 | * @return {Promise} Resolves to Buffer and matching Schema 24 | */ 25 | function parseMessage(b, sMap) { 26 | return new Promise((res, rej) => { 27 | 28 | // Handle blobs 29 | if (typeof Blob !== 'undefined' && b instanceof Blob) { 30 | toBuffer(b, (err, buff) => { 31 | if(err) rej(err); 32 | 33 | const schema = sMap.get(buff[0]); 34 | 35 | res({schema, buff}); 36 | }); 37 | } 38 | 39 | // Handle Buffer/ArrayBuffer 40 | else { 41 | let buff = b; 42 | // Convert ArrayBuffer so we can parse the first byte for the right schema 43 | if(typeof ArrayBuffer !== 'undefined' && b instanceof ArrayBuffer) buff = Buffer.from(b); 44 | 45 | try { 46 | const schema = sMap.get(buff[0]); 47 | 48 | res({schema, buff}); 49 | } catch (e) { 50 | rej(e); 51 | } 52 | } 53 | }); 54 | } 55 | 56 | /** 57 | * Stub pub/sub 58 | */ 59 | 60 | const stubPubSub = { 61 | publish(subject, msg, exclude) { 62 | if(!this.listeners[`paulrevere.${subject}`]) return; 63 | 64 | this.listeners[`paulrevere.${subject}`].forEach(cb => cb(msg, exclude)); 65 | }, 66 | 67 | subscribe(subject, cb) { 68 | if(!this.listeners[`paulrevere.${subject}`]) this.listeners[`paulrevere.${subject}`] = []; 69 | 70 | this.listeners[`paulrevere.${subject}`].push(cb); 71 | }, 72 | 73 | listeners: {} 74 | }; 75 | 76 | /** 77 | * Schema class handles its own tranmission and reception of data 78 | */ 79 | class Schema { 80 | constructor(builtSchema, schemaIndex, websocket, clientId, pubSub) { 81 | this[si] = schemaIndex; 82 | this[bs] = builtSchema; 83 | this[ws] = websocket; 84 | this[ci] = clientId; 85 | this[ps] = pubSub; 86 | this[rb] = buff => { 87 | const msg = this[bs].decode(buff); 88 | 89 | this[om](msg); 90 | }; 91 | 92 | // Default to noop 93 | this[om] = () => {}; 94 | 95 | // Subscribe to broadcasts 96 | if(isNode && this[ps]) { 97 | this[ps].subscribe(String(this[si]), (msg, exclude) => { 98 | 99 | this[ws].clients.forEach(c => { 100 | 101 | // Exclude a specific client 102 | // Check for argument existence to avoid accidental `undefined === undefined === true` 103 | if(exclude && exclude === c.__uuid) return; 104 | 105 | // Set the schema index 106 | msg.__schema = this[si]; 107 | // Set the client id 108 | msg.__uuid = this[ci]; 109 | 110 | c.send(this[bs].encode(msg)); 111 | }); 112 | }); 113 | } 114 | } 115 | 116 | onMessage(cb) { 117 | this[om] = cb; 118 | } 119 | 120 | send(msg = {}) { 121 | // Set the schema index 122 | msg.__schema = this[si]; 123 | // Set the client id 124 | msg.__uuid = this[ci]; 125 | 126 | this[ws].send(this[bs].encode(msg)); 127 | } 128 | 129 | /** 130 | * Broadcast a message to all clients, and optionally exclude one 131 | * @param {Object} msg - Message to broadcast. Must follow the rules set in the schema 132 | * @param {Client} [exclude] - Client to exclude from the broadcast 133 | */ 134 | broadcast(msg = {}, exclude = {}) { 135 | if(!isNode || !this[ps]) throw Error('Cannot broadcast from single client'); 136 | 137 | this[ps].publish(String(this[si]), msg, exclude.__uuid); 138 | } 139 | } 140 | 141 | class Client { 142 | constructor(uwsClient, builtSchemas) { 143 | this.__uuid = uwsClient.__uuid; 144 | this.upgradeReq = uwsClient.upgradeReq; 145 | this[wsc] = uwsClient; 146 | this[schemaMap] = new Map(); 147 | 148 | let i = 0; 149 | builtSchemas.forEach((builtSchema, key) => { 150 | const schema = new Schema(builtSchema, i, this[wsc], this.__uuid); 151 | 152 | this[schemaMap].set(i, schema); 153 | 154 | // Set a public property for the consumer to use 155 | this[key] = schema; 156 | i++; 157 | }); 158 | 159 | this[wsc].on('message', m => { 160 | parseMessage(m, this[schemaMap]) 161 | .then(({schema, buff}) => schema[rb](buff)) 162 | .catch(e => console.error(e)); 163 | }); 164 | } 165 | 166 | close() { 167 | this[wsc].close(); 168 | } 169 | 170 | onClose(cb) { 171 | this[wsc].on('close', cb); 172 | } 173 | } 174 | 175 | class PaulRevere { 176 | constructor(schemas = {message: {payload: 'string', meta: {timestamp: 'varuint'}}}, { url, queryParams = {}, server, pubSub = stubPubSub } = {}) { 177 | if(url && typeof url !== 'string') throw new TypeError('Remote url must be a string'); 178 | if(url && server) throw new Error('Remote and Server cannot both be defined'); 179 | 180 | this[schemaMap] = new Map(); 181 | this[id] = uuid.v4(); 182 | 183 | // Switch between client and server websocket 184 | let query; 185 | switch(true) { 186 | case !!url: 187 | query = Object.assign({}, queryParams, {clientId: this[id]}); 188 | this[ws] = new WebSocket(url + urlUtil.format({query})); 189 | break; 190 | 191 | case !!server: 192 | if(!isNode) throw new Error('Cannot create WebSocket server in browser environment'); 193 | 194 | this[ws] = new WebSocket.Server({server}); 195 | break; 196 | 197 | default: 198 | throw new Error('Remote or Server must be defined'); 199 | } 200 | 201 | // Local reference of the schemapack schemas for Clients to use 202 | let builtSchemas = new Map(); 203 | 204 | // Map all of the Schemas to an index 205 | Object.keys(schemas).forEach((key, i) => { 206 | const builtSchema = build(Object.assign({ 207 | // Adding this parameter to a schema allows us to parse it later as a buffer 208 | // so the receipient does not need to know what type of information was sent 209 | __schema: 'uint8', 210 | __uuid: 'string' 211 | }, schemas[key])); 212 | 213 | const schema = new Schema(builtSchema, i, this[ws], this[id], pubSub); 214 | 215 | this[schemaMap].set(i, schema); 216 | builtSchemas.set(key, builtSchema); 217 | 218 | // Set a public property for the consumer to use 219 | this[key] = schema; 220 | }); 221 | 222 | // Set up listeners 223 | if(isNode) { 224 | this[ws].on('message', m => { 225 | parseMessage(m, this[schemaMap]) 226 | .then(({schema, buff}) => schema[rb](buff)) 227 | .catch(e => console.error(e)); 228 | }); 229 | } else { 230 | this[ws].onmessage = m => { 231 | parseMessage(m.data, this[schemaMap]) 232 | .then(({schema, buff}) => schema[rb](buff)) 233 | .catch(e => console.error(e)); 234 | }; 235 | 236 | this.onClose = cb => { 237 | this[ws].onclose = cb; 238 | }; 239 | } 240 | 241 | // For servers, bind a connection listener and return a Client 242 | if(typeof remote !== 'string') { 243 | this.onConnection = cb => { 244 | this[ws].on('connection', (c, req) => { 245 | // Add the connection request to the client 246 | c.upgradeReq = req; 247 | 248 | c.__uuid = urlUtil.parse(c.upgradeReq.url, true).query.clientId || uuid.v4(); 249 | 250 | const client = new Client(c, builtSchemas); 251 | 252 | cb(client); 253 | }); 254 | 255 | return this; 256 | }; 257 | } 258 | } 259 | 260 | get rawClients() { 261 | return this[ws].clients; 262 | } 263 | 264 | close() { 265 | this[ws].close(); 266 | } 267 | } 268 | 269 | module.exports = PaulRevere; 270 | -------------------------------------------------------------------------------- /src/websocket-client.js: -------------------------------------------------------------------------------- 1 | if(window.WebSocket) { 2 | module.exports = window.WebSocket; 3 | } else { 4 | module.exports = {}; 5 | } 6 | -------------------------------------------------------------------------------- /src/websocket.js: -------------------------------------------------------------------------------- 1 | const ws = require('ws'); 2 | 3 | module.exports = ws; 4 | --------------------------------------------------------------------------------