├── .gitignore ├── .travis.yml ├── LICENSE ├── Procfile ├── README.md ├── app.json ├── bin.js ├── index.html ├── index.js ├── package-lock.json ├── package.json ├── server.js └── tests ├── boilerplate.js ├── browser.test.js ├── server.test.js └── serverws.test.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | sudo: false 2 | language: node_js 3 | node_js: 4 | - '8' 5 | - '10' 6 | - '11' 7 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2017 Antoine Bluchet & Gael Moliner 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /Procfile: -------------------------------------------------------------------------------- 1 | web: node ./bin.js -p $PORT 2 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Signalhubws 2 | 3 | [![Build Status](https://travis-ci.org/soyuka/signalhubws.svg?branch=master)](https://travis-ci.org/soyuka/signalhubws) 4 | 5 | Drop in replacement for signalhub with websockets. 6 | 7 | Note: Binary is just launching server (similar to `signalhub listen -p $PORT`) 8 | 9 | See https://github.com/mafintosh/signalhub 10 | 11 | ## Deploy with Heroku 12 | 13 | [![Deploy](https://www.herokucdn.com/deploy/button.png)](https://heroku.com/deploy) 14 | 15 | Or via the CLI (after cloning this repo, from within the project root): 16 | ``` 17 | heroku login 18 | heroku git:remote -a 19 | git push heroku master 20 | ``` 21 | 22 | 23 | ## API 24 | 25 | #### `hub = signalhubws(appName, urls, WebSocketClass)` 26 | 27 | Create a new hub client. If you have more than one hub running specify them in an array 28 | 29 | ``` js 30 | // use more than one server for redundancy 31 | var hub = signalhubws('my-app-name', [ 32 | 'wss://signalhub1.example.com', 33 | 'wss://signalhub2.example.com', 34 | 'wss://signalhub3.example.com' 35 | ]) 36 | ``` 37 | 38 | The `appName` is used to namespace the subscriptions/broadcast so you can reuse the 39 | signalhub for more than one app. 40 | 41 | The `WebSocketClass` allows you to override the socket class implementation. `signalhubws` ships with the [`cws`](https://github.com/ClusterWS/cWS) package on nodejs and uses the native `Websocket` implementation on browsers. 42 | 43 | #### `stream = hub.subscribe(channel)` 44 | 45 | Subscribe to a channel on the hub. Returns a readable stream of messages 46 | 47 | #### `hub.broadcast(channel, message, [callback])` 48 | 49 | Broadcast a new message to a channel on the hub 50 | 51 | #### `hub.close([callback])` 52 | 53 | Close all subscriptions 54 | -------------------------------------------------------------------------------- /app.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "signalhubws", 3 | "description": "Signalhub implementation using websockets", 4 | "repository": "https://github.com/soyuka/signalhubws" 5 | } -------------------------------------------------------------------------------- /bin.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | var server = require('./server')() 4 | var argv = require('minimist')(process.argv.slice(2)) 5 | 6 | if (argv.help || argv.h) { 7 | console.log('signalhubws --port|-p 3300') 8 | process.exit(1) 9 | } 10 | 11 | const port = process.env.PORT || argv.port || argv.p || 3300 12 | 13 | server.listen(port, () => { 14 | console.log('Signalhubws running on %s', port) 15 | }) 16 | 17 | process.on('unhandledRejection', function (err) { 18 | console.error('Unhandled rejection:', err.message) 19 | }) 20 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 |

Not found

2 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const events = require('events') 2 | const through2 = require('through2') 3 | const inherits = require('inherits') 4 | const WebSocket = (typeof window !== 'undefined' && window.WebSocket) ? window.WebSocket : null 5 | 6 | function SignalhubWs (app, urls, WebSocketClass) { 7 | this.opened = false 8 | this.sockets = [] 9 | this.app = app 10 | const channels = this.channels = new Map() 11 | this.subscribers = { 12 | get length () { 13 | return channels.size 14 | } 15 | } 16 | 17 | if (!urls || (Array.isArray(urls) && urls.length === 0)) { 18 | throw Error('No URL specified') 19 | } 20 | 21 | if (!Array.isArray(urls)) { 22 | urls = [urls] 23 | } 24 | 25 | urls = urls.map(function (url) { 26 | url = url.replace(/\/$/, '') 27 | return url.indexOf('://') === -1 ? 'ws://' + url : url 28 | }) 29 | 30 | let countOpen = 0 31 | 32 | for (let index = 0; index < urls.length; index++) { 33 | const socket = new WebSocketClass(`${urls[index]}/${app}`) 34 | 35 | this.sockets.push(socket) 36 | 37 | socket.addEventListener('open', () => { 38 | if (++countOpen === urls.length) { 39 | this.opened = true 40 | this.emit('open') 41 | for (let channel of this.channels.values()) { 42 | channel.emit('open') 43 | } 44 | } 45 | }) 46 | 47 | socket.addEventListener('message', (message) => { 48 | this.onMessage(message) 49 | }) 50 | 51 | socket.addEventListener('error', (event) => { 52 | if (this.listeners('error').length > 0) { 53 | this.emit('error', { event, url: urls[index] }) 54 | } else { 55 | // no event handler, console.error instead of uncaught exception 56 | console.error(event) 57 | } 58 | }) 59 | } 60 | } 61 | 62 | inherits(SignalhubWs, events.EventEmitter) 63 | 64 | SignalhubWs.prototype.subscribe = function (channel) { 65 | if (this.closed) { 66 | throw new Error('Cannot subscribe after close') 67 | } 68 | 69 | if (this.channels.has(channel)) { 70 | return this.channels.get(channel) 71 | } 72 | 73 | // use a stream for channel 74 | this.channels.set(channel, through2.obj()) 75 | 76 | this.channels.get(channel).on('close', () => { 77 | this.channels.delete(channel) 78 | }) 79 | 80 | if (this.opened) { 81 | process.nextTick(() => { 82 | if (this.channels.has(channel)) { 83 | this.channels.get(channel).emit('open') 84 | } 85 | }) 86 | } 87 | 88 | return this.channels.get(channel) 89 | } 90 | 91 | SignalhubWs.prototype.broadcast = function (channel, message, cb) { 92 | if (this.closed) { 93 | throw new Error('Cannot broadcast after close') 94 | } 95 | 96 | const data = { 97 | app: this.app, 98 | channel: channel, 99 | message: message 100 | } 101 | 102 | this.sockets.forEach((socket) => { 103 | socket.send(JSON.stringify(data)) 104 | }) 105 | 106 | cb && cb() 107 | } 108 | 109 | SignalhubWs.prototype.onMessage = function (message) { 110 | message = JSON.parse(message.data) 111 | 112 | for (let key of this.channels.keys()) { 113 | if (message.channel === key) { 114 | this.channels.get(key).write(message.message) 115 | continue 116 | } 117 | 118 | if (!Array.isArray(key)) { 119 | continue 120 | } 121 | 122 | for (let i = 0; i < key.length; i++) { 123 | if (key[i] === message.channel) { 124 | this.channels.get(key).write(message.message) 125 | } 126 | } 127 | } 128 | } 129 | 130 | SignalhubWs.prototype.close = function (cb) { 131 | if (this.closed) { 132 | if (cb) process.nextTick(cb) 133 | return 134 | } 135 | 136 | this.once('close', () => { 137 | if (cb) cb() 138 | this.closed = true 139 | }) 140 | 141 | const len = this.sockets.length 142 | if (len === 0) { 143 | this.emit('close') 144 | return 145 | } 146 | 147 | this.once('close:socket', () => { 148 | this._closeChannels() 149 | }) 150 | 151 | let closed = 0 152 | this.sockets.forEach((socket) => { 153 | socket.addEventListener('close', () => { 154 | if (++closed === len) { 155 | this.emit('close:socket') 156 | } 157 | }) 158 | 159 | process.nextTick(function () { 160 | socket.close() 161 | }) 162 | }) 163 | } 164 | 165 | SignalhubWs.prototype._closeChannels = function () { 166 | const len = this.channels.size 167 | if (len === 0) { 168 | this.emit('close') 169 | return 170 | } 171 | 172 | let closed = 0 173 | for (let channel of this.channels.values()) { 174 | process.nextTick(() => { 175 | channel.end(() => { 176 | if (++closed === len) { 177 | this.channels.clear() 178 | this.emit('close') 179 | } 180 | }) 181 | }) 182 | } 183 | } 184 | 185 | module.exports = function (app, urls, WebSocketClass = WebSocket) { 186 | if (!WebSocketClass) { 187 | throw TypeError('No WebSocket class given.') 188 | } 189 | return new SignalhubWs(app, urls, WebSocketClass) 190 | } 191 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "signalhubws", 3 | "version": "1.0.12", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@clusterws/cws": { 8 | "version": "0.15.2", 9 | "resolved": "https://registry.npmjs.org/@clusterws/cws/-/cws-0.15.2.tgz", 10 | "integrity": "sha512-nTXrmbv8IK38VBvfhdhigrxC7GvN4fsDrImCGx/b8jb3AP34e5B23cfXQCxZ2H3M3rywWbkeNdX9bGc01nX2rw==" 11 | }, 12 | "acorn": { 13 | "version": "6.4.1", 14 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.1.tgz", 15 | "integrity": "sha512-ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA==", 16 | "dev": true 17 | }, 18 | "acorn-jsx": { 19 | "version": "5.0.1", 20 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 21 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 22 | "dev": true 23 | }, 24 | "ajv": { 25 | "version": "6.7.0", 26 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.7.0.tgz", 27 | "integrity": "sha512-RZXPviBTtfmtka9n9sy1N5M5b82CbxWIR6HIis4s3WQTXDJamc/0gpCWNGz6EWdWp4DOfjzJfhz/AS9zVPjjWg==", 28 | "dev": true, 29 | "requires": { 30 | "fast-deep-equal": "^2.0.1", 31 | "fast-json-stable-stringify": "^2.0.0", 32 | "json-schema-traverse": "^0.4.1", 33 | "uri-js": "^4.2.2" 34 | } 35 | }, 36 | "ajv-keywords": { 37 | "version": "3.2.0", 38 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.2.0.tgz", 39 | "integrity": "sha1-6GuBnGAs+IIa1jdBNpjx3sAhhHo=", 40 | "dev": true 41 | }, 42 | "ansi-escapes": { 43 | "version": "3.1.0", 44 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", 45 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", 46 | "dev": true 47 | }, 48 | "ansi-regex": { 49 | "version": "2.1.1", 50 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 51 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 52 | "dev": true 53 | }, 54 | "ansi-styles": { 55 | "version": "2.2.1", 56 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 57 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 58 | "dev": true 59 | }, 60 | "argparse": { 61 | "version": "1.0.10", 62 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 63 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 64 | "dev": true, 65 | "requires": { 66 | "sprintf-js": "~1.0.2" 67 | } 68 | }, 69 | "array-includes": { 70 | "version": "3.0.3", 71 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 72 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 73 | "dev": true, 74 | "requires": { 75 | "define-properties": "^1.1.2", 76 | "es-abstract": "^1.7.0" 77 | } 78 | }, 79 | "async-limiter": { 80 | "version": "1.0.0", 81 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz", 82 | "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg==", 83 | "dev": true 84 | }, 85 | "babel-code-frame": { 86 | "version": "6.26.0", 87 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 88 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 89 | "dev": true, 90 | "requires": { 91 | "chalk": "^1.1.3", 92 | "esutils": "^2.0.2", 93 | "js-tokens": "^3.0.2" 94 | }, 95 | "dependencies": { 96 | "chalk": { 97 | "version": "1.1.3", 98 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 99 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 100 | "dev": true, 101 | "requires": { 102 | "ansi-styles": "^2.2.1", 103 | "escape-string-regexp": "^1.0.2", 104 | "has-ansi": "^2.0.0", 105 | "strip-ansi": "^3.0.0", 106 | "supports-color": "^2.0.0" 107 | } 108 | }, 109 | "strip-ansi": { 110 | "version": "3.0.1", 111 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 112 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 113 | "dev": true, 114 | "requires": { 115 | "ansi-regex": "^2.0.0" 116 | } 117 | } 118 | } 119 | }, 120 | "balanced-match": { 121 | "version": "1.0.0", 122 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 123 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 124 | "dev": true 125 | }, 126 | "brace-expansion": { 127 | "version": "1.1.11", 128 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 129 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 130 | "dev": true, 131 | "requires": { 132 | "balanced-match": "^1.0.0", 133 | "concat-map": "0.0.1" 134 | } 135 | }, 136 | "builtin-modules": { 137 | "version": "1.1.1", 138 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 139 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 140 | "dev": true 141 | }, 142 | "caller-path": { 143 | "version": "0.1.0", 144 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 145 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 146 | "dev": true, 147 | "requires": { 148 | "callsites": "^0.2.0" 149 | } 150 | }, 151 | "callsites": { 152 | "version": "0.2.0", 153 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 154 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 155 | "dev": true 156 | }, 157 | "chalk": { 158 | "version": "2.4.2", 159 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 160 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 161 | "dev": true, 162 | "requires": { 163 | "ansi-styles": "^3.2.1", 164 | "escape-string-regexp": "^1.0.5", 165 | "supports-color": "^5.3.0" 166 | }, 167 | "dependencies": { 168 | "ansi-styles": { 169 | "version": "3.2.1", 170 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 171 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 172 | "dev": true, 173 | "requires": { 174 | "color-convert": "^1.9.0" 175 | } 176 | }, 177 | "supports-color": { 178 | "version": "5.5.0", 179 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 180 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 181 | "dev": true, 182 | "requires": { 183 | "has-flag": "^3.0.0" 184 | } 185 | } 186 | } 187 | }, 188 | "chardet": { 189 | "version": "0.4.2", 190 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.4.2.tgz", 191 | "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", 192 | "dev": true 193 | }, 194 | "circular-json": { 195 | "version": "0.3.3", 196 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 197 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 198 | "dev": true 199 | }, 200 | "cli-cursor": { 201 | "version": "2.1.0", 202 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 203 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 204 | "dev": true, 205 | "requires": { 206 | "restore-cursor": "^2.0.0" 207 | } 208 | }, 209 | "cli-width": { 210 | "version": "2.2.0", 211 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 212 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 213 | "dev": true 214 | }, 215 | "color-convert": { 216 | "version": "1.9.3", 217 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 218 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 219 | "dev": true, 220 | "requires": { 221 | "color-name": "1.1.3" 222 | } 223 | }, 224 | "color-name": { 225 | "version": "1.1.3", 226 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 227 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 228 | "dev": true 229 | }, 230 | "concat-map": { 231 | "version": "0.0.1", 232 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 233 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 234 | "dev": true 235 | }, 236 | "contains-path": { 237 | "version": "0.1.0", 238 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 239 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 240 | "dev": true 241 | }, 242 | "cross-spawn": { 243 | "version": "6.0.5", 244 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 245 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 246 | "dev": true, 247 | "requires": { 248 | "nice-try": "^1.0.4", 249 | "path-key": "^2.0.1", 250 | "semver": "^5.5.0", 251 | "shebang-command": "^1.2.0", 252 | "which": "^1.2.9" 253 | } 254 | }, 255 | "debug": { 256 | "version": "4.1.1", 257 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 258 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 259 | "requires": { 260 | "ms": "^2.1.1" 261 | } 262 | }, 263 | "debug-log": { 264 | "version": "1.0.1", 265 | "resolved": "https://registry.npmjs.org/debug-log/-/debug-log-1.0.1.tgz", 266 | "integrity": "sha1-IwdjLUwEOCuN+KMvcLiVBG1SdF8=", 267 | "dev": true 268 | }, 269 | "deep-equal": { 270 | "version": "1.0.1", 271 | "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", 272 | "integrity": "sha1-9dJgKStmDghO/0zbyfCK0yR0SLU=", 273 | "dev": true 274 | }, 275 | "deep-is": { 276 | "version": "0.1.3", 277 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 278 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 279 | "dev": true 280 | }, 281 | "define-properties": { 282 | "version": "1.1.3", 283 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 284 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 285 | "dev": true, 286 | "requires": { 287 | "object-keys": "^1.0.12" 288 | } 289 | }, 290 | "defined": { 291 | "version": "1.0.0", 292 | "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", 293 | "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=", 294 | "dev": true 295 | }, 296 | "deglob": { 297 | "version": "2.1.1", 298 | "resolved": "https://registry.npmjs.org/deglob/-/deglob-2.1.1.tgz", 299 | "integrity": "sha512-2kjwuGGonL7gWE1XU4Fv79+vVzpoQCl0V+boMwWtOQJV2AGDabCwez++nB1Nli/8BabAfZQ/UuHPlp6AymKdWw==", 300 | "dev": true, 301 | "requires": { 302 | "find-root": "^1.0.0", 303 | "glob": "^7.0.5", 304 | "ignore": "^3.0.9", 305 | "pkg-config": "^1.1.0", 306 | "run-parallel": "^1.1.2", 307 | "uniq": "^1.0.1" 308 | }, 309 | "dependencies": { 310 | "ignore": { 311 | "version": "3.3.10", 312 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", 313 | "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==", 314 | "dev": true 315 | } 316 | } 317 | }, 318 | "doctrine": { 319 | "version": "2.1.0", 320 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 321 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 322 | "dev": true, 323 | "requires": { 324 | "esutils": "^2.0.2" 325 | } 326 | }, 327 | "error-ex": { 328 | "version": "1.3.2", 329 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 330 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 331 | "dev": true, 332 | "requires": { 333 | "is-arrayish": "^0.2.1" 334 | } 335 | }, 336 | "es-abstract": { 337 | "version": "1.13.0", 338 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 339 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 340 | "dev": true, 341 | "requires": { 342 | "es-to-primitive": "^1.2.0", 343 | "function-bind": "^1.1.1", 344 | "has": "^1.0.3", 345 | "is-callable": "^1.1.4", 346 | "is-regex": "^1.0.4", 347 | "object-keys": "^1.0.12" 348 | } 349 | }, 350 | "es-to-primitive": { 351 | "version": "1.2.0", 352 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 353 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 354 | "dev": true, 355 | "requires": { 356 | "is-callable": "^1.1.4", 357 | "is-date-object": "^1.0.1", 358 | "is-symbol": "^1.0.2" 359 | } 360 | }, 361 | "escape-string-regexp": { 362 | "version": "1.0.5", 363 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 364 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 365 | "dev": true 366 | }, 367 | "eslint": { 368 | "version": "5.4.0", 369 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.4.0.tgz", 370 | "integrity": "sha512-UIpL91XGex3qtL6qwyCQJar2j3osKxK9e3ano3OcGEIRM4oWIpCkDg9x95AXEC2wMs7PnxzOkPZ2gq+tsMS9yg==", 371 | "dev": true, 372 | "requires": { 373 | "ajv": "^6.5.0", 374 | "babel-code-frame": "^6.26.0", 375 | "chalk": "^2.1.0", 376 | "cross-spawn": "^6.0.5", 377 | "debug": "^3.1.0", 378 | "doctrine": "^2.1.0", 379 | "eslint-scope": "^4.0.0", 380 | "eslint-utils": "^1.3.1", 381 | "eslint-visitor-keys": "^1.0.0", 382 | "espree": "^4.0.0", 383 | "esquery": "^1.0.1", 384 | "esutils": "^2.0.2", 385 | "file-entry-cache": "^2.0.0", 386 | "functional-red-black-tree": "^1.0.1", 387 | "glob": "^7.1.2", 388 | "globals": "^11.7.0", 389 | "ignore": "^4.0.2", 390 | "imurmurhash": "^0.1.4", 391 | "inquirer": "^5.2.0", 392 | "is-resolvable": "^1.1.0", 393 | "js-yaml": "^3.11.0", 394 | "json-stable-stringify-without-jsonify": "^1.0.1", 395 | "levn": "^0.3.0", 396 | "lodash": "^4.17.5", 397 | "minimatch": "^3.0.4", 398 | "mkdirp": "^0.5.1", 399 | "natural-compare": "^1.4.0", 400 | "optionator": "^0.8.2", 401 | "path-is-inside": "^1.0.2", 402 | "pluralize": "^7.0.0", 403 | "progress": "^2.0.0", 404 | "regexpp": "^2.0.0", 405 | "require-uncached": "^1.0.3", 406 | "semver": "^5.5.0", 407 | "strip-ansi": "^4.0.0", 408 | "strip-json-comments": "^2.0.1", 409 | "table": "^4.0.3", 410 | "text-table": "^0.2.0" 411 | }, 412 | "dependencies": { 413 | "debug": { 414 | "version": "3.2.6", 415 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 416 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 417 | "dev": true, 418 | "requires": { 419 | "ms": "^2.1.1" 420 | } 421 | } 422 | } 423 | }, 424 | "eslint-config-standard": { 425 | "version": "12.0.0", 426 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-12.0.0.tgz", 427 | "integrity": "sha512-COUz8FnXhqFitYj4DTqHzidjIL/t4mumGZto5c7DrBpvWoie+Sn3P4sLEzUGeYhRElWuFEf8K1S1EfvD1vixCQ==", 428 | "dev": true 429 | }, 430 | "eslint-config-standard-jsx": { 431 | "version": "6.0.2", 432 | "resolved": "https://registry.npmjs.org/eslint-config-standard-jsx/-/eslint-config-standard-jsx-6.0.2.tgz", 433 | "integrity": "sha512-D+YWAoXw+2GIdbMBRAzWwr1ZtvnSf4n4yL0gKGg7ShUOGXkSOLerI17K4F6LdQMJPNMoWYqepzQD/fKY+tXNSg==", 434 | "dev": true 435 | }, 436 | "eslint-import-resolver-node": { 437 | "version": "0.3.2", 438 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 439 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 440 | "dev": true, 441 | "requires": { 442 | "debug": "^2.6.9", 443 | "resolve": "^1.5.0" 444 | }, 445 | "dependencies": { 446 | "debug": { 447 | "version": "2.6.9", 448 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 449 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 450 | "dev": true, 451 | "requires": { 452 | "ms": "2.0.0" 453 | } 454 | }, 455 | "ms": { 456 | "version": "2.0.0", 457 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 458 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 459 | "dev": true 460 | } 461 | } 462 | }, 463 | "eslint-module-utils": { 464 | "version": "2.2.0", 465 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.2.0.tgz", 466 | "integrity": "sha1-snA2LNiLGkitMIl2zn+lTphBF0Y=", 467 | "dev": true, 468 | "requires": { 469 | "debug": "^2.6.8", 470 | "pkg-dir": "^1.0.0" 471 | }, 472 | "dependencies": { 473 | "debug": { 474 | "version": "2.6.9", 475 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 476 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 477 | "dev": true, 478 | "requires": { 479 | "ms": "2.0.0" 480 | } 481 | }, 482 | "ms": { 483 | "version": "2.0.0", 484 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 485 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 486 | "dev": true 487 | } 488 | } 489 | }, 490 | "eslint-plugin-es": { 491 | "version": "1.4.0", 492 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-1.4.0.tgz", 493 | "integrity": "sha512-XfFmgFdIUDgvaRAlaXUkxrRg5JSADoRC8IkKLc/cISeR3yHVMefFHQZpcyXXEUUPHfy5DwviBcrfqlyqEwlQVw==", 494 | "dev": true, 495 | "requires": { 496 | "eslint-utils": "^1.3.0", 497 | "regexpp": "^2.0.1" 498 | } 499 | }, 500 | "eslint-plugin-import": { 501 | "version": "2.14.0", 502 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.14.0.tgz", 503 | "integrity": "sha512-FpuRtniD/AY6sXByma2Wr0TXvXJ4nA/2/04VPlfpmUDPOpOY264x+ILiwnrk/k4RINgDAyFZByxqPUbSQ5YE7g==", 504 | "dev": true, 505 | "requires": { 506 | "contains-path": "^0.1.0", 507 | "debug": "^2.6.8", 508 | "doctrine": "1.5.0", 509 | "eslint-import-resolver-node": "^0.3.1", 510 | "eslint-module-utils": "^2.2.0", 511 | "has": "^1.0.1", 512 | "lodash": "^4.17.4", 513 | "minimatch": "^3.0.3", 514 | "read-pkg-up": "^2.0.0", 515 | "resolve": "^1.6.0" 516 | }, 517 | "dependencies": { 518 | "debug": { 519 | "version": "2.6.9", 520 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 521 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 522 | "dev": true, 523 | "requires": { 524 | "ms": "2.0.0" 525 | } 526 | }, 527 | "doctrine": { 528 | "version": "1.5.0", 529 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 530 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 531 | "dev": true, 532 | "requires": { 533 | "esutils": "^2.0.2", 534 | "isarray": "^1.0.0" 535 | } 536 | }, 537 | "ms": { 538 | "version": "2.0.0", 539 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 540 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 541 | "dev": true 542 | } 543 | } 544 | }, 545 | "eslint-plugin-node": { 546 | "version": "7.0.1", 547 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-7.0.1.tgz", 548 | "integrity": "sha512-lfVw3TEqThwq0j2Ba/Ckn2ABdwmL5dkOgAux1rvOk6CO7A6yGyPI2+zIxN6FyNkp1X1X/BSvKOceD6mBWSj4Yw==", 549 | "dev": true, 550 | "requires": { 551 | "eslint-plugin-es": "^1.3.1", 552 | "eslint-utils": "^1.3.1", 553 | "ignore": "^4.0.2", 554 | "minimatch": "^3.0.4", 555 | "resolve": "^1.8.1", 556 | "semver": "^5.5.0" 557 | }, 558 | "dependencies": { 559 | "resolve": { 560 | "version": "1.9.0", 561 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.9.0.tgz", 562 | "integrity": "sha512-TZNye00tI67lwYvzxCxHGjwTNlUV70io54/Ed4j6PscB8xVfuBJpRenI/o6dVk0cY0PYTY27AgCoGGxRnYuItQ==", 563 | "dev": true, 564 | "requires": { 565 | "path-parse": "^1.0.6" 566 | } 567 | } 568 | } 569 | }, 570 | "eslint-plugin-promise": { 571 | "version": "4.0.1", 572 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-4.0.1.tgz", 573 | "integrity": "sha512-Si16O0+Hqz1gDHsys6RtFRrW7cCTB6P7p3OJmKp3Y3dxpQE2qwOA7d3xnV+0mBmrPoi0RBnxlCKvqu70te6wjg==", 574 | "dev": true 575 | }, 576 | "eslint-plugin-react": { 577 | "version": "7.11.1", 578 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.11.1.tgz", 579 | "integrity": "sha512-cVVyMadRyW7qsIUh3FHp3u6QHNhOgVrLQYdQEB1bPWBsgbNCHdFAeNMquBMCcZJu59eNthX053L70l7gRt4SCw==", 580 | "dev": true, 581 | "requires": { 582 | "array-includes": "^3.0.3", 583 | "doctrine": "^2.1.0", 584 | "has": "^1.0.3", 585 | "jsx-ast-utils": "^2.0.1", 586 | "prop-types": "^15.6.2" 587 | } 588 | }, 589 | "eslint-plugin-standard": { 590 | "version": "4.0.0", 591 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-4.0.0.tgz", 592 | "integrity": "sha512-OwxJkR6TQiYMmt1EsNRMe5qG3GsbjlcOhbGUBY4LtavF9DsLaTcoR+j2Tdjqi23oUwKNUqX7qcn5fPStafMdlA==", 593 | "dev": true 594 | }, 595 | "eslint-scope": { 596 | "version": "4.0.0", 597 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", 598 | "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", 599 | "dev": true, 600 | "requires": { 601 | "esrecurse": "^4.1.0", 602 | "estraverse": "^4.1.1" 603 | } 604 | }, 605 | "eslint-utils": { 606 | "version": "1.4.2", 607 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.2.tgz", 608 | "integrity": "sha512-eAZS2sEUMlIeCjBeubdj45dmBHQwPHWyBcT1VSYB7o9x9WRRqKxyUoiXlRjyAwzN7YEzHJlYg0NmzDRWx6GP4Q==", 609 | "dev": true, 610 | "requires": { 611 | "eslint-visitor-keys": "^1.0.0" 612 | } 613 | }, 614 | "eslint-visitor-keys": { 615 | "version": "1.0.0", 616 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 617 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 618 | "dev": true 619 | }, 620 | "espree": { 621 | "version": "4.1.0", 622 | "resolved": "https://registry.npmjs.org/espree/-/espree-4.1.0.tgz", 623 | "integrity": "sha512-I5BycZW6FCVIub93TeVY1s7vjhP9CY6cXCznIRfiig7nRviKZYdRnj/sHEWC6A7WE9RDWOFq9+7OsWSYz8qv2w==", 624 | "dev": true, 625 | "requires": { 626 | "acorn": "^6.0.2", 627 | "acorn-jsx": "^5.0.0", 628 | "eslint-visitor-keys": "^1.0.0" 629 | } 630 | }, 631 | "esprima": { 632 | "version": "4.0.1", 633 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 634 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 635 | "dev": true 636 | }, 637 | "esquery": { 638 | "version": "1.0.1", 639 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 640 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 641 | "dev": true, 642 | "requires": { 643 | "estraverse": "^4.0.0" 644 | } 645 | }, 646 | "esrecurse": { 647 | "version": "4.2.1", 648 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 649 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 650 | "dev": true, 651 | "requires": { 652 | "estraverse": "^4.1.0" 653 | } 654 | }, 655 | "estraverse": { 656 | "version": "4.2.0", 657 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 658 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 659 | "dev": true 660 | }, 661 | "esutils": { 662 | "version": "2.0.2", 663 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 664 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 665 | "dev": true 666 | }, 667 | "events": { 668 | "version": "3.0.0", 669 | "resolved": "https://registry.npmjs.org/events/-/events-3.0.0.tgz", 670 | "integrity": "sha512-Dc381HFWJzEOhQ+d8pkNon++bk9h6cdAoAj4iE6Q4y6xgTzySWXlKn05/TVNpjnfRqi/X0EpJEJohPjNI3zpVA==" 671 | }, 672 | "external-editor": { 673 | "version": "2.2.0", 674 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.2.0.tgz", 675 | "integrity": "sha512-bSn6gvGxKt+b7+6TKEv1ZycHleA7aHhRHyAqJyp5pbUFuYYNIzpZnQDk7AsYckyWdEnTeAnay0aCy2aV6iTk9A==", 676 | "dev": true, 677 | "requires": { 678 | "chardet": "^0.4.0", 679 | "iconv-lite": "^0.4.17", 680 | "tmp": "^0.0.33" 681 | } 682 | }, 683 | "fast-deep-equal": { 684 | "version": "2.0.1", 685 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 686 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 687 | "dev": true 688 | }, 689 | "fast-json-stable-stringify": { 690 | "version": "2.0.0", 691 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 692 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 693 | "dev": true 694 | }, 695 | "fast-levenshtein": { 696 | "version": "2.0.6", 697 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 698 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 699 | "dev": true 700 | }, 701 | "figures": { 702 | "version": "2.0.0", 703 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 704 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 705 | "dev": true, 706 | "requires": { 707 | "escape-string-regexp": "^1.0.5" 708 | } 709 | }, 710 | "file-entry-cache": { 711 | "version": "2.0.0", 712 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 713 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 714 | "dev": true, 715 | "requires": { 716 | "flat-cache": "^1.2.1", 717 | "object-assign": "^4.0.1" 718 | } 719 | }, 720 | "find-root": { 721 | "version": "1.1.0", 722 | "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", 723 | "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==", 724 | "dev": true 725 | }, 726 | "find-up": { 727 | "version": "1.1.2", 728 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 729 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 730 | "dev": true, 731 | "requires": { 732 | "path-exists": "^2.0.0", 733 | "pinkie-promise": "^2.0.0" 734 | } 735 | }, 736 | "flat-cache": { 737 | "version": "1.3.4", 738 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.4.tgz", 739 | "integrity": "sha512-VwyB3Lkgacfik2vhqR4uv2rvebqmDvFu4jlN/C1RzWoJEo8I7z4Q404oiqYCkq41mni8EzQnm95emU9seckwtg==", 740 | "dev": true, 741 | "requires": { 742 | "circular-json": "^0.3.1", 743 | "graceful-fs": "^4.1.2", 744 | "rimraf": "~2.6.2", 745 | "write": "^0.2.1" 746 | } 747 | }, 748 | "for-each": { 749 | "version": "0.3.3", 750 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 751 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 752 | "dev": true, 753 | "requires": { 754 | "is-callable": "^1.1.3" 755 | } 756 | }, 757 | "fs.realpath": { 758 | "version": "1.0.0", 759 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 760 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 761 | "dev": true 762 | }, 763 | "function-bind": { 764 | "version": "1.1.1", 765 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 766 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 767 | "dev": true 768 | }, 769 | "functional-red-black-tree": { 770 | "version": "1.0.1", 771 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 772 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 773 | "dev": true 774 | }, 775 | "get-stdin": { 776 | "version": "6.0.0", 777 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", 778 | "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", 779 | "dev": true 780 | }, 781 | "glob": { 782 | "version": "7.1.3", 783 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 784 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 785 | "dev": true, 786 | "requires": { 787 | "fs.realpath": "^1.0.0", 788 | "inflight": "^1.0.4", 789 | "inherits": "2", 790 | "minimatch": "^3.0.4", 791 | "once": "^1.3.0", 792 | "path-is-absolute": "^1.0.0" 793 | } 794 | }, 795 | "globals": { 796 | "version": "11.10.0", 797 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.10.0.tgz", 798 | "integrity": "sha512-0GZF1RiPKU97IHUO5TORo9w1PwrH/NBPl+fS7oMLdaTRiYmYbwK4NWoZWrAdd0/abG9R2BU+OiwyQpTpE6pdfQ==", 799 | "dev": true 800 | }, 801 | "graceful-fs": { 802 | "version": "4.1.15", 803 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 804 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 805 | "dev": true 806 | }, 807 | "has": { 808 | "version": "1.0.3", 809 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 810 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 811 | "dev": true, 812 | "requires": { 813 | "function-bind": "^1.1.1" 814 | } 815 | }, 816 | "has-ansi": { 817 | "version": "2.0.0", 818 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 819 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 820 | "dev": true, 821 | "requires": { 822 | "ansi-regex": "^2.0.0" 823 | } 824 | }, 825 | "has-flag": { 826 | "version": "3.0.0", 827 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 828 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 829 | "dev": true 830 | }, 831 | "has-symbols": { 832 | "version": "1.0.0", 833 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 834 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 835 | "dev": true 836 | }, 837 | "hosted-git-info": { 838 | "version": "2.7.1", 839 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 840 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 841 | "dev": true 842 | }, 843 | "iconv-lite": { 844 | "version": "0.4.24", 845 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 846 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 847 | "dev": true, 848 | "requires": { 849 | "safer-buffer": ">= 2.1.2 < 3" 850 | } 851 | }, 852 | "ignore": { 853 | "version": "4.0.6", 854 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 855 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 856 | "dev": true 857 | }, 858 | "imurmurhash": { 859 | "version": "0.1.4", 860 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 861 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 862 | "dev": true 863 | }, 864 | "inflight": { 865 | "version": "1.0.6", 866 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 867 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 868 | "dev": true, 869 | "requires": { 870 | "once": "^1.3.0", 871 | "wrappy": "1" 872 | } 873 | }, 874 | "inherits": { 875 | "version": "2.0.3", 876 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 877 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 878 | }, 879 | "inquirer": { 880 | "version": "5.2.0", 881 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-5.2.0.tgz", 882 | "integrity": "sha512-E9BmnJbAKLPGonz0HeWHtbKf+EeSP93paWO3ZYoUpq/aowXvYGjjCSuashhXPpzbArIjBbji39THkxTz9ZeEUQ==", 883 | "dev": true, 884 | "requires": { 885 | "ansi-escapes": "^3.0.0", 886 | "chalk": "^2.0.0", 887 | "cli-cursor": "^2.1.0", 888 | "cli-width": "^2.0.0", 889 | "external-editor": "^2.1.0", 890 | "figures": "^2.0.0", 891 | "lodash": "^4.3.0", 892 | "mute-stream": "0.0.7", 893 | "run-async": "^2.2.0", 894 | "rxjs": "^5.5.2", 895 | "string-width": "^2.1.0", 896 | "strip-ansi": "^4.0.0", 897 | "through": "^2.3.6" 898 | } 899 | }, 900 | "is-arrayish": { 901 | "version": "0.2.1", 902 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 903 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 904 | "dev": true 905 | }, 906 | "is-builtin-module": { 907 | "version": "1.0.0", 908 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 909 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 910 | "dev": true, 911 | "requires": { 912 | "builtin-modules": "^1.0.0" 913 | } 914 | }, 915 | "is-callable": { 916 | "version": "1.1.4", 917 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 918 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 919 | "dev": true 920 | }, 921 | "is-date-object": { 922 | "version": "1.0.1", 923 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 924 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 925 | "dev": true 926 | }, 927 | "is-fullwidth-code-point": { 928 | "version": "2.0.0", 929 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 930 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 931 | "dev": true 932 | }, 933 | "is-promise": { 934 | "version": "2.1.0", 935 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 936 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 937 | "dev": true 938 | }, 939 | "is-regex": { 940 | "version": "1.0.4", 941 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 942 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 943 | "dev": true, 944 | "requires": { 945 | "has": "^1.0.1" 946 | } 947 | }, 948 | "is-resolvable": { 949 | "version": "1.1.0", 950 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", 951 | "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", 952 | "dev": true 953 | }, 954 | "is-symbol": { 955 | "version": "1.0.2", 956 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 957 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 958 | "dev": true, 959 | "requires": { 960 | "has-symbols": "^1.0.0" 961 | } 962 | }, 963 | "is-typedarray": { 964 | "version": "1.0.0", 965 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 966 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 967 | "dev": true 968 | }, 969 | "isarray": { 970 | "version": "1.0.0", 971 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 972 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 973 | "dev": true 974 | }, 975 | "isexe": { 976 | "version": "2.0.0", 977 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 978 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 979 | "dev": true 980 | }, 981 | "js-tokens": { 982 | "version": "3.0.2", 983 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 984 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 985 | "dev": true 986 | }, 987 | "js-yaml": { 988 | "version": "3.13.1", 989 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 990 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 991 | "dev": true, 992 | "requires": { 993 | "argparse": "^1.0.7", 994 | "esprima": "^4.0.0" 995 | } 996 | }, 997 | "json-parse-better-errors": { 998 | "version": "1.0.2", 999 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1000 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1001 | "dev": true 1002 | }, 1003 | "json-schema-traverse": { 1004 | "version": "0.4.1", 1005 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1006 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1007 | "dev": true 1008 | }, 1009 | "json-stable-stringify-without-jsonify": { 1010 | "version": "1.0.1", 1011 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1012 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1013 | "dev": true 1014 | }, 1015 | "jsx-ast-utils": { 1016 | "version": "2.0.1", 1017 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.0.1.tgz", 1018 | "integrity": "sha1-6AGxs5mF4g//yHtA43SAgOLcrH8=", 1019 | "dev": true, 1020 | "requires": { 1021 | "array-includes": "^3.0.3" 1022 | } 1023 | }, 1024 | "levn": { 1025 | "version": "0.3.0", 1026 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1027 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1028 | "dev": true, 1029 | "requires": { 1030 | "prelude-ls": "~1.1.2", 1031 | "type-check": "~0.3.2" 1032 | } 1033 | }, 1034 | "load-json-file": { 1035 | "version": "2.0.0", 1036 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1037 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1038 | "dev": true, 1039 | "requires": { 1040 | "graceful-fs": "^4.1.2", 1041 | "parse-json": "^2.2.0", 1042 | "pify": "^2.0.0", 1043 | "strip-bom": "^3.0.0" 1044 | } 1045 | }, 1046 | "locate-path": { 1047 | "version": "2.0.0", 1048 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1049 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1050 | "dev": true, 1051 | "requires": { 1052 | "p-locate": "^2.0.0", 1053 | "path-exists": "^3.0.0" 1054 | }, 1055 | "dependencies": { 1056 | "path-exists": { 1057 | "version": "3.0.0", 1058 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1059 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1060 | "dev": true 1061 | } 1062 | } 1063 | }, 1064 | "lodash": { 1065 | "version": "4.17.19", 1066 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1067 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 1068 | "dev": true 1069 | }, 1070 | "loose-envify": { 1071 | "version": "1.4.0", 1072 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1073 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1074 | "dev": true, 1075 | "requires": { 1076 | "js-tokens": "^3.0.0 || ^4.0.0" 1077 | } 1078 | }, 1079 | "mimic-fn": { 1080 | "version": "1.2.0", 1081 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1082 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1083 | "dev": true 1084 | }, 1085 | "minimatch": { 1086 | "version": "3.0.4", 1087 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1088 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1089 | "dev": true, 1090 | "requires": { 1091 | "brace-expansion": "^1.1.7" 1092 | } 1093 | }, 1094 | "minimist": { 1095 | "version": "1.2.3", 1096 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.3.tgz", 1097 | "integrity": "sha512-+bMdgqjMN/Z77a6NlY/I3U5LlRDbnmaAk6lDveAPKwSpcPM4tKAuYsvYF8xjhOPXhOYGe/73vVLVez5PW+jqhw==" 1098 | }, 1099 | "mkdirp": { 1100 | "version": "0.5.1", 1101 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1102 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1103 | "dev": true, 1104 | "requires": { 1105 | "minimist": "0.0.8" 1106 | }, 1107 | "dependencies": { 1108 | "minimist": { 1109 | "version": "0.0.8", 1110 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1111 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1112 | "dev": true 1113 | } 1114 | } 1115 | }, 1116 | "ms": { 1117 | "version": "2.1.1", 1118 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1119 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1120 | }, 1121 | "mute-stream": { 1122 | "version": "0.0.7", 1123 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1124 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1125 | "dev": true 1126 | }, 1127 | "nan": { 1128 | "version": "2.12.1", 1129 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.12.1.tgz", 1130 | "integrity": "sha512-JY7V6lRkStKcKTvHO5NVSQRv+RV+FIL5pvDoLiAtSL9pKlC5x9PKQcZDsq7m4FO4d57mkhC6Z+QhAh3Jdk5JFw==", 1131 | "dev": true 1132 | }, 1133 | "natural-compare": { 1134 | "version": "1.4.0", 1135 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1136 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1137 | "dev": true 1138 | }, 1139 | "nice-try": { 1140 | "version": "1.0.5", 1141 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1142 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1143 | "dev": true 1144 | }, 1145 | "normalize-package-data": { 1146 | "version": "2.4.0", 1147 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 1148 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 1149 | "dev": true, 1150 | "requires": { 1151 | "hosted-git-info": "^2.1.4", 1152 | "is-builtin-module": "^1.0.0", 1153 | "semver": "2 || 3 || 4 || 5", 1154 | "validate-npm-package-license": "^3.0.1" 1155 | } 1156 | }, 1157 | "object-assign": { 1158 | "version": "4.1.1", 1159 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1160 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1161 | "dev": true 1162 | }, 1163 | "object-inspect": { 1164 | "version": "1.6.0", 1165 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.6.0.tgz", 1166 | "integrity": "sha512-GJzfBZ6DgDAmnuaM3104jR4s1Myxr3Y3zfIyN4z3UdqN69oSRacNK8UhnobDdC+7J2AHCjGwxQubNJfE70SXXQ==", 1167 | "dev": true 1168 | }, 1169 | "object-keys": { 1170 | "version": "1.0.12", 1171 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.12.tgz", 1172 | "integrity": "sha512-FTMyFUm2wBcGHnH2eXmz7tC6IwlqQZ6mVZ+6dm6vZ4IQIHjs6FdNsQBuKGPuUUUY6NfJw2PshC08Tn6LzLDOag==", 1173 | "dev": true 1174 | }, 1175 | "once": { 1176 | "version": "1.4.0", 1177 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1178 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1179 | "dev": true, 1180 | "requires": { 1181 | "wrappy": "1" 1182 | } 1183 | }, 1184 | "onetime": { 1185 | "version": "2.0.1", 1186 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1187 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1188 | "dev": true, 1189 | "requires": { 1190 | "mimic-fn": "^1.0.0" 1191 | } 1192 | }, 1193 | "optionator": { 1194 | "version": "0.8.2", 1195 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1196 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1197 | "dev": true, 1198 | "requires": { 1199 | "deep-is": "~0.1.3", 1200 | "fast-levenshtein": "~2.0.4", 1201 | "levn": "~0.3.0", 1202 | "prelude-ls": "~1.1.2", 1203 | "type-check": "~0.3.2", 1204 | "wordwrap": "~1.0.0" 1205 | } 1206 | }, 1207 | "os-tmpdir": { 1208 | "version": "1.0.2", 1209 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1210 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1211 | "dev": true 1212 | }, 1213 | "p-limit": { 1214 | "version": "1.3.0", 1215 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1216 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1217 | "dev": true, 1218 | "requires": { 1219 | "p-try": "^1.0.0" 1220 | } 1221 | }, 1222 | "p-locate": { 1223 | "version": "2.0.0", 1224 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1225 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1226 | "dev": true, 1227 | "requires": { 1228 | "p-limit": "^1.1.0" 1229 | } 1230 | }, 1231 | "p-try": { 1232 | "version": "1.0.0", 1233 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1234 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1235 | "dev": true 1236 | }, 1237 | "parse-json": { 1238 | "version": "2.2.0", 1239 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1240 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1241 | "dev": true, 1242 | "requires": { 1243 | "error-ex": "^1.2.0" 1244 | } 1245 | }, 1246 | "path-exists": { 1247 | "version": "2.1.0", 1248 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 1249 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 1250 | "dev": true, 1251 | "requires": { 1252 | "pinkie-promise": "^2.0.0" 1253 | } 1254 | }, 1255 | "path-is-absolute": { 1256 | "version": "1.0.1", 1257 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1258 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1259 | "dev": true 1260 | }, 1261 | "path-is-inside": { 1262 | "version": "1.0.2", 1263 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1264 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1265 | "dev": true 1266 | }, 1267 | "path-key": { 1268 | "version": "2.0.1", 1269 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1270 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1271 | "dev": true 1272 | }, 1273 | "path-parse": { 1274 | "version": "1.0.6", 1275 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1276 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1277 | "dev": true 1278 | }, 1279 | "path-type": { 1280 | "version": "2.0.0", 1281 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1282 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1283 | "dev": true, 1284 | "requires": { 1285 | "pify": "^2.0.0" 1286 | } 1287 | }, 1288 | "pify": { 1289 | "version": "2.3.0", 1290 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1291 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1292 | "dev": true 1293 | }, 1294 | "pinkie": { 1295 | "version": "2.0.4", 1296 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1297 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 1298 | "dev": true 1299 | }, 1300 | "pinkie-promise": { 1301 | "version": "2.0.1", 1302 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1303 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 1304 | "dev": true, 1305 | "requires": { 1306 | "pinkie": "^2.0.0" 1307 | } 1308 | }, 1309 | "pkg-conf": { 1310 | "version": "2.1.0", 1311 | "resolved": "https://registry.npmjs.org/pkg-conf/-/pkg-conf-2.1.0.tgz", 1312 | "integrity": "sha1-ISZRTKbyq/69FoWW3xi6V4Z/AFg=", 1313 | "dev": true, 1314 | "requires": { 1315 | "find-up": "^2.0.0", 1316 | "load-json-file": "^4.0.0" 1317 | }, 1318 | "dependencies": { 1319 | "find-up": { 1320 | "version": "2.1.0", 1321 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1322 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1323 | "dev": true, 1324 | "requires": { 1325 | "locate-path": "^2.0.0" 1326 | } 1327 | }, 1328 | "load-json-file": { 1329 | "version": "4.0.0", 1330 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1331 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 1332 | "dev": true, 1333 | "requires": { 1334 | "graceful-fs": "^4.1.2", 1335 | "parse-json": "^4.0.0", 1336 | "pify": "^3.0.0", 1337 | "strip-bom": "^3.0.0" 1338 | } 1339 | }, 1340 | "parse-json": { 1341 | "version": "4.0.0", 1342 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1343 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1344 | "dev": true, 1345 | "requires": { 1346 | "error-ex": "^1.3.1", 1347 | "json-parse-better-errors": "^1.0.1" 1348 | } 1349 | }, 1350 | "pify": { 1351 | "version": "3.0.0", 1352 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1353 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1354 | "dev": true 1355 | } 1356 | } 1357 | }, 1358 | "pkg-config": { 1359 | "version": "1.1.1", 1360 | "resolved": "https://registry.npmjs.org/pkg-config/-/pkg-config-1.1.1.tgz", 1361 | "integrity": "sha1-VX7yLXPaPIg3EHdmxS6tq94pj+Q=", 1362 | "dev": true, 1363 | "requires": { 1364 | "debug-log": "^1.0.0", 1365 | "find-root": "^1.0.0", 1366 | "xtend": "^4.0.1" 1367 | } 1368 | }, 1369 | "pkg-dir": { 1370 | "version": "1.0.0", 1371 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", 1372 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", 1373 | "dev": true, 1374 | "requires": { 1375 | "find-up": "^1.0.0" 1376 | } 1377 | }, 1378 | "pluralize": { 1379 | "version": "7.0.0", 1380 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 1381 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 1382 | "dev": true 1383 | }, 1384 | "prelude-ls": { 1385 | "version": "1.1.2", 1386 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1387 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1388 | "dev": true 1389 | }, 1390 | "progress": { 1391 | "version": "2.0.3", 1392 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1393 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1394 | "dev": true 1395 | }, 1396 | "prop-types": { 1397 | "version": "15.6.2", 1398 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.6.2.tgz", 1399 | "integrity": "sha512-3pboPvLiWD7dkI3qf3KbUe6hKFKa52w+AE0VCqECtf+QHAKgOL37tTaNCnuX1nAAQ4ZhyP+kYVKf8rLmJ/feDQ==", 1400 | "dev": true, 1401 | "requires": { 1402 | "loose-envify": "^1.3.1", 1403 | "object-assign": "^4.1.1" 1404 | } 1405 | }, 1406 | "punycode": { 1407 | "version": "2.1.1", 1408 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1409 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1410 | "dev": true 1411 | }, 1412 | "read-pkg": { 1413 | "version": "2.0.0", 1414 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1415 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1416 | "dev": true, 1417 | "requires": { 1418 | "load-json-file": "^2.0.0", 1419 | "normalize-package-data": "^2.3.2", 1420 | "path-type": "^2.0.0" 1421 | } 1422 | }, 1423 | "read-pkg-up": { 1424 | "version": "2.0.0", 1425 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1426 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1427 | "dev": true, 1428 | "requires": { 1429 | "find-up": "^2.0.0", 1430 | "read-pkg": "^2.0.0" 1431 | }, 1432 | "dependencies": { 1433 | "find-up": { 1434 | "version": "2.1.0", 1435 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1436 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1437 | "dev": true, 1438 | "requires": { 1439 | "locate-path": "^2.0.0" 1440 | } 1441 | } 1442 | } 1443 | }, 1444 | "readable-stream": { 1445 | "version": "3.1.1", 1446 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.1.1.tgz", 1447 | "integrity": "sha512-DkN66hPyqDhnIQ6Jcsvx9bFjhw214O4poMBcIMgPVpQvNy9a0e0Uhg5SqySyDKAmUlwt8LonTBz1ezOnM8pUdA==", 1448 | "requires": { 1449 | "inherits": "^2.0.3", 1450 | "string_decoder": "^1.1.1", 1451 | "util-deprecate": "^1.0.1" 1452 | } 1453 | }, 1454 | "regexpp": { 1455 | "version": "2.0.1", 1456 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1457 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1458 | "dev": true 1459 | }, 1460 | "require-uncached": { 1461 | "version": "1.0.3", 1462 | "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 1463 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 1464 | "dev": true, 1465 | "requires": { 1466 | "caller-path": "^0.1.0", 1467 | "resolve-from": "^1.0.0" 1468 | } 1469 | }, 1470 | "resolve": { 1471 | "version": "1.7.1", 1472 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.7.1.tgz", 1473 | "integrity": "sha512-c7rwLofp8g1U+h1KNyHL/jicrKg1Ek4q+Lr33AL65uZTinUZHe30D5HlyN5V9NW0JX1D5dXQ4jqW5l7Sy/kGfw==", 1474 | "dev": true, 1475 | "requires": { 1476 | "path-parse": "^1.0.5" 1477 | } 1478 | }, 1479 | "resolve-from": { 1480 | "version": "1.0.1", 1481 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 1482 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 1483 | "dev": true 1484 | }, 1485 | "restore-cursor": { 1486 | "version": "2.0.0", 1487 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1488 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1489 | "dev": true, 1490 | "requires": { 1491 | "onetime": "^2.0.0", 1492 | "signal-exit": "^3.0.2" 1493 | } 1494 | }, 1495 | "resumer": { 1496 | "version": "0.0.0", 1497 | "resolved": "https://registry.npmjs.org/resumer/-/resumer-0.0.0.tgz", 1498 | "integrity": "sha1-8ej0YeQGS6Oegq883CqMiT0HZ1k=", 1499 | "dev": true, 1500 | "requires": { 1501 | "through": "~2.3.4" 1502 | } 1503 | }, 1504 | "rimraf": { 1505 | "version": "2.6.3", 1506 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1507 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1508 | "dev": true, 1509 | "requires": { 1510 | "glob": "^7.1.3" 1511 | } 1512 | }, 1513 | "run-async": { 1514 | "version": "2.3.0", 1515 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1516 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1517 | "dev": true, 1518 | "requires": { 1519 | "is-promise": "^2.1.0" 1520 | } 1521 | }, 1522 | "run-parallel": { 1523 | "version": "1.1.9", 1524 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.9.tgz", 1525 | "integrity": "sha512-DEqnSRTDw/Tc3FXf49zedI638Z9onwUotBMiUFKmrO2sdFKIbXamXGQ3Axd4qgphxKB4kw/qP1w5kTxnfU1B9Q==", 1526 | "dev": true 1527 | }, 1528 | "rxjs": { 1529 | "version": "5.5.12", 1530 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-5.5.12.tgz", 1531 | "integrity": "sha512-xx2itnL5sBbqeeiVgNPVuQQ1nC8Jp2WfNJhXWHmElW9YmrpS9UVnNzhP3EH3HFqexO5Tlp8GhYY+WEcqcVMvGw==", 1532 | "dev": true, 1533 | "requires": { 1534 | "symbol-observable": "1.0.1" 1535 | } 1536 | }, 1537 | "safe-buffer": { 1538 | "version": "5.1.2", 1539 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1540 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1541 | }, 1542 | "safer-buffer": { 1543 | "version": "2.1.2", 1544 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1545 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1546 | "dev": true 1547 | }, 1548 | "semver": { 1549 | "version": "5.6.0", 1550 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 1551 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", 1552 | "dev": true 1553 | }, 1554 | "shebang-command": { 1555 | "version": "1.2.0", 1556 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1557 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1558 | "dev": true, 1559 | "requires": { 1560 | "shebang-regex": "^1.0.0" 1561 | } 1562 | }, 1563 | "shebang-regex": { 1564 | "version": "1.0.0", 1565 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1566 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1567 | "dev": true 1568 | }, 1569 | "signal-exit": { 1570 | "version": "3.0.2", 1571 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1572 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1573 | "dev": true 1574 | }, 1575 | "slice-ansi": { 1576 | "version": "1.0.0", 1577 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 1578 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 1579 | "dev": true, 1580 | "requires": { 1581 | "is-fullwidth-code-point": "^2.0.0" 1582 | } 1583 | }, 1584 | "spdx-correct": { 1585 | "version": "3.1.0", 1586 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 1587 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 1588 | "dev": true, 1589 | "requires": { 1590 | "spdx-expression-parse": "^3.0.0", 1591 | "spdx-license-ids": "^3.0.0" 1592 | } 1593 | }, 1594 | "spdx-exceptions": { 1595 | "version": "2.2.0", 1596 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 1597 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 1598 | "dev": true 1599 | }, 1600 | "spdx-expression-parse": { 1601 | "version": "3.0.0", 1602 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1603 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1604 | "dev": true, 1605 | "requires": { 1606 | "spdx-exceptions": "^2.1.0", 1607 | "spdx-license-ids": "^3.0.0" 1608 | } 1609 | }, 1610 | "spdx-license-ids": { 1611 | "version": "3.0.3", 1612 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz", 1613 | "integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==", 1614 | "dev": true 1615 | }, 1616 | "sprintf-js": { 1617 | "version": "1.0.3", 1618 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1619 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1620 | "dev": true 1621 | }, 1622 | "standard": { 1623 | "version": "12.0.1", 1624 | "resolved": "https://registry.npmjs.org/standard/-/standard-12.0.1.tgz", 1625 | "integrity": "sha512-UqdHjh87OG2gUrNCSM4QRLF5n9h3TFPwrCNyVlkqu31Hej0L/rc8hzKqVvkb2W3x0WMq7PzZdkLfEcBhVOR6lg==", 1626 | "dev": true, 1627 | "requires": { 1628 | "eslint": "~5.4.0", 1629 | "eslint-config-standard": "12.0.0", 1630 | "eslint-config-standard-jsx": "6.0.2", 1631 | "eslint-plugin-import": "~2.14.0", 1632 | "eslint-plugin-node": "~7.0.1", 1633 | "eslint-plugin-promise": "~4.0.0", 1634 | "eslint-plugin-react": "~7.11.1", 1635 | "eslint-plugin-standard": "~4.0.0", 1636 | "standard-engine": "~9.0.0" 1637 | } 1638 | }, 1639 | "standard-engine": { 1640 | "version": "9.0.0", 1641 | "resolved": "https://registry.npmjs.org/standard-engine/-/standard-engine-9.0.0.tgz", 1642 | "integrity": "sha512-ZfNfCWZ2Xq67VNvKMPiVMKHnMdvxYzvZkf1AH8/cw2NLDBm5LRsxMqvEJpsjLI/dUosZ3Z1d6JlHDp5rAvvk2w==", 1643 | "dev": true, 1644 | "requires": { 1645 | "deglob": "^2.1.0", 1646 | "get-stdin": "^6.0.0", 1647 | "minimist": "^1.1.0", 1648 | "pkg-conf": "^2.0.0" 1649 | } 1650 | }, 1651 | "string-width": { 1652 | "version": "2.1.1", 1653 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1654 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1655 | "dev": true, 1656 | "requires": { 1657 | "is-fullwidth-code-point": "^2.0.0", 1658 | "strip-ansi": "^4.0.0" 1659 | } 1660 | }, 1661 | "string.prototype.trim": { 1662 | "version": "1.1.2", 1663 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.1.2.tgz", 1664 | "integrity": "sha1-0E3iyJ4Tf019IG8Ia17S+ua+jOo=", 1665 | "dev": true, 1666 | "requires": { 1667 | "define-properties": "^1.1.2", 1668 | "es-abstract": "^1.5.0", 1669 | "function-bind": "^1.0.2" 1670 | } 1671 | }, 1672 | "string_decoder": { 1673 | "version": "1.2.0", 1674 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.2.0.tgz", 1675 | "integrity": "sha512-6YqyX6ZWEYguAxgZzHGL7SsCeGx3V2TtOTqZz1xSTSWnqsbWwbptafNyvf/ACquZUXV3DANr5BDIwNYe1mN42w==", 1676 | "requires": { 1677 | "safe-buffer": "~5.1.0" 1678 | } 1679 | }, 1680 | "strip-ansi": { 1681 | "version": "4.0.0", 1682 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1683 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1684 | "dev": true, 1685 | "requires": { 1686 | "ansi-regex": "^3.0.0" 1687 | }, 1688 | "dependencies": { 1689 | "ansi-regex": { 1690 | "version": "3.0.0", 1691 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1692 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1693 | "dev": true 1694 | } 1695 | } 1696 | }, 1697 | "strip-bom": { 1698 | "version": "3.0.0", 1699 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1700 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1701 | "dev": true 1702 | }, 1703 | "strip-json-comments": { 1704 | "version": "2.0.1", 1705 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1706 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1707 | "dev": true 1708 | }, 1709 | "supports-color": { 1710 | "version": "2.0.0", 1711 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1712 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1713 | "dev": true 1714 | }, 1715 | "symbol-observable": { 1716 | "version": "1.0.1", 1717 | "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.0.1.tgz", 1718 | "integrity": "sha1-g0D8RwLDEi310iKI+IKD9RPT/dQ=", 1719 | "dev": true 1720 | }, 1721 | "table": { 1722 | "version": "4.0.3", 1723 | "resolved": "https://registry.npmjs.org/table/-/table-4.0.3.tgz", 1724 | "integrity": "sha512-S7rnFITmBH1EnyKcvxBh1LjYeQMmnZtCXSEbHcH6S0NoKit24ZuFO/T1vDcLdYsLQkM188PVVhQmzKIuThNkKg==", 1725 | "dev": true, 1726 | "requires": { 1727 | "ajv": "^6.0.1", 1728 | "ajv-keywords": "^3.0.0", 1729 | "chalk": "^2.1.0", 1730 | "lodash": "^4.17.4", 1731 | "slice-ansi": "1.0.0", 1732 | "string-width": "^2.1.1" 1733 | } 1734 | }, 1735 | "tape": { 1736 | "version": "4.9.2", 1737 | "resolved": "https://registry.npmjs.org/tape/-/tape-4.9.2.tgz", 1738 | "integrity": "sha512-lPXKRKILZ1kZaUy5ynWKs8ATGSUO7HAFHCFnBam6FaGSqPdOwMWbxXHq4EXFLE8WRTleo/YOMXkaUTRmTB1Fiw==", 1739 | "dev": true, 1740 | "requires": { 1741 | "deep-equal": "~1.0.1", 1742 | "defined": "~1.0.0", 1743 | "for-each": "~0.3.3", 1744 | "function-bind": "~1.1.1", 1745 | "glob": "~7.1.2", 1746 | "has": "~1.0.3", 1747 | "inherits": "~2.0.3", 1748 | "minimist": "~1.2.0", 1749 | "object-inspect": "~1.6.0", 1750 | "resolve": "~1.7.1", 1751 | "resumer": "~0.0.0", 1752 | "string.prototype.trim": "~1.1.2", 1753 | "through": "~2.3.8" 1754 | } 1755 | }, 1756 | "text-table": { 1757 | "version": "0.2.0", 1758 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1759 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1760 | "dev": true 1761 | }, 1762 | "through": { 1763 | "version": "2.3.8", 1764 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1765 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1766 | "dev": true 1767 | }, 1768 | "through2": { 1769 | "version": "3.0.0", 1770 | "resolved": "https://registry.npmjs.org/through2/-/through2-3.0.0.tgz", 1771 | "integrity": "sha512-8B+sevlqP4OiCjonI1Zw03Sf8PuV1eRsYQgLad5eonILOdyeRsY27A/2Ze8IlvlMvq31OH+3fz/styI7Ya62yQ==", 1772 | "requires": { 1773 | "readable-stream": "2 || 3", 1774 | "xtend": "~4.0.1" 1775 | } 1776 | }, 1777 | "tmp": { 1778 | "version": "0.0.33", 1779 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1780 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1781 | "dev": true, 1782 | "requires": { 1783 | "os-tmpdir": "~1.0.2" 1784 | } 1785 | }, 1786 | "type-check": { 1787 | "version": "0.3.2", 1788 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1789 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1790 | "dev": true, 1791 | "requires": { 1792 | "prelude-ls": "~1.1.2" 1793 | } 1794 | }, 1795 | "typedarray-to-buffer": { 1796 | "version": "3.1.5", 1797 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1798 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1799 | "dev": true, 1800 | "requires": { 1801 | "is-typedarray": "^1.0.0" 1802 | } 1803 | }, 1804 | "uniq": { 1805 | "version": "1.0.1", 1806 | "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", 1807 | "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", 1808 | "dev": true 1809 | }, 1810 | "uri-js": { 1811 | "version": "4.2.2", 1812 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1813 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1814 | "dev": true, 1815 | "requires": { 1816 | "punycode": "^2.1.0" 1817 | } 1818 | }, 1819 | "util-deprecate": { 1820 | "version": "1.0.2", 1821 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1822 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1823 | }, 1824 | "validate-npm-package-license": { 1825 | "version": "3.0.4", 1826 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1827 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1828 | "dev": true, 1829 | "requires": { 1830 | "spdx-correct": "^3.0.0", 1831 | "spdx-expression-parse": "^3.0.0" 1832 | } 1833 | }, 1834 | "websocket": { 1835 | "version": "1.0.28", 1836 | "resolved": "https://registry.npmjs.org/websocket/-/websocket-1.0.28.tgz", 1837 | "integrity": "sha512-00y/20/80P7H4bCYkzuuvvfDvh+dgtXi5kzDf3UcZwN6boTYaKvsrtZ5lIYm1Gsg48siMErd9M4zjSYfYFHTrA==", 1838 | "dev": true, 1839 | "requires": { 1840 | "debug": "^2.2.0", 1841 | "nan": "^2.11.0", 1842 | "typedarray-to-buffer": "^3.1.5", 1843 | "yaeti": "^0.0.6" 1844 | }, 1845 | "dependencies": { 1846 | "debug": { 1847 | "version": "2.6.9", 1848 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1849 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1850 | "dev": true, 1851 | "requires": { 1852 | "ms": "2.0.0" 1853 | } 1854 | }, 1855 | "ms": { 1856 | "version": "2.0.0", 1857 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1858 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1859 | "dev": true 1860 | } 1861 | } 1862 | }, 1863 | "which": { 1864 | "version": "1.3.1", 1865 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1866 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1867 | "dev": true, 1868 | "requires": { 1869 | "isexe": "^2.0.0" 1870 | } 1871 | }, 1872 | "wordwrap": { 1873 | "version": "1.0.0", 1874 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 1875 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 1876 | "dev": true 1877 | }, 1878 | "wrappy": { 1879 | "version": "1.0.2", 1880 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1881 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1882 | "dev": true 1883 | }, 1884 | "write": { 1885 | "version": "0.2.1", 1886 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 1887 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 1888 | "dev": true, 1889 | "requires": { 1890 | "mkdirp": "^0.5.1" 1891 | } 1892 | }, 1893 | "ws": { 1894 | "version": "6.1.2", 1895 | "resolved": "https://registry.npmjs.org/ws/-/ws-6.1.2.tgz", 1896 | "integrity": "sha512-rfUqzvz0WxmSXtJpPMX2EeASXabOrSMk1ruMOV3JBTBjo4ac2lDjGGsbQSyxj8Odhw5fBib8ZKEjDNvgouNKYw==", 1897 | "dev": true, 1898 | "requires": { 1899 | "async-limiter": "~1.0.0" 1900 | } 1901 | }, 1902 | "xtend": { 1903 | "version": "4.0.1", 1904 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 1905 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 1906 | }, 1907 | "yaeti": { 1908 | "version": "0.0.6", 1909 | "resolved": "https://registry.npmjs.org/yaeti/-/yaeti-0.0.6.tgz", 1910 | "integrity": "sha1-8m9ITXJoTPQr7ft2lwqhYI+/lXc=", 1911 | "dev": true 1912 | } 1913 | } 1914 | } 1915 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "signalhubws", 3 | "version": "1.0.12", 4 | "description": "Drop in replacement for signalhub with websockets", 5 | "main": "index.js", 6 | "bin": "bin.js", 7 | "scripts": { 8 | "test": "standard && tape tests/**/*.test.js", 9 | "start": "node bin.js" 10 | }, 11 | "keywords": [], 12 | "author": "", 13 | "license": "MIT", 14 | "dependencies": { 15 | "@clusterws/cws": "^0.15.2", 16 | "debug": "^4.1.1", 17 | "events": "^3.0.0", 18 | "inherits": "^2.0.3", 19 | "minimist": "^1.2.0", 20 | "through2": "^3.0.0" 21 | }, 22 | "devDependencies": { 23 | "standard": "^12.0.1", 24 | "tape": "^4.9.2", 25 | "ws": "^6.1.2", 26 | "websocket": "^1.0.28" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | var debug = require('debug')('signalhubws') 2 | 3 | module.exports = function (WebSocketClass) { 4 | var wss 5 | var clients = [] 6 | var WebSocketServer = WebSocketClass || require('@clusterws/cws').WebSocketServer 7 | 8 | function listen (port, cb) { 9 | wss = new WebSocketServer({ port: port }) 10 | 11 | wss.on('connection', function (ws, req) { 12 | var app = req.url.split('?')[0].split('#')[0].substring(1).split('/') 13 | ws.app = app[app.length - 1] 14 | 15 | clients.push(ws) 16 | 17 | ws.on('close', () => { 18 | const i = clients.findIndex(c => c === ws) 19 | clients.splice(i, 1) 20 | }) 21 | 22 | ws.on('message', (data) => { 23 | var jsond 24 | try { 25 | jsond = JSON.parse(data) 26 | } catch (e) { 27 | console.error(e.message) 28 | return 29 | } 30 | 31 | debug('Got message', jsond) 32 | 33 | clients.forEach((client) => { 34 | if (jsond.app === client.app) { 35 | debug('Broadcasting on app: %s', client.app) 36 | client.send(data) 37 | } 38 | }) 39 | }) 40 | }) 41 | 42 | wss.on('listening', function () { 43 | cb() 44 | }) 45 | } 46 | 47 | return { 48 | listen: listen, 49 | close: (cb) => { 50 | wss.close(cb) 51 | } 52 | } 53 | } 54 | -------------------------------------------------------------------------------- /tests/boilerplate.js: -------------------------------------------------------------------------------- 1 | /** 2 | * This is pretty much a copy/paste from 3 | * https://github.com/mafintosh/signalhub/blob/master/test.js 4 | */ 5 | module.exports = function (test, server, client, port) { 6 | test('subscribe', function (t) { 7 | var c = client('app', [`localhost:${port}`]) 8 | 9 | c.subscribe('hello').on('data', function (message) { 10 | t.same(message, { hello: 'world' }) 11 | t.end() 12 | c.close() 13 | }).on('open', function () { 14 | c.broadcast('hello', { hello: 'world' }) 15 | }) 16 | }) 17 | 18 | test('subscribe two apps', function (t) { 19 | t.plan(2) 20 | 21 | var missing = 2 22 | var c1 = client('app1', [`localhost:${port}`]) 23 | 24 | c1.subscribe('hello').on('data', function (message) { 25 | t.same(message, { hello: 'world' }) 26 | done() 27 | }).on('open', function () { 28 | c1.broadcast('hello', { hello: 'world' }) 29 | }) 30 | 31 | var c2 = client('app2', [`localhost:${port}`]) 32 | 33 | c2.subscribe('hello').on('data', function (message) { 34 | t.same(message, { hello: 'world' }) 35 | done() 36 | }).on('open', function () { 37 | c2.broadcast('hello', { hello: 'world' }) 38 | }) 39 | 40 | function done () { 41 | if (--missing) return 42 | setTimeout(function () { 43 | c1.close() 44 | c2.close() 45 | t.end() 46 | }, 100) 47 | } 48 | }) 49 | 50 | test('subscribe with trailing /', function (t) { 51 | var c = client('app', [`localhost:${port}/`]) 52 | 53 | c.subscribe('hello').on('data', function (message) { 54 | t.same(message, { hello: 'world' }) 55 | t.end() 56 | c.close() 57 | }).on('open', function () { 58 | c.broadcast('hello', { hello: 'world' }) 59 | }) 60 | }) 61 | 62 | test('subscribe to many', function (t) { 63 | var c = client('app', [`localhost:${port}`]) 64 | var msgs = ['stranger', 'friend'] 65 | 66 | c.subscribe(['hello', 'goodbye']).on('data', function (message) { 67 | t.same(message, { msg: msgs.shift() }) 68 | if (msgs.length === 0) { 69 | c.close(function () { 70 | t.equal(c.subscribers.length, 0, 'all subscribers closed') 71 | t.end() 72 | }) 73 | } 74 | }).on('open', function () { 75 | c.broadcast('hello', { msg: 'stranger' }, function () { 76 | c.broadcast('goodbye', { msg: 'friend' }) 77 | }) 78 | }) 79 | }) 80 | 81 | test('close multiple', function (t) { 82 | var c = client('app', [`localhost:${port}`]) 83 | 84 | c.subscribe(['hello', 'goodbye']) 85 | c.subscribe(['hi', 'bye']) 86 | c.close(function () { 87 | t.equal(c.subscribers.length, 0, 'all subscribers closed') 88 | t.end() 89 | }) 90 | }) 91 | 92 | test('subscribe to channels with slash in the name', function (t) { 93 | var c = client('app', [`localhost:${port}`]) 94 | 95 | c.subscribe('hello/people').on('data', function (message) { 96 | t.same(message, [1, 2, 3]) 97 | t.end() 98 | c.close() 99 | }).on('open', function () { 100 | c.broadcast('hello/people', [1, 2, 3]) 101 | }) 102 | }) 103 | 104 | test('open emitted with multiple hubs', function (t) { 105 | var c = client('app', [ 106 | `localhost:${port}`, 107 | `localhost:${port}` 108 | ]) 109 | c.subscribe('hello').on('open', function () { 110 | t.ok(true, 'got an open event') 111 | c.close() 112 | t.end() 113 | }) 114 | }) 115 | 116 | test('subscribe to channels with slash in the url', function (t) { 117 | var c = client('app', [`localhost:${port}/foo`]) 118 | 119 | c.subscribe('hello/bar').on('data', function (message) { 120 | t.same(message, [1, 2, 3]) 121 | t.end() 122 | c.close() 123 | }).on('open', function () { 124 | c.broadcast('hello/bar', [1, 2, 3]) 125 | }) 126 | }) 127 | 128 | test('invalid url', function (t) { 129 | t.timeoutAfter(5000) 130 | try { 131 | const invalidUrl = 'ws://invalid_url' 132 | const c = client('app', [invalidUrl]) 133 | c.on('error', (e) => { 134 | t.same(e.url, invalidUrl) 135 | t.end() 136 | }) 137 | } catch (e) { 138 | t.fail() 139 | } 140 | }) 141 | 142 | test('undefined url', function (t) { 143 | t.timeoutAfter(5000) 144 | try { 145 | client('app') 146 | t.fail() 147 | } catch (e) { 148 | t.same(e.message, 'No URL specified') 149 | t.end() 150 | } 151 | }) 152 | 153 | test('empty url list', function (t) { 154 | t.timeoutAfter(5000) 155 | try { 156 | client('app', []) 157 | t.fail() 158 | } catch (e) { 159 | t.same(e.message, 'No URL specified') 160 | t.end() 161 | } 162 | }) 163 | 164 | test('end', function (t) { 165 | server.close() 166 | t.ok(true) 167 | t.end() 168 | }) 169 | } 170 | -------------------------------------------------------------------------------- /tests/browser.test.js: -------------------------------------------------------------------------------- 1 | global.window = {} 2 | window.WebSocket = require('websocket').w3cwebsocket 3 | var test = require('tape') 4 | var macro = require('./boilerplate') 5 | var server = require('../server')() 6 | var browserClient = require('../index') 7 | 8 | var PORT = 9000 9 | server.listen(PORT, () => { 10 | macro(test, server, browserClient, PORT) 11 | }) 12 | -------------------------------------------------------------------------------- /tests/server.test.js: -------------------------------------------------------------------------------- 1 | var test = require('tape') 2 | var macro = require('./boilerplate') 3 | var server = require('../server')() 4 | var browserClient = require('../index') 5 | var serverClient = (app, urls) => browserClient(app, urls, require('websocket').w3cwebsocket) 6 | 7 | var PORT = 9001 8 | server.listen(PORT, () => { 9 | macro(test, server, serverClient, PORT) 10 | }) 11 | -------------------------------------------------------------------------------- /tests/serverws.test.js: -------------------------------------------------------------------------------- 1 | var test = require('tape') 2 | var macro = require('./boilerplate') 3 | var server = require('../server')(require('ws').WebSocketServer) 4 | var browserClient = require('../index') 5 | var serverClient = (app, urls) => browserClient(app, urls, require('websocket').w3cwebsocket) 6 | 7 | var PORT = 9001 8 | server.listen(PORT, () => { 9 | macro(test, server, serverClient, PORT) 10 | }) 11 | --------------------------------------------------------------------------------