├── .gitignore ├── packages ├── automerge-server-test │ ├── .gitignore │ ├── package.json │ ├── index.js │ └── package-lock.json ├── automerge-client-test │ ├── .gitignore │ ├── package.json │ ├── index.js │ ├── package-lock.json │ └── reconnecting-websocket.js ├── automerge-server │ ├── index.js │ ├── package.json │ ├── package-lock.json │ └── main.js └── automerge-client │ ├── index.js │ ├── package.json │ ├── package-lock.json │ └── main.js ├── lerna.json ├── .prettierrc ├── package.json └── LICENSE /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /packages/automerge-server-test/.gitignore: -------------------------------------------------------------------------------- 1 | docs -------------------------------------------------------------------------------- /packages/automerge-client-test/.gitignore: -------------------------------------------------------------------------------- 1 | store.json -------------------------------------------------------------------------------- /lerna.json: -------------------------------------------------------------------------------- 1 | { 2 | "packages": [ 3 | "packages/*" 4 | ], 5 | "version": "0.0.6" 6 | } 7 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "semi": false, 3 | "trailingComma": "all", 4 | "singleQuote": true 5 | } 6 | -------------------------------------------------------------------------------- /packages/automerge-server/index.js: -------------------------------------------------------------------------------- 1 | require = require('esm')(module) 2 | module.exports = require('./main.js') 3 | -------------------------------------------------------------------------------- /packages/automerge-client/index.js: -------------------------------------------------------------------------------- 1 | // this is here to allow importing from nodejs 2 | require = require('esm')(module) 3 | module.exports = require('./main.js') 4 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "root", 3 | "private": true, 4 | "devDependencies": { 5 | "lerna": "^3.3.2" 6 | }, 7 | "scripts": { 8 | "bootstrap": "lerna bootstrap", 9 | "publish": "lerna publish" 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /packages/automerge-client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-client", 3 | "version": "0.0.6", 4 | "description": "Client for automerge-server", 5 | "main": "index.js", 6 | "module": "main.js", 7 | "repository": { 8 | "type": "git", 9 | "url": "git+https://gitlab.com/isabella.skorepova/automerge-client-server.git" 10 | }, 11 | "author": "Isabella Skořepová ", 12 | "license": "MIT", 13 | "bugs": { 14 | "url": "https://gitlab.com/isabella.skorepova/automerge-client-server/issues" 15 | }, 16 | "homepage": "https://gitlab.com/isabella.skorepova/automerge-client-server#readme", 17 | "dependencies": { 18 | "automerge": "^0.8.0", 19 | "esm": "^3.0.82" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /packages/automerge-server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-server", 3 | "version": "0.0.6", 4 | "description": "Websocket server for automerge", 5 | "main": "index.js", 6 | "module": "main.js", 7 | "repository": { 8 | "type": "git", 9 | "url": "git+https://gitlab.com/isabella.skorepova/automerge-client-server.git" 10 | }, 11 | "author": "Isabella Skořepová ", 12 | "license": "MIT", 13 | "bugs": { 14 | "url": "https://gitlab.com/isabella.skorepova/automerge-client-server/issues" 15 | }, 16 | "homepage": "https://gitlab.com/isabella.skorepova/automerge-client-server#readme", 17 | "dependencies": { 18 | "automerge": "^0.8.0", 19 | "esm": "^3.0.82" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /packages/automerge-client-test/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-client-test", 3 | "version": "0.0.6", 4 | "private": true, 5 | "description": "This is only here to test automerge-client. It does not get published to npm.", 6 | "main": "index.js", 7 | "repository": { 8 | "type": "git", 9 | "url": "git+https://gitlab.com/isabella.skorepova/automerge-client-server.git" 10 | }, 11 | "author": "Isabella Skořepová ", 12 | "license": "MIT", 13 | "bugs": { 14 | "url": "https://gitlab.com/isabella.skorepova/automerge-client-server/issues" 15 | }, 16 | "homepage": "https://gitlab.com/isabella.skorepova/automerge-client-server#readme", 17 | "dependencies": { 18 | "automerge": "^0.8.0", 19 | "automerge-client": "^0.0.6", 20 | "universal-websocket-client": "^1.0.2" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /packages/automerge-server-test/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-server-test", 3 | "version": "0.0.6", 4 | "private": true, 5 | "description": "This is only here to test automerge-server. It does not get published to npm.", 6 | "main": "index.js", 7 | "scripts": { 8 | "watch": "nodemon -i docs index.js" 9 | }, 10 | "repository": { 11 | "type": "git", 12 | "url": "git+https://gitlab.com/isabella.skorepova/automerge-client-server.git" 13 | }, 14 | "author": "Isabella Skořepová ", 15 | "license": "MIT", 16 | "bugs": { 17 | "url": "https://gitlab.com/isabella.skorepova/automerge-client-server/issues" 18 | }, 19 | "homepage": "https://gitlab.com/isabella.skorepova/automerge-client-server#readme", 20 | "dependencies": { 21 | "automerge": "^0.8.0", 22 | "automerge-server": "^0.0.6", 23 | "ws": "^6.0.0" 24 | }, 25 | "devDependencies": { 26 | "nodemon": "^2.0.2" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 Isabella Skořepová 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 all 13 | 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 THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /packages/automerge-server-test/index.js: -------------------------------------------------------------------------------- 1 | const AutomergeServer = require('automerge-server').default 2 | const http = require('http') 3 | const WebSocket = require('ws') 4 | const Automerge = require('automerge') 5 | const fs = require('fs') 6 | const path = require('path') 7 | const { promisify } = require('util') 8 | 9 | const dir = path.join(__dirname, 'docs') 10 | try { 11 | fs.mkdirSync(dir) 12 | } catch (e) { 13 | if (e.code !== 'EEXIST') throw e 14 | } 15 | 16 | function fname(id) { 17 | return path.join(dir, id + '.json') 18 | } 19 | 20 | const automergeServer = new AutomergeServer({ 21 | loadDocument: async id => { 22 | if (/^[a-z]+$/.exec(id)) { 23 | try { 24 | return await promisify(fs.readFile)(fname(id), 'utf8') 25 | } catch (e) { 26 | if (e.code === 'ENOENT') return null // create new 27 | return false // 404 28 | } 29 | } 30 | 31 | return Promise.resolve(false) 32 | }, 33 | saveDocument: (id, text) => { 34 | console.log('Saving', id) 35 | if (/[a-z]+/.exec(id)) { 36 | return promisify(fs.writeFile)(fname(id), text, 'utf8') 37 | } 38 | return Promise.resolve() 39 | }, 40 | }) 41 | 42 | const server = http.createServer() 43 | const wss = new WebSocket.Server({ server }) 44 | 45 | wss.on('connection', (ws, req) => { 46 | if (req.url === '/automerge') { 47 | automergeServer.handleSocket(ws, req) 48 | } else { 49 | ws.send('Invalid route') 50 | ws.close() 51 | } 52 | }) 53 | 54 | const PORT = 3000 55 | server.listen(PORT, () => { 56 | console.log(`Listening on http://localhost:${PORT}`) 57 | }) 58 | -------------------------------------------------------------------------------- /packages/automerge-client-test/index.js: -------------------------------------------------------------------------------- 1 | const Automerge = require('automerge') 2 | const AutomergeClient = require('automerge-client').default 3 | const fs = require('fs') 4 | const path = require('path') 5 | const WebSocket = require('./reconnecting-websocket') 6 | 7 | const readline = require('readline') 8 | 9 | const socket = new WebSocket('http://localhost:3000/automerge') 10 | 11 | socket.addEventListener('close', () => { 12 | if (socket._shouldReconnect) socket._connect() 13 | }) 14 | 15 | const storeFile = path.join(__dirname, 'store.json') 16 | const client = new AutomergeClient({ 17 | socket, 18 | savedData: (() => { 19 | try { 20 | return fs.readFileSync(storeFile, 'utf8') 21 | } catch (e) { 22 | return undefined 23 | } 24 | })(), 25 | save: data => fs.writeFile(storeFile, data, 'utf8', () => {}), 26 | }) 27 | 28 | const rl = readline.createInterface({ 29 | input: process.stdin, 30 | output: process.stdout, 31 | }) 32 | 33 | function handleLine() { 34 | rl.question('automerge> ', line => { 35 | const [cmd, ...args] = line.trim().split(/ +/) 36 | console.log(cmd, args) 37 | if (cmd === 'subscribe' || cmd === 's') { 38 | subscribe(args) 39 | } else if (['c', 'ch', 'change'].includes(cmd)) { 40 | change(args) 41 | } else { 42 | console.error('Unknown command "' + cmd + '"') 43 | } 44 | 45 | handleLine() 46 | }) 47 | } 48 | handleLine() 49 | 50 | function subscribe(args) { 51 | client.subscribe(args) 52 | } 53 | 54 | function change(args) { 55 | const ret = client.change(args[0], doc => { 56 | doc[args[1]] = args[2] 57 | }) 58 | if (!ret) { 59 | console.error('Failed to change doc') 60 | } 61 | } 62 | -------------------------------------------------------------------------------- /packages/automerge-client/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-client", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "automerge": { 8 | "version": "0.8.0", 9 | "resolved": "https://registry.npmjs.org/automerge/-/automerge-0.8.0.tgz", 10 | "integrity": "sha512-TB+b+N/VATzQH3hQrzAmTvfyyo04SNUer9ml4M1PRSQ4Bq0OYgclqi3hdYlNG4d/rSWKq897nbkg7gbni7CV2w==", 11 | "requires": { 12 | "immutable": "^3.8.2", 13 | "transit-immutable-js": "^0.7.0", 14 | "transit-js": "^0.8.861", 15 | "uuid": "3.1.0" 16 | } 17 | }, 18 | "esm": { 19 | "version": "3.0.82", 20 | "resolved": "https://registry.npmjs.org/esm/-/esm-3.0.82.tgz", 21 | "integrity": "sha512-vakh2il2Q9QdwCUEiFQqtamOANcGATh5OlMRLaXsvOhuuzr/SXdngYw1rwJjesrljbnsq3+UZ5+3Y3uszc/U/w==" 22 | }, 23 | "immutable": { 24 | "version": "3.8.2", 25 | "resolved": "https://registry.npmjs.org/immutable/-/immutable-3.8.2.tgz", 26 | "integrity": "sha1-wkOZUUVbs5kT2vKBN28VMOEErfM=" 27 | }, 28 | "transit-immutable-js": { 29 | "version": "0.7.0", 30 | "resolved": "https://registry.npmjs.org/transit-immutable-js/-/transit-immutable-js-0.7.0.tgz", 31 | "integrity": "sha1-mT4lCJtjEf9AIUD1VidtbSUwBdk=" 32 | }, 33 | "transit-js": { 34 | "version": "0.8.861", 35 | "resolved": "https://registry.npmjs.org/transit-js/-/transit-js-0.8.861.tgz", 36 | "integrity": "sha512-4O9OrYPZw6C0M5gMTvaeOp+xYz6EF79JsyxIvqXHlt+pisSrioJWFOE80N8aCPoJLcNaXF442RZrVtdmd4wkDQ==" 37 | }, 38 | "uuid": { 39 | "version": "3.1.0", 40 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 41 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 42 | } 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /packages/automerge-server/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-server", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "automerge": { 8 | "version": "0.8.0", 9 | "resolved": "https://registry.npmjs.org/automerge/-/automerge-0.8.0.tgz", 10 | "integrity": "sha512-TB+b+N/VATzQH3hQrzAmTvfyyo04SNUer9ml4M1PRSQ4Bq0OYgclqi3hdYlNG4d/rSWKq897nbkg7gbni7CV2w==", 11 | "requires": { 12 | "immutable": "^3.8.2", 13 | "transit-immutable-js": "^0.7.0", 14 | "transit-js": "^0.8.861", 15 | "uuid": "3.1.0" 16 | } 17 | }, 18 | "esm": { 19 | "version": "3.0.82", 20 | "resolved": "https://registry.npmjs.org/esm/-/esm-3.0.82.tgz", 21 | "integrity": "sha512-vakh2il2Q9QdwCUEiFQqtamOANcGATh5OlMRLaXsvOhuuzr/SXdngYw1rwJjesrljbnsq3+UZ5+3Y3uszc/U/w==" 22 | }, 23 | "immutable": { 24 | "version": "3.8.2", 25 | "resolved": "https://registry.npmjs.org/immutable/-/immutable-3.8.2.tgz", 26 | "integrity": "sha1-wkOZUUVbs5kT2vKBN28VMOEErfM=" 27 | }, 28 | "transit-immutable-js": { 29 | "version": "0.7.0", 30 | "resolved": "https://registry.npmjs.org/transit-immutable-js/-/transit-immutable-js-0.7.0.tgz", 31 | "integrity": "sha1-mT4lCJtjEf9AIUD1VidtbSUwBdk=" 32 | }, 33 | "transit-js": { 34 | "version": "0.8.861", 35 | "resolved": "https://registry.npmjs.org/transit-js/-/transit-js-0.8.861.tgz", 36 | "integrity": "sha512-4O9OrYPZw6C0M5gMTvaeOp+xYz6EF79JsyxIvqXHlt+pisSrioJWFOE80N8aCPoJLcNaXF442RZrVtdmd4wkDQ==" 37 | }, 38 | "uuid": { 39 | "version": "3.1.0", 40 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 41 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 42 | } 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /packages/automerge-client-test/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-client-test", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "async-limiter": { 8 | "version": "1.0.0", 9 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz", 10 | "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg==" 11 | }, 12 | "automerge": { 13 | "version": "0.8.0", 14 | "resolved": "https://registry.npmjs.org/automerge/-/automerge-0.8.0.tgz", 15 | "integrity": "sha512-TB+b+N/VATzQH3hQrzAmTvfyyo04SNUer9ml4M1PRSQ4Bq0OYgclqi3hdYlNG4d/rSWKq897nbkg7gbni7CV2w==", 16 | "requires": { 17 | "immutable": "^3.8.2", 18 | "transit-immutable-js": "^0.7.0", 19 | "transit-js": "^0.8.861", 20 | "uuid": "3.1.0" 21 | } 22 | }, 23 | "immutable": { 24 | "version": "3.8.2", 25 | "resolved": "https://registry.npmjs.org/immutable/-/immutable-3.8.2.tgz", 26 | "integrity": "sha1-wkOZUUVbs5kT2vKBN28VMOEErfM=" 27 | }, 28 | "safe-buffer": { 29 | "version": "5.1.2", 30 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 31 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 32 | }, 33 | "transit-immutable-js": { 34 | "version": "0.7.0", 35 | "resolved": "https://registry.npmjs.org/transit-immutable-js/-/transit-immutable-js-0.7.0.tgz", 36 | "integrity": "sha1-mT4lCJtjEf9AIUD1VidtbSUwBdk=" 37 | }, 38 | "transit-js": { 39 | "version": "0.8.861", 40 | "resolved": "https://registry.npmjs.org/transit-js/-/transit-js-0.8.861.tgz", 41 | "integrity": "sha512-4O9OrYPZw6C0M5gMTvaeOp+xYz6EF79JsyxIvqXHlt+pisSrioJWFOE80N8aCPoJLcNaXF442RZrVtdmd4wkDQ==" 42 | }, 43 | "ultron": { 44 | "version": "1.1.1", 45 | "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.1.1.tgz", 46 | "integrity": "sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og==" 47 | }, 48 | "universal-websocket-client": { 49 | "version": "1.0.2", 50 | "resolved": "https://registry.npmjs.org/universal-websocket-client/-/universal-websocket-client-1.0.2.tgz", 51 | "integrity": "sha512-Pi6BdJtEAISb77GTbOLBLIWdYGezXgnJejrVBYKXxzNTsLcjJS+mWIJ2BRZElSlOG/wc7+yfOe5y30bzTu3Qqg==", 52 | "requires": { 53 | "ws": "^3.3.3" 54 | } 55 | }, 56 | "uuid": { 57 | "version": "3.1.0", 58 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 59 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 60 | }, 61 | "ws": { 62 | "version": "3.3.3", 63 | "resolved": "https://registry.npmjs.org/ws/-/ws-3.3.3.tgz", 64 | "integrity": "sha512-nnWLa/NwZSt4KQJu51MYlCcSQ5g7INpOrOMt4XV8j4dqTXdmlUmSHQ8/oLC069ckre0fRsgfvsKwbTdtKLCDkA==", 65 | "requires": { 66 | "async-limiter": "~1.0.0", 67 | "safe-buffer": "~5.1.0", 68 | "ultron": "~1.1.0" 69 | } 70 | } 71 | } 72 | } 73 | -------------------------------------------------------------------------------- /packages/automerge-client/main.js: -------------------------------------------------------------------------------- 1 | import Automerge, { DocSet } from 'automerge' 2 | 3 | // Returns true if all components of clock1 are less than or equal to those of clock2. 4 | // Returns false if there is at least one component in which clock1 is greater than clock2 5 | // (that is, either clock1 is overall greater than clock2, or the clocks are incomparable). 6 | function lessOrEqual(doc1, doc2) { 7 | const clock1 = doc1._state.getIn(['opSet', 'clock']) 8 | const clock2 = doc2._state.getIn(['opSet', 'clock']) 9 | return clock1 10 | .keySeq() 11 | .concat(clock2.keySeq()) 12 | .reduce( 13 | (result, key) => result && clock1.get(key, 0) <= clock2.get(key, 0), 14 | true, 15 | ) 16 | } 17 | 18 | function unique(el, i, list) { 19 | return list.indexOf(el) === i 20 | } 21 | 22 | function doSave(docs) { 23 | const ret = {} 24 | for (const [k, v] of Object.entries(docs)) { 25 | ret[k] = Automerge.save(v) 26 | } 27 | return JSON.stringify(ret) 28 | } 29 | 30 | function doLoad(string) { 31 | if (!string) return {} 32 | const docs = JSON.parse(string) 33 | const ret = {} 34 | for (const [k, v] of Object.entries(docs)) { 35 | ret[k] = Automerge.load(v) 36 | } 37 | return ret 38 | } 39 | 40 | export default class AutomergeClient { 41 | constructor({ socket, save, savedData, onChange } = {}) { 42 | if (!socket) 43 | throw new Error('You have to specify websocket as socket param') 44 | this.socket = socket 45 | this.save = save 46 | this.docs = doLoad(savedData) 47 | this.onChange = onChange || (() => {}) 48 | this.subscribeList = [] 49 | 50 | socket.addEventListener('message', this.private_onMessage.bind(this)) 51 | socket.addEventListener('open', this.private_onOpen.bind(this)) 52 | socket.addEventListener('close', this.private_onClose.bind(this)) 53 | socket.addEventListener('error', evt => console.log('error', evt)) 54 | socket.addEventListener('connecting', evt => console.log('connecting', evt)) 55 | } 56 | 57 | private_onMessage(msg) { 58 | const frame = JSON.parse(msg.data) 59 | console.log('message', frame) 60 | 61 | if (frame.action === 'automerge') { 62 | this.autocon.receiveMsg(frame.data) 63 | } else if (frame.action === 'error') { 64 | console.error('Recieved server-side error ' + frame.message) 65 | } else if (frame.action === 'subscribed') { 66 | console.error('Subscribed to ' + JSON.stringify(frame.id)) 67 | } else { 68 | console.error('Unknown action "' + frame.action + '"') 69 | } 70 | } 71 | 72 | private_onOpen() { 73 | console.log('open') 74 | const send = data => { 75 | this.socket.send(JSON.stringify({ action: 'automerge', data })) 76 | } 77 | 78 | const docSet = (this.docSet = new DocSet()) 79 | docSet.registerHandler((docId, doc) => { 80 | if (!this.docs[docId] || lessOrEqual(this.docs[docId], doc)) { 81 | // local changes are reflected in new doc 82 | this.docs[docId] = doc 83 | } else { 84 | // local changes are NOT reflected in new doc 85 | const merged = Automerge.merge(this.docs[docId], doc) 86 | setTimeout(() => docSet.setDoc(docId, merged), 0) 87 | } 88 | this.subscribeList = this.subscribeList.filter(el => el !== docId) 89 | 90 | if (this.save) { 91 | this.save(doSave(this.docs)) 92 | } 93 | 94 | this.onChange(docId, this.docs[docId]) 95 | }) 96 | 97 | const autocon = (this.autocon = new Automerge.Connection(docSet, send)) 98 | autocon.open() 99 | this.subscribe(Object.keys(this.docs).concat(this.subscribeList)) 100 | } 101 | 102 | private_onClose() { 103 | console.log('close') 104 | if (this.autocon) { 105 | this.autocon.close() 106 | } 107 | 108 | this.docSet = null 109 | this.autocon = null 110 | } 111 | 112 | change(id, changer) { 113 | if (!(id in this.docs)) { 114 | return false 115 | } 116 | this.docs[id] = Automerge.change(this.docs[id], changer) 117 | if (this.docSet) { 118 | this.docSet.setDoc(id, this.docs[id]) 119 | } 120 | return true 121 | } 122 | 123 | subscribe(ids) { 124 | if (ids.length <= 0) return 125 | console.log('Trying to subscribe to ' + JSON.stringify(ids)) 126 | this.subscribeList = this.subscribeList.concat(ids).filter(unique) 127 | if (this.socket.readyState === 1) { 128 | // OPEN 129 | this.socket.send( 130 | JSON.stringify({ action: 'subscribe', ids: ids.filter(unique) }), 131 | ) 132 | } 133 | } 134 | 135 | unsubscribe(ids) { 136 | if (ids.length <= 0) return 137 | 138 | this.subscribeList = this.subscribeList.filter((value,index) => { 139 | return ids.indexOf(value) == -1 140 | }) 141 | 142 | if (this.socket.readyState === 1) { 143 | // OPEN 144 | this.socket.send( 145 | JSON.stringify({ action: 'unsubscribe', ids: ids.filter(unique) }), 146 | ) 147 | } 148 | } 149 | } 150 | -------------------------------------------------------------------------------- /packages/automerge-server/main.js: -------------------------------------------------------------------------------- 1 | import Automerge, { DocSet } from 'automerge' 2 | 3 | /* 4 | * checkAccess: (id: string, req: Request) => Promise 5 | * loadDocument: (id: string) => Promise 6 | * saveDocument: (id: string, document: string) => Promise 7 | */ 8 | 9 | /* 10 | 11 | # Protocol 12 | 13 | ## Same in both directions 14 | 15 | Object with key action. Other keys depend on action 16 | 17 | ### automerge 18 | 19 | frame.data is forwarded to automerge 20 | 21 | ### error 22 | 23 | prints the error 24 | 25 | ## Client to server 26 | 27 | ### subscribe 28 | 29 | subscribes to documents identified by frame.ids 30 | 31 | ### unsubscribe 32 | 33 | unsubscribes from documents identified by frame.ids 34 | 35 | ## Server to client 36 | 37 | ### subscribed 38 | 39 | Sent after successful subscription. Contains id field as doc identifier. 40 | 41 | */ 42 | 43 | class Document { 44 | constructor(id, onChange) { 45 | this.sets = [] // { set, handler } 46 | this.id = id 47 | this.onChange = onChange 48 | } 49 | 50 | set(doc) { 51 | this.doc = doc 52 | this.onChange(this.id, this.doc) 53 | 54 | for (const set of this.sets) { 55 | set.setDoc(this.id, this.doc) 56 | } 57 | return this 58 | } 59 | 60 | addToSet(docSet) { 61 | if (this.sets.some(set => set.set === docSet)) { 62 | // prevent adding twice 63 | return 64 | } 65 | 66 | docSet.setDoc(this.id, this.doc) 67 | 68 | const handler = (docId, doc) => { 69 | console.log('handler', docId, doc) 70 | if (docId !== this.id) return // not this doc 71 | if (doc === this.doc) return // already handled 72 | this.doc = doc 73 | this.onChange(this.id, this.doc) 74 | 75 | for (const other of this.sets) { 76 | if (other.set === docSet) continue 77 | other.set.setDoc(docId, doc) 78 | } 79 | } 80 | docSet.registerHandler(handler) 81 | this.sets.push({ set: docSet, handler }) 82 | } 83 | 84 | removeFromSet(docSet) { 85 | const set = this.sets.find(set => set.set === docSet) 86 | if (!set) return // this doc is not in specified set 87 | 88 | docSet.unregisterHandler(set.handler) 89 | this.sets = this.sets.filter(set => set.set !== docSet) 90 | } 91 | } 92 | 93 | export default class AutomergeServer { 94 | constructor({ 95 | loadDocument, 96 | saveDocument, 97 | checkAccess = (id, req) => Promise.resolve(true), 98 | }) { 99 | if (typeof loadDocument !== 'function') 100 | throw new Error('loadDocument option must be function') 101 | if (typeof saveDocument !== 'function') 102 | throw new Error('saveDocument option must be function') 103 | 104 | this.loadDocument = loadDocument 105 | this.saveDocument = saveDocument 106 | this.checkAccess = checkAccess 107 | 108 | this.docs = {} 109 | this.onChange = this.onChange.bind(this) 110 | } 111 | 112 | onChange(id, doc) { 113 | this.saveDocument(id, Automerge.save(doc), doc) 114 | } 115 | 116 | getDoc(id) { 117 | if (this.docs[id]) return this.docs[id] 118 | this.docs[id] = Promise.resolve(this.loadDocument(id)) 119 | .then(doc => { 120 | if (doc === false) return false // 404 121 | 122 | // ok 123 | if (typeof doc === 'string') { 124 | // string means loading previously save doc 125 | return Automerge.load(doc) 126 | } 127 | if (!doc) { 128 | // if falsy create new empty document 129 | return Automerge.change(Automerge.init(), doc => { 130 | doc.docId = id 131 | }) 132 | } 133 | // if not falsy nor string we expect automerge document 134 | // created via Automerge.init() 135 | return doc 136 | }) 137 | .then(doc => { 138 | if (doc === false) return false // 404 139 | return new Document(id, this.onChange).set(doc) 140 | }) 141 | return this.docs[id] 142 | } 143 | 144 | handleSocket(ws, req) { 145 | console.log('open') 146 | const docSet = new DocSet() 147 | 148 | docSet.registerHandler((id, doc) => console.log('handler', id, doc)) 149 | 150 | let subscribedDocuments = [] // Document[] 151 | let subscribingDocuments = [] // { id: string, cancel: boolean }[] 152 | const removeFromSubscribedDocuments = id => { 153 | subscribingDocuments = subscribingDocuments.filter(d => d.id !== id) 154 | subscribedDocuments = subscribedDocuments.filter(d => d.id !== id) 155 | } 156 | 157 | const send = (action, data) => 158 | console.log('sending', action, data) || 159 | ws.send(JSON.stringify({ action, ...data })) 160 | 161 | const autocon = new Automerge.Connection(docSet, data => { 162 | send('automerge', { data }) 163 | }) 164 | 165 | const subscribeToDoc = id => { 166 | if ( 167 | subscribingDocuments.some(a => a.id === id) || 168 | subscribedDocuments.some(a => a.id === id) 169 | ) { 170 | send('error', { 171 | message: 'Already subscribed or subscribing', 172 | id, 173 | }) 174 | return 175 | } 176 | subscribingDocuments.push({ id, cancel: false }) 177 | 178 | this.checkAccess(id, req) 179 | .then(access => { 180 | if (access) { 181 | return this.getDoc(id) 182 | } else { 183 | send('error', { 184 | message: 'Access denied', 185 | id, 186 | }) 187 | removeFromSubscribedDocuments(id) 188 | return null 189 | } 190 | }) 191 | .then(doc => { 192 | if (doc === null) return 193 | if (doc === false) { 194 | // 404 195 | send('error', { 196 | message: 'Document not found', 197 | id, 198 | }) 199 | removeFromSubscribedDocuments(id) 200 | } else { 201 | const { cancel } = subscribingDocuments.find(d => d.id === id) 202 | if (!cancel) { 203 | doc.addToSet(docSet) 204 | subscribedDocuments.push(doc) 205 | send('subscribed', { id }) 206 | } 207 | subscribingDocuments = subscribingDocuments.filter(d => d.id !== id) 208 | } 209 | }) 210 | .catch(e => { 211 | removeFromSubscribedDocuments(id) 212 | send('error', { 213 | message: 'Internal server error', 214 | id, 215 | }) 216 | console.error('Error occurred while checking access for ' + id) 217 | console.error(e) 218 | }) 219 | } 220 | 221 | const unsubscribe = id => { 222 | const subscribing = subscribingDocuments.find(d => d.id === id) 223 | if (subscribing) { 224 | subscribing.cancel = true 225 | } else { 226 | const subscribed = subscribedDocuments.find(d => d.id === id) 227 | subscribed.removeFromSet(docSet) 228 | subscribedDocuments = subscribedDocuments.filter(d => d.id !== id) 229 | } 230 | } 231 | 232 | const automergeMessage = data => { 233 | console.log(data) 234 | if (subscribedDocuments.some(doc => doc.id === data.docId)) { 235 | autocon.receiveMsg(data) 236 | } else { 237 | send('error', { 238 | message: 'Sending changes to doc which you are not subscribed to', 239 | }) 240 | } 241 | } 242 | 243 | const handleFrame = frame => { 244 | console.log('handling', frame) 245 | if (frame.action === 'automerge') { 246 | automergeMessage(frame.data) 247 | } else if (frame.action === 'error') { 248 | console.error('Recieved error frame from client', frame) 249 | } else if (frame.action === 'subscribe') { 250 | frame.ids.forEach(id => subscribeToDoc(id)) 251 | } else if (frame.action === 'unsubscribe') { 252 | frame.ids.forEach(id => unsubscribe(id)) 253 | } else { 254 | send('error', { 255 | message: 'Unknown action ' + frame.action, 256 | }) 257 | } 258 | } 259 | 260 | ws.on('message', message => { 261 | try { 262 | const frame = JSON.parse(message.toString()) 263 | if (typeof frame === 'object' && frame !== null) { 264 | handleFrame(frame) 265 | } 266 | } catch (e) { 267 | console.error(e) 268 | } 269 | }) 270 | 271 | autocon.open() 272 | 273 | ws.on('close', () => { 274 | console.log('close') 275 | autocon.close() 276 | subscribedDocuments.forEach(doc => doc.removeFromSet(docSet)) 277 | }) 278 | } 279 | } 280 | -------------------------------------------------------------------------------- /packages/automerge-client-test/reconnecting-websocket.js: -------------------------------------------------------------------------------- 1 | // MIT License: 2 | // 3 | // Copyright (c) 2010-2012, Joe Walnes 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 | 23 | // Originally from https://github.com/joewalnes/reconnecting-websocket/blob/master/reconnecting-websocket.js 24 | // modified to use universal-websocket-client 25 | 26 | /* 27 | I also removed browser-only CustomEvent and replace EventTarget with simple 28 | custom implementation. This makes this *not* drop-in replacement for WebSocket 29 | but since automerge-client-test is only consumer of this I don't care :-) 30 | */ 31 | 32 | const WebSocket = require('universal-websocket-client') 33 | 34 | class EventTarget { 35 | constructor() { 36 | this.listeners = {} 37 | } 38 | 39 | addEventListener(type, listener) { 40 | if (!this.listeners[type]) this.listeners[type] = [] 41 | this.listeners[type].push(listener) 42 | } 43 | 44 | removeEventListener(type, listener) { 45 | if (!this.listeners[type]) return 46 | this.listeners[type] = this.listeners[type].filter(l => l !== listener) 47 | } 48 | 49 | dispatchEvent(event) { 50 | const l = this.listeners[event.type] || [] 51 | l.forEach(handler => handler(event)) 52 | } 53 | } 54 | 55 | function ReconnectingWebSocket(url, protocols, options) { 56 | // Default settings 57 | var settings = { 58 | /** Whether this instance should log debug messages. */ 59 | debug: false, 60 | 61 | /** Whether or not the websocket should attempt to connect immediately upon instantiation. */ 62 | automaticOpen: true, 63 | 64 | /** The number of milliseconds to delay before attempting to reconnect. */ 65 | reconnectInterval: 1000, 66 | /** The maximum number of milliseconds to delay a reconnection attempt. */ 67 | maxReconnectInterval: 30000, 68 | /** The rate of increase of the reconnect delay. Allows reconnect attempts to back off when problems persist. */ 69 | reconnectDecay: 1.5, 70 | 71 | /** The maximum time in milliseconds to wait for a connection to succeed before closing and retrying. */ 72 | timeoutInterval: 2000, 73 | 74 | /** The maximum number of reconnection attempts to make. Unlimited if null. */ 75 | maxReconnectAttempts: null, 76 | 77 | /** The binary type, possible values 'blob' or 'arraybuffer', default 'blob'. */ 78 | binaryType: 'blob', 79 | } 80 | if (!options) { 81 | options = {} 82 | } 83 | 84 | // Overwrite and define settings with options if they exist. 85 | for (var key in settings) { 86 | if (typeof options[key] !== 'undefined') { 87 | this[key] = options[key] 88 | } else { 89 | this[key] = settings[key] 90 | } 91 | } 92 | 93 | // These should be treated as read-only properties 94 | 95 | /** The URL as resolved by the constructor. This is always an absolute URL. Read only. */ 96 | this.url = url 97 | 98 | /** The number of attempted reconnects since starting, or the last successful connection. Read only. */ 99 | this.reconnectAttempts = 0 100 | 101 | /** 102 | * The current state of the connection. 103 | * Can be one of: WebSocket.CONNECTING, WebSocket.OPEN, WebSocket.CLOSING, WebSocket.CLOSED 104 | * Read only. 105 | */ 106 | this.readyState = WebSocket.CONNECTING 107 | 108 | /** 109 | * A string indicating the name of the sub-protocol the server selected; this will be one of 110 | * the strings specified in the protocols parameter when creating the WebSocket object. 111 | * Read only. 112 | */ 113 | this.protocol = null 114 | 115 | // Private state variables 116 | 117 | var self = this 118 | var ws 119 | var forcedClose = false 120 | var timedOut = false 121 | var eventTarget = new EventTarget() 122 | 123 | // Wire up "on*" properties as event handlers 124 | 125 | eventTarget.addEventListener('open', function(event) { 126 | self.onopen(event) 127 | }) 128 | eventTarget.addEventListener('close', function(event) { 129 | self.onclose(event) 130 | }) 131 | eventTarget.addEventListener('connecting', function(event) { 132 | self.onconnecting(event) 133 | }) 134 | eventTarget.addEventListener('message', function(event) { 135 | self.onmessage(event) 136 | }) 137 | eventTarget.addEventListener('error', function(event) { 138 | self.onerror(event) 139 | }) 140 | 141 | // Expose the API required by EventTarget 142 | 143 | this.addEventListener = eventTarget.addEventListener.bind(eventTarget) 144 | this.removeEventListener = eventTarget.removeEventListener.bind(eventTarget) 145 | this.dispatchEvent = eventTarget.dispatchEvent.bind(eventTarget) 146 | 147 | this.open = function(reconnectAttempt) { 148 | ws = new WebSocket(self.url, protocols || []) 149 | ws.binaryType = this.binaryType 150 | 151 | if (reconnectAttempt) { 152 | if ( 153 | this.maxReconnectAttempts && 154 | this.reconnectAttempts > this.maxReconnectAttempts 155 | ) { 156 | return 157 | } 158 | } else { 159 | eventTarget.dispatchEvent({ type: 'connecting' }) 160 | this.reconnectAttempts = 0 161 | } 162 | 163 | if (self.debug || ReconnectingWebSocket.debugAll) { 164 | console.debug('ReconnectingWebSocket', 'attempt-connect', self.url) 165 | } 166 | 167 | var localWs = ws 168 | var timeout = setTimeout(function() { 169 | if (self.debug || ReconnectingWebSocket.debugAll) { 170 | console.debug('ReconnectingWebSocket', 'connection-timeout', self.url) 171 | } 172 | timedOut = true 173 | localWs.close() 174 | timedOut = false 175 | }, self.timeoutInterval) 176 | 177 | ws.onopen = function(event) { 178 | clearTimeout(timeout) 179 | if (self.debug || ReconnectingWebSocket.debugAll) { 180 | console.debug('ReconnectingWebSocket', 'onopen', self.url) 181 | } 182 | self.protocol = ws.protocol 183 | self.readyState = WebSocket.OPEN 184 | self.reconnectAttempts = 0 185 | var e = { type: 'open' } 186 | e.isReconnect = reconnectAttempt 187 | reconnectAttempt = false 188 | eventTarget.dispatchEvent(e) 189 | } 190 | 191 | ws.onclose = function(event) { 192 | clearTimeout(timeout) 193 | ws = null 194 | if (forcedClose) { 195 | self.readyState = WebSocket.CLOSED 196 | eventTarget.dispatchEvent({ type: 'close' }) 197 | } else { 198 | self.readyState = WebSocket.CONNECTING 199 | var e = { type: 'connecting' } 200 | e.code = event.code 201 | e.reason = event.reason 202 | e.wasClean = event.wasClean 203 | eventTarget.dispatchEvent(e) 204 | if (!reconnectAttempt && !timedOut) { 205 | if (self.debug || ReconnectingWebSocket.debugAll) { 206 | console.debug('ReconnectingWebSocket', 'onclose', self.url) 207 | } 208 | eventTarget.dispatchEvent({ type: 'close' }) 209 | } 210 | 211 | var timeout = 212 | self.reconnectInterval * 213 | Math.pow(self.reconnectDecay, self.reconnectAttempts) 214 | setTimeout(function() { 215 | self.reconnectAttempts++ 216 | self.open(true) 217 | }, timeout > self.maxReconnectInterval 218 | ? self.maxReconnectInterval 219 | : timeout) 220 | } 221 | } 222 | ws.onmessage = function(event) { 223 | if (self.debug || ReconnectingWebSocket.debugAll) { 224 | console.debug( 225 | 'ReconnectingWebSocket', 226 | 'onmessage', 227 | self.url, 228 | event.data, 229 | ) 230 | } 231 | var e = { type: 'message' } 232 | e.data = event.data 233 | eventTarget.dispatchEvent(e) 234 | } 235 | ws.onerror = function(event) { 236 | if (self.debug || ReconnectingWebSocket.debugAll) { 237 | console.debug('ReconnectingWebSocket', 'onerror', self.url, event) 238 | } 239 | eventTarget.dispatchEvent({ type: 'error' }) 240 | } 241 | } 242 | 243 | // Whether or not to create a websocket upon instantiation 244 | if (this.automaticOpen == true) { 245 | this.open(false) 246 | } 247 | 248 | /** 249 | * Transmits data to the server over the WebSocket connection. 250 | * 251 | * @param data a text string, ArrayBuffer or Blob to send to the server. 252 | */ 253 | this.send = function(data) { 254 | if (ws) { 255 | if (self.debug || ReconnectingWebSocket.debugAll) { 256 | console.debug('ReconnectingWebSocket', 'send', self.url, data) 257 | } 258 | return ws.send(data) 259 | } else { 260 | throw 'INVALID_STATE_ERR : Pausing to reconnect websocket' 261 | } 262 | } 263 | 264 | /** 265 | * Closes the WebSocket connection or connection attempt, if any. 266 | * If the connection is already CLOSED, this method does nothing. 267 | */ 268 | this.close = function(code, reason) { 269 | // Default CLOSE_NORMAL code 270 | if (typeof code == 'undefined') { 271 | code = 1000 272 | } 273 | forcedClose = true 274 | if (ws) { 275 | ws.close(code, reason) 276 | } 277 | } 278 | 279 | /** 280 | * Additional public API method to refresh the connection if still open (close, re-open). 281 | * For example, if the app suspects bad data / missed heart beats, it can try to refresh. 282 | */ 283 | this.refresh = function() { 284 | if (ws) { 285 | ws.close() 286 | } 287 | } 288 | } 289 | 290 | /** 291 | * An event listener to be called when the WebSocket connection's readyState changes to OPEN; 292 | * this indicates that the connection is ready to send and receive data. 293 | */ 294 | ReconnectingWebSocket.prototype.onopen = function(event) {} 295 | /** An event listener to be called when the WebSocket connection's readyState changes to CLOSED. */ 296 | ReconnectingWebSocket.prototype.onclose = function(event) {} 297 | /** An event listener to be called when a connection begins being attempted. */ 298 | ReconnectingWebSocket.prototype.onconnecting = function(event) {} 299 | /** An event listener to be called when a message is received from the server. */ 300 | ReconnectingWebSocket.prototype.onmessage = function(event) {} 301 | /** An event listener to be called when an error occurs. */ 302 | ReconnectingWebSocket.prototype.onerror = function(event) {} 303 | 304 | /** 305 | * Whether all instances of ReconnectingWebSocket should log debug messages. 306 | * Setting this to true is the equivalent of setting all instances of ReconnectingWebSocket.debug to true. 307 | */ 308 | ReconnectingWebSocket.debugAll = false 309 | 310 | ReconnectingWebSocket.CONNECTING = WebSocket.CONNECTING 311 | ReconnectingWebSocket.OPEN = WebSocket.OPEN 312 | ReconnectingWebSocket.CLOSING = WebSocket.CLOSING 313 | ReconnectingWebSocket.CLOSED = WebSocket.CLOSED 314 | 315 | module.exports = ReconnectingWebSocket 316 | -------------------------------------------------------------------------------- /packages/automerge-server-test/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "automerge-server-test", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abbrev": { 8 | "version": "1.1.1", 9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 11 | "dev": true 12 | }, 13 | "ansi-align": { 14 | "version": "2.0.0", 15 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz", 16 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=", 17 | "dev": true, 18 | "requires": { 19 | "string-width": "^2.0.0" 20 | } 21 | }, 22 | "ansi-regex": { 23 | "version": "3.0.0", 24 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 25 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 26 | "dev": true 27 | }, 28 | "ansi-styles": { 29 | "version": "3.2.1", 30 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 31 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 32 | "dev": true, 33 | "requires": { 34 | "color-convert": "^1.9.0" 35 | } 36 | }, 37 | "anymatch": { 38 | "version": "2.0.0", 39 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", 40 | "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", 41 | "dev": true, 42 | "requires": { 43 | "micromatch": "^3.1.4", 44 | "normalize-path": "^2.1.1" 45 | } 46 | }, 47 | "arr-diff": { 48 | "version": "4.0.0", 49 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", 50 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", 51 | "dev": true 52 | }, 53 | "arr-flatten": { 54 | "version": "1.1.0", 55 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 56 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 57 | "dev": true 58 | }, 59 | "arr-union": { 60 | "version": "3.1.0", 61 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", 62 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", 63 | "dev": true 64 | }, 65 | "array-unique": { 66 | "version": "0.3.2", 67 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", 68 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", 69 | "dev": true 70 | }, 71 | "assign-symbols": { 72 | "version": "1.0.0", 73 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", 74 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", 75 | "dev": true 76 | }, 77 | "async-each": { 78 | "version": "1.0.1", 79 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 80 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", 81 | "dev": true 82 | }, 83 | "async-limiter": { 84 | "version": "1.0.0", 85 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.0.tgz", 86 | "integrity": "sha512-jp/uFnooOiO+L211eZOoSyzpOITMXx1rBITauYykG3BRYPu8h0UcxsPNB04RR5vo4Tyz3+ay17tR6JVf9qzYWg==" 87 | }, 88 | "atob": { 89 | "version": "2.1.2", 90 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", 91 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", 92 | "dev": true 93 | }, 94 | "automerge": { 95 | "version": "0.8.0", 96 | "resolved": "https://registry.npmjs.org/automerge/-/automerge-0.8.0.tgz", 97 | "integrity": "sha512-TB+b+N/VATzQH3hQrzAmTvfyyo04SNUer9ml4M1PRSQ4Bq0OYgclqi3hdYlNG4d/rSWKq897nbkg7gbni7CV2w==", 98 | "requires": { 99 | "immutable": "^3.8.2", 100 | "transit-immutable-js": "^0.7.0", 101 | "transit-js": "^0.8.861", 102 | "uuid": "3.1.0" 103 | } 104 | }, 105 | "balanced-match": { 106 | "version": "1.0.0", 107 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 108 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 109 | "dev": true 110 | }, 111 | "base": { 112 | "version": "0.11.2", 113 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", 114 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", 115 | "dev": true, 116 | "requires": { 117 | "cache-base": "^1.0.1", 118 | "class-utils": "^0.3.5", 119 | "component-emitter": "^1.2.1", 120 | "define-property": "^1.0.0", 121 | "isobject": "^3.0.1", 122 | "mixin-deep": "^1.2.0", 123 | "pascalcase": "^0.1.1" 124 | }, 125 | "dependencies": { 126 | "define-property": { 127 | "version": "1.0.0", 128 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 129 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 130 | "dev": true, 131 | "requires": { 132 | "is-descriptor": "^1.0.0" 133 | } 134 | }, 135 | "is-accessor-descriptor": { 136 | "version": "1.0.0", 137 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 138 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 139 | "dev": true, 140 | "requires": { 141 | "kind-of": "^6.0.0" 142 | } 143 | }, 144 | "is-data-descriptor": { 145 | "version": "1.0.0", 146 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 147 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 148 | "dev": true, 149 | "requires": { 150 | "kind-of": "^6.0.0" 151 | } 152 | }, 153 | "is-descriptor": { 154 | "version": "1.0.2", 155 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 156 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 157 | "dev": true, 158 | "requires": { 159 | "is-accessor-descriptor": "^1.0.0", 160 | "is-data-descriptor": "^1.0.0", 161 | "kind-of": "^6.0.2" 162 | } 163 | } 164 | } 165 | }, 166 | "binary-extensions": { 167 | "version": "1.11.0", 168 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.11.0.tgz", 169 | "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=", 170 | "dev": true 171 | }, 172 | "boxen": { 173 | "version": "1.3.0", 174 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.3.0.tgz", 175 | "integrity": "sha512-TNPjfTr432qx7yOjQyaXm3dSR0MH9vXp7eT1BFSl/C51g+EFnOR9hTg1IreahGBmDNCehscshe45f+C1TBZbLw==", 176 | "dev": true, 177 | "requires": { 178 | "ansi-align": "^2.0.0", 179 | "camelcase": "^4.0.0", 180 | "chalk": "^2.0.1", 181 | "cli-boxes": "^1.0.0", 182 | "string-width": "^2.0.0", 183 | "term-size": "^1.2.0", 184 | "widest-line": "^2.0.0" 185 | } 186 | }, 187 | "brace-expansion": { 188 | "version": "1.1.11", 189 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 190 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 191 | "dev": true, 192 | "requires": { 193 | "balanced-match": "^1.0.0", 194 | "concat-map": "0.0.1" 195 | } 196 | }, 197 | "braces": { 198 | "version": "2.3.2", 199 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", 200 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", 201 | "dev": true, 202 | "requires": { 203 | "arr-flatten": "^1.1.0", 204 | "array-unique": "^0.3.2", 205 | "extend-shallow": "^2.0.1", 206 | "fill-range": "^4.0.0", 207 | "isobject": "^3.0.1", 208 | "repeat-element": "^1.1.2", 209 | "snapdragon": "^0.8.1", 210 | "snapdragon-node": "^2.0.1", 211 | "split-string": "^3.0.2", 212 | "to-regex": "^3.0.1" 213 | }, 214 | "dependencies": { 215 | "extend-shallow": { 216 | "version": "2.0.1", 217 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 218 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 219 | "dev": true, 220 | "requires": { 221 | "is-extendable": "^0.1.0" 222 | } 223 | } 224 | } 225 | }, 226 | "cache-base": { 227 | "version": "1.0.1", 228 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", 229 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", 230 | "dev": true, 231 | "requires": { 232 | "collection-visit": "^1.0.0", 233 | "component-emitter": "^1.2.1", 234 | "get-value": "^2.0.6", 235 | "has-value": "^1.0.0", 236 | "isobject": "^3.0.1", 237 | "set-value": "^2.0.0", 238 | "to-object-path": "^0.3.0", 239 | "union-value": "^1.0.0", 240 | "unset-value": "^1.0.0" 241 | } 242 | }, 243 | "camelcase": { 244 | "version": "4.1.0", 245 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 246 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", 247 | "dev": true 248 | }, 249 | "capture-stack-trace": { 250 | "version": "1.0.1", 251 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.1.tgz", 252 | "integrity": "sha512-mYQLZnx5Qt1JgB1WEiMCf2647plpGeQ2NMR/5L0HNZzGQo4fuSPnK+wjfPnKZV0aiJDgzmWqqkV/g7JD+DW0qw==", 253 | "dev": true 254 | }, 255 | "chalk": { 256 | "version": "2.4.1", 257 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 258 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 259 | "dev": true, 260 | "requires": { 261 | "ansi-styles": "^3.2.1", 262 | "escape-string-regexp": "^1.0.5", 263 | "supports-color": "^5.3.0" 264 | } 265 | }, 266 | "chokidar": { 267 | "version": "2.0.4", 268 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.0.4.tgz", 269 | "integrity": "sha512-z9n7yt9rOvIJrMhvDtDictKrkFHeihkNl6uWMmZlmL6tJtX9Cs+87oK+teBx+JIgzvbX3yZHT3eF8vpbDxHJXQ==", 270 | "dev": true, 271 | "requires": { 272 | "anymatch": "^2.0.0", 273 | "async-each": "^1.0.0", 274 | "braces": "^2.3.0", 275 | "fsevents": "^1.2.2", 276 | "glob-parent": "^3.1.0", 277 | "inherits": "^2.0.1", 278 | "is-binary-path": "^1.0.0", 279 | "is-glob": "^4.0.0", 280 | "lodash.debounce": "^4.0.8", 281 | "normalize-path": "^2.1.1", 282 | "path-is-absolute": "^1.0.0", 283 | "readdirp": "^2.0.0", 284 | "upath": "^1.0.5" 285 | } 286 | }, 287 | "ci-info": { 288 | "version": "1.5.1", 289 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.5.1.tgz", 290 | "integrity": "sha512-fKFIKXaYiL1exImwJ0AhR/6jxFPSKQBk2ayV5NiNoruUs2+rxC2kNw0EG+1Z9dugZRdCrppskQ8DN2cyaUM1Hw==", 291 | "dev": true 292 | }, 293 | "class-utils": { 294 | "version": "0.3.6", 295 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", 296 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", 297 | "dev": true, 298 | "requires": { 299 | "arr-union": "^3.1.0", 300 | "define-property": "^0.2.5", 301 | "isobject": "^3.0.0", 302 | "static-extend": "^0.1.1" 303 | }, 304 | "dependencies": { 305 | "define-property": { 306 | "version": "0.2.5", 307 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 308 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 309 | "dev": true, 310 | "requires": { 311 | "is-descriptor": "^0.1.0" 312 | } 313 | } 314 | } 315 | }, 316 | "cli-boxes": { 317 | "version": "1.0.0", 318 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz", 319 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=", 320 | "dev": true 321 | }, 322 | "collection-visit": { 323 | "version": "1.0.0", 324 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", 325 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", 326 | "dev": true, 327 | "requires": { 328 | "map-visit": "^1.0.0", 329 | "object-visit": "^1.0.0" 330 | } 331 | }, 332 | "color-convert": { 333 | "version": "1.9.3", 334 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 335 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 336 | "dev": true, 337 | "requires": { 338 | "color-name": "1.1.3" 339 | } 340 | }, 341 | "color-name": { 342 | "version": "1.1.3", 343 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 344 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 345 | "dev": true 346 | }, 347 | "component-emitter": { 348 | "version": "1.2.1", 349 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 350 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", 351 | "dev": true 352 | }, 353 | "concat-map": { 354 | "version": "0.0.1", 355 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 356 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 357 | "dev": true 358 | }, 359 | "configstore": { 360 | "version": "3.1.2", 361 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.2.tgz", 362 | "integrity": "sha512-vtv5HtGjcYUgFrXc6Kx747B83MRRVS5R1VTEQoXvuP+kMI+if6uywV0nDGoiydJRy4yk7h9od5Og0kxx4zUXmw==", 363 | "dev": true, 364 | "requires": { 365 | "dot-prop": "^4.1.0", 366 | "graceful-fs": "^4.1.2", 367 | "make-dir": "^1.0.0", 368 | "unique-string": "^1.0.0", 369 | "write-file-atomic": "^2.0.0", 370 | "xdg-basedir": "^3.0.0" 371 | } 372 | }, 373 | "copy-descriptor": { 374 | "version": "0.1.1", 375 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", 376 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", 377 | "dev": true 378 | }, 379 | "core-util-is": { 380 | "version": "1.0.2", 381 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 382 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 383 | "dev": true 384 | }, 385 | "create-error-class": { 386 | "version": "3.0.2", 387 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz", 388 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=", 389 | "dev": true, 390 | "requires": { 391 | "capture-stack-trace": "^1.0.0" 392 | } 393 | }, 394 | "cross-spawn": { 395 | "version": "5.1.0", 396 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 397 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 398 | "dev": true, 399 | "requires": { 400 | "lru-cache": "^4.0.1", 401 | "shebang-command": "^1.2.0", 402 | "which": "^1.2.9" 403 | } 404 | }, 405 | "crypto-random-string": { 406 | "version": "1.0.0", 407 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz", 408 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=", 409 | "dev": true 410 | }, 411 | "debug": { 412 | "version": "3.2.5", 413 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.5.tgz", 414 | "integrity": "sha512-D61LaDQPQkxJ5AUM2mbSJRbPkNs/TmdmOeLAi1hgDkpDfIfetSrjmWhccwtuResSwMbACjx/xXQofvM9CE/aeg==", 415 | "dev": true, 416 | "requires": { 417 | "ms": "^2.1.1" 418 | }, 419 | "dependencies": { 420 | "ms": { 421 | "version": "2.1.1", 422 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 423 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 424 | "dev": true 425 | } 426 | } 427 | }, 428 | "decode-uri-component": { 429 | "version": "0.2.0", 430 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", 431 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", 432 | "dev": true 433 | }, 434 | "deep-extend": { 435 | "version": "0.6.0", 436 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 437 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 438 | "dev": true 439 | }, 440 | "define-property": { 441 | "version": "2.0.2", 442 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", 443 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", 444 | "dev": true, 445 | "requires": { 446 | "is-descriptor": "^1.0.2", 447 | "isobject": "^3.0.1" 448 | }, 449 | "dependencies": { 450 | "is-accessor-descriptor": { 451 | "version": "1.0.0", 452 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 453 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 454 | "dev": true, 455 | "requires": { 456 | "kind-of": "^6.0.0" 457 | } 458 | }, 459 | "is-data-descriptor": { 460 | "version": "1.0.0", 461 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 462 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 463 | "dev": true, 464 | "requires": { 465 | "kind-of": "^6.0.0" 466 | } 467 | }, 468 | "is-descriptor": { 469 | "version": "1.0.2", 470 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 471 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 472 | "dev": true, 473 | "requires": { 474 | "is-accessor-descriptor": "^1.0.0", 475 | "is-data-descriptor": "^1.0.0", 476 | "kind-of": "^6.0.2" 477 | } 478 | } 479 | } 480 | }, 481 | "dot-prop": { 482 | "version": "4.2.0", 483 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", 484 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", 485 | "dev": true, 486 | "requires": { 487 | "is-obj": "^1.0.0" 488 | } 489 | }, 490 | "duplexer": { 491 | "version": "0.1.1", 492 | "resolved": "http://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 493 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", 494 | "dev": true 495 | }, 496 | "duplexer3": { 497 | "version": "0.1.4", 498 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 499 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 500 | "dev": true 501 | }, 502 | "escape-string-regexp": { 503 | "version": "1.0.5", 504 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 505 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 506 | "dev": true 507 | }, 508 | "event-stream": { 509 | "version": "3.3.6", 510 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.6.tgz", 511 | "integrity": "sha512-dGXNg4F/FgVzlApjzItL+7naHutA3fDqbV/zAZqDDlXTjiMnQmZKu+prImWKszeBM5UQeGvAl3u1wBiKeDh61g==", 512 | "dev": true, 513 | "requires": { 514 | "duplexer": "^0.1.1", 515 | "flatmap-stream": "^0.1.0", 516 | "from": "^0.1.7", 517 | "map-stream": "0.0.7", 518 | "pause-stream": "^0.0.11", 519 | "split": "^1.0.1", 520 | "stream-combiner": "^0.2.2", 521 | "through": "^2.3.8" 522 | } 523 | }, 524 | "execa": { 525 | "version": "0.7.0", 526 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 527 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 528 | "dev": true, 529 | "requires": { 530 | "cross-spawn": "^5.0.1", 531 | "get-stream": "^3.0.0", 532 | "is-stream": "^1.1.0", 533 | "npm-run-path": "^2.0.0", 534 | "p-finally": "^1.0.0", 535 | "signal-exit": "^3.0.0", 536 | "strip-eof": "^1.0.0" 537 | } 538 | }, 539 | "expand-brackets": { 540 | "version": "2.1.4", 541 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", 542 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", 543 | "dev": true, 544 | "requires": { 545 | "debug": "^2.3.3", 546 | "define-property": "^0.2.5", 547 | "extend-shallow": "^2.0.1", 548 | "posix-character-classes": "^0.1.0", 549 | "regex-not": "^1.0.0", 550 | "snapdragon": "^0.8.1", 551 | "to-regex": "^3.0.1" 552 | }, 553 | "dependencies": { 554 | "debug": { 555 | "version": "2.6.9", 556 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 557 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 558 | "dev": true, 559 | "requires": { 560 | "ms": "2.0.0" 561 | } 562 | }, 563 | "define-property": { 564 | "version": "0.2.5", 565 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 566 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 567 | "dev": true, 568 | "requires": { 569 | "is-descriptor": "^0.1.0" 570 | } 571 | }, 572 | "extend-shallow": { 573 | "version": "2.0.1", 574 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 575 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 576 | "dev": true, 577 | "requires": { 578 | "is-extendable": "^0.1.0" 579 | } 580 | } 581 | } 582 | }, 583 | "extend-shallow": { 584 | "version": "3.0.2", 585 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", 586 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", 587 | "dev": true, 588 | "requires": { 589 | "assign-symbols": "^1.0.0", 590 | "is-extendable": "^1.0.1" 591 | }, 592 | "dependencies": { 593 | "is-extendable": { 594 | "version": "1.0.1", 595 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 596 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 597 | "dev": true, 598 | "requires": { 599 | "is-plain-object": "^2.0.4" 600 | } 601 | } 602 | } 603 | }, 604 | "extglob": { 605 | "version": "2.0.4", 606 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", 607 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", 608 | "dev": true, 609 | "requires": { 610 | "array-unique": "^0.3.2", 611 | "define-property": "^1.0.0", 612 | "expand-brackets": "^2.1.4", 613 | "extend-shallow": "^2.0.1", 614 | "fragment-cache": "^0.2.1", 615 | "regex-not": "^1.0.0", 616 | "snapdragon": "^0.8.1", 617 | "to-regex": "^3.0.1" 618 | }, 619 | "dependencies": { 620 | "define-property": { 621 | "version": "1.0.0", 622 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 623 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 624 | "dev": true, 625 | "requires": { 626 | "is-descriptor": "^1.0.0" 627 | } 628 | }, 629 | "extend-shallow": { 630 | "version": "2.0.1", 631 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 632 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 633 | "dev": true, 634 | "requires": { 635 | "is-extendable": "^0.1.0" 636 | } 637 | }, 638 | "is-accessor-descriptor": { 639 | "version": "1.0.0", 640 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 641 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 642 | "dev": true, 643 | "requires": { 644 | "kind-of": "^6.0.0" 645 | } 646 | }, 647 | "is-data-descriptor": { 648 | "version": "1.0.0", 649 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 650 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 651 | "dev": true, 652 | "requires": { 653 | "kind-of": "^6.0.0" 654 | } 655 | }, 656 | "is-descriptor": { 657 | "version": "1.0.2", 658 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 659 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 660 | "dev": true, 661 | "requires": { 662 | "is-accessor-descriptor": "^1.0.0", 663 | "is-data-descriptor": "^1.0.0", 664 | "kind-of": "^6.0.2" 665 | } 666 | } 667 | } 668 | }, 669 | "fill-range": { 670 | "version": "4.0.0", 671 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", 672 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", 673 | "dev": true, 674 | "requires": { 675 | "extend-shallow": "^2.0.1", 676 | "is-number": "^3.0.0", 677 | "repeat-string": "^1.6.1", 678 | "to-regex-range": "^2.1.0" 679 | }, 680 | "dependencies": { 681 | "extend-shallow": { 682 | "version": "2.0.1", 683 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 684 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 685 | "dev": true, 686 | "requires": { 687 | "is-extendable": "^0.1.0" 688 | } 689 | } 690 | } 691 | }, 692 | "flatmap-stream": { 693 | "version": "0.1.0", 694 | "resolved": "https://registry.npmjs.org/flatmap-stream/-/flatmap-stream-0.1.0.tgz", 695 | "integrity": "sha512-Nlic4ZRYxikqnK5rj3YoxDVKGGtUjcNDUtvQ7XsdGLZmMwdUYnXf10o1zcXtzEZTBgc6GxeRpQxV/Wu3WPIIHA==", 696 | "dev": true 697 | }, 698 | "for-in": { 699 | "version": "1.0.2", 700 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 701 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 702 | "dev": true 703 | }, 704 | "fragment-cache": { 705 | "version": "0.2.1", 706 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", 707 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", 708 | "dev": true, 709 | "requires": { 710 | "map-cache": "^0.2.2" 711 | } 712 | }, 713 | "from": { 714 | "version": "0.1.7", 715 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 716 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=", 717 | "dev": true 718 | }, 719 | "fsevents": { 720 | "version": "1.2.4", 721 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz", 722 | "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", 723 | "dev": true, 724 | "optional": true, 725 | "requires": { 726 | "nan": "^2.9.2", 727 | "node-pre-gyp": "^0.10.0" 728 | }, 729 | "dependencies": { 730 | "abbrev": { 731 | "version": "1.1.1", 732 | "bundled": true, 733 | "dev": true, 734 | "optional": true 735 | }, 736 | "ansi-regex": { 737 | "version": "2.1.1", 738 | "bundled": true, 739 | "dev": true 740 | }, 741 | "aproba": { 742 | "version": "1.2.0", 743 | "bundled": true, 744 | "dev": true, 745 | "optional": true 746 | }, 747 | "are-we-there-yet": { 748 | "version": "1.1.4", 749 | "bundled": true, 750 | "dev": true, 751 | "optional": true, 752 | "requires": { 753 | "delegates": "^1.0.0", 754 | "readable-stream": "^2.0.6" 755 | } 756 | }, 757 | "balanced-match": { 758 | "version": "1.0.0", 759 | "bundled": true, 760 | "dev": true, 761 | "optional": true 762 | }, 763 | "brace-expansion": { 764 | "version": "1.1.11", 765 | "bundled": true, 766 | "dev": true, 767 | "optional": true, 768 | "requires": { 769 | "balanced-match": "^1.0.0", 770 | "concat-map": "0.0.1" 771 | } 772 | }, 773 | "chownr": { 774 | "version": "1.0.1", 775 | "bundled": true, 776 | "dev": true, 777 | "optional": true 778 | }, 779 | "code-point-at": { 780 | "version": "1.1.0", 781 | "bundled": true, 782 | "dev": true, 783 | "optional": true 784 | }, 785 | "concat-map": { 786 | "version": "0.0.1", 787 | "bundled": true, 788 | "dev": true, 789 | "optional": true 790 | }, 791 | "console-control-strings": { 792 | "version": "1.1.0", 793 | "bundled": true, 794 | "dev": true, 795 | "optional": true 796 | }, 797 | "core-util-is": { 798 | "version": "1.0.2", 799 | "bundled": true, 800 | "dev": true, 801 | "optional": true 802 | }, 803 | "debug": { 804 | "version": "2.6.9", 805 | "bundled": true, 806 | "dev": true, 807 | "optional": true, 808 | "requires": { 809 | "ms": "2.0.0" 810 | } 811 | }, 812 | "deep-extend": { 813 | "version": "0.5.1", 814 | "bundled": true, 815 | "dev": true, 816 | "optional": true 817 | }, 818 | "delegates": { 819 | "version": "1.0.0", 820 | "bundled": true, 821 | "dev": true, 822 | "optional": true 823 | }, 824 | "detect-libc": { 825 | "version": "1.0.3", 826 | "bundled": true, 827 | "dev": true, 828 | "optional": true 829 | }, 830 | "fs-minipass": { 831 | "version": "1.2.5", 832 | "bundled": true, 833 | "dev": true, 834 | "optional": true, 835 | "requires": { 836 | "minipass": "^2.2.1" 837 | } 838 | }, 839 | "fs.realpath": { 840 | "version": "1.0.0", 841 | "bundled": true, 842 | "dev": true, 843 | "optional": true 844 | }, 845 | "gauge": { 846 | "version": "2.7.4", 847 | "bundled": true, 848 | "dev": true, 849 | "optional": true, 850 | "requires": { 851 | "aproba": "^1.0.3", 852 | "console-control-strings": "^1.0.0", 853 | "has-unicode": "^2.0.0", 854 | "object-assign": "^4.1.0", 855 | "signal-exit": "^3.0.0", 856 | "string-width": "^1.0.1", 857 | "strip-ansi": "^3.0.1", 858 | "wide-align": "^1.1.0" 859 | } 860 | }, 861 | "glob": { 862 | "version": "7.1.2", 863 | "bundled": true, 864 | "dev": true, 865 | "optional": true, 866 | "requires": { 867 | "fs.realpath": "^1.0.0", 868 | "inflight": "^1.0.4", 869 | "inherits": "2", 870 | "minimatch": "^3.0.4", 871 | "once": "^1.3.0", 872 | "path-is-absolute": "^1.0.0" 873 | } 874 | }, 875 | "has-unicode": { 876 | "version": "2.0.1", 877 | "bundled": true, 878 | "dev": true, 879 | "optional": true 880 | }, 881 | "iconv-lite": { 882 | "version": "0.4.21", 883 | "bundled": true, 884 | "dev": true, 885 | "optional": true, 886 | "requires": { 887 | "safer-buffer": "^2.1.0" 888 | } 889 | }, 890 | "ignore-walk": { 891 | "version": "3.0.1", 892 | "bundled": true, 893 | "dev": true, 894 | "optional": true, 895 | "requires": { 896 | "minimatch": "^3.0.4" 897 | } 898 | }, 899 | "inflight": { 900 | "version": "1.0.6", 901 | "bundled": true, 902 | "dev": true, 903 | "optional": true, 904 | "requires": { 905 | "once": "^1.3.0", 906 | "wrappy": "1" 907 | } 908 | }, 909 | "inherits": { 910 | "version": "2.0.3", 911 | "bundled": true, 912 | "dev": true, 913 | "optional": true 914 | }, 915 | "ini": { 916 | "version": "1.3.5", 917 | "bundled": true, 918 | "dev": true, 919 | "optional": true 920 | }, 921 | "is-fullwidth-code-point": { 922 | "version": "1.0.0", 923 | "bundled": true, 924 | "dev": true, 925 | "optional": true, 926 | "requires": { 927 | "number-is-nan": "^1.0.0" 928 | } 929 | }, 930 | "isarray": { 931 | "version": "1.0.0", 932 | "bundled": true, 933 | "dev": true, 934 | "optional": true 935 | }, 936 | "minimatch": { 937 | "version": "3.0.4", 938 | "bundled": true, 939 | "dev": true, 940 | "optional": true, 941 | "requires": { 942 | "brace-expansion": "^1.1.7" 943 | } 944 | }, 945 | "minimist": { 946 | "version": "0.0.8", 947 | "bundled": true, 948 | "dev": true, 949 | "optional": true 950 | }, 951 | "minipass": { 952 | "version": "2.2.4", 953 | "bundled": true, 954 | "dev": true, 955 | "optional": true, 956 | "requires": { 957 | "safe-buffer": "^5.1.1", 958 | "yallist": "^3.0.0" 959 | } 960 | }, 961 | "minizlib": { 962 | "version": "1.1.0", 963 | "bundled": true, 964 | "dev": true, 965 | "optional": true, 966 | "requires": { 967 | "minipass": "^2.2.1" 968 | } 969 | }, 970 | "mkdirp": { 971 | "version": "0.5.1", 972 | "bundled": true, 973 | "dev": true, 974 | "optional": true, 975 | "requires": { 976 | "minimist": "0.0.8" 977 | } 978 | }, 979 | "ms": { 980 | "version": "2.0.0", 981 | "bundled": true, 982 | "dev": true, 983 | "optional": true 984 | }, 985 | "needle": { 986 | "version": "2.2.0", 987 | "bundled": true, 988 | "dev": true, 989 | "optional": true, 990 | "requires": { 991 | "debug": "^2.1.2", 992 | "iconv-lite": "^0.4.4", 993 | "sax": "^1.2.4" 994 | } 995 | }, 996 | "node-pre-gyp": { 997 | "version": "0.10.0", 998 | "bundled": true, 999 | "dev": true, 1000 | "optional": true, 1001 | "requires": { 1002 | "detect-libc": "^1.0.2", 1003 | "mkdirp": "^0.5.1", 1004 | "needle": "^2.2.0", 1005 | "nopt": "^4.0.1", 1006 | "npm-packlist": "^1.1.6", 1007 | "npmlog": "^4.0.2", 1008 | "rc": "^1.1.7", 1009 | "rimraf": "^2.6.1", 1010 | "semver": "^5.3.0", 1011 | "tar": "^4" 1012 | } 1013 | }, 1014 | "nopt": { 1015 | "version": "4.0.1", 1016 | "bundled": true, 1017 | "dev": true, 1018 | "optional": true, 1019 | "requires": { 1020 | "abbrev": "1", 1021 | "osenv": "^0.1.4" 1022 | } 1023 | }, 1024 | "npm-bundled": { 1025 | "version": "1.0.3", 1026 | "bundled": true, 1027 | "dev": true, 1028 | "optional": true 1029 | }, 1030 | "npm-packlist": { 1031 | "version": "1.1.10", 1032 | "bundled": true, 1033 | "dev": true, 1034 | "optional": true, 1035 | "requires": { 1036 | "ignore-walk": "^3.0.1", 1037 | "npm-bundled": "^1.0.1" 1038 | } 1039 | }, 1040 | "npmlog": { 1041 | "version": "4.1.2", 1042 | "bundled": true, 1043 | "dev": true, 1044 | "optional": true, 1045 | "requires": { 1046 | "are-we-there-yet": "~1.1.2", 1047 | "console-control-strings": "~1.1.0", 1048 | "gauge": "~2.7.3", 1049 | "set-blocking": "~2.0.0" 1050 | } 1051 | }, 1052 | "number-is-nan": { 1053 | "version": "1.0.1", 1054 | "bundled": true, 1055 | "dev": true, 1056 | "optional": true 1057 | }, 1058 | "object-assign": { 1059 | "version": "4.1.1", 1060 | "bundled": true, 1061 | "dev": true, 1062 | "optional": true 1063 | }, 1064 | "once": { 1065 | "version": "1.4.0", 1066 | "bundled": true, 1067 | "dev": true, 1068 | "optional": true, 1069 | "requires": { 1070 | "wrappy": "1" 1071 | } 1072 | }, 1073 | "os-homedir": { 1074 | "version": "1.0.2", 1075 | "bundled": true, 1076 | "dev": true, 1077 | "optional": true 1078 | }, 1079 | "os-tmpdir": { 1080 | "version": "1.0.2", 1081 | "bundled": true, 1082 | "dev": true, 1083 | "optional": true 1084 | }, 1085 | "osenv": { 1086 | "version": "0.1.5", 1087 | "bundled": true, 1088 | "dev": true, 1089 | "optional": true, 1090 | "requires": { 1091 | "os-homedir": "^1.0.0", 1092 | "os-tmpdir": "^1.0.0" 1093 | } 1094 | }, 1095 | "path-is-absolute": { 1096 | "version": "1.0.1", 1097 | "bundled": true, 1098 | "dev": true, 1099 | "optional": true 1100 | }, 1101 | "process-nextick-args": { 1102 | "version": "2.0.0", 1103 | "bundled": true, 1104 | "dev": true, 1105 | "optional": true 1106 | }, 1107 | "rc": { 1108 | "version": "1.2.7", 1109 | "bundled": true, 1110 | "dev": true, 1111 | "optional": true, 1112 | "requires": { 1113 | "deep-extend": "^0.5.1", 1114 | "ini": "~1.3.0", 1115 | "minimist": "^1.2.0", 1116 | "strip-json-comments": "~2.0.1" 1117 | }, 1118 | "dependencies": { 1119 | "minimist": { 1120 | "version": "1.2.0", 1121 | "bundled": true, 1122 | "dev": true, 1123 | "optional": true 1124 | } 1125 | } 1126 | }, 1127 | "readable-stream": { 1128 | "version": "2.3.6", 1129 | "bundled": true, 1130 | "dev": true, 1131 | "optional": true, 1132 | "requires": { 1133 | "core-util-is": "~1.0.0", 1134 | "inherits": "~2.0.3", 1135 | "isarray": "~1.0.0", 1136 | "process-nextick-args": "~2.0.0", 1137 | "safe-buffer": "~5.1.1", 1138 | "string_decoder": "~1.1.1", 1139 | "util-deprecate": "~1.0.1" 1140 | } 1141 | }, 1142 | "rimraf": { 1143 | "version": "2.6.2", 1144 | "bundled": true, 1145 | "dev": true, 1146 | "optional": true, 1147 | "requires": { 1148 | "glob": "^7.0.5" 1149 | } 1150 | }, 1151 | "safe-buffer": { 1152 | "version": "5.1.1", 1153 | "bundled": true, 1154 | "dev": true 1155 | }, 1156 | "safer-buffer": { 1157 | "version": "2.1.2", 1158 | "bundled": true, 1159 | "dev": true, 1160 | "optional": true 1161 | }, 1162 | "sax": { 1163 | "version": "1.2.4", 1164 | "bundled": true, 1165 | "dev": true, 1166 | "optional": true 1167 | }, 1168 | "semver": { 1169 | "version": "5.5.0", 1170 | "bundled": true, 1171 | "dev": true, 1172 | "optional": true 1173 | }, 1174 | "set-blocking": { 1175 | "version": "2.0.0", 1176 | "bundled": true, 1177 | "dev": true, 1178 | "optional": true 1179 | }, 1180 | "signal-exit": { 1181 | "version": "3.0.2", 1182 | "bundled": true, 1183 | "dev": true, 1184 | "optional": true 1185 | }, 1186 | "string-width": { 1187 | "version": "1.0.2", 1188 | "bundled": true, 1189 | "dev": true, 1190 | "optional": true, 1191 | "requires": { 1192 | "code-point-at": "^1.0.0", 1193 | "is-fullwidth-code-point": "^1.0.0", 1194 | "strip-ansi": "^3.0.0" 1195 | } 1196 | }, 1197 | "string_decoder": { 1198 | "version": "1.1.1", 1199 | "bundled": true, 1200 | "dev": true, 1201 | "optional": true, 1202 | "requires": { 1203 | "safe-buffer": "~5.1.0" 1204 | } 1205 | }, 1206 | "strip-ansi": { 1207 | "version": "3.0.1", 1208 | "bundled": true, 1209 | "dev": true, 1210 | "requires": { 1211 | "ansi-regex": "^2.0.0" 1212 | } 1213 | }, 1214 | "strip-json-comments": { 1215 | "version": "2.0.1", 1216 | "bundled": true, 1217 | "dev": true, 1218 | "optional": true 1219 | }, 1220 | "tar": { 1221 | "version": "4.4.1", 1222 | "bundled": true, 1223 | "dev": true, 1224 | "optional": true, 1225 | "requires": { 1226 | "chownr": "^1.0.1", 1227 | "fs-minipass": "^1.2.5", 1228 | "minipass": "^2.2.4", 1229 | "minizlib": "^1.1.0", 1230 | "mkdirp": "^0.5.0", 1231 | "safe-buffer": "^5.1.1", 1232 | "yallist": "^3.0.2" 1233 | } 1234 | }, 1235 | "util-deprecate": { 1236 | "version": "1.0.2", 1237 | "bundled": true, 1238 | "dev": true, 1239 | "optional": true 1240 | }, 1241 | "wide-align": { 1242 | "version": "1.1.2", 1243 | "bundled": true, 1244 | "dev": true, 1245 | "optional": true, 1246 | "requires": { 1247 | "string-width": "^1.0.2" 1248 | } 1249 | }, 1250 | "wrappy": { 1251 | "version": "1.0.2", 1252 | "bundled": true, 1253 | "dev": true 1254 | }, 1255 | "yallist": { 1256 | "version": "3.0.2", 1257 | "bundled": true, 1258 | "dev": true 1259 | } 1260 | } 1261 | }, 1262 | "get-stream": { 1263 | "version": "3.0.0", 1264 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 1265 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", 1266 | "dev": true 1267 | }, 1268 | "get-value": { 1269 | "version": "2.0.6", 1270 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", 1271 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", 1272 | "dev": true 1273 | }, 1274 | "glob-parent": { 1275 | "version": "3.1.0", 1276 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 1277 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 1278 | "dev": true, 1279 | "requires": { 1280 | "is-glob": "^3.1.0", 1281 | "path-dirname": "^1.0.0" 1282 | }, 1283 | "dependencies": { 1284 | "is-glob": { 1285 | "version": "3.1.0", 1286 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 1287 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 1288 | "dev": true, 1289 | "requires": { 1290 | "is-extglob": "^2.1.0" 1291 | } 1292 | } 1293 | } 1294 | }, 1295 | "global-dirs": { 1296 | "version": "0.1.1", 1297 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz", 1298 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=", 1299 | "dev": true, 1300 | "requires": { 1301 | "ini": "^1.3.4" 1302 | } 1303 | }, 1304 | "got": { 1305 | "version": "6.7.1", 1306 | "resolved": "http://registry.npmjs.org/got/-/got-6.7.1.tgz", 1307 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=", 1308 | "dev": true, 1309 | "requires": { 1310 | "create-error-class": "^3.0.0", 1311 | "duplexer3": "^0.1.4", 1312 | "get-stream": "^3.0.0", 1313 | "is-redirect": "^1.0.0", 1314 | "is-retry-allowed": "^1.0.0", 1315 | "is-stream": "^1.0.0", 1316 | "lowercase-keys": "^1.0.0", 1317 | "safe-buffer": "^5.0.1", 1318 | "timed-out": "^4.0.0", 1319 | "unzip-response": "^2.0.1", 1320 | "url-parse-lax": "^1.0.0" 1321 | } 1322 | }, 1323 | "graceful-fs": { 1324 | "version": "4.1.11", 1325 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1326 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 1327 | "dev": true 1328 | }, 1329 | "has-flag": { 1330 | "version": "3.0.0", 1331 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1332 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1333 | "dev": true 1334 | }, 1335 | "has-value": { 1336 | "version": "1.0.0", 1337 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", 1338 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", 1339 | "dev": true, 1340 | "requires": { 1341 | "get-value": "^2.0.6", 1342 | "has-values": "^1.0.0", 1343 | "isobject": "^3.0.0" 1344 | } 1345 | }, 1346 | "has-values": { 1347 | "version": "1.0.0", 1348 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", 1349 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", 1350 | "dev": true, 1351 | "requires": { 1352 | "is-number": "^3.0.0", 1353 | "kind-of": "^4.0.0" 1354 | }, 1355 | "dependencies": { 1356 | "kind-of": { 1357 | "version": "4.0.0", 1358 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 1359 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 1360 | "dev": true, 1361 | "requires": { 1362 | "is-buffer": "^1.1.5" 1363 | } 1364 | } 1365 | } 1366 | }, 1367 | "ignore-by-default": { 1368 | "version": "1.0.1", 1369 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1370 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1371 | "dev": true 1372 | }, 1373 | "immutable": { 1374 | "version": "3.8.2", 1375 | "resolved": "https://registry.npmjs.org/immutable/-/immutable-3.8.2.tgz", 1376 | "integrity": "sha1-wkOZUUVbs5kT2vKBN28VMOEErfM=" 1377 | }, 1378 | "import-lazy": { 1379 | "version": "2.1.0", 1380 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1381 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 1382 | "dev": true 1383 | }, 1384 | "imurmurhash": { 1385 | "version": "0.1.4", 1386 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1387 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1388 | "dev": true 1389 | }, 1390 | "inherits": { 1391 | "version": "2.0.3", 1392 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1393 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1394 | "dev": true 1395 | }, 1396 | "ini": { 1397 | "version": "1.3.5", 1398 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1399 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 1400 | "dev": true 1401 | }, 1402 | "is-accessor-descriptor": { 1403 | "version": "0.1.6", 1404 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", 1405 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", 1406 | "dev": true, 1407 | "requires": { 1408 | "kind-of": "^3.0.2" 1409 | }, 1410 | "dependencies": { 1411 | "kind-of": { 1412 | "version": "3.2.2", 1413 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1414 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1415 | "dev": true, 1416 | "requires": { 1417 | "is-buffer": "^1.1.5" 1418 | } 1419 | } 1420 | } 1421 | }, 1422 | "is-binary-path": { 1423 | "version": "1.0.1", 1424 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1425 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1426 | "dev": true, 1427 | "requires": { 1428 | "binary-extensions": "^1.0.0" 1429 | } 1430 | }, 1431 | "is-buffer": { 1432 | "version": "1.1.6", 1433 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1434 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1435 | "dev": true 1436 | }, 1437 | "is-ci": { 1438 | "version": "1.2.1", 1439 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz", 1440 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==", 1441 | "dev": true, 1442 | "requires": { 1443 | "ci-info": "^1.5.0" 1444 | } 1445 | }, 1446 | "is-data-descriptor": { 1447 | "version": "0.1.4", 1448 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", 1449 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", 1450 | "dev": true, 1451 | "requires": { 1452 | "kind-of": "^3.0.2" 1453 | }, 1454 | "dependencies": { 1455 | "kind-of": { 1456 | "version": "3.2.2", 1457 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1458 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1459 | "dev": true, 1460 | "requires": { 1461 | "is-buffer": "^1.1.5" 1462 | } 1463 | } 1464 | } 1465 | }, 1466 | "is-descriptor": { 1467 | "version": "0.1.6", 1468 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", 1469 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", 1470 | "dev": true, 1471 | "requires": { 1472 | "is-accessor-descriptor": "^0.1.6", 1473 | "is-data-descriptor": "^0.1.4", 1474 | "kind-of": "^5.0.0" 1475 | }, 1476 | "dependencies": { 1477 | "kind-of": { 1478 | "version": "5.1.0", 1479 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", 1480 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", 1481 | "dev": true 1482 | } 1483 | } 1484 | }, 1485 | "is-extendable": { 1486 | "version": "0.1.1", 1487 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1488 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1489 | "dev": true 1490 | }, 1491 | "is-extglob": { 1492 | "version": "2.1.1", 1493 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1494 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1495 | "dev": true 1496 | }, 1497 | "is-fullwidth-code-point": { 1498 | "version": "2.0.0", 1499 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1500 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1501 | "dev": true 1502 | }, 1503 | "is-glob": { 1504 | "version": "4.0.0", 1505 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", 1506 | "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", 1507 | "dev": true, 1508 | "requires": { 1509 | "is-extglob": "^2.1.1" 1510 | } 1511 | }, 1512 | "is-installed-globally": { 1513 | "version": "0.1.0", 1514 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz", 1515 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=", 1516 | "dev": true, 1517 | "requires": { 1518 | "global-dirs": "^0.1.0", 1519 | "is-path-inside": "^1.0.0" 1520 | } 1521 | }, 1522 | "is-npm": { 1523 | "version": "1.0.0", 1524 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz", 1525 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=", 1526 | "dev": true 1527 | }, 1528 | "is-number": { 1529 | "version": "3.0.0", 1530 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 1531 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 1532 | "dev": true, 1533 | "requires": { 1534 | "kind-of": "^3.0.2" 1535 | }, 1536 | "dependencies": { 1537 | "kind-of": { 1538 | "version": "3.2.2", 1539 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1540 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1541 | "dev": true, 1542 | "requires": { 1543 | "is-buffer": "^1.1.5" 1544 | } 1545 | } 1546 | } 1547 | }, 1548 | "is-obj": { 1549 | "version": "1.0.1", 1550 | "resolved": "http://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1551 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1552 | "dev": true 1553 | }, 1554 | "is-path-inside": { 1555 | "version": "1.0.1", 1556 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 1557 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 1558 | "dev": true, 1559 | "requires": { 1560 | "path-is-inside": "^1.0.1" 1561 | } 1562 | }, 1563 | "is-plain-object": { 1564 | "version": "2.0.4", 1565 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1566 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1567 | "dev": true, 1568 | "requires": { 1569 | "isobject": "^3.0.1" 1570 | } 1571 | }, 1572 | "is-redirect": { 1573 | "version": "1.0.0", 1574 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz", 1575 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=", 1576 | "dev": true 1577 | }, 1578 | "is-retry-allowed": { 1579 | "version": "1.1.0", 1580 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz", 1581 | "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=", 1582 | "dev": true 1583 | }, 1584 | "is-stream": { 1585 | "version": "1.1.0", 1586 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1587 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1588 | "dev": true 1589 | }, 1590 | "is-windows": { 1591 | "version": "1.0.2", 1592 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1593 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1594 | "dev": true 1595 | }, 1596 | "isarray": { 1597 | "version": "1.0.0", 1598 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1599 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1600 | "dev": true 1601 | }, 1602 | "isexe": { 1603 | "version": "2.0.0", 1604 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1605 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1606 | "dev": true 1607 | }, 1608 | "isobject": { 1609 | "version": "3.0.1", 1610 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1611 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", 1612 | "dev": true 1613 | }, 1614 | "kind-of": { 1615 | "version": "6.0.2", 1616 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 1617 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 1618 | "dev": true 1619 | }, 1620 | "latest-version": { 1621 | "version": "3.1.0", 1622 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz", 1623 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=", 1624 | "dev": true, 1625 | "requires": { 1626 | "package-json": "^4.0.0" 1627 | } 1628 | }, 1629 | "lodash.debounce": { 1630 | "version": "4.0.8", 1631 | "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", 1632 | "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", 1633 | "dev": true 1634 | }, 1635 | "lowercase-keys": { 1636 | "version": "1.0.1", 1637 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 1638 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 1639 | "dev": true 1640 | }, 1641 | "lru-cache": { 1642 | "version": "4.1.3", 1643 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.3.tgz", 1644 | "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", 1645 | "dev": true, 1646 | "requires": { 1647 | "pseudomap": "^1.0.2", 1648 | "yallist": "^2.1.2" 1649 | } 1650 | }, 1651 | "make-dir": { 1652 | "version": "1.3.0", 1653 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz", 1654 | "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==", 1655 | "dev": true, 1656 | "requires": { 1657 | "pify": "^3.0.0" 1658 | } 1659 | }, 1660 | "map-cache": { 1661 | "version": "0.2.2", 1662 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 1663 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", 1664 | "dev": true 1665 | }, 1666 | "map-stream": { 1667 | "version": "0.0.7", 1668 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.0.7.tgz", 1669 | "integrity": "sha1-ih8HiW2CsQkmvTdEokIACfiJdKg=", 1670 | "dev": true 1671 | }, 1672 | "map-visit": { 1673 | "version": "1.0.0", 1674 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", 1675 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", 1676 | "dev": true, 1677 | "requires": { 1678 | "object-visit": "^1.0.0" 1679 | } 1680 | }, 1681 | "micromatch": { 1682 | "version": "3.1.10", 1683 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", 1684 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", 1685 | "dev": true, 1686 | "requires": { 1687 | "arr-diff": "^4.0.0", 1688 | "array-unique": "^0.3.2", 1689 | "braces": "^2.3.1", 1690 | "define-property": "^2.0.2", 1691 | "extend-shallow": "^3.0.2", 1692 | "extglob": "^2.0.4", 1693 | "fragment-cache": "^0.2.1", 1694 | "kind-of": "^6.0.2", 1695 | "nanomatch": "^1.2.9", 1696 | "object.pick": "^1.3.0", 1697 | "regex-not": "^1.0.0", 1698 | "snapdragon": "^0.8.1", 1699 | "to-regex": "^3.0.2" 1700 | } 1701 | }, 1702 | "minimatch": { 1703 | "version": "3.0.4", 1704 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1705 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1706 | "dev": true, 1707 | "requires": { 1708 | "brace-expansion": "^1.1.7" 1709 | } 1710 | }, 1711 | "minimist": { 1712 | "version": "1.2.0", 1713 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1714 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1715 | "dev": true 1716 | }, 1717 | "mixin-deep": { 1718 | "version": "1.3.1", 1719 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", 1720 | "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", 1721 | "dev": true, 1722 | "requires": { 1723 | "for-in": "^1.0.2", 1724 | "is-extendable": "^1.0.1" 1725 | }, 1726 | "dependencies": { 1727 | "is-extendable": { 1728 | "version": "1.0.1", 1729 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 1730 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 1731 | "dev": true, 1732 | "requires": { 1733 | "is-plain-object": "^2.0.4" 1734 | } 1735 | } 1736 | } 1737 | }, 1738 | "ms": { 1739 | "version": "2.0.0", 1740 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1741 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1742 | "dev": true 1743 | }, 1744 | "nan": { 1745 | "version": "2.11.0", 1746 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.11.0.tgz", 1747 | "integrity": "sha512-F4miItu2rGnV2ySkXOQoA8FKz/SR2Q2sWP0sbTxNxz/tuokeC8WxOhPMcwi0qIyGtVn/rrSeLbvVkznqCdwYnw==", 1748 | "dev": true, 1749 | "optional": true 1750 | }, 1751 | "nanomatch": { 1752 | "version": "1.2.13", 1753 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", 1754 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", 1755 | "dev": true, 1756 | "requires": { 1757 | "arr-diff": "^4.0.0", 1758 | "array-unique": "^0.3.2", 1759 | "define-property": "^2.0.2", 1760 | "extend-shallow": "^3.0.2", 1761 | "fragment-cache": "^0.2.1", 1762 | "is-windows": "^1.0.2", 1763 | "kind-of": "^6.0.2", 1764 | "object.pick": "^1.3.0", 1765 | "regex-not": "^1.0.0", 1766 | "snapdragon": "^0.8.1", 1767 | "to-regex": "^3.0.1" 1768 | } 1769 | }, 1770 | "nodemon": { 1771 | "version": "1.18.4", 1772 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.18.4.tgz", 1773 | "integrity": "sha512-hyK6vl65IPnky/ee+D3IWvVGgJa/m3No2/Xc/3wanS6Ce1MWjCzH6NnhPJ/vZM+6JFym16jtHx51lmCMB9HDtg==", 1774 | "dev": true, 1775 | "requires": { 1776 | "chokidar": "^2.0.2", 1777 | "debug": "^3.1.0", 1778 | "ignore-by-default": "^1.0.1", 1779 | "minimatch": "^3.0.4", 1780 | "pstree.remy": "^1.1.0", 1781 | "semver": "^5.5.0", 1782 | "supports-color": "^5.2.0", 1783 | "touch": "^3.1.0", 1784 | "undefsafe": "^2.0.2", 1785 | "update-notifier": "^2.3.0" 1786 | } 1787 | }, 1788 | "nopt": { 1789 | "version": "1.0.10", 1790 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1791 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1792 | "dev": true, 1793 | "requires": { 1794 | "abbrev": "1" 1795 | } 1796 | }, 1797 | "normalize-path": { 1798 | "version": "2.1.1", 1799 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1800 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1801 | "dev": true, 1802 | "requires": { 1803 | "remove-trailing-separator": "^1.0.1" 1804 | } 1805 | }, 1806 | "npm-run-path": { 1807 | "version": "2.0.2", 1808 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1809 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1810 | "dev": true, 1811 | "requires": { 1812 | "path-key": "^2.0.0" 1813 | } 1814 | }, 1815 | "object-copy": { 1816 | "version": "0.1.0", 1817 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", 1818 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", 1819 | "dev": true, 1820 | "requires": { 1821 | "copy-descriptor": "^0.1.0", 1822 | "define-property": "^0.2.5", 1823 | "kind-of": "^3.0.3" 1824 | }, 1825 | "dependencies": { 1826 | "define-property": { 1827 | "version": "0.2.5", 1828 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 1829 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 1830 | "dev": true, 1831 | "requires": { 1832 | "is-descriptor": "^0.1.0" 1833 | } 1834 | }, 1835 | "kind-of": { 1836 | "version": "3.2.2", 1837 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1838 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1839 | "dev": true, 1840 | "requires": { 1841 | "is-buffer": "^1.1.5" 1842 | } 1843 | } 1844 | } 1845 | }, 1846 | "object-visit": { 1847 | "version": "1.0.1", 1848 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", 1849 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", 1850 | "dev": true, 1851 | "requires": { 1852 | "isobject": "^3.0.0" 1853 | } 1854 | }, 1855 | "object.pick": { 1856 | "version": "1.3.0", 1857 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 1858 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 1859 | "dev": true, 1860 | "requires": { 1861 | "isobject": "^3.0.1" 1862 | } 1863 | }, 1864 | "p-finally": { 1865 | "version": "1.0.0", 1866 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1867 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 1868 | "dev": true 1869 | }, 1870 | "package-json": { 1871 | "version": "4.0.1", 1872 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz", 1873 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=", 1874 | "dev": true, 1875 | "requires": { 1876 | "got": "^6.7.1", 1877 | "registry-auth-token": "^3.0.1", 1878 | "registry-url": "^3.0.3", 1879 | "semver": "^5.1.0" 1880 | } 1881 | }, 1882 | "pascalcase": { 1883 | "version": "0.1.1", 1884 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", 1885 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", 1886 | "dev": true 1887 | }, 1888 | "path-dirname": { 1889 | "version": "1.0.2", 1890 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 1891 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 1892 | "dev": true 1893 | }, 1894 | "path-is-absolute": { 1895 | "version": "1.0.1", 1896 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1897 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1898 | "dev": true 1899 | }, 1900 | "path-is-inside": { 1901 | "version": "1.0.2", 1902 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1903 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1904 | "dev": true 1905 | }, 1906 | "path-key": { 1907 | "version": "2.0.1", 1908 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1909 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1910 | "dev": true 1911 | }, 1912 | "pause-stream": { 1913 | "version": "0.0.11", 1914 | "resolved": "http://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1915 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1916 | "dev": true, 1917 | "requires": { 1918 | "through": "~2.3" 1919 | } 1920 | }, 1921 | "pify": { 1922 | "version": "3.0.0", 1923 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1924 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1925 | "dev": true 1926 | }, 1927 | "posix-character-classes": { 1928 | "version": "0.1.1", 1929 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", 1930 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", 1931 | "dev": true 1932 | }, 1933 | "prepend-http": { 1934 | "version": "1.0.4", 1935 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", 1936 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", 1937 | "dev": true 1938 | }, 1939 | "process-nextick-args": { 1940 | "version": "2.0.0", 1941 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1942 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1943 | "dev": true 1944 | }, 1945 | "ps-tree": { 1946 | "version": "1.1.0", 1947 | "resolved": "https://registry.npmjs.org/ps-tree/-/ps-tree-1.1.0.tgz", 1948 | "integrity": "sha1-tCGyQUDWID8e08dplrRCewjowBQ=", 1949 | "dev": true, 1950 | "requires": { 1951 | "event-stream": "~3.3.0" 1952 | } 1953 | }, 1954 | "pseudomap": { 1955 | "version": "1.0.2", 1956 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1957 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 1958 | "dev": true 1959 | }, 1960 | "pstree.remy": { 1961 | "version": "1.1.0", 1962 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.0.tgz", 1963 | "integrity": "sha512-q5I5vLRMVtdWa8n/3UEzZX7Lfghzrg9eG2IKk2ENLSofKRCXVqMvMUHxCKgXNaqH/8ebhBxrqftHWnyTFweJ5Q==", 1964 | "dev": true, 1965 | "requires": { 1966 | "ps-tree": "^1.1.0" 1967 | } 1968 | }, 1969 | "rc": { 1970 | "version": "1.2.8", 1971 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1972 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1973 | "dev": true, 1974 | "requires": { 1975 | "deep-extend": "^0.6.0", 1976 | "ini": "~1.3.0", 1977 | "minimist": "^1.2.0", 1978 | "strip-json-comments": "~2.0.1" 1979 | } 1980 | }, 1981 | "readable-stream": { 1982 | "version": "2.3.6", 1983 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 1984 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 1985 | "dev": true, 1986 | "requires": { 1987 | "core-util-is": "~1.0.0", 1988 | "inherits": "~2.0.3", 1989 | "isarray": "~1.0.0", 1990 | "process-nextick-args": "~2.0.0", 1991 | "safe-buffer": "~5.1.1", 1992 | "string_decoder": "~1.1.1", 1993 | "util-deprecate": "~1.0.1" 1994 | } 1995 | }, 1996 | "readdirp": { 1997 | "version": "2.2.1", 1998 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", 1999 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", 2000 | "dev": true, 2001 | "requires": { 2002 | "graceful-fs": "^4.1.11", 2003 | "micromatch": "^3.1.10", 2004 | "readable-stream": "^2.0.2" 2005 | } 2006 | }, 2007 | "regex-not": { 2008 | "version": "1.0.2", 2009 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", 2010 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", 2011 | "dev": true, 2012 | "requires": { 2013 | "extend-shallow": "^3.0.2", 2014 | "safe-regex": "^1.1.0" 2015 | } 2016 | }, 2017 | "registry-auth-token": { 2018 | "version": "3.3.2", 2019 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.3.2.tgz", 2020 | "integrity": "sha512-JL39c60XlzCVgNrO+qq68FoNb56w/m7JYvGR2jT5iR1xBrUA3Mfx5Twk5rqTThPmQKMWydGmq8oFtDlxfrmxnQ==", 2021 | "dev": true, 2022 | "requires": { 2023 | "rc": "^1.1.6", 2024 | "safe-buffer": "^5.0.1" 2025 | } 2026 | }, 2027 | "registry-url": { 2028 | "version": "3.1.0", 2029 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz", 2030 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=", 2031 | "dev": true, 2032 | "requires": { 2033 | "rc": "^1.0.1" 2034 | } 2035 | }, 2036 | "remove-trailing-separator": { 2037 | "version": "1.1.0", 2038 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2039 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2040 | "dev": true 2041 | }, 2042 | "repeat-element": { 2043 | "version": "1.1.3", 2044 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", 2045 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", 2046 | "dev": true 2047 | }, 2048 | "repeat-string": { 2049 | "version": "1.6.1", 2050 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2051 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2052 | "dev": true 2053 | }, 2054 | "resolve-url": { 2055 | "version": "0.2.1", 2056 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", 2057 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", 2058 | "dev": true 2059 | }, 2060 | "ret": { 2061 | "version": "0.1.15", 2062 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", 2063 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", 2064 | "dev": true 2065 | }, 2066 | "safe-buffer": { 2067 | "version": "5.1.2", 2068 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2069 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2070 | "dev": true 2071 | }, 2072 | "safe-regex": { 2073 | "version": "1.1.0", 2074 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", 2075 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", 2076 | "dev": true, 2077 | "requires": { 2078 | "ret": "~0.1.10" 2079 | } 2080 | }, 2081 | "semver": { 2082 | "version": "5.5.1", 2083 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.1.tgz", 2084 | "integrity": "sha512-PqpAxfrEhlSUWge8dwIp4tZnQ25DIOthpiaHNIthsjEFQD6EvqUKUDM7L8O2rShkFccYo1VjJR0coWfNkCubRw==", 2085 | "dev": true 2086 | }, 2087 | "semver-diff": { 2088 | "version": "2.1.0", 2089 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz", 2090 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=", 2091 | "dev": true, 2092 | "requires": { 2093 | "semver": "^5.0.3" 2094 | } 2095 | }, 2096 | "set-value": { 2097 | "version": "2.0.0", 2098 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", 2099 | "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", 2100 | "dev": true, 2101 | "requires": { 2102 | "extend-shallow": "^2.0.1", 2103 | "is-extendable": "^0.1.1", 2104 | "is-plain-object": "^2.0.3", 2105 | "split-string": "^3.0.1" 2106 | }, 2107 | "dependencies": { 2108 | "extend-shallow": { 2109 | "version": "2.0.1", 2110 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2111 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2112 | "dev": true, 2113 | "requires": { 2114 | "is-extendable": "^0.1.0" 2115 | } 2116 | } 2117 | } 2118 | }, 2119 | "shebang-command": { 2120 | "version": "1.2.0", 2121 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2122 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2123 | "dev": true, 2124 | "requires": { 2125 | "shebang-regex": "^1.0.0" 2126 | } 2127 | }, 2128 | "shebang-regex": { 2129 | "version": "1.0.0", 2130 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2131 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2132 | "dev": true 2133 | }, 2134 | "signal-exit": { 2135 | "version": "3.0.2", 2136 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2137 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2138 | "dev": true 2139 | }, 2140 | "snapdragon": { 2141 | "version": "0.8.2", 2142 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", 2143 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", 2144 | "dev": true, 2145 | "requires": { 2146 | "base": "^0.11.1", 2147 | "debug": "^2.2.0", 2148 | "define-property": "^0.2.5", 2149 | "extend-shallow": "^2.0.1", 2150 | "map-cache": "^0.2.2", 2151 | "source-map": "^0.5.6", 2152 | "source-map-resolve": "^0.5.0", 2153 | "use": "^3.1.0" 2154 | }, 2155 | "dependencies": { 2156 | "debug": { 2157 | "version": "2.6.9", 2158 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2159 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2160 | "dev": true, 2161 | "requires": { 2162 | "ms": "2.0.0" 2163 | } 2164 | }, 2165 | "define-property": { 2166 | "version": "0.2.5", 2167 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2168 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2169 | "dev": true, 2170 | "requires": { 2171 | "is-descriptor": "^0.1.0" 2172 | } 2173 | }, 2174 | "extend-shallow": { 2175 | "version": "2.0.1", 2176 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2177 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2178 | "dev": true, 2179 | "requires": { 2180 | "is-extendable": "^0.1.0" 2181 | } 2182 | } 2183 | } 2184 | }, 2185 | "snapdragon-node": { 2186 | "version": "2.1.1", 2187 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", 2188 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", 2189 | "dev": true, 2190 | "requires": { 2191 | "define-property": "^1.0.0", 2192 | "isobject": "^3.0.0", 2193 | "snapdragon-util": "^3.0.1" 2194 | }, 2195 | "dependencies": { 2196 | "define-property": { 2197 | "version": "1.0.0", 2198 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 2199 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 2200 | "dev": true, 2201 | "requires": { 2202 | "is-descriptor": "^1.0.0" 2203 | } 2204 | }, 2205 | "is-accessor-descriptor": { 2206 | "version": "1.0.0", 2207 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 2208 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 2209 | "dev": true, 2210 | "requires": { 2211 | "kind-of": "^6.0.0" 2212 | } 2213 | }, 2214 | "is-data-descriptor": { 2215 | "version": "1.0.0", 2216 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 2217 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 2218 | "dev": true, 2219 | "requires": { 2220 | "kind-of": "^6.0.0" 2221 | } 2222 | }, 2223 | "is-descriptor": { 2224 | "version": "1.0.2", 2225 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 2226 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 2227 | "dev": true, 2228 | "requires": { 2229 | "is-accessor-descriptor": "^1.0.0", 2230 | "is-data-descriptor": "^1.0.0", 2231 | "kind-of": "^6.0.2" 2232 | } 2233 | } 2234 | } 2235 | }, 2236 | "snapdragon-util": { 2237 | "version": "3.0.1", 2238 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", 2239 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", 2240 | "dev": true, 2241 | "requires": { 2242 | "kind-of": "^3.2.0" 2243 | }, 2244 | "dependencies": { 2245 | "kind-of": { 2246 | "version": "3.2.2", 2247 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2248 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2249 | "dev": true, 2250 | "requires": { 2251 | "is-buffer": "^1.1.5" 2252 | } 2253 | } 2254 | } 2255 | }, 2256 | "source-map": { 2257 | "version": "0.5.7", 2258 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2259 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2260 | "dev": true 2261 | }, 2262 | "source-map-resolve": { 2263 | "version": "0.5.2", 2264 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", 2265 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", 2266 | "dev": true, 2267 | "requires": { 2268 | "atob": "^2.1.1", 2269 | "decode-uri-component": "^0.2.0", 2270 | "resolve-url": "^0.2.1", 2271 | "source-map-url": "^0.4.0", 2272 | "urix": "^0.1.0" 2273 | } 2274 | }, 2275 | "source-map-url": { 2276 | "version": "0.4.0", 2277 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", 2278 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", 2279 | "dev": true 2280 | }, 2281 | "split": { 2282 | "version": "1.0.1", 2283 | "resolved": "https://registry.npmjs.org/split/-/split-1.0.1.tgz", 2284 | "integrity": "sha512-mTyOoPbrivtXnwnIxZRFYRrPNtEFKlpB2fvjSnCQUiAA6qAZzqwna5envK4uk6OIeP17CsdF3rSBGYVBsU0Tkg==", 2285 | "dev": true, 2286 | "requires": { 2287 | "through": "2" 2288 | } 2289 | }, 2290 | "split-string": { 2291 | "version": "3.1.0", 2292 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", 2293 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", 2294 | "dev": true, 2295 | "requires": { 2296 | "extend-shallow": "^3.0.0" 2297 | } 2298 | }, 2299 | "static-extend": { 2300 | "version": "0.1.2", 2301 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", 2302 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", 2303 | "dev": true, 2304 | "requires": { 2305 | "define-property": "^0.2.5", 2306 | "object-copy": "^0.1.0" 2307 | }, 2308 | "dependencies": { 2309 | "define-property": { 2310 | "version": "0.2.5", 2311 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2312 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2313 | "dev": true, 2314 | "requires": { 2315 | "is-descriptor": "^0.1.0" 2316 | } 2317 | } 2318 | } 2319 | }, 2320 | "stream-combiner": { 2321 | "version": "0.2.2", 2322 | "resolved": "http://registry.npmjs.org/stream-combiner/-/stream-combiner-0.2.2.tgz", 2323 | "integrity": "sha1-rsjLrBd7Vrb0+kec7YwZEs7lKFg=", 2324 | "dev": true, 2325 | "requires": { 2326 | "duplexer": "~0.1.1", 2327 | "through": "~2.3.4" 2328 | } 2329 | }, 2330 | "string-width": { 2331 | "version": "2.1.1", 2332 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2333 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2334 | "dev": true, 2335 | "requires": { 2336 | "is-fullwidth-code-point": "^2.0.0", 2337 | "strip-ansi": "^4.0.0" 2338 | } 2339 | }, 2340 | "string_decoder": { 2341 | "version": "1.1.1", 2342 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2343 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2344 | "dev": true, 2345 | "requires": { 2346 | "safe-buffer": "~5.1.0" 2347 | } 2348 | }, 2349 | "strip-ansi": { 2350 | "version": "4.0.0", 2351 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2352 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2353 | "dev": true, 2354 | "requires": { 2355 | "ansi-regex": "^3.0.0" 2356 | } 2357 | }, 2358 | "strip-eof": { 2359 | "version": "1.0.0", 2360 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 2361 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 2362 | "dev": true 2363 | }, 2364 | "strip-json-comments": { 2365 | "version": "2.0.1", 2366 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2367 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2368 | "dev": true 2369 | }, 2370 | "supports-color": { 2371 | "version": "5.5.0", 2372 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2373 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2374 | "dev": true, 2375 | "requires": { 2376 | "has-flag": "^3.0.0" 2377 | } 2378 | }, 2379 | "term-size": { 2380 | "version": "1.2.0", 2381 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz", 2382 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=", 2383 | "dev": true, 2384 | "requires": { 2385 | "execa": "^0.7.0" 2386 | } 2387 | }, 2388 | "through": { 2389 | "version": "2.3.8", 2390 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 2391 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2392 | "dev": true 2393 | }, 2394 | "timed-out": { 2395 | "version": "4.0.1", 2396 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz", 2397 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=", 2398 | "dev": true 2399 | }, 2400 | "to-object-path": { 2401 | "version": "0.3.0", 2402 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", 2403 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", 2404 | "dev": true, 2405 | "requires": { 2406 | "kind-of": "^3.0.2" 2407 | }, 2408 | "dependencies": { 2409 | "kind-of": { 2410 | "version": "3.2.2", 2411 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2412 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2413 | "dev": true, 2414 | "requires": { 2415 | "is-buffer": "^1.1.5" 2416 | } 2417 | } 2418 | } 2419 | }, 2420 | "to-regex": { 2421 | "version": "3.0.2", 2422 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", 2423 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", 2424 | "dev": true, 2425 | "requires": { 2426 | "define-property": "^2.0.2", 2427 | "extend-shallow": "^3.0.2", 2428 | "regex-not": "^1.0.2", 2429 | "safe-regex": "^1.1.0" 2430 | } 2431 | }, 2432 | "to-regex-range": { 2433 | "version": "2.1.1", 2434 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", 2435 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", 2436 | "dev": true, 2437 | "requires": { 2438 | "is-number": "^3.0.0", 2439 | "repeat-string": "^1.6.1" 2440 | } 2441 | }, 2442 | "touch": { 2443 | "version": "3.1.0", 2444 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2445 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2446 | "dev": true, 2447 | "requires": { 2448 | "nopt": "~1.0.10" 2449 | } 2450 | }, 2451 | "transit-immutable-js": { 2452 | "version": "0.7.0", 2453 | "resolved": "https://registry.npmjs.org/transit-immutable-js/-/transit-immutable-js-0.7.0.tgz", 2454 | "integrity": "sha1-mT4lCJtjEf9AIUD1VidtbSUwBdk=" 2455 | }, 2456 | "transit-js": { 2457 | "version": "0.8.861", 2458 | "resolved": "https://registry.npmjs.org/transit-js/-/transit-js-0.8.861.tgz", 2459 | "integrity": "sha512-4O9OrYPZw6C0M5gMTvaeOp+xYz6EF79JsyxIvqXHlt+pisSrioJWFOE80N8aCPoJLcNaXF442RZrVtdmd4wkDQ==" 2460 | }, 2461 | "undefsafe": { 2462 | "version": "2.0.2", 2463 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.2.tgz", 2464 | "integrity": "sha1-Il9rngM3Zj4Njnz9aG/Cg2zKznY=", 2465 | "dev": true, 2466 | "requires": { 2467 | "debug": "^2.2.0" 2468 | }, 2469 | "dependencies": { 2470 | "debug": { 2471 | "version": "2.6.9", 2472 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2473 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2474 | "dev": true, 2475 | "requires": { 2476 | "ms": "2.0.0" 2477 | } 2478 | } 2479 | } 2480 | }, 2481 | "union-value": { 2482 | "version": "1.0.0", 2483 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", 2484 | "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", 2485 | "dev": true, 2486 | "requires": { 2487 | "arr-union": "^3.1.0", 2488 | "get-value": "^2.0.6", 2489 | "is-extendable": "^0.1.1", 2490 | "set-value": "^0.4.3" 2491 | }, 2492 | "dependencies": { 2493 | "extend-shallow": { 2494 | "version": "2.0.1", 2495 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2496 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2497 | "dev": true, 2498 | "requires": { 2499 | "is-extendable": "^0.1.0" 2500 | } 2501 | }, 2502 | "set-value": { 2503 | "version": "0.4.3", 2504 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", 2505 | "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", 2506 | "dev": true, 2507 | "requires": { 2508 | "extend-shallow": "^2.0.1", 2509 | "is-extendable": "^0.1.1", 2510 | "is-plain-object": "^2.0.1", 2511 | "to-object-path": "^0.3.0" 2512 | } 2513 | } 2514 | } 2515 | }, 2516 | "unique-string": { 2517 | "version": "1.0.0", 2518 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz", 2519 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=", 2520 | "dev": true, 2521 | "requires": { 2522 | "crypto-random-string": "^1.0.0" 2523 | } 2524 | }, 2525 | "unset-value": { 2526 | "version": "1.0.0", 2527 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", 2528 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", 2529 | "dev": true, 2530 | "requires": { 2531 | "has-value": "^0.3.1", 2532 | "isobject": "^3.0.0" 2533 | }, 2534 | "dependencies": { 2535 | "has-value": { 2536 | "version": "0.3.1", 2537 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", 2538 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", 2539 | "dev": true, 2540 | "requires": { 2541 | "get-value": "^2.0.3", 2542 | "has-values": "^0.1.4", 2543 | "isobject": "^2.0.0" 2544 | }, 2545 | "dependencies": { 2546 | "isobject": { 2547 | "version": "2.1.0", 2548 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 2549 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 2550 | "dev": true, 2551 | "requires": { 2552 | "isarray": "1.0.0" 2553 | } 2554 | } 2555 | } 2556 | }, 2557 | "has-values": { 2558 | "version": "0.1.4", 2559 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", 2560 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", 2561 | "dev": true 2562 | } 2563 | } 2564 | }, 2565 | "unzip-response": { 2566 | "version": "2.0.1", 2567 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz", 2568 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=", 2569 | "dev": true 2570 | }, 2571 | "upath": { 2572 | "version": "1.1.0", 2573 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.0.tgz", 2574 | "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==", 2575 | "dev": true 2576 | }, 2577 | "update-notifier": { 2578 | "version": "2.5.0", 2579 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.5.0.tgz", 2580 | "integrity": "sha512-gwMdhgJHGuj/+wHJJs9e6PcCszpxR1b236igrOkUofGhqJuG+amlIKwApH1IW1WWl7ovZxsX49lMBWLxSdm5Dw==", 2581 | "dev": true, 2582 | "requires": { 2583 | "boxen": "^1.2.1", 2584 | "chalk": "^2.0.1", 2585 | "configstore": "^3.0.0", 2586 | "import-lazy": "^2.1.0", 2587 | "is-ci": "^1.0.10", 2588 | "is-installed-globally": "^0.1.0", 2589 | "is-npm": "^1.0.0", 2590 | "latest-version": "^3.0.0", 2591 | "semver-diff": "^2.0.0", 2592 | "xdg-basedir": "^3.0.0" 2593 | } 2594 | }, 2595 | "urix": { 2596 | "version": "0.1.0", 2597 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", 2598 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", 2599 | "dev": true 2600 | }, 2601 | "url-parse-lax": { 2602 | "version": "1.0.0", 2603 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz", 2604 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=", 2605 | "dev": true, 2606 | "requires": { 2607 | "prepend-http": "^1.0.1" 2608 | } 2609 | }, 2610 | "use": { 2611 | "version": "3.1.1", 2612 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", 2613 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", 2614 | "dev": true 2615 | }, 2616 | "util-deprecate": { 2617 | "version": "1.0.2", 2618 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2619 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2620 | "dev": true 2621 | }, 2622 | "uuid": { 2623 | "version": "3.1.0", 2624 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 2625 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" 2626 | }, 2627 | "which": { 2628 | "version": "1.3.1", 2629 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2630 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2631 | "dev": true, 2632 | "requires": { 2633 | "isexe": "^2.0.0" 2634 | } 2635 | }, 2636 | "widest-line": { 2637 | "version": "2.0.0", 2638 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-2.0.0.tgz", 2639 | "integrity": "sha1-AUKk6KJD+IgsAjOqDgKBqnYVInM=", 2640 | "dev": true, 2641 | "requires": { 2642 | "string-width": "^2.1.1" 2643 | } 2644 | }, 2645 | "write-file-atomic": { 2646 | "version": "2.3.0", 2647 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.3.0.tgz", 2648 | "integrity": "sha512-xuPeK4OdjWqtfi59ylvVL0Yn35SF3zgcAcv7rBPFHVaEapaDr4GdGgm3j7ckTwH9wHL7fGmgfAnb0+THrHb8tA==", 2649 | "dev": true, 2650 | "requires": { 2651 | "graceful-fs": "^4.1.11", 2652 | "imurmurhash": "^0.1.4", 2653 | "signal-exit": "^3.0.2" 2654 | } 2655 | }, 2656 | "ws": { 2657 | "version": "6.0.0", 2658 | "resolved": "https://registry.npmjs.org/ws/-/ws-6.0.0.tgz", 2659 | "integrity": "sha512-c2UlYcAZp1VS8AORtpq6y4RJIkJ9dQz18W32SpR/qXGfLDZ2jU4y4wKvvZwqbi7U6gxFQTeE+urMbXU/tsDy4w==", 2660 | "requires": { 2661 | "async-limiter": "~1.0.0" 2662 | } 2663 | }, 2664 | "xdg-basedir": { 2665 | "version": "3.0.0", 2666 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz", 2667 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=", 2668 | "dev": true 2669 | }, 2670 | "yallist": { 2671 | "version": "2.1.2", 2672 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 2673 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 2674 | "dev": true 2675 | } 2676 | } 2677 | } 2678 | --------------------------------------------------------------------------------