├── .editorconfig ├── .gitignore ├── README.md ├── package-lock.json ├── package.json ├── rollup.config.js ├── src ├── mongo-adapter.js ├── utils.js └── y-mongodb.js ├── tests ├── index.js └── y-mongodb.tests.js └── tsconfig.json /.editorconfig: -------------------------------------------------------------------------------- 1 | [*] 2 | charset=utf-8 3 | end_of_line=lf 4 | trim_trailing_whitespace=true 5 | insert_final_newline=true 6 | indent_style=space 7 | indent_size=2 8 | 9 | [{.babelrc,.prettierrc,.stylelintrc,.eslintrc,jest.config,*.json,*.jsb3,*.jsb2,*.bowerrc,*.graphqlconfig}] 10 | indent_style=space 11 | indent_size=2 12 | 13 | [{tsconfig.spec.json,tsconfig.app.json,tsconfig.json,tsconfig.e2e.json}] 14 | indent_style=space 15 | indent_size=2 16 | 17 | [*.js.map] 18 | indent_style=space 19 | indent_size=2 20 | 21 | [{server-cluster-ip-service,.analysis_options,*.yml,*.yaml}] 22 | indent_style=space 23 | indent_size=2 24 | 25 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | .nyc_output 4 | .idea 5 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | 2 | # Mongodb database adapter for [Yjs](https://github.com/yjs/yjs) 3 | Persistent Mongodb storage for [y-websocket](https://github.com/yjs/y-websocket) server 4 | 5 | ### Notes: 6 | * This is a fork of [Y-leveldb](https://github.com/yjs/y-leveldb) 7 | * This is not officially supported by the Yjs team. 8 | 9 | ## Use it 10 | ```sh 11 | npm install y-mongodb --save 12 | ``` 13 | 14 | #### create a simple server 15 | ```js 16 | const http = require('http'); 17 | const WebSocket = require('ws'); 18 | const Y = require('yjs'); 19 | const { MongodbPersistence } = require('y-mongodb'); 20 | const utils = require('y-websocket/bin/utils.js'); 21 | 22 | const location = process.env.MONGODB_URI; 23 | const collection = 'yjs-transactions'; 24 | const ldb = new MongodbPersistence(location, collection); 25 | 26 | const production = process.env.PRODUCTION != null; 27 | const port = process.env.PORT || 8080; 28 | 29 | 30 | const server = http.createServer((request, response) => { 31 | response.writeHead(200, { 'Content-Type': 'text/plain' }); 32 | response.end('okay'); 33 | }); 34 | 35 | 36 | // const wss = new WebSocket.Server({ server }); 37 | const wss = new WebSocket.Server({ noServer: true }); 38 | 39 | wss.on('connection', utils.setupWSConnection); 40 | server.on('upgrade', (request, socket, head) => { 41 | // You may check auth of request here.. 42 | /** 43 | * @param {any} ws 44 | */ 45 | const handleAuth = ws => { 46 | wss.emit('connection', ws, request) 47 | } 48 | wss.handleUpgrade(request, socket, head, handleAuth) 49 | }); 50 | 51 | /* 52 | Persistence must have the following signature: 53 | { bindState: function(string,WSSharedDoc):void, writeState:function(string,WSSharedDoc):Promise } 54 | */ 55 | utils.setPersistence({ 56 | bindState: async (docName, ydoc) => { 57 | // Here you listen to granular document updates and store them in the database 58 | // You don't have to do this, but it ensures that you don't lose content when the server crashes 59 | // See https://github.com/yjs/yjs#Document-Updates for documentation on how to encode 60 | // document updates 61 | 62 | const persistedYdoc = await ldb.getYDoc(docName); 63 | const newUpdates = Y.encodeStateAsUpdate(ydoc); 64 | ldb.storeUpdate(docName, newUpdates) 65 | Y.applyUpdate(ydoc, Y.encodeStateAsUpdate(persistedYdoc)); 66 | ydoc.on('update', async update => { 67 | ldb.storeUpdate(docName, update); 68 | }) 69 | }, 70 | writeState: async (docName, ydoc) => { 71 | // This is called when all connections to the document are closed. 72 | // In the future, this method might also be called in intervals or after a certain number of updates. 73 | return new Promise(resolve => { 74 | // When the returned Promise resolves, the document will be destroyed. 75 | // So make sure that the document really has been written to the database. 76 | resolve() 77 | }) 78 | } 79 | }) 80 | 81 | server.listen(port); 82 | 83 | console.log(`Listening to http://localhost:${port} ${production ? '(production)' : ''}`) 84 | 85 | ``` 86 | 87 | 88 | ## API 89 | 90 | ### `persistence = MongodbPersistence(mongoUril, collection)` 91 | 92 | Create a mongo persistence instance. 93 | 94 | #### `persistence.getYDoc(docName: string): Promise` 95 | 96 | Create a Y.Doc instance with the data stored in mongodb. 97 | 98 | #### `persistence.storeUpdate(docName: string, update: Uint8Array): Promise` 99 | Store a transaction to the database. 100 | 101 | #### `persistence.clearDocument(docName: string): Promise` 102 | Delete a document, and all associated data from the database. 103 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "y-mongodb", 3 | "version": "0.1.11", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.10.4", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 10 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 11 | "requires": { 12 | "@babel/highlight": "^7.10.4" 13 | } 14 | }, 15 | "@babel/generator": { 16 | "version": "7.10.5", 17 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.10.5.tgz", 18 | "integrity": "sha512-3vXxr3FEW7E7lJZiWQ3bM4+v/Vyr9C+hpolQ8BGFr9Y8Ri2tFLWTixmwKBafDujO1WVah4fhZBeU1bieKdghig==", 19 | "requires": { 20 | "@babel/types": "^7.10.5", 21 | "jsesc": "^2.5.1", 22 | "source-map": "^0.5.0" 23 | } 24 | }, 25 | "@babel/helper-function-name": { 26 | "version": "7.10.4", 27 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", 28 | "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", 29 | "requires": { 30 | "@babel/helper-get-function-arity": "^7.10.4", 31 | "@babel/template": "^7.10.4", 32 | "@babel/types": "^7.10.4" 33 | } 34 | }, 35 | "@babel/helper-get-function-arity": { 36 | "version": "7.10.4", 37 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", 38 | "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", 39 | "requires": { 40 | "@babel/types": "^7.10.4" 41 | } 42 | }, 43 | "@babel/helper-split-export-declaration": { 44 | "version": "7.10.4", 45 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.10.4.tgz", 46 | "integrity": "sha512-pySBTeoUff56fL5CBU2hWm9TesA4r/rOkI9DyJLvvgz09MB9YtfIYe3iBriVaYNaPe+Alua0vBIOVOLs2buWhg==", 47 | "requires": { 48 | "@babel/types": "^7.10.4" 49 | } 50 | }, 51 | "@babel/helper-validator-identifier": { 52 | "version": "7.10.4", 53 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 54 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==" 55 | }, 56 | "@babel/highlight": { 57 | "version": "7.10.4", 58 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 59 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 60 | "requires": { 61 | "@babel/helper-validator-identifier": "^7.10.4", 62 | "chalk": "^2.0.0", 63 | "js-tokens": "^4.0.0" 64 | } 65 | }, 66 | "@babel/parser": { 67 | "version": "7.10.5", 68 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.10.5.tgz", 69 | "integrity": "sha512-wfryxy4bE1UivvQKSQDU4/X6dr+i8bctjUjj8Zyt3DQy7NtPizJXT8M52nqpNKL+nq2PW8lxk4ZqLj0fD4B4hQ==" 70 | }, 71 | "@babel/template": { 72 | "version": "7.10.4", 73 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz", 74 | "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==", 75 | "requires": { 76 | "@babel/code-frame": "^7.10.4", 77 | "@babel/parser": "^7.10.4", 78 | "@babel/types": "^7.10.4" 79 | } 80 | }, 81 | "@babel/traverse": { 82 | "version": "7.10.5", 83 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.10.5.tgz", 84 | "integrity": "sha512-yc/fyv2gUjPqzTz0WHeRJH2pv7jA9kA7mBX2tXl/x5iOE81uaVPuGPtaYk7wmkx4b67mQ7NqI8rmT2pF47KYKQ==", 85 | "requires": { 86 | "@babel/code-frame": "^7.10.4", 87 | "@babel/generator": "^7.10.5", 88 | "@babel/helper-function-name": "^7.10.4", 89 | "@babel/helper-split-export-declaration": "^7.10.4", 90 | "@babel/parser": "^7.10.5", 91 | "@babel/types": "^7.10.5", 92 | "debug": "^4.1.0", 93 | "globals": "^11.1.0", 94 | "lodash": "^4.17.19" 95 | } 96 | }, 97 | "@babel/types": { 98 | "version": "7.10.5", 99 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.10.5.tgz", 100 | "integrity": "sha512-ixV66KWfCI6GKoA/2H9v6bQdbfXEwwpOdQ8cRvb4F+eyvhlaHxWFMQB4+3d9QFJXZsiiiqVrewNV0DFEQpyT4Q==", 101 | "requires": { 102 | "@babel/helper-validator-identifier": "^7.10.4", 103 | "lodash": "^4.17.19", 104 | "to-fast-properties": "^2.0.0" 105 | } 106 | }, 107 | "@rollup/plugin-commonjs": { 108 | "version": "14.0.0", 109 | "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-14.0.0.tgz", 110 | "integrity": "sha512-+PSmD9ePwTAeU106i9FRdc+Zb3XUWyW26mo5Atr2mk82hor8+nPwkztEjFo8/B1fJKfaQDg9aM2bzQkjhi7zOw==", 111 | "dev": true, 112 | "requires": { 113 | "@rollup/pluginutils": "^3.0.8", 114 | "commondir": "^1.0.1", 115 | "estree-walker": "^1.0.1", 116 | "glob": "^7.1.2", 117 | "is-reference": "^1.1.2", 118 | "magic-string": "^0.25.2", 119 | "resolve": "^1.11.0" 120 | } 121 | }, 122 | "@rollup/plugin-json": { 123 | "version": "4.1.0", 124 | "resolved": "https://registry.npmjs.org/@rollup/plugin-json/-/plugin-json-4.1.0.tgz", 125 | "integrity": "sha512-yfLbTdNS6amI/2OpmbiBoW12vngr5NW2jCJVZSBEz+H5KfUJZ2M7sDjk0U6GOOdCWFVScShte29o9NezJ53TPw==", 126 | "dev": true, 127 | "requires": { 128 | "@rollup/pluginutils": "^3.0.8" 129 | } 130 | }, 131 | "@rollup/plugin-node-resolve": { 132 | "version": "8.4.0", 133 | "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-8.4.0.tgz", 134 | "integrity": "sha512-LFqKdRLn0ShtQyf6SBYO69bGE1upV6wUhBX0vFOUnLAyzx5cwp8svA0eHUnu8+YU57XOkrMtfG63QOpQx25pHQ==", 135 | "dev": true, 136 | "requires": { 137 | "@rollup/pluginutils": "^3.1.0", 138 | "@types/resolve": "1.17.1", 139 | "builtin-modules": "^3.1.0", 140 | "deep-freeze": "^0.0.1", 141 | "deepmerge": "^4.2.2", 142 | "is-module": "^1.0.0", 143 | "resolve": "^1.17.0" 144 | } 145 | }, 146 | "@rollup/pluginutils": { 147 | "version": "3.1.0", 148 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", 149 | "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", 150 | "dev": true, 151 | "requires": { 152 | "@types/estree": "0.0.39", 153 | "estree-walker": "^1.0.1", 154 | "picomatch": "^2.2.2" 155 | } 156 | }, 157 | "@types/color-name": { 158 | "version": "1.1.1", 159 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 160 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 161 | "dev": true 162 | }, 163 | "@types/estree": { 164 | "version": "0.0.39", 165 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 166 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 167 | "dev": true 168 | }, 169 | "@types/node": { 170 | "version": "14.0.23", 171 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.0.23.tgz", 172 | "integrity": "sha512-Z4U8yDAl5TFkmYsZdFPdjeMa57NOvnaf1tljHzhouaPEp7LCj2JKkejpI1ODviIAQuW4CcQmxkQ77rnLsOOoKw==", 173 | "dev": true 174 | }, 175 | "@types/resolve": { 176 | "version": "1.17.1", 177 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz", 178 | "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==", 179 | "dev": true, 180 | "requires": { 181 | "@types/node": "*" 182 | } 183 | }, 184 | "acorn": { 185 | "version": "7.3.1", 186 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.3.1.tgz", 187 | "integrity": "sha512-tLc0wSnatxAQHVHUapaHdz72pi9KUyHjq5KyHjGg9Y8Ifdc79pTh2XvI6I1/chZbnM7QtNKzh66ooDogPZSleA==", 188 | "dev": true 189 | }, 190 | "acorn-jsx": { 191 | "version": "5.2.0", 192 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 193 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 194 | "dev": true 195 | }, 196 | "ajv": { 197 | "version": "6.12.3", 198 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.3.tgz", 199 | "integrity": "sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA==", 200 | "dev": true, 201 | "requires": { 202 | "fast-deep-equal": "^3.1.1", 203 | "fast-json-stable-stringify": "^2.0.0", 204 | "json-schema-traverse": "^0.4.1", 205 | "uri-js": "^4.2.2" 206 | } 207 | }, 208 | "ansi-escapes": { 209 | "version": "4.3.1", 210 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 211 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 212 | "dev": true, 213 | "requires": { 214 | "type-fest": "^0.11.0" 215 | }, 216 | "dependencies": { 217 | "type-fest": { 218 | "version": "0.11.0", 219 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 220 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 221 | "dev": true 222 | } 223 | } 224 | }, 225 | "ansi-regex": { 226 | "version": "4.1.0", 227 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 228 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 229 | }, 230 | "ansi-styles": { 231 | "version": "3.2.1", 232 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 233 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 234 | "requires": { 235 | "color-convert": "^1.9.0" 236 | } 237 | }, 238 | "append-transform": { 239 | "version": "1.0.0", 240 | "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-1.0.0.tgz", 241 | "integrity": "sha512-P009oYkeHyU742iSZJzZZywj4QRJdnTWffaKuJQLablCZ1uz6/cW4yaRgcDaoQ+uwOxxnt0gRUcwfsNP2ri0gw==", 242 | "requires": { 243 | "default-require-extensions": "^2.0.0" 244 | } 245 | }, 246 | "archy": { 247 | "version": "1.0.0", 248 | "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", 249 | "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=" 250 | }, 251 | "argparse": { 252 | "version": "1.0.10", 253 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 254 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 255 | "requires": { 256 | "sprintf-js": "~1.0.2" 257 | } 258 | }, 259 | "array-includes": { 260 | "version": "3.1.1", 261 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.1.tgz", 262 | "integrity": "sha512-c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ==", 263 | "dev": true, 264 | "requires": { 265 | "define-properties": "^1.1.3", 266 | "es-abstract": "^1.17.0", 267 | "is-string": "^1.0.5" 268 | } 269 | }, 270 | "astral-regex": { 271 | "version": "1.0.0", 272 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 273 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 274 | "dev": true 275 | }, 276 | "balanced-match": { 277 | "version": "1.0.0", 278 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 279 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 280 | }, 281 | "bl": { 282 | "version": "2.2.1", 283 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 284 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 285 | "requires": { 286 | "readable-stream": "^2.3.5", 287 | "safe-buffer": "^5.1.1" 288 | } 289 | }, 290 | "brace-expansion": { 291 | "version": "1.1.11", 292 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 293 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 294 | "requires": { 295 | "balanced-match": "^1.0.0", 296 | "concat-map": "0.0.1" 297 | } 298 | }, 299 | "bson": { 300 | "version": "1.1.4", 301 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.4.tgz", 302 | "integrity": "sha512-S/yKGU1syOMzO86+dGpg2qGoDL0zvzcb262G+gqEy6TgP6rt6z6qxSFX/8X6vLC91P7G7C3nLs0+bvDzmvBA3Q==" 303 | }, 304 | "builtin-modules": { 305 | "version": "3.1.0", 306 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", 307 | "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==", 308 | "dev": true 309 | }, 310 | "caching-transform": { 311 | "version": "3.0.2", 312 | "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-3.0.2.tgz", 313 | "integrity": "sha512-Mtgcv3lh3U0zRii/6qVgQODdPA4G3zhG+jtbCWj39RXuUFTMzH0vcdMtaJS1jPowd+It2Pqr6y3NJMQqOqCE2w==", 314 | "requires": { 315 | "hasha": "^3.0.0", 316 | "make-dir": "^2.0.0", 317 | "package-hash": "^3.0.0", 318 | "write-file-atomic": "^2.4.2" 319 | } 320 | }, 321 | "callsites": { 322 | "version": "3.1.0", 323 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 324 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 325 | "dev": true 326 | }, 327 | "camelcase": { 328 | "version": "5.3.1", 329 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 330 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" 331 | }, 332 | "chalk": { 333 | "version": "2.4.2", 334 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 335 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 336 | "requires": { 337 | "ansi-styles": "^3.2.1", 338 | "escape-string-regexp": "^1.0.5", 339 | "supports-color": "^5.3.0" 340 | } 341 | }, 342 | "chardet": { 343 | "version": "0.7.0", 344 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 345 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 346 | "dev": true 347 | }, 348 | "cli-cursor": { 349 | "version": "3.1.0", 350 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 351 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 352 | "dev": true, 353 | "requires": { 354 | "restore-cursor": "^3.1.0" 355 | } 356 | }, 357 | "cli-width": { 358 | "version": "3.0.0", 359 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz", 360 | "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==", 361 | "dev": true 362 | }, 363 | "cliui": { 364 | "version": "5.0.0", 365 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 366 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 367 | "requires": { 368 | "string-width": "^3.1.0", 369 | "strip-ansi": "^5.2.0", 370 | "wrap-ansi": "^5.1.0" 371 | } 372 | }, 373 | "color-convert": { 374 | "version": "1.9.3", 375 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 376 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 377 | "requires": { 378 | "color-name": "1.1.3" 379 | } 380 | }, 381 | "color-name": { 382 | "version": "1.1.3", 383 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 384 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 385 | }, 386 | "commondir": { 387 | "version": "1.0.1", 388 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 389 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=" 390 | }, 391 | "concat-map": { 392 | "version": "0.0.1", 393 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 394 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 395 | }, 396 | "contains-path": { 397 | "version": "0.1.0", 398 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 399 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 400 | "dev": true 401 | }, 402 | "convert-source-map": { 403 | "version": "1.7.0", 404 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 405 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 406 | "requires": { 407 | "safe-buffer": "~5.1.1" 408 | }, 409 | "dependencies": { 410 | "safe-buffer": { 411 | "version": "5.1.2", 412 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 413 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 414 | } 415 | } 416 | }, 417 | "core-util-is": { 418 | "version": "1.0.2", 419 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 420 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 421 | }, 422 | "cp-file": { 423 | "version": "6.2.0", 424 | "resolved": "https://registry.npmjs.org/cp-file/-/cp-file-6.2.0.tgz", 425 | "integrity": "sha512-fmvV4caBnofhPe8kOcitBwSn2f39QLjnAnGq3gO9dfd75mUytzKNZB1hde6QHunW2Rt+OwuBOMc3i1tNElbszA==", 426 | "requires": { 427 | "graceful-fs": "^4.1.2", 428 | "make-dir": "^2.0.0", 429 | "nested-error-stacks": "^2.0.0", 430 | "pify": "^4.0.1", 431 | "safe-buffer": "^5.0.1" 432 | } 433 | }, 434 | "cross-spawn": { 435 | "version": "4.0.2", 436 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-4.0.2.tgz", 437 | "integrity": "sha1-e5JHYhwjrf3ThWAEqCPL45dCTUE=", 438 | "requires": { 439 | "lru-cache": "^4.0.1", 440 | "which": "^1.2.9" 441 | } 442 | }, 443 | "debug": { 444 | "version": "4.1.1", 445 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 446 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 447 | "requires": { 448 | "ms": "^2.1.1" 449 | } 450 | }, 451 | "debug-log": { 452 | "version": "1.0.1", 453 | "resolved": "https://registry.npmjs.org/debug-log/-/debug-log-1.0.1.tgz", 454 | "integrity": "sha1-IwdjLUwEOCuN+KMvcLiVBG1SdF8=", 455 | "dev": true 456 | }, 457 | "decamelize": { 458 | "version": "1.2.0", 459 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 460 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 461 | }, 462 | "deep-freeze": { 463 | "version": "0.0.1", 464 | "resolved": "https://registry.npmjs.org/deep-freeze/-/deep-freeze-0.0.1.tgz", 465 | "integrity": "sha1-OgsABd4YZygZ39OM0x+RF5yJPoQ=", 466 | "dev": true 467 | }, 468 | "deep-is": { 469 | "version": "0.1.3", 470 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 471 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 472 | "dev": true 473 | }, 474 | "deepmerge": { 475 | "version": "4.2.2", 476 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", 477 | "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", 478 | "dev": true 479 | }, 480 | "default-require-extensions": { 481 | "version": "2.0.0", 482 | "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-2.0.0.tgz", 483 | "integrity": "sha1-9fj7sYp9bVCyH2QfZJ67Uiz+JPc=", 484 | "requires": { 485 | "strip-bom": "^3.0.0" 486 | } 487 | }, 488 | "define-properties": { 489 | "version": "1.1.3", 490 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 491 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 492 | "dev": true, 493 | "requires": { 494 | "object-keys": "^1.0.12" 495 | } 496 | }, 497 | "deglob": { 498 | "version": "4.0.1", 499 | "resolved": "https://registry.npmjs.org/deglob/-/deglob-4.0.1.tgz", 500 | "integrity": "sha512-/g+RDZ7yf2HvoW+E5Cy+K94YhgcFgr6C8LuHZD1O5HoNPkf3KY6RfXJ0DBGlB/NkLi5gml+G9zqRzk9S0mHZCg==", 501 | "dev": true, 502 | "requires": { 503 | "find-root": "^1.0.0", 504 | "glob": "^7.0.5", 505 | "ignore": "^5.0.0", 506 | "pkg-config": "^1.1.0", 507 | "run-parallel": "^1.1.2", 508 | "uniq": "^1.0.1" 509 | }, 510 | "dependencies": { 511 | "ignore": { 512 | "version": "5.1.8", 513 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 514 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 515 | "dev": true 516 | } 517 | } 518 | }, 519 | "denque": { 520 | "version": "1.4.1", 521 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 522 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==" 523 | }, 524 | "doctrine": { 525 | "version": "3.0.0", 526 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 527 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 528 | "dev": true, 529 | "requires": { 530 | "esutils": "^2.0.2" 531 | } 532 | }, 533 | "each-series": { 534 | "version": "1.0.0", 535 | "resolved": "https://registry.npmjs.org/each-series/-/each-series-1.0.0.tgz", 536 | "integrity": "sha1-+Ibmxm39sl7x/nNWQUbuXLR4r8s=" 537 | }, 538 | "emoji-regex": { 539 | "version": "7.0.3", 540 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 541 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 542 | }, 543 | "error-ex": { 544 | "version": "1.3.2", 545 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 546 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 547 | "requires": { 548 | "is-arrayish": "^0.2.1" 549 | } 550 | }, 551 | "es-abstract": { 552 | "version": "1.17.6", 553 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz", 554 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==", 555 | "dev": true, 556 | "requires": { 557 | "es-to-primitive": "^1.2.1", 558 | "function-bind": "^1.1.1", 559 | "has": "^1.0.3", 560 | "has-symbols": "^1.0.1", 561 | "is-callable": "^1.2.0", 562 | "is-regex": "^1.1.0", 563 | "object-inspect": "^1.7.0", 564 | "object-keys": "^1.1.1", 565 | "object.assign": "^4.1.0", 566 | "string.prototype.trimend": "^1.0.1", 567 | "string.prototype.trimstart": "^1.0.1" 568 | } 569 | }, 570 | "es-to-primitive": { 571 | "version": "1.2.1", 572 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 573 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 574 | "dev": true, 575 | "requires": { 576 | "is-callable": "^1.1.4", 577 | "is-date-object": "^1.0.1", 578 | "is-symbol": "^1.0.2" 579 | } 580 | }, 581 | "es6-error": { 582 | "version": "4.1.1", 583 | "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", 584 | "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==" 585 | }, 586 | "escape-string-regexp": { 587 | "version": "1.0.5", 588 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 589 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 590 | }, 591 | "eslint": { 592 | "version": "6.8.0", 593 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 594 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 595 | "dev": true, 596 | "requires": { 597 | "@babel/code-frame": "^7.0.0", 598 | "ajv": "^6.10.0", 599 | "chalk": "^2.1.0", 600 | "cross-spawn": "^6.0.5", 601 | "debug": "^4.0.1", 602 | "doctrine": "^3.0.0", 603 | "eslint-scope": "^5.0.0", 604 | "eslint-utils": "^1.4.3", 605 | "eslint-visitor-keys": "^1.1.0", 606 | "espree": "^6.1.2", 607 | "esquery": "^1.0.1", 608 | "esutils": "^2.0.2", 609 | "file-entry-cache": "^5.0.1", 610 | "functional-red-black-tree": "^1.0.1", 611 | "glob-parent": "^5.0.0", 612 | "globals": "^12.1.0", 613 | "ignore": "^4.0.6", 614 | "import-fresh": "^3.0.0", 615 | "imurmurhash": "^0.1.4", 616 | "inquirer": "^7.0.0", 617 | "is-glob": "^4.0.0", 618 | "js-yaml": "^3.13.1", 619 | "json-stable-stringify-without-jsonify": "^1.0.1", 620 | "levn": "^0.3.0", 621 | "lodash": "^4.17.14", 622 | "minimatch": "^3.0.4", 623 | "mkdirp": "^0.5.1", 624 | "natural-compare": "^1.4.0", 625 | "optionator": "^0.8.3", 626 | "progress": "^2.0.0", 627 | "regexpp": "^2.0.1", 628 | "semver": "^6.1.2", 629 | "strip-ansi": "^5.2.0", 630 | "strip-json-comments": "^3.0.1", 631 | "table": "^5.2.3", 632 | "text-table": "^0.2.0", 633 | "v8-compile-cache": "^2.0.3" 634 | }, 635 | "dependencies": { 636 | "cross-spawn": { 637 | "version": "6.0.5", 638 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 639 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 640 | "dev": true, 641 | "requires": { 642 | "nice-try": "^1.0.4", 643 | "path-key": "^2.0.1", 644 | "semver": "^5.5.0", 645 | "shebang-command": "^1.2.0", 646 | "which": "^1.2.9" 647 | }, 648 | "dependencies": { 649 | "semver": { 650 | "version": "5.7.1", 651 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 652 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 653 | "dev": true 654 | } 655 | } 656 | }, 657 | "globals": { 658 | "version": "12.4.0", 659 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 660 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 661 | "dev": true, 662 | "requires": { 663 | "type-fest": "^0.8.1" 664 | } 665 | }, 666 | "semver": { 667 | "version": "6.3.0", 668 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 669 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 670 | "dev": true 671 | } 672 | } 673 | }, 674 | "eslint-config-standard": { 675 | "version": "14.1.1", 676 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-14.1.1.tgz", 677 | "integrity": "sha512-Z9B+VR+JIXRxz21udPTL9HpFMyoMUEeX1G251EQ6e05WD9aPVtVBn09XUmZ259wCMlCDmYDSZG62Hhm+ZTJcUg==", 678 | "dev": true 679 | }, 680 | "eslint-config-standard-jsx": { 681 | "version": "8.1.0", 682 | "resolved": "https://registry.npmjs.org/eslint-config-standard-jsx/-/eslint-config-standard-jsx-8.1.0.tgz", 683 | "integrity": "sha512-ULVC8qH8qCqbU792ZOO6DaiaZyHNS/5CZt3hKqHkEhVlhPEPN3nfBqqxJCyp59XrjIBZPu1chMYe9T2DXZ7TMw==", 684 | "dev": true 685 | }, 686 | "eslint-import-resolver-node": { 687 | "version": "0.3.4", 688 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.4.tgz", 689 | "integrity": "sha512-ogtf+5AB/O+nM6DIeBUNr2fuT7ot9Qg/1harBfBtaP13ekEWFQEEMP94BCB7zaNW3gyY+8SHYF00rnqYwXKWOA==", 690 | "dev": true, 691 | "requires": { 692 | "debug": "^2.6.9", 693 | "resolve": "^1.13.1" 694 | }, 695 | "dependencies": { 696 | "debug": { 697 | "version": "2.6.9", 698 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 699 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 700 | "dev": true, 701 | "requires": { 702 | "ms": "2.0.0" 703 | } 704 | }, 705 | "ms": { 706 | "version": "2.0.0", 707 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 708 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 709 | "dev": true 710 | } 711 | } 712 | }, 713 | "eslint-module-utils": { 714 | "version": "2.6.0", 715 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz", 716 | "integrity": "sha512-6j9xxegbqe8/kZY8cYpcp0xhbK0EgJlg3g9mib3/miLaExuuwc3n5UEfSnU6hWMbT0FAYVvDbL9RrRgpUeQIvA==", 717 | "dev": true, 718 | "requires": { 719 | "debug": "^2.6.9", 720 | "pkg-dir": "^2.0.0" 721 | }, 722 | "dependencies": { 723 | "debug": { 724 | "version": "2.6.9", 725 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 726 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 727 | "dev": true, 728 | "requires": { 729 | "ms": "2.0.0" 730 | } 731 | }, 732 | "find-up": { 733 | "version": "2.1.0", 734 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 735 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 736 | "dev": true, 737 | "requires": { 738 | "locate-path": "^2.0.0" 739 | } 740 | }, 741 | "locate-path": { 742 | "version": "2.0.0", 743 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 744 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 745 | "dev": true, 746 | "requires": { 747 | "p-locate": "^2.0.0", 748 | "path-exists": "^3.0.0" 749 | } 750 | }, 751 | "ms": { 752 | "version": "2.0.0", 753 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 754 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 755 | "dev": true 756 | }, 757 | "p-limit": { 758 | "version": "1.3.0", 759 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 760 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 761 | "dev": true, 762 | "requires": { 763 | "p-try": "^1.0.0" 764 | } 765 | }, 766 | "p-locate": { 767 | "version": "2.0.0", 768 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 769 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 770 | "dev": true, 771 | "requires": { 772 | "p-limit": "^1.1.0" 773 | } 774 | }, 775 | "p-try": { 776 | "version": "1.0.0", 777 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 778 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 779 | "dev": true 780 | }, 781 | "pkg-dir": { 782 | "version": "2.0.0", 783 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 784 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 785 | "dev": true, 786 | "requires": { 787 | "find-up": "^2.1.0" 788 | } 789 | } 790 | } 791 | }, 792 | "eslint-plugin-es": { 793 | "version": "2.0.0", 794 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-2.0.0.tgz", 795 | "integrity": "sha512-f6fceVtg27BR02EYnBhgWLFQfK6bN4Ll0nQFrBHOlCsAyxeZkn0NHns5O0YZOPrV1B3ramd6cgFwaoFLcSkwEQ==", 796 | "dev": true, 797 | "requires": { 798 | "eslint-utils": "^1.4.2", 799 | "regexpp": "^3.0.0" 800 | }, 801 | "dependencies": { 802 | "regexpp": { 803 | "version": "3.1.0", 804 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 805 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 806 | "dev": true 807 | } 808 | } 809 | }, 810 | "eslint-plugin-import": { 811 | "version": "2.18.2", 812 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.18.2.tgz", 813 | "integrity": "sha512-5ohpsHAiUBRNaBWAF08izwUGlbrJoJJ+W9/TBwsGoR1MnlgfwMIKrFeSjWbt6moabiXW9xNvtFz+97KHRfI4HQ==", 814 | "dev": true, 815 | "requires": { 816 | "array-includes": "^3.0.3", 817 | "contains-path": "^0.1.0", 818 | "debug": "^2.6.9", 819 | "doctrine": "1.5.0", 820 | "eslint-import-resolver-node": "^0.3.2", 821 | "eslint-module-utils": "^2.4.0", 822 | "has": "^1.0.3", 823 | "minimatch": "^3.0.4", 824 | "object.values": "^1.1.0", 825 | "read-pkg-up": "^2.0.0", 826 | "resolve": "^1.11.0" 827 | }, 828 | "dependencies": { 829 | "debug": { 830 | "version": "2.6.9", 831 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 832 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 833 | "dev": true, 834 | "requires": { 835 | "ms": "2.0.0" 836 | } 837 | }, 838 | "doctrine": { 839 | "version": "1.5.0", 840 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 841 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 842 | "dev": true, 843 | "requires": { 844 | "esutils": "^2.0.2", 845 | "isarray": "^1.0.0" 846 | } 847 | }, 848 | "find-up": { 849 | "version": "2.1.0", 850 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 851 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 852 | "dev": true, 853 | "requires": { 854 | "locate-path": "^2.0.0" 855 | } 856 | }, 857 | "load-json-file": { 858 | "version": "2.0.0", 859 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 860 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 861 | "dev": true, 862 | "requires": { 863 | "graceful-fs": "^4.1.2", 864 | "parse-json": "^2.2.0", 865 | "pify": "^2.0.0", 866 | "strip-bom": "^3.0.0" 867 | } 868 | }, 869 | "locate-path": { 870 | "version": "2.0.0", 871 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 872 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 873 | "dev": true, 874 | "requires": { 875 | "p-locate": "^2.0.0", 876 | "path-exists": "^3.0.0" 877 | } 878 | }, 879 | "ms": { 880 | "version": "2.0.0", 881 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 882 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 883 | "dev": true 884 | }, 885 | "p-limit": { 886 | "version": "1.3.0", 887 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 888 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 889 | "dev": true, 890 | "requires": { 891 | "p-try": "^1.0.0" 892 | } 893 | }, 894 | "p-locate": { 895 | "version": "2.0.0", 896 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 897 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 898 | "dev": true, 899 | "requires": { 900 | "p-limit": "^1.1.0" 901 | } 902 | }, 903 | "p-try": { 904 | "version": "1.0.0", 905 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 906 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 907 | "dev": true 908 | }, 909 | "parse-json": { 910 | "version": "2.2.0", 911 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 912 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 913 | "dev": true, 914 | "requires": { 915 | "error-ex": "^1.2.0" 916 | } 917 | }, 918 | "path-type": { 919 | "version": "2.0.0", 920 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 921 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 922 | "dev": true, 923 | "requires": { 924 | "pify": "^2.0.0" 925 | } 926 | }, 927 | "pify": { 928 | "version": "2.3.0", 929 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 930 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 931 | "dev": true 932 | }, 933 | "read-pkg": { 934 | "version": "2.0.0", 935 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 936 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 937 | "dev": true, 938 | "requires": { 939 | "load-json-file": "^2.0.0", 940 | "normalize-package-data": "^2.3.2", 941 | "path-type": "^2.0.0" 942 | } 943 | }, 944 | "read-pkg-up": { 945 | "version": "2.0.0", 946 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 947 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 948 | "dev": true, 949 | "requires": { 950 | "find-up": "^2.0.0", 951 | "read-pkg": "^2.0.0" 952 | } 953 | } 954 | } 955 | }, 956 | "eslint-plugin-node": { 957 | "version": "10.0.0", 958 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-10.0.0.tgz", 959 | "integrity": "sha512-1CSyM/QCjs6PXaT18+zuAXsjXGIGo5Rw630rSKwokSs2jrYURQc4R5JZpoanNCqwNmepg+0eZ9L7YiRUJb8jiQ==", 960 | "dev": true, 961 | "requires": { 962 | "eslint-plugin-es": "^2.0.0", 963 | "eslint-utils": "^1.4.2", 964 | "ignore": "^5.1.1", 965 | "minimatch": "^3.0.4", 966 | "resolve": "^1.10.1", 967 | "semver": "^6.1.0" 968 | }, 969 | "dependencies": { 970 | "ignore": { 971 | "version": "5.1.8", 972 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz", 973 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==", 974 | "dev": true 975 | }, 976 | "semver": { 977 | "version": "6.3.0", 978 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 979 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 980 | "dev": true 981 | } 982 | } 983 | }, 984 | "eslint-plugin-promise": { 985 | "version": "4.2.1", 986 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-4.2.1.tgz", 987 | "integrity": "sha512-VoM09vT7bfA7D+upt+FjeBO5eHIJQBUWki1aPvB+vbNiHS3+oGIJGIeyBtKQTME6UPXXy3vV07OL1tHd3ANuDw==", 988 | "dev": true 989 | }, 990 | "eslint-plugin-react": { 991 | "version": "7.14.3", 992 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.14.3.tgz", 993 | "integrity": "sha512-EzdyyBWC4Uz2hPYBiEJrKCUi2Fn+BJ9B/pJQcjw5X+x/H2Nm59S4MJIvL4O5NEE0+WbnQwEBxWY03oUk+Bc3FA==", 994 | "dev": true, 995 | "requires": { 996 | "array-includes": "^3.0.3", 997 | "doctrine": "^2.1.0", 998 | "has": "^1.0.3", 999 | "jsx-ast-utils": "^2.1.0", 1000 | "object.entries": "^1.1.0", 1001 | "object.fromentries": "^2.0.0", 1002 | "object.values": "^1.1.0", 1003 | "prop-types": "^15.7.2", 1004 | "resolve": "^1.10.1" 1005 | }, 1006 | "dependencies": { 1007 | "doctrine": { 1008 | "version": "2.1.0", 1009 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1010 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1011 | "dev": true, 1012 | "requires": { 1013 | "esutils": "^2.0.2" 1014 | } 1015 | } 1016 | } 1017 | }, 1018 | "eslint-plugin-standard": { 1019 | "version": "4.0.1", 1020 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-4.0.1.tgz", 1021 | "integrity": "sha512-v/KBnfyaOMPmZc/dmc6ozOdWqekGp7bBGq4jLAecEfPGmfKiWS4sA8sC0LqiV9w5qmXAtXVn4M3p1jSyhY85SQ==", 1022 | "dev": true 1023 | }, 1024 | "eslint-scope": { 1025 | "version": "5.1.0", 1026 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.0.tgz", 1027 | "integrity": "sha512-iiGRvtxWqgtx5m8EyQUJihBloE4EnYeGE/bz1wSPwJE6tZuJUtHlhqDM4Xj2ukE8Dyy1+HCZ4hE0fzIVMzb58w==", 1028 | "dev": true, 1029 | "requires": { 1030 | "esrecurse": "^4.1.0", 1031 | "estraverse": "^4.1.1" 1032 | } 1033 | }, 1034 | "eslint-utils": { 1035 | "version": "1.4.3", 1036 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 1037 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 1038 | "dev": true, 1039 | "requires": { 1040 | "eslint-visitor-keys": "^1.1.0" 1041 | } 1042 | }, 1043 | "eslint-visitor-keys": { 1044 | "version": "1.3.0", 1045 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1046 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1047 | "dev": true 1048 | }, 1049 | "espree": { 1050 | "version": "6.2.1", 1051 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", 1052 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", 1053 | "dev": true, 1054 | "requires": { 1055 | "acorn": "^7.1.1", 1056 | "acorn-jsx": "^5.2.0", 1057 | "eslint-visitor-keys": "^1.1.0" 1058 | } 1059 | }, 1060 | "esprima": { 1061 | "version": "4.0.1", 1062 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1063 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 1064 | }, 1065 | "esquery": { 1066 | "version": "1.3.1", 1067 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 1068 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 1069 | "dev": true, 1070 | "requires": { 1071 | "estraverse": "^5.1.0" 1072 | }, 1073 | "dependencies": { 1074 | "estraverse": { 1075 | "version": "5.1.0", 1076 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 1077 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 1078 | "dev": true 1079 | } 1080 | } 1081 | }, 1082 | "esrecurse": { 1083 | "version": "4.2.1", 1084 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1085 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1086 | "dev": true, 1087 | "requires": { 1088 | "estraverse": "^4.1.0" 1089 | } 1090 | }, 1091 | "estraverse": { 1092 | "version": "4.3.0", 1093 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1094 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1095 | "dev": true 1096 | }, 1097 | "estree-walker": { 1098 | "version": "1.0.1", 1099 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", 1100 | "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", 1101 | "dev": true 1102 | }, 1103 | "esutils": { 1104 | "version": "2.0.3", 1105 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1106 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1107 | "dev": true 1108 | }, 1109 | "external-editor": { 1110 | "version": "3.1.0", 1111 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 1112 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 1113 | "dev": true, 1114 | "requires": { 1115 | "chardet": "^0.7.0", 1116 | "iconv-lite": "^0.4.24", 1117 | "tmp": "^0.0.33" 1118 | } 1119 | }, 1120 | "fast-deep-equal": { 1121 | "version": "3.1.3", 1122 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1123 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1124 | "dev": true 1125 | }, 1126 | "fast-json-stable-stringify": { 1127 | "version": "2.1.0", 1128 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1129 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1130 | "dev": true 1131 | }, 1132 | "fast-levenshtein": { 1133 | "version": "2.0.6", 1134 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1135 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1136 | "dev": true 1137 | }, 1138 | "figures": { 1139 | "version": "3.2.0", 1140 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 1141 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 1142 | "dev": true, 1143 | "requires": { 1144 | "escape-string-regexp": "^1.0.5" 1145 | } 1146 | }, 1147 | "file-entry-cache": { 1148 | "version": "5.0.1", 1149 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 1150 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 1151 | "dev": true, 1152 | "requires": { 1153 | "flat-cache": "^2.0.1" 1154 | } 1155 | }, 1156 | "find-cache-dir": { 1157 | "version": "2.1.0", 1158 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", 1159 | "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", 1160 | "requires": { 1161 | "commondir": "^1.0.1", 1162 | "make-dir": "^2.0.0", 1163 | "pkg-dir": "^3.0.0" 1164 | } 1165 | }, 1166 | "find-root": { 1167 | "version": "1.1.0", 1168 | "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", 1169 | "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==", 1170 | "dev": true 1171 | }, 1172 | "find-up": { 1173 | "version": "3.0.0", 1174 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1175 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1176 | "requires": { 1177 | "locate-path": "^3.0.0" 1178 | } 1179 | }, 1180 | "flat-cache": { 1181 | "version": "2.0.1", 1182 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 1183 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 1184 | "dev": true, 1185 | "requires": { 1186 | "flatted": "^2.0.0", 1187 | "rimraf": "2.6.3", 1188 | "write": "1.0.3" 1189 | }, 1190 | "dependencies": { 1191 | "rimraf": { 1192 | "version": "2.6.3", 1193 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1194 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1195 | "dev": true, 1196 | "requires": { 1197 | "glob": "^7.1.3" 1198 | } 1199 | } 1200 | } 1201 | }, 1202 | "flatted": { 1203 | "version": "2.0.2", 1204 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 1205 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 1206 | "dev": true 1207 | }, 1208 | "foreground-child": { 1209 | "version": "1.5.6", 1210 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-1.5.6.tgz", 1211 | "integrity": "sha1-T9ca0t/elnibmApcCilZN8svXOk=", 1212 | "requires": { 1213 | "cross-spawn": "^4", 1214 | "signal-exit": "^3.0.0" 1215 | } 1216 | }, 1217 | "fs.realpath": { 1218 | "version": "1.0.0", 1219 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1220 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 1221 | }, 1222 | "fsevents": { 1223 | "version": "2.1.3", 1224 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 1225 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 1226 | "dev": true, 1227 | "optional": true 1228 | }, 1229 | "function-bind": { 1230 | "version": "1.1.1", 1231 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1232 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1233 | "dev": true 1234 | }, 1235 | "functional-red-black-tree": { 1236 | "version": "1.0.1", 1237 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1238 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1239 | "dev": true 1240 | }, 1241 | "get-caller-file": { 1242 | "version": "2.0.5", 1243 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1244 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" 1245 | }, 1246 | "get-stdin": { 1247 | "version": "7.0.0", 1248 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-7.0.0.tgz", 1249 | "integrity": "sha512-zRKcywvrXlXsA0v0i9Io4KDRaAw7+a1ZpjRwl9Wox8PFlVCCHra7E9c4kqXCoCM9nR5tBkaTTZRBoCm60bFqTQ==", 1250 | "dev": true 1251 | }, 1252 | "glob": { 1253 | "version": "7.1.6", 1254 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1255 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1256 | "requires": { 1257 | "fs.realpath": "^1.0.0", 1258 | "inflight": "^1.0.4", 1259 | "inherits": "2", 1260 | "minimatch": "^3.0.4", 1261 | "once": "^1.3.0", 1262 | "path-is-absolute": "^1.0.0" 1263 | } 1264 | }, 1265 | "glob-parent": { 1266 | "version": "5.1.1", 1267 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1268 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1269 | "dev": true, 1270 | "requires": { 1271 | "is-glob": "^4.0.1" 1272 | } 1273 | }, 1274 | "globals": { 1275 | "version": "11.12.0", 1276 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1277 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" 1278 | }, 1279 | "graceful-fs": { 1280 | "version": "4.2.4", 1281 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1282 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==" 1283 | }, 1284 | "has": { 1285 | "version": "1.0.3", 1286 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1287 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1288 | "dev": true, 1289 | "requires": { 1290 | "function-bind": "^1.1.1" 1291 | } 1292 | }, 1293 | "has-flag": { 1294 | "version": "3.0.0", 1295 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1296 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 1297 | }, 1298 | "has-symbols": { 1299 | "version": "1.0.1", 1300 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1301 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1302 | "dev": true 1303 | }, 1304 | "hasha": { 1305 | "version": "3.0.0", 1306 | "resolved": "https://registry.npmjs.org/hasha/-/hasha-3.0.0.tgz", 1307 | "integrity": "sha1-UqMvq4Vp1BymmmH/GiFPjrfIvTk=", 1308 | "requires": { 1309 | "is-stream": "^1.0.1" 1310 | } 1311 | }, 1312 | "hosted-git-info": { 1313 | "version": "2.8.8", 1314 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz", 1315 | "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==" 1316 | }, 1317 | "html-escaper": { 1318 | "version": "2.0.2", 1319 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1320 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==" 1321 | }, 1322 | "iconv-lite": { 1323 | "version": "0.4.24", 1324 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1325 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1326 | "dev": true, 1327 | "requires": { 1328 | "safer-buffer": ">= 2.1.2 < 3" 1329 | } 1330 | }, 1331 | "ignore": { 1332 | "version": "4.0.6", 1333 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1334 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1335 | "dev": true 1336 | }, 1337 | "import-fresh": { 1338 | "version": "3.2.1", 1339 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1340 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1341 | "dev": true, 1342 | "requires": { 1343 | "parent-module": "^1.0.0", 1344 | "resolve-from": "^4.0.0" 1345 | }, 1346 | "dependencies": { 1347 | "resolve-from": { 1348 | "version": "4.0.0", 1349 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1350 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1351 | "dev": true 1352 | } 1353 | } 1354 | }, 1355 | "imurmurhash": { 1356 | "version": "0.1.4", 1357 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1358 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 1359 | }, 1360 | "inflight": { 1361 | "version": "1.0.6", 1362 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1363 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1364 | "requires": { 1365 | "once": "^1.3.0", 1366 | "wrappy": "1" 1367 | } 1368 | }, 1369 | "inherits": { 1370 | "version": "2.0.4", 1371 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1372 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1373 | }, 1374 | "inquirer": { 1375 | "version": "7.3.2", 1376 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.3.2.tgz", 1377 | "integrity": "sha512-DF4osh1FM6l0RJc5YWYhSDB6TawiBRlbV9Cox8MWlidU218Tb7fm3lQTULyUJDfJ0tjbzl0W4q651mrCCEM55w==", 1378 | "dev": true, 1379 | "requires": { 1380 | "ansi-escapes": "^4.2.1", 1381 | "chalk": "^4.1.0", 1382 | "cli-cursor": "^3.1.0", 1383 | "cli-width": "^3.0.0", 1384 | "external-editor": "^3.0.3", 1385 | "figures": "^3.0.0", 1386 | "lodash": "^4.17.16", 1387 | "mute-stream": "0.0.8", 1388 | "run-async": "^2.4.0", 1389 | "rxjs": "^6.6.0", 1390 | "string-width": "^4.1.0", 1391 | "strip-ansi": "^6.0.0", 1392 | "through": "^2.3.6" 1393 | }, 1394 | "dependencies": { 1395 | "ansi-regex": { 1396 | "version": "5.0.0", 1397 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1398 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1399 | "dev": true 1400 | }, 1401 | "ansi-styles": { 1402 | "version": "4.2.1", 1403 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 1404 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1405 | "dev": true, 1406 | "requires": { 1407 | "@types/color-name": "^1.1.1", 1408 | "color-convert": "^2.0.1" 1409 | } 1410 | }, 1411 | "chalk": { 1412 | "version": "4.1.0", 1413 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1414 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1415 | "dev": true, 1416 | "requires": { 1417 | "ansi-styles": "^4.1.0", 1418 | "supports-color": "^7.1.0" 1419 | } 1420 | }, 1421 | "color-convert": { 1422 | "version": "2.0.1", 1423 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1424 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1425 | "dev": true, 1426 | "requires": { 1427 | "color-name": "~1.1.4" 1428 | } 1429 | }, 1430 | "color-name": { 1431 | "version": "1.1.4", 1432 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1433 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1434 | "dev": true 1435 | }, 1436 | "emoji-regex": { 1437 | "version": "8.0.0", 1438 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1439 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1440 | "dev": true 1441 | }, 1442 | "has-flag": { 1443 | "version": "4.0.0", 1444 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1445 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1446 | "dev": true 1447 | }, 1448 | "is-fullwidth-code-point": { 1449 | "version": "3.0.0", 1450 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1451 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1452 | "dev": true 1453 | }, 1454 | "string-width": { 1455 | "version": "4.2.0", 1456 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1457 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1458 | "dev": true, 1459 | "requires": { 1460 | "emoji-regex": "^8.0.0", 1461 | "is-fullwidth-code-point": "^3.0.0", 1462 | "strip-ansi": "^6.0.0" 1463 | } 1464 | }, 1465 | "strip-ansi": { 1466 | "version": "6.0.0", 1467 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1468 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1469 | "dev": true, 1470 | "requires": { 1471 | "ansi-regex": "^5.0.0" 1472 | } 1473 | }, 1474 | "supports-color": { 1475 | "version": "7.1.0", 1476 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1477 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1478 | "dev": true, 1479 | "requires": { 1480 | "has-flag": "^4.0.0" 1481 | } 1482 | } 1483 | } 1484 | }, 1485 | "is-arrayish": { 1486 | "version": "0.2.1", 1487 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1488 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" 1489 | }, 1490 | "is-callable": { 1491 | "version": "1.2.0", 1492 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.0.tgz", 1493 | "integrity": "sha512-pyVD9AaGLxtg6srb2Ng6ynWJqkHU9bEM087AKck0w8QwDarTfNcpIYoU8x8Hv2Icm8u6kFJM18Dag8lyqGkviw==", 1494 | "dev": true 1495 | }, 1496 | "is-date-object": { 1497 | "version": "1.0.2", 1498 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1499 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1500 | "dev": true 1501 | }, 1502 | "is-extglob": { 1503 | "version": "2.1.1", 1504 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1505 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1506 | "dev": true 1507 | }, 1508 | "is-fullwidth-code-point": { 1509 | "version": "2.0.0", 1510 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1511 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 1512 | }, 1513 | "is-glob": { 1514 | "version": "4.0.1", 1515 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1516 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1517 | "dev": true, 1518 | "requires": { 1519 | "is-extglob": "^2.1.1" 1520 | } 1521 | }, 1522 | "is-module": { 1523 | "version": "1.0.0", 1524 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 1525 | "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=", 1526 | "dev": true 1527 | }, 1528 | "is-reference": { 1529 | "version": "1.2.1", 1530 | "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.2.1.tgz", 1531 | "integrity": "sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==", 1532 | "dev": true, 1533 | "requires": { 1534 | "@types/estree": "*" 1535 | } 1536 | }, 1537 | "is-regex": { 1538 | "version": "1.1.0", 1539 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.0.tgz", 1540 | "integrity": "sha512-iI97M8KTWID2la5uYXlkbSDQIg4F6o1sYboZKKTDpnDQMLtUL86zxhgDet3Q2SriaYsyGqZ6Mn2SjbRKeLHdqw==", 1541 | "dev": true, 1542 | "requires": { 1543 | "has-symbols": "^1.0.1" 1544 | } 1545 | }, 1546 | "is-stream": { 1547 | "version": "1.1.0", 1548 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1549 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 1550 | }, 1551 | "is-string": { 1552 | "version": "1.0.5", 1553 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 1554 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 1555 | "dev": true 1556 | }, 1557 | "is-symbol": { 1558 | "version": "1.0.3", 1559 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1560 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1561 | "dev": true, 1562 | "requires": { 1563 | "has-symbols": "^1.0.1" 1564 | } 1565 | }, 1566 | "isarray": { 1567 | "version": "1.0.0", 1568 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1569 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1570 | }, 1571 | "isexe": { 1572 | "version": "2.0.0", 1573 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1574 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1575 | }, 1576 | "isomorphic.js": { 1577 | "version": "0.1.4", 1578 | "resolved": "https://registry.npmjs.org/isomorphic.js/-/isomorphic.js-0.1.4.tgz", 1579 | "integrity": "sha512-t9zbgkjE7f9f2M6OSW49YEq0lUrSdAllBbWFUZoeck/rnnFae6UlhmDtXWs48VJY3ZpryCoZsRiAiKD44hPIGQ==" 1580 | }, 1581 | "istanbul-lib-coverage": { 1582 | "version": "2.0.5", 1583 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.5.tgz", 1584 | "integrity": "sha512-8aXznuEPCJvGnMSRft4udDRDtb1V3pkQkMMI5LI+6HuQz5oQ4J2UFn1H82raA3qJtyOLkkwVqICBQkjnGtn5mA==" 1585 | }, 1586 | "istanbul-lib-hook": { 1587 | "version": "2.0.7", 1588 | "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-2.0.7.tgz", 1589 | "integrity": "sha512-vrRztU9VRRFDyC+aklfLoeXyNdTfga2EI3udDGn4cZ6fpSXpHLV9X6CHvfoMCPtggg8zvDDmC4b9xfu0z6/llA==", 1590 | "requires": { 1591 | "append-transform": "^1.0.0" 1592 | } 1593 | }, 1594 | "istanbul-lib-instrument": { 1595 | "version": "3.3.0", 1596 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-3.3.0.tgz", 1597 | "integrity": "sha512-5nnIN4vo5xQZHdXno/YDXJ0G+I3dAm4XgzfSVTPLQpj/zAV2dV6Juy0yaf10/zrJOJeHoN3fraFe+XRq2bFVZA==", 1598 | "requires": { 1599 | "@babel/generator": "^7.4.0", 1600 | "@babel/parser": "^7.4.3", 1601 | "@babel/template": "^7.4.0", 1602 | "@babel/traverse": "^7.4.3", 1603 | "@babel/types": "^7.4.0", 1604 | "istanbul-lib-coverage": "^2.0.5", 1605 | "semver": "^6.0.0" 1606 | }, 1607 | "dependencies": { 1608 | "semver": { 1609 | "version": "6.3.0", 1610 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1611 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1612 | } 1613 | } 1614 | }, 1615 | "istanbul-lib-report": { 1616 | "version": "2.0.8", 1617 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-2.0.8.tgz", 1618 | "integrity": "sha512-fHBeG573EIihhAblwgxrSenp0Dby6tJMFR/HvlerBsrCTD5bkUuoNtn3gVh29ZCS824cGGBPn7Sg7cNk+2xUsQ==", 1619 | "requires": { 1620 | "istanbul-lib-coverage": "^2.0.5", 1621 | "make-dir": "^2.1.0", 1622 | "supports-color": "^6.1.0" 1623 | }, 1624 | "dependencies": { 1625 | "supports-color": { 1626 | "version": "6.1.0", 1627 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", 1628 | "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", 1629 | "requires": { 1630 | "has-flag": "^3.0.0" 1631 | } 1632 | } 1633 | } 1634 | }, 1635 | "istanbul-lib-source-maps": { 1636 | "version": "3.0.6", 1637 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-3.0.6.tgz", 1638 | "integrity": "sha512-R47KzMtDJH6X4/YW9XTx+jrLnZnscW4VpNN+1PViSYTejLVPWv7oov+Duf8YQSPyVRUvueQqz1TcsC6mooZTXw==", 1639 | "requires": { 1640 | "debug": "^4.1.1", 1641 | "istanbul-lib-coverage": "^2.0.5", 1642 | "make-dir": "^2.1.0", 1643 | "rimraf": "^2.6.3", 1644 | "source-map": "^0.6.1" 1645 | }, 1646 | "dependencies": { 1647 | "source-map": { 1648 | "version": "0.6.1", 1649 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1650 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 1651 | } 1652 | } 1653 | }, 1654 | "istanbul-reports": { 1655 | "version": "2.2.7", 1656 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-2.2.7.tgz", 1657 | "integrity": "sha512-uu1F/L1o5Y6LzPVSVZXNOoD/KXpJue9aeLRd0sM9uMXfZvzomB0WxVamWb5ue8kA2vVWEmW7EG+A5n3f1kqHKg==", 1658 | "requires": { 1659 | "html-escaper": "^2.0.0" 1660 | } 1661 | }, 1662 | "js-tokens": { 1663 | "version": "4.0.0", 1664 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1665 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 1666 | }, 1667 | "js-yaml": { 1668 | "version": "3.14.0", 1669 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1670 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1671 | "requires": { 1672 | "argparse": "^1.0.7", 1673 | "esprima": "^4.0.0" 1674 | } 1675 | }, 1676 | "jsesc": { 1677 | "version": "2.5.2", 1678 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1679 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==" 1680 | }, 1681 | "json-parse-better-errors": { 1682 | "version": "1.0.2", 1683 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1684 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" 1685 | }, 1686 | "json-schema-traverse": { 1687 | "version": "0.4.1", 1688 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1689 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1690 | "dev": true 1691 | }, 1692 | "json-stable-stringify-without-jsonify": { 1693 | "version": "1.0.1", 1694 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1695 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1696 | "dev": true 1697 | }, 1698 | "jsx-ast-utils": { 1699 | "version": "2.4.1", 1700 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.4.1.tgz", 1701 | "integrity": "sha512-z1xSldJ6imESSzOjd3NNkieVJKRlKYSOtMG8SFyCj2FIrvSaSuli/WjpBkEzCBoR9bYYYFgqJw61Xhu7Lcgk+w==", 1702 | "dev": true, 1703 | "requires": { 1704 | "array-includes": "^3.1.1", 1705 | "object.assign": "^4.1.0" 1706 | } 1707 | }, 1708 | "levn": { 1709 | "version": "0.3.0", 1710 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1711 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1712 | "dev": true, 1713 | "requires": { 1714 | "prelude-ls": "~1.1.2", 1715 | "type-check": "~0.3.2" 1716 | } 1717 | }, 1718 | "lib0": { 1719 | "version": "0.2.32", 1720 | "resolved": "https://registry.npmjs.org/lib0/-/lib0-0.2.32.tgz", 1721 | "integrity": "sha512-cHHKhHTojtvFSsthTk+CKuD17jMHIxuZxYpTzXj9TeQLPNoGNDPl6ax+J6eFETVe3ZvPMh3V0nGfJgGo6QgSvA==", 1722 | "requires": { 1723 | "isomorphic.js": "^0.1.3" 1724 | } 1725 | }, 1726 | "load-json-file": { 1727 | "version": "4.0.0", 1728 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1729 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 1730 | "requires": { 1731 | "graceful-fs": "^4.1.2", 1732 | "parse-json": "^4.0.0", 1733 | "pify": "^3.0.0", 1734 | "strip-bom": "^3.0.0" 1735 | }, 1736 | "dependencies": { 1737 | "pify": { 1738 | "version": "3.0.0", 1739 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1740 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" 1741 | } 1742 | } 1743 | }, 1744 | "locate-path": { 1745 | "version": "3.0.0", 1746 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1747 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1748 | "requires": { 1749 | "p-locate": "^3.0.0", 1750 | "path-exists": "^3.0.0" 1751 | } 1752 | }, 1753 | "lodash": { 1754 | "version": "4.17.19", 1755 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1756 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==" 1757 | }, 1758 | "lodash.flattendeep": { 1759 | "version": "4.4.0", 1760 | "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", 1761 | "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=" 1762 | }, 1763 | "loose-envify": { 1764 | "version": "1.4.0", 1765 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1766 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1767 | "dev": true, 1768 | "requires": { 1769 | "js-tokens": "^3.0.0 || ^4.0.0" 1770 | } 1771 | }, 1772 | "lru-cache": { 1773 | "version": "4.1.5", 1774 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 1775 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 1776 | "requires": { 1777 | "pseudomap": "^1.0.2", 1778 | "yallist": "^2.1.2" 1779 | } 1780 | }, 1781 | "magic-string": { 1782 | "version": "0.25.7", 1783 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.7.tgz", 1784 | "integrity": "sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA==", 1785 | "dev": true, 1786 | "requires": { 1787 | "sourcemap-codec": "^1.4.4" 1788 | } 1789 | }, 1790 | "make-dir": { 1791 | "version": "2.1.0", 1792 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", 1793 | "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", 1794 | "requires": { 1795 | "pify": "^4.0.1", 1796 | "semver": "^5.6.0" 1797 | } 1798 | }, 1799 | "memory-pager": { 1800 | "version": "1.5.0", 1801 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1802 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1803 | "optional": true 1804 | }, 1805 | "merge-source-map": { 1806 | "version": "1.1.0", 1807 | "resolved": "https://registry.npmjs.org/merge-source-map/-/merge-source-map-1.1.0.tgz", 1808 | "integrity": "sha512-Qkcp7P2ygktpMPh2mCQZaf3jhN6D3Z/qVZHSdWvQ+2Ef5HgRAPBO57A77+ENm0CPx2+1Ce/MYKi3ymqdfuqibw==", 1809 | "requires": { 1810 | "source-map": "^0.6.1" 1811 | }, 1812 | "dependencies": { 1813 | "source-map": { 1814 | "version": "0.6.1", 1815 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1816 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 1817 | } 1818 | } 1819 | }, 1820 | "mimic-fn": { 1821 | "version": "2.1.0", 1822 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1823 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1824 | "dev": true 1825 | }, 1826 | "minimatch": { 1827 | "version": "3.0.4", 1828 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1829 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1830 | "requires": { 1831 | "brace-expansion": "^1.1.7" 1832 | } 1833 | }, 1834 | "minimist": { 1835 | "version": "1.2.5", 1836 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1837 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1838 | }, 1839 | "mkdirp": { 1840 | "version": "0.5.5", 1841 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1842 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1843 | "requires": { 1844 | "minimist": "^1.2.5" 1845 | } 1846 | }, 1847 | "mongodb": { 1848 | "version": "3.5.9", 1849 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.5.9.tgz", 1850 | "integrity": "sha512-vXHBY1CsGYcEPoVWhwgxIBeWqP3dSu9RuRDsoLRPTITrcrgm1f0Ubu1xqF9ozMwv53agmEiZm0YGo+7WL3Nbug==", 1851 | "requires": { 1852 | "bl": "^2.2.0", 1853 | "bson": "^1.1.4", 1854 | "denque": "^1.4.1", 1855 | "require_optional": "^1.0.1", 1856 | "safe-buffer": "^5.1.2", 1857 | "saslprep": "^1.0.0" 1858 | } 1859 | }, 1860 | "mongoist": { 1861 | "version": "2.5.2", 1862 | "resolved": "https://registry.npmjs.org/mongoist/-/mongoist-2.5.2.tgz", 1863 | "integrity": "sha512-9npemLFh4L9yVh5boo0+/1lzCAEwScN//CIIuWGrxuw7AceAgF36FFLBZb9/wEzOYks2OmtQqSzXBzKU9zZ8Ag==", 1864 | "requires": { 1865 | "debug": "^4.1.1", 1866 | "mongodb": "^3.3.2" 1867 | } 1868 | }, 1869 | "mongojs": { 1870 | "version": "3.1.0", 1871 | "resolved": "https://registry.npmjs.org/mongojs/-/mongojs-3.1.0.tgz", 1872 | "integrity": "sha512-aXJ4xfXwx9s1cqtKTZ24PypXiWhIgvgENObQzCGbV4QBxEVedy3yuErhx6znk959cF2dOzL2ClgXJvIhfgkpIQ==", 1873 | "requires": { 1874 | "each-series": "^1.0.0", 1875 | "mongodb": "^3.3.2", 1876 | "nyc": "^14.1.1", 1877 | "once": "^1.4.0", 1878 | "parse-mongo-url": "^1.1.1", 1879 | "readable-stream": "^3.4.0", 1880 | "thunky": "^1.1.0", 1881 | "to-mongodb-core": "^2.0.0" 1882 | }, 1883 | "dependencies": { 1884 | "readable-stream": { 1885 | "version": "3.6.0", 1886 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1887 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1888 | "requires": { 1889 | "inherits": "^2.0.3", 1890 | "string_decoder": "^1.1.1", 1891 | "util-deprecate": "^1.0.1" 1892 | } 1893 | } 1894 | } 1895 | }, 1896 | "ms": { 1897 | "version": "2.1.2", 1898 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1899 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1900 | }, 1901 | "mute-stream": { 1902 | "version": "0.0.8", 1903 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1904 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1905 | "dev": true 1906 | }, 1907 | "natural-compare": { 1908 | "version": "1.4.0", 1909 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1910 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1911 | "dev": true 1912 | }, 1913 | "nested-error-stacks": { 1914 | "version": "2.1.0", 1915 | "resolved": "https://registry.npmjs.org/nested-error-stacks/-/nested-error-stacks-2.1.0.tgz", 1916 | "integrity": "sha512-AO81vsIO1k1sM4Zrd6Hu7regmJN1NSiAja10gc4bX3F0wd+9rQmcuHQaHVQCYIEC8iFXnE+mavh23GOt7wBgug==" 1917 | }, 1918 | "nice-try": { 1919 | "version": "1.0.5", 1920 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1921 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1922 | "dev": true 1923 | }, 1924 | "normalize-package-data": { 1925 | "version": "2.5.0", 1926 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1927 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1928 | "requires": { 1929 | "hosted-git-info": "^2.1.4", 1930 | "resolve": "^1.10.0", 1931 | "semver": "2 || 3 || 4 || 5", 1932 | "validate-npm-package-license": "^3.0.1" 1933 | } 1934 | }, 1935 | "nyc": { 1936 | "version": "14.1.1", 1937 | "resolved": "https://registry.npmjs.org/nyc/-/nyc-14.1.1.tgz", 1938 | "integrity": "sha512-OI0vm6ZGUnoGZv/tLdZ2esSVzDwUC88SNs+6JoSOMVxA+gKMB8Tk7jBwgemLx4O40lhhvZCVw1C+OYLOBOPXWw==", 1939 | "requires": { 1940 | "archy": "^1.0.0", 1941 | "caching-transform": "^3.0.2", 1942 | "convert-source-map": "^1.6.0", 1943 | "cp-file": "^6.2.0", 1944 | "find-cache-dir": "^2.1.0", 1945 | "find-up": "^3.0.0", 1946 | "foreground-child": "^1.5.6", 1947 | "glob": "^7.1.3", 1948 | "istanbul-lib-coverage": "^2.0.5", 1949 | "istanbul-lib-hook": "^2.0.7", 1950 | "istanbul-lib-instrument": "^3.3.0", 1951 | "istanbul-lib-report": "^2.0.8", 1952 | "istanbul-lib-source-maps": "^3.0.6", 1953 | "istanbul-reports": "^2.2.4", 1954 | "js-yaml": "^3.13.1", 1955 | "make-dir": "^2.1.0", 1956 | "merge-source-map": "^1.1.0", 1957 | "resolve-from": "^4.0.0", 1958 | "rimraf": "^2.6.3", 1959 | "signal-exit": "^3.0.2", 1960 | "spawn-wrap": "^1.4.2", 1961 | "test-exclude": "^5.2.3", 1962 | "uuid": "^3.3.2", 1963 | "yargs": "^13.2.2", 1964 | "yargs-parser": "^13.0.0" 1965 | }, 1966 | "dependencies": { 1967 | "resolve-from": { 1968 | "version": "4.0.0", 1969 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1970 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" 1971 | } 1972 | } 1973 | }, 1974 | "object-assign": { 1975 | "version": "4.1.1", 1976 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1977 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1978 | "dev": true 1979 | }, 1980 | "object-inspect": { 1981 | "version": "1.8.0", 1982 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1983 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 1984 | "dev": true 1985 | }, 1986 | "object-keys": { 1987 | "version": "1.1.1", 1988 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1989 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1990 | "dev": true 1991 | }, 1992 | "object.assign": { 1993 | "version": "4.1.0", 1994 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1995 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1996 | "dev": true, 1997 | "requires": { 1998 | "define-properties": "^1.1.2", 1999 | "function-bind": "^1.1.1", 2000 | "has-symbols": "^1.0.0", 2001 | "object-keys": "^1.0.11" 2002 | } 2003 | }, 2004 | "object.entries": { 2005 | "version": "1.1.2", 2006 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.2.tgz", 2007 | "integrity": "sha512-BQdB9qKmb/HyNdMNWVr7O3+z5MUIx3aiegEIJqjMBbBf0YT9RRxTJSim4mzFqtyr7PDAHigq0N9dO0m0tRakQA==", 2008 | "dev": true, 2009 | "requires": { 2010 | "define-properties": "^1.1.3", 2011 | "es-abstract": "^1.17.5", 2012 | "has": "^1.0.3" 2013 | } 2014 | }, 2015 | "object.fromentries": { 2016 | "version": "2.0.2", 2017 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.2.tgz", 2018 | "integrity": "sha512-r3ZiBH7MQppDJVLx6fhD618GKNG40CZYH9wgwdhKxBDDbQgjeWGGd4AtkZad84d291YxvWe7bJGuE65Anh0dxQ==", 2019 | "dev": true, 2020 | "requires": { 2021 | "define-properties": "^1.1.3", 2022 | "es-abstract": "^1.17.0-next.1", 2023 | "function-bind": "^1.1.1", 2024 | "has": "^1.0.3" 2025 | } 2026 | }, 2027 | "object.values": { 2028 | "version": "1.1.1", 2029 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.1.tgz", 2030 | "integrity": "sha512-WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA==", 2031 | "dev": true, 2032 | "requires": { 2033 | "define-properties": "^1.1.3", 2034 | "es-abstract": "^1.17.0-next.1", 2035 | "function-bind": "^1.1.1", 2036 | "has": "^1.0.3" 2037 | } 2038 | }, 2039 | "once": { 2040 | "version": "1.4.0", 2041 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2042 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2043 | "requires": { 2044 | "wrappy": "1" 2045 | } 2046 | }, 2047 | "onetime": { 2048 | "version": "5.1.0", 2049 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 2050 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 2051 | "dev": true, 2052 | "requires": { 2053 | "mimic-fn": "^2.1.0" 2054 | } 2055 | }, 2056 | "optionator": { 2057 | "version": "0.8.3", 2058 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 2059 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 2060 | "dev": true, 2061 | "requires": { 2062 | "deep-is": "~0.1.3", 2063 | "fast-levenshtein": "~2.0.6", 2064 | "levn": "~0.3.0", 2065 | "prelude-ls": "~1.1.2", 2066 | "type-check": "~0.3.2", 2067 | "word-wrap": "~1.2.3" 2068 | } 2069 | }, 2070 | "os-homedir": { 2071 | "version": "1.0.2", 2072 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 2073 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 2074 | }, 2075 | "os-tmpdir": { 2076 | "version": "1.0.2", 2077 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2078 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 2079 | "dev": true 2080 | }, 2081 | "p-limit": { 2082 | "version": "2.3.0", 2083 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2084 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2085 | "requires": { 2086 | "p-try": "^2.0.0" 2087 | } 2088 | }, 2089 | "p-locate": { 2090 | "version": "3.0.0", 2091 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2092 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2093 | "requires": { 2094 | "p-limit": "^2.0.0" 2095 | } 2096 | }, 2097 | "p-try": { 2098 | "version": "2.2.0", 2099 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2100 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" 2101 | }, 2102 | "package-hash": { 2103 | "version": "3.0.0", 2104 | "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-3.0.0.tgz", 2105 | "integrity": "sha512-lOtmukMDVvtkL84rJHI7dpTYq+0rli8N2wlnqUcBuDWCfVhRUfOmnR9SsoHFMLpACvEV60dX7rd0rFaYDZI+FA==", 2106 | "requires": { 2107 | "graceful-fs": "^4.1.15", 2108 | "hasha": "^3.0.0", 2109 | "lodash.flattendeep": "^4.4.0", 2110 | "release-zalgo": "^1.0.0" 2111 | } 2112 | }, 2113 | "parent-module": { 2114 | "version": "1.0.1", 2115 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2116 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2117 | "dev": true, 2118 | "requires": { 2119 | "callsites": "^3.0.0" 2120 | } 2121 | }, 2122 | "parse-json": { 2123 | "version": "4.0.0", 2124 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 2125 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 2126 | "requires": { 2127 | "error-ex": "^1.3.1", 2128 | "json-parse-better-errors": "^1.0.1" 2129 | } 2130 | }, 2131 | "parse-mongo-url": { 2132 | "version": "1.1.1", 2133 | "resolved": "https://registry.npmjs.org/parse-mongo-url/-/parse-mongo-url-1.1.1.tgz", 2134 | "integrity": "sha1-ZiON9fjnwMjKTNlw1KtqE3PrdbU=" 2135 | }, 2136 | "path-exists": { 2137 | "version": "3.0.0", 2138 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2139 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" 2140 | }, 2141 | "path-is-absolute": { 2142 | "version": "1.0.1", 2143 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2144 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 2145 | }, 2146 | "path-key": { 2147 | "version": "2.0.1", 2148 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2149 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2150 | "dev": true 2151 | }, 2152 | "path-parse": { 2153 | "version": "1.0.6", 2154 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2155 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" 2156 | }, 2157 | "path-type": { 2158 | "version": "3.0.0", 2159 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 2160 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 2161 | "requires": { 2162 | "pify": "^3.0.0" 2163 | }, 2164 | "dependencies": { 2165 | "pify": { 2166 | "version": "3.0.0", 2167 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2168 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" 2169 | } 2170 | } 2171 | }, 2172 | "picomatch": { 2173 | "version": "2.2.2", 2174 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 2175 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 2176 | "dev": true 2177 | }, 2178 | "pify": { 2179 | "version": "4.0.1", 2180 | "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", 2181 | "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" 2182 | }, 2183 | "pkg-conf": { 2184 | "version": "3.1.0", 2185 | "resolved": "https://registry.npmjs.org/pkg-conf/-/pkg-conf-3.1.0.tgz", 2186 | "integrity": "sha512-m0OTbR/5VPNPqO1ph6Fqbj7Hv6QU7gR/tQW40ZqrL1rjgCU85W6C1bJn0BItuJqnR98PWzw7Z8hHeChD1WrgdQ==", 2187 | "dev": true, 2188 | "requires": { 2189 | "find-up": "^3.0.0", 2190 | "load-json-file": "^5.2.0" 2191 | }, 2192 | "dependencies": { 2193 | "load-json-file": { 2194 | "version": "5.3.0", 2195 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-5.3.0.tgz", 2196 | "integrity": "sha512-cJGP40Jc/VXUsp8/OrnyKyTZ1y6v/dphm3bioS+RrKXjK2BB6wHUd6JptZEFDGgGahMT+InnZO5i1Ei9mpC8Bw==", 2197 | "dev": true, 2198 | "requires": { 2199 | "graceful-fs": "^4.1.15", 2200 | "parse-json": "^4.0.0", 2201 | "pify": "^4.0.1", 2202 | "strip-bom": "^3.0.0", 2203 | "type-fest": "^0.3.0" 2204 | } 2205 | }, 2206 | "type-fest": { 2207 | "version": "0.3.1", 2208 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.3.1.tgz", 2209 | "integrity": "sha512-cUGJnCdr4STbePCgqNFbpVNCepa+kAVohJs1sLhxzdH+gnEoOd8VhbYa7pD3zZYGiURWM2xzEII3fQcRizDkYQ==", 2210 | "dev": true 2211 | } 2212 | } 2213 | }, 2214 | "pkg-config": { 2215 | "version": "1.1.1", 2216 | "resolved": "https://registry.npmjs.org/pkg-config/-/pkg-config-1.1.1.tgz", 2217 | "integrity": "sha1-VX7yLXPaPIg3EHdmxS6tq94pj+Q=", 2218 | "dev": true, 2219 | "requires": { 2220 | "debug-log": "^1.0.0", 2221 | "find-root": "^1.0.0", 2222 | "xtend": "^4.0.1" 2223 | } 2224 | }, 2225 | "pkg-dir": { 2226 | "version": "3.0.0", 2227 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", 2228 | "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", 2229 | "requires": { 2230 | "find-up": "^3.0.0" 2231 | } 2232 | }, 2233 | "prelude-ls": { 2234 | "version": "1.1.2", 2235 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2236 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2237 | "dev": true 2238 | }, 2239 | "process-nextick-args": { 2240 | "version": "2.0.1", 2241 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2242 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 2243 | }, 2244 | "progress": { 2245 | "version": "2.0.3", 2246 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2247 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2248 | "dev": true 2249 | }, 2250 | "prop-types": { 2251 | "version": "15.7.2", 2252 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", 2253 | "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", 2254 | "dev": true, 2255 | "requires": { 2256 | "loose-envify": "^1.4.0", 2257 | "object-assign": "^4.1.1", 2258 | "react-is": "^16.8.1" 2259 | } 2260 | }, 2261 | "pseudomap": { 2262 | "version": "1.0.2", 2263 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2264 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 2265 | }, 2266 | "punycode": { 2267 | "version": "2.1.1", 2268 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2269 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2270 | "dev": true 2271 | }, 2272 | "react-is": { 2273 | "version": "16.13.1", 2274 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 2275 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 2276 | "dev": true 2277 | }, 2278 | "read-pkg": { 2279 | "version": "3.0.0", 2280 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 2281 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 2282 | "requires": { 2283 | "load-json-file": "^4.0.0", 2284 | "normalize-package-data": "^2.3.2", 2285 | "path-type": "^3.0.0" 2286 | } 2287 | }, 2288 | "read-pkg-up": { 2289 | "version": "4.0.0", 2290 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-4.0.0.tgz", 2291 | "integrity": "sha512-6etQSH7nJGsK0RbG/2TeDzZFa8shjQ1um+SwQQ5cwKy0dhSXdOncEhb1CPpvQG4h7FyOV6EB6YlV0yJvZQNAkA==", 2292 | "requires": { 2293 | "find-up": "^3.0.0", 2294 | "read-pkg": "^3.0.0" 2295 | } 2296 | }, 2297 | "readable-stream": { 2298 | "version": "2.3.7", 2299 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 2300 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2301 | "requires": { 2302 | "core-util-is": "~1.0.0", 2303 | "inherits": "~2.0.3", 2304 | "isarray": "~1.0.0", 2305 | "process-nextick-args": "~2.0.0", 2306 | "safe-buffer": "~5.1.1", 2307 | "string_decoder": "~1.1.1", 2308 | "util-deprecate": "~1.0.1" 2309 | }, 2310 | "dependencies": { 2311 | "safe-buffer": { 2312 | "version": "5.1.2", 2313 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2314 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2315 | } 2316 | } 2317 | }, 2318 | "regexpp": { 2319 | "version": "2.0.1", 2320 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 2321 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 2322 | "dev": true 2323 | }, 2324 | "release-zalgo": { 2325 | "version": "1.0.0", 2326 | "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", 2327 | "integrity": "sha1-CXALflB0Mpc5Mw5TXFqQ+2eFFzA=", 2328 | "requires": { 2329 | "es6-error": "^4.0.1" 2330 | } 2331 | }, 2332 | "require-directory": { 2333 | "version": "2.1.1", 2334 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2335 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 2336 | }, 2337 | "require-main-filename": { 2338 | "version": "2.0.0", 2339 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2340 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" 2341 | }, 2342 | "require_optional": { 2343 | "version": "1.0.1", 2344 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 2345 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 2346 | "requires": { 2347 | "resolve-from": "^2.0.0", 2348 | "semver": "^5.1.0" 2349 | } 2350 | }, 2351 | "resolve": { 2352 | "version": "1.17.0", 2353 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 2354 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 2355 | "requires": { 2356 | "path-parse": "^1.0.6" 2357 | } 2358 | }, 2359 | "resolve-from": { 2360 | "version": "2.0.0", 2361 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 2362 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 2363 | }, 2364 | "restore-cursor": { 2365 | "version": "3.1.0", 2366 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 2367 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 2368 | "dev": true, 2369 | "requires": { 2370 | "onetime": "^5.1.0", 2371 | "signal-exit": "^3.0.2" 2372 | } 2373 | }, 2374 | "rimraf": { 2375 | "version": "2.7.1", 2376 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2377 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2378 | "requires": { 2379 | "glob": "^7.1.3" 2380 | } 2381 | }, 2382 | "rollup": { 2383 | "version": "2.21.0", 2384 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.21.0.tgz", 2385 | "integrity": "sha512-BEGgy+wSzux7Ycq58pRiWEOBZaXRXTuvzl1gsm7gqmsAHxkWf9nyA5V2LN9fGSHhhDQd0/C13iRzSh4bbIpWZQ==", 2386 | "dev": true, 2387 | "requires": { 2388 | "fsevents": "~2.1.2" 2389 | } 2390 | }, 2391 | "rollup-plugin-inject": { 2392 | "version": "3.0.2", 2393 | "resolved": "https://registry.npmjs.org/rollup-plugin-inject/-/rollup-plugin-inject-3.0.2.tgz", 2394 | "integrity": "sha512-ptg9PQwzs3orn4jkgXJ74bfs5vYz1NCZlSQMBUA0wKcGp5i5pA1AO3fOUEte8enhGUC+iapTCzEWw2jEFFUO/w==", 2395 | "dev": true, 2396 | "requires": { 2397 | "estree-walker": "^0.6.1", 2398 | "magic-string": "^0.25.3", 2399 | "rollup-pluginutils": "^2.8.1" 2400 | }, 2401 | "dependencies": { 2402 | "estree-walker": { 2403 | "version": "0.6.1", 2404 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 2405 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 2406 | "dev": true 2407 | } 2408 | } 2409 | }, 2410 | "rollup-plugin-node-polyfills": { 2411 | "version": "0.2.1", 2412 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-polyfills/-/rollup-plugin-node-polyfills-0.2.1.tgz", 2413 | "integrity": "sha512-4kCrKPTJ6sK4/gLL/U5QzVT8cxJcofO0OU74tnB19F40cmuAKSzH5/siithxlofFEjwvw1YAhPmbvGNA6jEroA==", 2414 | "dev": true, 2415 | "requires": { 2416 | "rollup-plugin-inject": "^3.0.0" 2417 | } 2418 | }, 2419 | "rollup-pluginutils": { 2420 | "version": "2.8.2", 2421 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.2.tgz", 2422 | "integrity": "sha512-EEp9NhnUkwY8aif6bxgovPHMoMoNr2FulJziTndpt5H9RdwC47GSGuII9XxpSdzVGM0GWrNPHV6ie1LTNJPaLQ==", 2423 | "dev": true, 2424 | "requires": { 2425 | "estree-walker": "^0.6.1" 2426 | }, 2427 | "dependencies": { 2428 | "estree-walker": { 2429 | "version": "0.6.1", 2430 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 2431 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 2432 | "dev": true 2433 | } 2434 | } 2435 | }, 2436 | "run-async": { 2437 | "version": "2.4.1", 2438 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 2439 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 2440 | "dev": true 2441 | }, 2442 | "run-parallel": { 2443 | "version": "1.1.9", 2444 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.9.tgz", 2445 | "integrity": "sha512-DEqnSRTDw/Tc3FXf49zedI638Z9onwUotBMiUFKmrO2sdFKIbXamXGQ3Axd4qgphxKB4kw/qP1w5kTxnfU1B9Q==", 2446 | "dev": true 2447 | }, 2448 | "rxjs": { 2449 | "version": "6.6.0", 2450 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.0.tgz", 2451 | "integrity": "sha512-3HMA8z/Oz61DUHe+SdOiQyzIf4tOx5oQHmMir7IZEu6TMqCLHT4LRcmNaUS0NwOz8VLvmmBduMsoaUvMaIiqzg==", 2452 | "dev": true, 2453 | "requires": { 2454 | "tslib": "^1.9.0" 2455 | } 2456 | }, 2457 | "safe-buffer": { 2458 | "version": "5.2.1", 2459 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2460 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2461 | }, 2462 | "safer-buffer": { 2463 | "version": "2.1.2", 2464 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2465 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2466 | "dev": true 2467 | }, 2468 | "saslprep": { 2469 | "version": "1.0.3", 2470 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 2471 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 2472 | "optional": true, 2473 | "requires": { 2474 | "sparse-bitfield": "^3.0.3" 2475 | } 2476 | }, 2477 | "semver": { 2478 | "version": "5.7.1", 2479 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2480 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 2481 | }, 2482 | "set-blocking": { 2483 | "version": "2.0.0", 2484 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2485 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 2486 | }, 2487 | "shebang-command": { 2488 | "version": "1.2.0", 2489 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2490 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2491 | "dev": true, 2492 | "requires": { 2493 | "shebang-regex": "^1.0.0" 2494 | } 2495 | }, 2496 | "shebang-regex": { 2497 | "version": "1.0.0", 2498 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2499 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2500 | "dev": true 2501 | }, 2502 | "signal-exit": { 2503 | "version": "3.0.3", 2504 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2505 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 2506 | }, 2507 | "slice-ansi": { 2508 | "version": "2.1.0", 2509 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2510 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2511 | "dev": true, 2512 | "requires": { 2513 | "ansi-styles": "^3.2.0", 2514 | "astral-regex": "^1.0.0", 2515 | "is-fullwidth-code-point": "^2.0.0" 2516 | } 2517 | }, 2518 | "source-map": { 2519 | "version": "0.5.7", 2520 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2521 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" 2522 | }, 2523 | "sourcemap-codec": { 2524 | "version": "1.4.8", 2525 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 2526 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 2527 | "dev": true 2528 | }, 2529 | "sparse-bitfield": { 2530 | "version": "3.0.3", 2531 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 2532 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 2533 | "optional": true, 2534 | "requires": { 2535 | "memory-pager": "^1.0.2" 2536 | } 2537 | }, 2538 | "spawn-wrap": { 2539 | "version": "1.4.3", 2540 | "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-1.4.3.tgz", 2541 | "integrity": "sha512-IgB8md0QW/+tWqcavuFgKYR/qIRvJkRLPJDFaoXtLLUaVcCDK0+HeFTkmQHj3eprcYhc+gOl0aEA1w7qZlYezw==", 2542 | "requires": { 2543 | "foreground-child": "^1.5.6", 2544 | "mkdirp": "^0.5.0", 2545 | "os-homedir": "^1.0.1", 2546 | "rimraf": "^2.6.2", 2547 | "signal-exit": "^3.0.2", 2548 | "which": "^1.3.0" 2549 | } 2550 | }, 2551 | "spdx-correct": { 2552 | "version": "3.1.1", 2553 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 2554 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 2555 | "requires": { 2556 | "spdx-expression-parse": "^3.0.0", 2557 | "spdx-license-ids": "^3.0.0" 2558 | } 2559 | }, 2560 | "spdx-exceptions": { 2561 | "version": "2.3.0", 2562 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 2563 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==" 2564 | }, 2565 | "spdx-expression-parse": { 2566 | "version": "3.0.1", 2567 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 2568 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 2569 | "requires": { 2570 | "spdx-exceptions": "^2.1.0", 2571 | "spdx-license-ids": "^3.0.0" 2572 | } 2573 | }, 2574 | "spdx-license-ids": { 2575 | "version": "3.0.5", 2576 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 2577 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==" 2578 | }, 2579 | "sprintf-js": { 2580 | "version": "1.0.3", 2581 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2582 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 2583 | }, 2584 | "standard": { 2585 | "version": "14.3.4", 2586 | "resolved": "https://registry.npmjs.org/standard/-/standard-14.3.4.tgz", 2587 | "integrity": "sha512-+lpOkFssMkljJ6eaILmqxHQ2n4csuEABmcubLTb9almFi1ElDzXb1819fjf/5ygSyePCq4kU2wMdb2fBfb9P9Q==", 2588 | "dev": true, 2589 | "requires": { 2590 | "eslint": "~6.8.0", 2591 | "eslint-config-standard": "14.1.1", 2592 | "eslint-config-standard-jsx": "8.1.0", 2593 | "eslint-plugin-import": "~2.18.0", 2594 | "eslint-plugin-node": "~10.0.0", 2595 | "eslint-plugin-promise": "~4.2.1", 2596 | "eslint-plugin-react": "~7.14.2", 2597 | "eslint-plugin-standard": "~4.0.0", 2598 | "standard-engine": "^12.0.0" 2599 | } 2600 | }, 2601 | "standard-engine": { 2602 | "version": "12.1.0", 2603 | "resolved": "https://registry.npmjs.org/standard-engine/-/standard-engine-12.1.0.tgz", 2604 | "integrity": "sha512-DVJnWM1CGkag4ucFLGdiYWa5/kJURPONmMmk17p8FT5NE4UnPZB1vxWnXnRo2sPSL78pWJG8xEM+1Tu19z0deg==", 2605 | "dev": true, 2606 | "requires": { 2607 | "deglob": "^4.0.1", 2608 | "get-stdin": "^7.0.0", 2609 | "minimist": "^1.2.5", 2610 | "pkg-conf": "^3.1.0" 2611 | } 2612 | }, 2613 | "string-width": { 2614 | "version": "3.1.0", 2615 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2616 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2617 | "requires": { 2618 | "emoji-regex": "^7.0.1", 2619 | "is-fullwidth-code-point": "^2.0.0", 2620 | "strip-ansi": "^5.1.0" 2621 | } 2622 | }, 2623 | "string.prototype.trimend": { 2624 | "version": "1.0.1", 2625 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 2626 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 2627 | "dev": true, 2628 | "requires": { 2629 | "define-properties": "^1.1.3", 2630 | "es-abstract": "^1.17.5" 2631 | } 2632 | }, 2633 | "string.prototype.trimstart": { 2634 | "version": "1.0.1", 2635 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 2636 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 2637 | "dev": true, 2638 | "requires": { 2639 | "define-properties": "^1.1.3", 2640 | "es-abstract": "^1.17.5" 2641 | } 2642 | }, 2643 | "string_decoder": { 2644 | "version": "1.1.1", 2645 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2646 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2647 | "requires": { 2648 | "safe-buffer": "~5.1.0" 2649 | }, 2650 | "dependencies": { 2651 | "safe-buffer": { 2652 | "version": "5.1.2", 2653 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2654 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2655 | } 2656 | } 2657 | }, 2658 | "strip-ansi": { 2659 | "version": "5.2.0", 2660 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2661 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2662 | "requires": { 2663 | "ansi-regex": "^4.1.0" 2664 | } 2665 | }, 2666 | "strip-bom": { 2667 | "version": "3.0.0", 2668 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2669 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=" 2670 | }, 2671 | "strip-json-comments": { 2672 | "version": "3.1.1", 2673 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2674 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2675 | "dev": true 2676 | }, 2677 | "supports-color": { 2678 | "version": "5.5.0", 2679 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2680 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2681 | "requires": { 2682 | "has-flag": "^3.0.0" 2683 | } 2684 | }, 2685 | "table": { 2686 | "version": "5.4.6", 2687 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 2688 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 2689 | "dev": true, 2690 | "requires": { 2691 | "ajv": "^6.10.2", 2692 | "lodash": "^4.17.14", 2693 | "slice-ansi": "^2.1.0", 2694 | "string-width": "^3.0.0" 2695 | } 2696 | }, 2697 | "test-exclude": { 2698 | "version": "5.2.3", 2699 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-5.2.3.tgz", 2700 | "integrity": "sha512-M+oxtseCFO3EDtAaGH7iiej3CBkzXqFMbzqYAACdzKui4eZA+pq3tZEwChvOdNfa7xxy8BfbmgJSIr43cC/+2g==", 2701 | "requires": { 2702 | "glob": "^7.1.3", 2703 | "minimatch": "^3.0.4", 2704 | "read-pkg-up": "^4.0.0", 2705 | "require-main-filename": "^2.0.0" 2706 | } 2707 | }, 2708 | "text-table": { 2709 | "version": "0.2.0", 2710 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2711 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2712 | "dev": true 2713 | }, 2714 | "through": { 2715 | "version": "2.3.8", 2716 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2717 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2718 | "dev": true 2719 | }, 2720 | "thunky": { 2721 | "version": "1.1.0", 2722 | "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", 2723 | "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==" 2724 | }, 2725 | "tmp": { 2726 | "version": "0.0.33", 2727 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2728 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2729 | "dev": true, 2730 | "requires": { 2731 | "os-tmpdir": "~1.0.2" 2732 | } 2733 | }, 2734 | "to-fast-properties": { 2735 | "version": "2.0.0", 2736 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2737 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=" 2738 | }, 2739 | "to-mongodb-core": { 2740 | "version": "2.0.0", 2741 | "resolved": "https://registry.npmjs.org/to-mongodb-core/-/to-mongodb-core-2.0.0.tgz", 2742 | "integrity": "sha1-NZbsdhOsmtO5ioncua77pWnNJ+s=" 2743 | }, 2744 | "tslib": { 2745 | "version": "1.13.0", 2746 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 2747 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==", 2748 | "dev": true 2749 | }, 2750 | "type-check": { 2751 | "version": "0.3.2", 2752 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2753 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2754 | "dev": true, 2755 | "requires": { 2756 | "prelude-ls": "~1.1.2" 2757 | } 2758 | }, 2759 | "type-fest": { 2760 | "version": "0.8.1", 2761 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2762 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2763 | "dev": true 2764 | }, 2765 | "typescript": { 2766 | "version": "3.9.6", 2767 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.6.tgz", 2768 | "integrity": "sha512-Pspx3oKAPJtjNwE92YS05HQoY7z2SFyOpHo9MqJor3BXAGNaPUs83CuVp9VISFkSjyRfiTpmKuAYGJB7S7hOxw==", 2769 | "dev": true 2770 | }, 2771 | "uniq": { 2772 | "version": "1.0.1", 2773 | "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", 2774 | "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", 2775 | "dev": true 2776 | }, 2777 | "uri-js": { 2778 | "version": "4.2.2", 2779 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2780 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2781 | "dev": true, 2782 | "requires": { 2783 | "punycode": "^2.1.0" 2784 | } 2785 | }, 2786 | "util-deprecate": { 2787 | "version": "1.0.2", 2788 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2789 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2790 | }, 2791 | "uuid": { 2792 | "version": "3.4.0", 2793 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 2794 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" 2795 | }, 2796 | "v8-compile-cache": { 2797 | "version": "2.1.1", 2798 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 2799 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 2800 | "dev": true 2801 | }, 2802 | "validate-npm-package-license": { 2803 | "version": "3.0.4", 2804 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2805 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2806 | "requires": { 2807 | "spdx-correct": "^3.0.0", 2808 | "spdx-expression-parse": "^3.0.0" 2809 | } 2810 | }, 2811 | "which": { 2812 | "version": "1.3.1", 2813 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2814 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2815 | "requires": { 2816 | "isexe": "^2.0.0" 2817 | } 2818 | }, 2819 | "which-module": { 2820 | "version": "2.0.0", 2821 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 2822 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" 2823 | }, 2824 | "word-wrap": { 2825 | "version": "1.2.3", 2826 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2827 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2828 | "dev": true 2829 | }, 2830 | "wrap-ansi": { 2831 | "version": "5.1.0", 2832 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 2833 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 2834 | "requires": { 2835 | "ansi-styles": "^3.2.0", 2836 | "string-width": "^3.0.0", 2837 | "strip-ansi": "^5.0.0" 2838 | } 2839 | }, 2840 | "wrappy": { 2841 | "version": "1.0.2", 2842 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2843 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2844 | }, 2845 | "write": { 2846 | "version": "1.0.3", 2847 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2848 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2849 | "dev": true, 2850 | "requires": { 2851 | "mkdirp": "^0.5.1" 2852 | } 2853 | }, 2854 | "write-file-atomic": { 2855 | "version": "2.4.3", 2856 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz", 2857 | "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==", 2858 | "requires": { 2859 | "graceful-fs": "^4.1.11", 2860 | "imurmurhash": "^0.1.4", 2861 | "signal-exit": "^3.0.2" 2862 | } 2863 | }, 2864 | "xtend": { 2865 | "version": "4.0.2", 2866 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2867 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2868 | "dev": true 2869 | }, 2870 | "y18n": { 2871 | "version": "4.0.0", 2872 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 2873 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==" 2874 | }, 2875 | "yallist": { 2876 | "version": "2.1.2", 2877 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 2878 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 2879 | }, 2880 | "yargs": { 2881 | "version": "13.3.2", 2882 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 2883 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 2884 | "requires": { 2885 | "cliui": "^5.0.0", 2886 | "find-up": "^3.0.0", 2887 | "get-caller-file": "^2.0.1", 2888 | "require-directory": "^2.1.1", 2889 | "require-main-filename": "^2.0.0", 2890 | "set-blocking": "^2.0.0", 2891 | "string-width": "^3.0.0", 2892 | "which-module": "^2.0.0", 2893 | "y18n": "^4.0.0", 2894 | "yargs-parser": "^13.1.2" 2895 | } 2896 | }, 2897 | "yargs-parser": { 2898 | "version": "13.1.2", 2899 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2900 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2901 | "requires": { 2902 | "camelcase": "^5.0.0", 2903 | "decamelize": "^1.2.0" 2904 | } 2905 | }, 2906 | "yjs": { 2907 | "version": "13.3.0", 2908 | "resolved": "https://registry.npmjs.org/yjs/-/yjs-13.3.0.tgz", 2909 | "integrity": "sha512-QdWZljN7OkAKen3VJ9P7sXwjuw+00WRXvmjZvgT28yMgxGnZ8w2LYP4GynuneLn53I6gud1PxB5zCeVODQC/dg==", 2910 | "dev": true, 2911 | "requires": { 2912 | "lib0": "^0.2.32" 2913 | } 2914 | } 2915 | } 2916 | } 2917 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "y-mongodb", 3 | "version": "0.1.11", 4 | "description": "Mongodb adapter for Yjs", 5 | "main": "./dist/y-mongodb.cjs", 6 | "module": "./src/y-mongodb.js", 7 | "types": "./dist/src/y-mongodb.d.ts", 8 | "sideEffects": false, 9 | "scripts": { 10 | "test": "rollup -c && nyc --check-coverage --lines 100 --branches 100 --functions 100 --statements 100 node ./dist/test.cjs", 11 | "clean": "rm -rf dist", 12 | "lint": "standard --fix && tsc", 13 | "dist": "rollup -c", 14 | "preversion": "npm run lint && npm run test && npm run clean && npm run dist && tsc && test -e dist/src/y-mongodb.d.ts && test -e dist/y-mongodb.cjs" 15 | }, 16 | "author": "Fadi Quader ", 17 | "license": "MIT", 18 | "bugs": { 19 | "url": "https://github.com/fadiquader/y-mongodb/issues" 20 | }, 21 | "dependencies": { 22 | "lib0": "^0.2.32", 23 | "mongoist": "^2.5.2", 24 | "mongojs": "^3.1.0" 25 | }, 26 | "devDependencies": { 27 | "@rollup/plugin-commonjs": "^14.0.0", 28 | "@rollup/plugin-json": "^4.1.0", 29 | "@rollup/plugin-node-resolve": "^8.4.0", 30 | "rollup": "^2.21.0", 31 | "rollup-plugin-node-polyfills": "^0.2.1", 32 | "standard": "^14.3.4", 33 | "typescript": "^3.9.6", 34 | "yjs": "^13.3.0" 35 | }, 36 | "peerDependencies": { 37 | "yjs": "^13.0.0" 38 | }, 39 | "files": [ 40 | "dist/*", 41 | "src/*" 42 | ], 43 | "standard": { 44 | "ignore": [ 45 | "/dist", 46 | "/node_modules", 47 | "/tests" 48 | ] 49 | }, 50 | "repository": { 51 | "type": "git", 52 | "url": "git+https://github.com/fadiquader/y-mongodb.git" 53 | }, 54 | "keywords": [ 55 | "Yjs", 56 | "Y-mongodb", 57 | "shared editing", 58 | "collaboration" 59 | ] 60 | } 61 | -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import resolve from '@rollup/plugin-node-resolve' 2 | import commonjs from '@rollup/plugin-commonjs' 3 | import nodePolyfills from 'rollup-plugin-node-polyfills' 4 | import json from '@rollup/plugin-json' 5 | 6 | export default [ 7 | { 8 | input: './tests/index.js', 9 | output: { 10 | file: './dist/test.cjs', 11 | format: 'cjs', 12 | sourcemap: true, 13 | paths: path => { 14 | if (/^lib0\//.test(path)) { 15 | return `lib0/dist/${path.slice(5, -3)}.cjs` 16 | } 17 | return path 18 | } 19 | }, 20 | external: id => /^(lib0|yjs)\//.test(id) 21 | }, 22 | { 23 | input: './tests/index.js', 24 | output: { 25 | file: './dist/test.js', 26 | format: 'iife', 27 | sourcemap: true 28 | }, 29 | plugins: [ 30 | resolve({ 31 | mainFields: ['module', 'browser', 'main'], 32 | preferBuiltins: false 33 | }), 34 | json(), 35 | commonjs(), 36 | nodePolyfills() 37 | ] 38 | }, 39 | { 40 | input: './src/y-mongodb.js', 41 | output: { 42 | name: 'Y', 43 | file: 'dist/y-mongodb.cjs', 44 | format: 'cjs', 45 | sourcemap: true, 46 | paths: path => { 47 | if (/^lib0\//.test(path)) { 48 | return `lib0/dist/${path.slice(5, -3)}.cjs` 49 | } 50 | return path 51 | } 52 | }, 53 | external: id => /^(lib0|yjs)\//.test(id) 54 | } 55 | ] 56 | -------------------------------------------------------------------------------- /src/mongo-adapter.js: -------------------------------------------------------------------------------- 1 | import mongojs from 'mongojs' 2 | import mongoist from 'mongoist' 3 | 4 | export class MongoAdapter { 5 | constructor (location, collection) { 6 | this.location = location 7 | this.collection = collection || 'yjs-writings' 8 | this.db = null 9 | this.open() 10 | } 11 | 12 | open () { 13 | const mongojsDb = mongojs(this.location, [this.collection]) 14 | this.db = mongoist(mongojsDb) 15 | } 16 | 17 | get (query) { 18 | return this.db[this.collection].findOne(query) 19 | } 20 | 21 | put (values) { 22 | if (!values.docName && !values.version && !values.value) { throw new Error('Document and version must be provided') } 23 | 24 | return this.db[this.collection].save(values) 25 | } 26 | 27 | del (query) { 28 | const bulk = this.db[this.collection].initializeOrderedBulkOp() 29 | bulk.find(query).remove() 30 | return bulk.execute() 31 | } 32 | 33 | readAsCursor (query, opts = {}) { 34 | let curs = this.db[this.collection].findAsCursor(query) 35 | if (opts.reverse) curs = curs.sort({ clock: -1 }) 36 | if (opts.limit) curs = curs.limit(opts.limit) 37 | return curs.toArray() 38 | } 39 | 40 | close () { 41 | this.db.close() 42 | } 43 | 44 | async flush () { 45 | await this.db.dropDatabase() 46 | await this.db.close() 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /src/utils.js: -------------------------------------------------------------------------------- 1 | import * as Y from 'yjs' 2 | import * as binary from 'lib0/binary.js' 3 | import * as encoding from 'lib0/encoding.js' 4 | import { Buffer } from 'buffer' 5 | 6 | export const PREFERRED_TRIM_SIZE = 400 7 | 8 | /** 9 | * @param {any} db 10 | * @param {string} docName 11 | * @param {number} from Greater than or equal 12 | * @param {number} to lower than (not equal) 13 | * @return {Promise} 14 | */ 15 | export const clearUpdatesRange = async (db, docName, from, to) => db.del({ 16 | docName, 17 | clock: { 18 | $gte: from, 19 | $lt: to 20 | } 21 | }) 22 | 23 | /** 24 | * @param {any} db 25 | * @param {string} docName 26 | * @param {Uint8Array} stateAsUpdate 27 | * @param {Uint8Array} stateVector 28 | * @return {Promise} returns the clock of the flushed doc 29 | */ 30 | export const flushDocument = async (db, docName, stateAsUpdate, stateVector) => { 31 | const clock = await storeUpdate(db, docName, stateAsUpdate) 32 | await writeStateVector(db, docName, stateVector, clock) 33 | await clearUpdatesRange(db, docName, 0, clock) 34 | return clock 35 | } 36 | 37 | /** 38 | * Create a unique key for a update message. 39 | * @param {string} docName 40 | * @param {number} clock must be unique 41 | * @return {Object} [opts.version, opts.docName, opts.action, opts.clock] 42 | */ 43 | export const createDocumentUpdateKey = (docName, clock) => ({ 44 | version: 'v1', 45 | action: 'update', 46 | docName, 47 | clock 48 | }) 49 | 50 | /** 51 | * @param {string} docName 52 | * @return {Object} [opts.docName, opts.version] 53 | */ 54 | export const createDocumentStateVectorKey = docName => { 55 | return { 56 | docName: docName, 57 | version: 'v1_sv' 58 | } 59 | } 60 | 61 | /** 62 | * Level expects a Buffer, but in Yjs we typically work with Uint8Arrays. 63 | * 64 | * Since Level thinks that these are two entirely different things, 65 | * we transform the Uint8array to a Buffer before storing it. 66 | * 67 | * @param {any} db 68 | * @param {Object} values 69 | */ 70 | export const mongoPut = async (db, values) => db.put(values) 71 | 72 | /** 73 | * @param {any} db 74 | * @param {object} query 75 | * @param {object} opts 76 | * @return {Promise>} 77 | */ 78 | export const getMongoBulkData = (db, query, opts) => db.readAsCursor(query, opts) 79 | 80 | /** 81 | * @param {any} db 82 | * @return {Promise} 83 | */ 84 | export const flushDB = db => db.flush() 85 | 86 | /** 87 | * Get all document updates for a specific document. 88 | * 89 | * @param {any} db 90 | * @param {string} docName 91 | * @param {any} [opts] 92 | * @return {Promise>} 93 | */ 94 | export const getMongoUpdates = async (db, docName, opts = {}) => getMongoBulkData(db, { 95 | ...createDocumentUpdateKey(docName, 0), 96 | clock: { 97 | $gte: 0, 98 | $lt: binary.BITS32 99 | } 100 | }, 101 | opts 102 | ) 103 | 104 | /** 105 | * @param {any} db 106 | * @param {string} docName 107 | * @return {Promise} Returns -1 if this document doesn't exist yet 108 | */ 109 | export const getCurrentUpdateClock = (db, docName) => getMongoUpdates(db, docName, { 110 | reverse: true, 111 | limit: 1 112 | }).then(updates => { 113 | if (updates.length === 0) { 114 | return -1 115 | } else { 116 | return updates[0].clock 117 | } 118 | }) 119 | 120 | /** 121 | * @param {any} db 122 | * @param {string} docName 123 | * @param {Uint8Array} sv state vector 124 | * @param {number} clock current clock of the document so we can determine when this statevector was created 125 | */ 126 | export const writeStateVector = async (db, docName, sv, clock) => { 127 | const encoder = encoding.createEncoder() 128 | encoding.writeVarUint8Array(encoder, sv) 129 | await mongoPut(db, { 130 | ...createDocumentStateVectorKey(docName), 131 | value: Buffer.from(encoding.toUint8Array(encoder)), 132 | clock 133 | }) 134 | } 135 | 136 | /** 137 | * @param {any} db 138 | * @param {string} docName 139 | * @param {Uint8Array} update 140 | * @return {Promise} Returns the clock of the stored update 141 | */ 142 | export const storeUpdate = async (db, docName, update) => { 143 | const clock = await getCurrentUpdateClock(db, docName) 144 | if (clock === -1) { 145 | const ydoc = new Y.Doc() 146 | Y.applyUpdate(ydoc, update) 147 | const sv = Y.encodeStateVector(ydoc) 148 | await writeStateVector(db, docName, sv, 0) 149 | } 150 | 151 | await mongoPut(db, { 152 | ...createDocumentUpdateKey(docName, clock + 1), 153 | value: Buffer.from(update) 154 | }) 155 | 156 | return clock + 1 157 | } 158 | 159 | /** 160 | * @param {Array} updates 161 | * @return {{update:Uint8Array, sv: Uint8Array}} 162 | */ 163 | export const mergeUpdates = (updates) => { 164 | const ydoc = new Y.Doc() 165 | ydoc.transact(() => { 166 | for (let i = 0; i < updates.length; i++) { 167 | Y.applyUpdate(ydoc, updates[i]) 168 | } 169 | }) 170 | return { update: Y.encodeStateAsUpdate(ydoc), sv: Y.encodeStateVector(ydoc) } 171 | } 172 | -------------------------------------------------------------------------------- /src/y-mongodb.js: -------------------------------------------------------------------------------- 1 | import * as Y from 'yjs' 2 | import * as binary from 'lib0/binary.js' 3 | import * as promise from 'lib0/promise.js' 4 | // 5 | import { MongoAdapter } from './mongo-adapter' 6 | import * as U from './utils' 7 | 8 | const getUpdates = docs => { 9 | if (!Array.isArray(docs) || !docs.length) return [] 10 | 11 | return docs.map(update => update.value.buffer) 12 | } 13 | 14 | export class MongodbPersistence { 15 | /** 16 | * @param {string} location 17 | * @param {string} [collection] 18 | */ 19 | constructor (location, collection) { 20 | const db = new MongoAdapter(location, collection) 21 | this.tr = promise.resolve() 22 | 23 | this._transact = f => { 24 | const currTr = this.tr 25 | this.tr = (async () => { 26 | await currTr 27 | let res = /** @type {any} */ (null) 28 | try { 29 | res = await f(db) 30 | } catch (err) { 31 | console.warn('Error during saving transaction', err) 32 | } 33 | return res 34 | })() 35 | return this.tr 36 | } 37 | } 38 | 39 | /** 40 | * @param {string} docName 41 | * @return {Promise} 42 | */ 43 | getYDoc (docName) { 44 | return this._transact(async db => { 45 | const docs = await U.getMongoUpdates(db, docName) 46 | const updates = getUpdates(docs) 47 | const ydoc = new Y.Doc() 48 | ydoc.transact(() => { 49 | for (let i = 0; i < updates.length; i++) { 50 | Y.applyUpdate(ydoc, updates[i]) 51 | } 52 | }) 53 | if (updates.length > U.PREFERRED_TRIM_SIZE) { 54 | await U.flushDocument(db, docName, Y.encodeStateAsUpdate(ydoc), Y.encodeStateVector(ydoc)) 55 | } 56 | return ydoc 57 | }) 58 | } 59 | 60 | /** 61 | * @param {string} docName 62 | * @param {Uint8Array} update 63 | * @return {Promise} Returns the clock of the stored update 64 | */ 65 | storeUpdate (docName, update) { 66 | return this._transact(db => U.storeUpdate(db, docName, update)) 67 | } 68 | 69 | /** 70 | * @param {string} docName 71 | * @return {Promise} 72 | */ 73 | clearDocument (docName) { 74 | return this._transact(async db => { 75 | await db.del(U.createDocumentStateVectorKey(docName)) 76 | await U.clearUpdatesRange(db, docName, 0, binary.BITS32) 77 | }) 78 | } 79 | 80 | /** 81 | * @param {string} docName 82 | * @return {Promise} 83 | */ 84 | flushDocument (docName) { 85 | return this._transact(async db => { 86 | const docs = await U.getMongoUpdates(db, docName) 87 | const updates = getUpdates(docs) 88 | const { update, sv } = U.mergeUpdates(updates) 89 | await U.flushDocument(db, docName, update, sv) 90 | }) 91 | } 92 | 93 | flushDB () { 94 | return this._transact(async db => { 95 | await U.flushDB(db) 96 | }) 97 | } 98 | } 99 | -------------------------------------------------------------------------------- /tests/index.js: -------------------------------------------------------------------------------- 1 | 2 | import * as mongodb from './y-mongodb.tests.js' 3 | 4 | import { runTests } from 'lib0/testing.js' 5 | import { isNode } from 'lib0/environment.js' 6 | 7 | if (isNode) { 8 | runTests({ 9 | mongodb 10 | }).then(success => { 11 | process.exit(success ? 0 : 1) 12 | }) 13 | 14 | } 15 | -------------------------------------------------------------------------------- /tests/y-mongodb.tests.js: -------------------------------------------------------------------------------- 1 | import * as Y from 'yjs' 2 | import { PREFERRED_TRIM_SIZE, getMongoUpdates } from '../src/utils' 3 | import { MongodbPersistence } from '../src/y-mongodb' 4 | import * as t from 'lib0/testing.js' 5 | // import * as decoding from 'lib0/decoding.js' 6 | 7 | const location = 'mongodb://localhost:27017/y-mongodb-test' 8 | const collection = 'mongodb://localhost:27017/y-transactions' 9 | 10 | const flushUpdatesHelper = (ldb, docName, actions) => { 11 | return Promise.all(actions.map(action => ldb.storeUpdate(action.docName, action.update))) 12 | }; 13 | 14 | 15 | export const testMongodbUpdateStorage = async tc => { 16 | const N = PREFERRED_TRIM_SIZE * 2 17 | 18 | const docName = tc.testName 19 | const ydoc1 = new Y.Doc() 20 | ydoc1.clientID = 0 21 | const dbPersistence = new MongodbPersistence(location, collection) 22 | await dbPersistence.clearDocument(docName) 23 | 24 | const updates = [] 25 | 26 | ydoc1.on('update', async update => { 27 | updates.push({ 28 | docName, 29 | update 30 | }) 31 | }); 32 | 33 | await flushUpdatesHelper(dbPersistence, docName, updates) 34 | 35 | const values = await dbPersistence._transact(db => getMongoUpdates(db, docName)) 36 | for (let i = 0; i < values.length; i++) { 37 | t.assert(values[i].clock === i) 38 | } 39 | 40 | const yarray = ydoc1.getArray('arr') 41 | for (let i = 0; i < N; i++) { 42 | yarray.insert(0, [i]) 43 | } 44 | 45 | await dbPersistence.flushDocument(docName) 46 | 47 | const mergedUpdates = await dbPersistence._transact(db => getMongoUpdates(db, docName)) 48 | t.assert(mergedUpdates.length === 1) 49 | 50 | await dbPersistence.flushDB(); 51 | }; 52 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es2018", 4 | "lib": ["es2018", "dom"], 5 | "allowJs": true, 6 | "checkJs": true, 7 | "declaration": true, 8 | "declarationMap": true, 9 | "emitDeclarationOnly": true, 10 | "strict": true, 11 | "noImplicitAny": false, 12 | "moduleResolution": "node", 13 | "outDir": "./dist" 14 | }, 15 | "include": ["./src/**/*", "./tests/**/*"], 16 | "exclude": ["../lib0/**/*", "node_modules/**/*", "dist", "dist/**/*.js"] 17 | } 18 | --------------------------------------------------------------------------------