├── .circleci └── config.yml ├── .gitignore ├── .nyc_output └── processinfo │ └── index.json ├── CHANGELOG.md ├── LICENSE ├── README.md ├── example-config.yml ├── mocha.opts ├── package-lock.json ├── package.json ├── src ├── connector.ts └── table-manager.ts ├── test ├── cache-connector.spec.ts ├── connection-params.ts ├── custom-version.spec.ts ├── fast-insertion.spec.ts └── multi-table.spec.ts ├── tsconfig.json └── tslint.json /.circleci/config.yml: -------------------------------------------------------------------------------- 1 | version: 2.1 2 | 3 | orbs: 4 | node: circleci/node@1.1.6 5 | coveralls: coveralls/coveralls@1.0.4 6 | 7 | jobs: 8 | build-and-test: 9 | docker: 10 | - image: circleci/node:lts 11 | - image: rethinkdb:latest 12 | working_directory: ~/circleci-build 13 | steps: 14 | - checkout 15 | - run: 16 | name: install dockerize 17 | command: wget https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz && sudo tar -C /usr/local/bin -xzvf dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz && rm dockerize-linux-amd64-$DOCKERIZE_VERSION.tar.gz 18 | environment: 19 | DOCKERIZE_VERSION: v0.3.0 20 | - run: 21 | name: Wait for mongo 22 | command: dockerize -wait tcp://localhost:28015 -timeout 1m 23 | - node/with-cache: 24 | steps: 25 | - run: npm install 26 | - run: npm run ci 27 | - persist_to_workspace: 28 | root: /home/circleci 29 | paths: 30 | - circleci-build 31 | - coveralls/upload 32 | 33 | deploy: 34 | docker: 35 | - image: circleci/node:lts 36 | working_directory: ~/circleci-build 37 | steps: 38 | - attach_workspace: 39 | at: /home/circleci 40 | - run: 41 | name: Publish to NPM 42 | command: | 43 | npm set //registry.npmjs.org/:_authToken=$NPM_TOKEN 44 | npm publish 45 | 46 | workflows: 47 | build-and-test: 48 | jobs: 49 | - build-and-test: 50 | filters: 51 | tags: 52 | only: /^v.*/ 53 | - deploy: 54 | context: connectors 55 | requires: 56 | - build-and-test 57 | filters: 58 | tags: 59 | only: /^v.*/ 60 | branches: 61 | ignore: /.*/ 62 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | dist 2 | 3 | # Logs 4 | logs 5 | *.log 6 | 7 | # Runtime data 8 | pids 9 | *.pid 10 | *.seed 11 | 12 | # Directory for instrumented libs generated by jscoverage/JSCover 13 | lib-cov 14 | 15 | # Coverage directory used by tools like istanbul 16 | coverage 17 | 18 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 19 | .grunt 20 | 21 | # Compiled binary addons (http://nodejs.org/api/addons.html) 22 | build/Release 23 | 24 | # Dependency directory 25 | # Commenting this out is preferred by some people, see 26 | # https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git- 27 | node_modules 28 | 29 | # Users Environment Variables 30 | .lock-wscript 31 | -------------------------------------------------------------------------------- /.nyc_output/processinfo/index.json: -------------------------------------------------------------------------------- 1 | {"processes":{},"files":{},"externalIds":{}} -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | ## [3.0.0] - 2021-04-08 2 | 3 | ### Fix 4 | 5 | - Use default table names 6 | 7 | ## [2.0.2] - 2021-04-08 8 | 9 | ### Misc 10 | 11 | - Updating dependencies 12 | 13 | ## [2.0.1] - 2020-04-12 14 | 15 | ### Improvement 16 | 17 | - Updating dependencies 18 | - Switching to circleci 19 | 20 | ## [2.0.0] 2019-08-07 21 | 22 | ### Feat 23 | 24 | - Use typescript 25 | - V4 API Compatible 26 | - Include a read-only that logs a warning if data is set via the API 27 | 28 | ## [1.0.2] 2016-07-25 29 | 30 | ### Bug Fix 31 | 32 | - Storage connector stores high level arrays under __dsList ( records should only contain objects and not arrays on a highlevel ) 33 | 34 | ## [1.0.1] 2016-07-13 35 | 36 | ### Bug Fix 37 | 38 | - Storage connector no longer mutates original object state 39 | 40 | ## [1.0.0] 2016-07-01 41 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright 2016 deepstreamHub GmbH 2 | 3 | Licensed under the Apache License, Version 2.0 (the "License"); 4 | you may not use this file except in compliance with the License. 5 | You may obtain a copy of the License at 6 | 7 | http://www.apache.org/licenses/LICENSE-2.0 8 | 9 | Unless required by applicable law or agreed to in writing, software 10 | distributed under the License is distributed on an "AS IS" BASIS, 11 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 | See the License for the specific language governing permissions and 13 | limitations under the License. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # deepstream.io-storage-rethinkdb 2 | [![Coverage Status](https://coveralls.io/repos/github/deepstreamIO/deepstream.io-storage-rethinkdb/badge.svg?branch=master)](https://coveralls.io/github/deepstreamIO/deepstream.io-storage-rethinkdb?branch=master) 3 | [![npm](https://img.shields.io/npm/v/deepstream.io-storage-rethinkdb.svg)](https://www.npmjs.com/package/deepstream.io-storage-rethinkdb) 4 | [![Dependency Status](https://david-dm.org/deepstreamIO/deepstream.io-storage-rethinkdb.svg)](https://david-dm.org/deepstreamIO/deepstream.io-storage-rethinkdb) 5 | [![devDependency Status](https://david-dm.org/deepstreamIO/deepstream.io-storage-rethinkdb/dev-status.svg)](https://david-dm.org/deepstreamIO/deepstream.io-storage-rethinkdb#info=devDependencies) 6 | [![devDependency Status](https://david-dm.org/deepstreamIO/deepstream.io-storage-rethinkdb/dev-status.svg)](https://david-dm.org/deepstreamIO/deepstream.io-storage-rethinkdb#info=devDependencies) 7 | 8 | [Deepstream](http://deepstream.io) storage connector for [RethinkDB](http://rethinkdb.com/) 9 | 10 | This connector uses [the npm rethinkdb package](https://www.npmjs.com/package/rethinkdb). Please have a look there for detailed options. 11 | 12 | **Warning**: This plugin will automatically create a table, if it doesn't exist yet. But be aware, in case you create a table manually, use "ds_id" as the primary key. Otherwise the plugin won't be able to find your records. 13 | 14 | ## Configuration Options 15 | ```yaml 16 | plugins: 17 | storage: 18 | name: rethinkdb 19 | options: 20 | host: ${RETHINKDB_HOST} 21 | port: ${RETHINKDB_PORT} 22 | db: 'someDb' 23 | defaultTable: 'someTable' 24 | splitChar: '/' 25 | ``` 26 | 27 | ```javascript 28 | { 29 | //The host that RethinkDb is listening on 30 | host: 'localhost', 31 | 32 | //The port that RethinkDb is listening on 33 | port: 28015, 34 | 35 | //(Optional) Authentication key for RethinkDb 36 | authKey: 'someString', 37 | 38 | //(Optional, defaults to 'deepstream') 39 | db: 'someDb', 40 | 41 | //(Optional, defaults to 'deepstream_records') 42 | defaultTable: 'someTable', 43 | 44 | /* (Optional) A character that's used as part of the 45 | * record names to split it into a tabel and an id part, e.g. 46 | * 47 | * books/dream-of-the-red-chamber 48 | * 49 | * would create a table called 'books' and store the record under the name 50 | * 'dream-of-the-red-chamber' 51 | */ 52 | splitChar: '/' 53 | } 54 | ``` 55 | 56 | ## Basic Setup 57 | ```javascript 58 | const { Deepstream } = require('@deepstream/server') 59 | 60 | const server = new Deepstream({ 61 | storage: { 62 | name: 'rethinkdb', 63 | options: { 64 | host: 'localhost', 65 | port: 28015 66 | } 67 | }, 68 | }) 69 | 70 | server.start(); 71 | ``` 72 | 73 | -------------------------------------------------------------------------------- /example-config.yml: -------------------------------------------------------------------------------- 1 | plugins: 2 | storage: 3 | name: rethinkdb 4 | options: 5 | host: ${RETHINKDB_HOST} 6 | port: 28015 7 | database: 'someDb' 8 | defaultTable: 'someTable' 9 | splitChar: '/' -------------------------------------------------------------------------------- /mocha.opts: -------------------------------------------------------------------------------- 1 | --reporter dot 2 | --require ts-node/register/transpile-only 3 | --exit 4 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@deepstream/storage-rethinkdb", 3 | "version": "3.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.8.3", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz", 10 | "integrity": "sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.8.3" 14 | } 15 | }, 16 | "@babel/core": { 17 | "version": "7.9.0", 18 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.9.0.tgz", 19 | "integrity": "sha512-kWc7L0fw1xwvI0zi8OKVBuxRVefwGOrKSQMvrQ3dW+bIIavBY3/NpXmpjMy7bQnLgwgzWQZ8TlM57YHpHNHz4w==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/code-frame": "^7.8.3", 23 | "@babel/generator": "^7.9.0", 24 | "@babel/helper-module-transforms": "^7.9.0", 25 | "@babel/helpers": "^7.9.0", 26 | "@babel/parser": "^7.9.0", 27 | "@babel/template": "^7.8.6", 28 | "@babel/traverse": "^7.9.0", 29 | "@babel/types": "^7.9.0", 30 | "convert-source-map": "^1.7.0", 31 | "debug": "^4.1.0", 32 | "gensync": "^1.0.0-beta.1", 33 | "json5": "^2.1.2", 34 | "lodash": "^4.17.13", 35 | "resolve": "^1.3.2", 36 | "semver": "^5.4.1", 37 | "source-map": "^0.5.0" 38 | }, 39 | "dependencies": { 40 | "debug": { 41 | "version": "4.1.1", 42 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 43 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 44 | "dev": true, 45 | "requires": { 46 | "ms": "^2.1.1" 47 | } 48 | } 49 | } 50 | }, 51 | "@babel/generator": { 52 | "version": "7.9.5", 53 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.9.5.tgz", 54 | "integrity": "sha512-GbNIxVB3ZJe3tLeDm1HSn2AhuD/mVcyLDpgtLXa5tplmWrJdF/elxB56XNqCuD6szyNkDi6wuoKXln3QeBmCHQ==", 55 | "dev": true, 56 | "requires": { 57 | "@babel/types": "^7.9.5", 58 | "jsesc": "^2.5.1", 59 | "lodash": "^4.17.13", 60 | "source-map": "^0.5.0" 61 | } 62 | }, 63 | "@babel/helper-function-name": { 64 | "version": "7.9.5", 65 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.9.5.tgz", 66 | "integrity": "sha512-JVcQZeXM59Cd1qanDUxv9fgJpt3NeKUaqBqUEvfmQ+BCOKq2xUgaWZW2hr0dkbyJgezYuplEoh5knmrnS68efw==", 67 | "dev": true, 68 | "requires": { 69 | "@babel/helper-get-function-arity": "^7.8.3", 70 | "@babel/template": "^7.8.3", 71 | "@babel/types": "^7.9.5" 72 | } 73 | }, 74 | "@babel/helper-get-function-arity": { 75 | "version": "7.8.3", 76 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.8.3.tgz", 77 | "integrity": "sha512-FVDR+Gd9iLjUMY1fzE2SR0IuaJToR4RkCDARVfsBBPSP53GEqSFjD8gNyxg246VUyc/ALRxFaAK8rVG7UT7xRA==", 78 | "dev": true, 79 | "requires": { 80 | "@babel/types": "^7.8.3" 81 | } 82 | }, 83 | "@babel/helper-member-expression-to-functions": { 84 | "version": "7.8.3", 85 | "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.8.3.tgz", 86 | "integrity": "sha512-fO4Egq88utkQFjbPrSHGmGLFqmrshs11d46WI+WZDESt7Wu7wN2G2Iu+NMMZJFDOVRHAMIkB5SNh30NtwCA7RA==", 87 | "dev": true, 88 | "requires": { 89 | "@babel/types": "^7.8.3" 90 | } 91 | }, 92 | "@babel/helper-module-imports": { 93 | "version": "7.8.3", 94 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.8.3.tgz", 95 | "integrity": "sha512-R0Bx3jippsbAEtzkpZ/6FIiuzOURPcMjHp+Z6xPe6DtApDJx+w7UYyOLanZqO8+wKR9G10s/FmHXvxaMd9s6Kg==", 96 | "dev": true, 97 | "requires": { 98 | "@babel/types": "^7.8.3" 99 | } 100 | }, 101 | "@babel/helper-module-transforms": { 102 | "version": "7.9.0", 103 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.9.0.tgz", 104 | "integrity": "sha512-0FvKyu0gpPfIQ8EkxlrAydOWROdHpBmiCiRwLkUiBGhCUPRRbVD2/tm3sFr/c/GWFrQ/ffutGUAnx7V0FzT2wA==", 105 | "dev": true, 106 | "requires": { 107 | "@babel/helper-module-imports": "^7.8.3", 108 | "@babel/helper-replace-supers": "^7.8.6", 109 | "@babel/helper-simple-access": "^7.8.3", 110 | "@babel/helper-split-export-declaration": "^7.8.3", 111 | "@babel/template": "^7.8.6", 112 | "@babel/types": "^7.9.0", 113 | "lodash": "^4.17.13" 114 | } 115 | }, 116 | "@babel/helper-optimise-call-expression": { 117 | "version": "7.8.3", 118 | "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.8.3.tgz", 119 | "integrity": "sha512-Kag20n86cbO2AvHca6EJsvqAd82gc6VMGule4HwebwMlwkpXuVqrNRj6CkCV2sKxgi9MyAUnZVnZ6lJ1/vKhHQ==", 120 | "dev": true, 121 | "requires": { 122 | "@babel/types": "^7.8.3" 123 | } 124 | }, 125 | "@babel/helper-replace-supers": { 126 | "version": "7.8.6", 127 | "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.8.6.tgz", 128 | "integrity": "sha512-PeMArdA4Sv/Wf4zXwBKPqVj7n9UF/xg6slNRtZW84FM7JpE1CbG8B612FyM4cxrf4fMAMGO0kR7voy1ForHHFA==", 129 | "dev": true, 130 | "requires": { 131 | "@babel/helper-member-expression-to-functions": "^7.8.3", 132 | "@babel/helper-optimise-call-expression": "^7.8.3", 133 | "@babel/traverse": "^7.8.6", 134 | "@babel/types": "^7.8.6" 135 | } 136 | }, 137 | "@babel/helper-simple-access": { 138 | "version": "7.8.3", 139 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.8.3.tgz", 140 | "integrity": "sha512-VNGUDjx5cCWg4vvCTR8qQ7YJYZ+HBjxOgXEl7ounz+4Sn7+LMD3CFrCTEU6/qXKbA2nKg21CwhhBzO0RpRbdCw==", 141 | "dev": true, 142 | "requires": { 143 | "@babel/template": "^7.8.3", 144 | "@babel/types": "^7.8.3" 145 | } 146 | }, 147 | "@babel/helper-split-export-declaration": { 148 | "version": "7.8.3", 149 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.8.3.tgz", 150 | "integrity": "sha512-3x3yOeyBhW851hroze7ElzdkeRXQYQbFIb7gLK1WQYsw2GWDay5gAJNw1sWJ0VFP6z5J1whqeXH/WCdCjZv6dA==", 151 | "dev": true, 152 | "requires": { 153 | "@babel/types": "^7.8.3" 154 | } 155 | }, 156 | "@babel/helper-validator-identifier": { 157 | "version": "7.9.5", 158 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz", 159 | "integrity": "sha512-/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g==", 160 | "dev": true 161 | }, 162 | "@babel/helpers": { 163 | "version": "7.9.2", 164 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.9.2.tgz", 165 | "integrity": "sha512-JwLvzlXVPjO8eU9c/wF9/zOIN7X6h8DYf7mG4CiFRZRvZNKEF5dQ3H3V+ASkHoIB3mWhatgl5ONhyqHRI6MppA==", 166 | "dev": true, 167 | "requires": { 168 | "@babel/template": "^7.8.3", 169 | "@babel/traverse": "^7.9.0", 170 | "@babel/types": "^7.9.0" 171 | } 172 | }, 173 | "@babel/highlight": { 174 | "version": "7.9.0", 175 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.9.0.tgz", 176 | "integrity": "sha512-lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ==", 177 | "dev": true, 178 | "requires": { 179 | "@babel/helper-validator-identifier": "^7.9.0", 180 | "chalk": "^2.0.0", 181 | "js-tokens": "^4.0.0" 182 | } 183 | }, 184 | "@babel/parser": { 185 | "version": "7.9.4", 186 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.9.4.tgz", 187 | "integrity": "sha512-bC49otXX6N0/VYhgOMh4gnP26E9xnDZK3TmbNpxYzzz9BQLBosQwfyOe9/cXUU3txYhTzLCbcqd5c8y/OmCjHA==", 188 | "dev": true 189 | }, 190 | "@babel/template": { 191 | "version": "7.8.6", 192 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.8.6.tgz", 193 | "integrity": "sha512-zbMsPMy/v0PWFZEhQJ66bqjhH+z0JgMoBWuikXybgG3Gkd/3t5oQ1Rw2WQhnSrsOmsKXnZOx15tkC4qON/+JPg==", 194 | "dev": true, 195 | "requires": { 196 | "@babel/code-frame": "^7.8.3", 197 | "@babel/parser": "^7.8.6", 198 | "@babel/types": "^7.8.6" 199 | } 200 | }, 201 | "@babel/traverse": { 202 | "version": "7.9.5", 203 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.9.5.tgz", 204 | "integrity": "sha512-c4gH3jsvSuGUezlP6rzSJ6jf8fYjLj3hsMZRx/nX0h+fmHN0w+ekubRrHPqnMec0meycA2nwCsJ7dC8IPem2FQ==", 205 | "dev": true, 206 | "requires": { 207 | "@babel/code-frame": "^7.8.3", 208 | "@babel/generator": "^7.9.5", 209 | "@babel/helper-function-name": "^7.9.5", 210 | "@babel/helper-split-export-declaration": "^7.8.3", 211 | "@babel/parser": "^7.9.0", 212 | "@babel/types": "^7.9.5", 213 | "debug": "^4.1.0", 214 | "globals": "^11.1.0", 215 | "lodash": "^4.17.13" 216 | }, 217 | "dependencies": { 218 | "debug": { 219 | "version": "4.1.1", 220 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 221 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 222 | "dev": true, 223 | "requires": { 224 | "ms": "^2.1.1" 225 | } 226 | } 227 | } 228 | }, 229 | "@babel/types": { 230 | "version": "7.9.5", 231 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.9.5.tgz", 232 | "integrity": "sha512-XjnvNqenk818r5zMaba+sLQjnbda31UfUURv3ei0qPQw4u+j2jMyJ5b11y8ZHYTRSI3NnInQkkkRT4fLqqPdHg==", 233 | "dev": true, 234 | "requires": { 235 | "@babel/helper-validator-identifier": "^7.9.5", 236 | "lodash": "^4.17.13", 237 | "to-fast-properties": "^2.0.0" 238 | } 239 | }, 240 | "@deepstream/protobuf": { 241 | "version": "1.0.1", 242 | "resolved": "https://registry.npmjs.org/@deepstream/protobuf/-/protobuf-1.0.1.tgz", 243 | "integrity": "sha512-D+Hg+GkZDKf6hcAhn+t6iTDHTGNiiJwmXSELQkuLrJ/hSboWKuDhnfv1Gi04vJbHl7K25of8OdypyyrHnD/3zg==", 244 | "dev": true, 245 | "requires": { 246 | "protobufjs": "^6.8.8" 247 | } 248 | }, 249 | "@deepstream/types": { 250 | "version": "2.0.9", 251 | "resolved": "https://registry.npmjs.org/@deepstream/types/-/types-2.0.9.tgz", 252 | "integrity": "sha512-uNTgY5zCe5fdI1+oNmXl9sxQ9Zn4KHXPqJKNt3sBrgtj5SSr3VpbjsSN4GRGLiv+lnQCXlh+Yihu1H3Lb1CLIg==" 253 | }, 254 | "@istanbuljs/load-nyc-config": { 255 | "version": "1.0.0", 256 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.0.0.tgz", 257 | "integrity": "sha512-ZR0rq/f/E4f4XcgnDvtMWXCUJpi8eO0rssVhmztsZqLIEFA9UUP9zmpE0VxlM+kv/E1ul2I876Fwil2ayptDVg==", 258 | "dev": true, 259 | "requires": { 260 | "camelcase": "^5.3.1", 261 | "find-up": "^4.1.0", 262 | "js-yaml": "^3.13.1", 263 | "resolve-from": "^5.0.0" 264 | }, 265 | "dependencies": { 266 | "find-up": { 267 | "version": "4.1.0", 268 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 269 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 270 | "dev": true, 271 | "requires": { 272 | "locate-path": "^5.0.0", 273 | "path-exists": "^4.0.0" 274 | } 275 | }, 276 | "locate-path": { 277 | "version": "5.0.0", 278 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 279 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 280 | "dev": true, 281 | "requires": { 282 | "p-locate": "^4.1.0" 283 | } 284 | }, 285 | "p-locate": { 286 | "version": "4.1.0", 287 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 288 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 289 | "dev": true, 290 | "requires": { 291 | "p-limit": "^2.2.0" 292 | } 293 | }, 294 | "path-exists": { 295 | "version": "4.0.0", 296 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 297 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 298 | "dev": true 299 | } 300 | } 301 | }, 302 | "@istanbuljs/schema": { 303 | "version": "0.1.2", 304 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz", 305 | "integrity": "sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==", 306 | "dev": true 307 | }, 308 | "@protobufjs/aspromise": { 309 | "version": "1.1.2", 310 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 311 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=", 312 | "dev": true 313 | }, 314 | "@protobufjs/base64": { 315 | "version": "1.1.2", 316 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 317 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==", 318 | "dev": true 319 | }, 320 | "@protobufjs/codegen": { 321 | "version": "2.0.4", 322 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 323 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==", 324 | "dev": true 325 | }, 326 | "@protobufjs/eventemitter": { 327 | "version": "1.1.0", 328 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 329 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=", 330 | "dev": true 331 | }, 332 | "@protobufjs/fetch": { 333 | "version": "1.1.0", 334 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 335 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 336 | "dev": true, 337 | "requires": { 338 | "@protobufjs/aspromise": "^1.1.1", 339 | "@protobufjs/inquire": "^1.1.0" 340 | } 341 | }, 342 | "@protobufjs/float": { 343 | "version": "1.0.2", 344 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 345 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=", 346 | "dev": true 347 | }, 348 | "@protobufjs/inquire": { 349 | "version": "1.1.0", 350 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 351 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=", 352 | "dev": true 353 | }, 354 | "@protobufjs/path": { 355 | "version": "1.1.2", 356 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 357 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=", 358 | "dev": true 359 | }, 360 | "@protobufjs/pool": { 361 | "version": "1.1.0", 362 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 363 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=", 364 | "dev": true 365 | }, 366 | "@protobufjs/utf8": { 367 | "version": "1.1.0", 368 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 369 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=", 370 | "dev": true 371 | }, 372 | "@types/chai": { 373 | "version": "4.2.11", 374 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.2.11.tgz", 375 | "integrity": "sha512-t7uW6eFafjO+qJ3BIV2gGUyZs27egcNRkUdalkud+Qa3+kg//f129iuOFivHDXQ+vnU3fDXuwgv0cqMCbcE8sw==", 376 | "dev": true 377 | }, 378 | "@types/color-name": { 379 | "version": "1.1.1", 380 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 381 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 382 | "dev": true 383 | }, 384 | "@types/long": { 385 | "version": "4.0.1", 386 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 387 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==", 388 | "dev": true 389 | }, 390 | "@types/mocha": { 391 | "version": "7.0.2", 392 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-7.0.2.tgz", 393 | "integrity": "sha512-ZvO2tAcjmMi8V/5Z3JsyofMe3hasRcaw88cto5etSVMwVQfeivGAlEYmaQgceUSVYFofVjT+ioHsATjdWcFt1w==", 394 | "dev": true 395 | }, 396 | "@types/node": { 397 | "version": "13.11.1", 398 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.11.1.tgz", 399 | "integrity": "sha512-eWQGP3qtxwL8FGneRrC5DwrJLGN4/dH1clNTuLfN81HCrxVtxRjygDTUoZJ5ASlDEeo0ppYFQjQIlXhtXpOn6g==", 400 | "dev": true 401 | }, 402 | "@types/rethinkdb": { 403 | "version": "2.3.14", 404 | "resolved": "https://registry.npmjs.org/@types/rethinkdb/-/rethinkdb-2.3.14.tgz", 405 | "integrity": "sha512-AxzeCg5cIgi8Jv4SzlFnQFottaM+NFlwtBZAEEqccbKAOBdayt/dsTevkVSPU7OjA01p0j6XtjrMVCCX+0QjRA==", 406 | "dev": true, 407 | "requires": { 408 | "@types/node": "*" 409 | } 410 | }, 411 | "aggregate-error": { 412 | "version": "3.0.1", 413 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.0.1.tgz", 414 | "integrity": "sha512-quoaXsZ9/BLNae5yiNoUz+Nhkwz83GhWwtYFglcjEQB2NDHCIpApbqXxIFnm4Pq/Nvhrsq5sYJFyohrrxnTGAA==", 415 | "dev": true, 416 | "requires": { 417 | "clean-stack": "^2.0.0", 418 | "indent-string": "^4.0.0" 419 | } 420 | }, 421 | "ajv": { 422 | "version": "6.12.6", 423 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 424 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 425 | "dev": true, 426 | "requires": { 427 | "fast-deep-equal": "^3.1.1", 428 | "fast-json-stable-stringify": "^2.0.0", 429 | "json-schema-traverse": "^0.4.1", 430 | "uri-js": "^4.2.2" 431 | } 432 | }, 433 | "ansi-colors": { 434 | "version": "3.2.3", 435 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 436 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 437 | "dev": true 438 | }, 439 | "ansi-regex": { 440 | "version": "3.0.0", 441 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 442 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 443 | "dev": true 444 | }, 445 | "ansi-styles": { 446 | "version": "3.2.1", 447 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 448 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 449 | "dev": true, 450 | "requires": { 451 | "color-convert": "^1.9.0" 452 | } 453 | }, 454 | "anymatch": { 455 | "version": "3.1.1", 456 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 457 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 458 | "dev": true, 459 | "requires": { 460 | "normalize-path": "^3.0.0", 461 | "picomatch": "^2.0.4" 462 | } 463 | }, 464 | "append-transform": { 465 | "version": "2.0.0", 466 | "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-2.0.0.tgz", 467 | "integrity": "sha512-7yeyCEurROLQJFv5Xj4lEGTy0borxepjFv1g22oAdqFu//SrAlDl1O1Nxx15SH1RoliUml6p8dwJW9jvZughhg==", 468 | "dev": true, 469 | "requires": { 470 | "default-require-extensions": "^3.0.0" 471 | } 472 | }, 473 | "archy": { 474 | "version": "1.0.0", 475 | "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", 476 | "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=", 477 | "dev": true 478 | }, 479 | "arg": { 480 | "version": "4.1.3", 481 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 482 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 483 | "dev": true 484 | }, 485 | "argparse": { 486 | "version": "1.0.10", 487 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 488 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 489 | "dev": true, 490 | "requires": { 491 | "sprintf-js": "~1.0.2" 492 | } 493 | }, 494 | "asn1": { 495 | "version": "0.2.4", 496 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 497 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 498 | "dev": true, 499 | "requires": { 500 | "safer-buffer": "~2.1.0" 501 | } 502 | }, 503 | "assert-plus": { 504 | "version": "1.0.0", 505 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 506 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 507 | "dev": true 508 | }, 509 | "assertion-error": { 510 | "version": "1.1.0", 511 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 512 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 513 | "dev": true 514 | }, 515 | "asynckit": { 516 | "version": "0.4.0", 517 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 518 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 519 | "dev": true 520 | }, 521 | "aws-sign2": { 522 | "version": "0.7.0", 523 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 524 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 525 | "dev": true 526 | }, 527 | "aws4": { 528 | "version": "1.9.1", 529 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.1.tgz", 530 | "integrity": "sha512-wMHVg2EOHaMRxbzgFJ9gtjOOCrI80OHLG14rxi28XwOW8ux6IiEbRCGGGqCtdAIg4FQCbW20k9RsT4y3gJlFug==", 531 | "dev": true 532 | }, 533 | "balanced-match": { 534 | "version": "1.0.0", 535 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 536 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 537 | "dev": true 538 | }, 539 | "bcrypt-pbkdf": { 540 | "version": "1.0.2", 541 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 542 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 543 | "dev": true, 544 | "requires": { 545 | "tweetnacl": "^0.14.3" 546 | } 547 | }, 548 | "binary-extensions": { 549 | "version": "2.0.0", 550 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", 551 | "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==", 552 | "dev": true 553 | }, 554 | "bluebird": { 555 | "version": "2.11.0", 556 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-2.11.0.tgz", 557 | "integrity": "sha1-U0uQM8AiyVecVro7Plpcqvu2UOE=" 558 | }, 559 | "brace-expansion": { 560 | "version": "1.1.11", 561 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 562 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 563 | "dev": true, 564 | "requires": { 565 | "balanced-match": "^1.0.0", 566 | "concat-map": "0.0.1" 567 | } 568 | }, 569 | "braces": { 570 | "version": "3.0.2", 571 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 572 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 573 | "dev": true, 574 | "requires": { 575 | "fill-range": "^7.0.1" 576 | } 577 | }, 578 | "browser-stdout": { 579 | "version": "1.3.1", 580 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 581 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 582 | "dev": true 583 | }, 584 | "buffer-from": { 585 | "version": "1.1.1", 586 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 587 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 588 | "dev": true 589 | }, 590 | "builtin-modules": { 591 | "version": "1.1.1", 592 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 593 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 594 | "dev": true 595 | }, 596 | "caching-transform": { 597 | "version": "4.0.0", 598 | "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", 599 | "integrity": "sha512-kpqOvwXnjjN44D89K5ccQC+RUrsy7jB/XLlRrx0D7/2HNcTPqzsb6XgYoErwko6QsV184CA2YgS1fxDiiDZMWA==", 600 | "dev": true, 601 | "requires": { 602 | "hasha": "^5.0.0", 603 | "make-dir": "^3.0.0", 604 | "package-hash": "^4.0.0", 605 | "write-file-atomic": "^3.0.0" 606 | } 607 | }, 608 | "camelcase": { 609 | "version": "5.3.1", 610 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 611 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 612 | "dev": true 613 | }, 614 | "caseless": { 615 | "version": "0.12.0", 616 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 617 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 618 | "dev": true 619 | }, 620 | "chai": { 621 | "version": "4.2.0", 622 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 623 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 624 | "dev": true, 625 | "requires": { 626 | "assertion-error": "^1.1.0", 627 | "check-error": "^1.0.2", 628 | "deep-eql": "^3.0.1", 629 | "get-func-name": "^2.0.0", 630 | "pathval": "^1.1.0", 631 | "type-detect": "^4.0.5" 632 | } 633 | }, 634 | "chalk": { 635 | "version": "2.4.2", 636 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 637 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 638 | "dev": true, 639 | "requires": { 640 | "ansi-styles": "^3.2.1", 641 | "escape-string-regexp": "^1.0.5", 642 | "supports-color": "^5.3.0" 643 | }, 644 | "dependencies": { 645 | "supports-color": { 646 | "version": "5.5.0", 647 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 648 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 649 | "dev": true, 650 | "requires": { 651 | "has-flag": "^3.0.0" 652 | } 653 | } 654 | } 655 | }, 656 | "check-error": { 657 | "version": "1.0.2", 658 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 659 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 660 | "dev": true 661 | }, 662 | "chokidar": { 663 | "version": "3.3.0", 664 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", 665 | "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", 666 | "dev": true, 667 | "requires": { 668 | "anymatch": "~3.1.1", 669 | "braces": "~3.0.2", 670 | "fsevents": "~2.1.1", 671 | "glob-parent": "~5.1.0", 672 | "is-binary-path": "~2.1.0", 673 | "is-glob": "~4.0.1", 674 | "normalize-path": "~3.0.0", 675 | "readdirp": "~3.2.0" 676 | } 677 | }, 678 | "clean-stack": { 679 | "version": "2.2.0", 680 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 681 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 682 | "dev": true 683 | }, 684 | "cliui": { 685 | "version": "5.0.0", 686 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 687 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 688 | "dev": true, 689 | "requires": { 690 | "string-width": "^3.1.0", 691 | "strip-ansi": "^5.2.0", 692 | "wrap-ansi": "^5.1.0" 693 | }, 694 | "dependencies": { 695 | "ansi-regex": { 696 | "version": "4.1.0", 697 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 698 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 699 | "dev": true 700 | }, 701 | "string-width": { 702 | "version": "3.1.0", 703 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 704 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 705 | "dev": true, 706 | "requires": { 707 | "emoji-regex": "^7.0.1", 708 | "is-fullwidth-code-point": "^2.0.0", 709 | "strip-ansi": "^5.1.0" 710 | } 711 | }, 712 | "strip-ansi": { 713 | "version": "5.2.0", 714 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 715 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 716 | "dev": true, 717 | "requires": { 718 | "ansi-regex": "^4.1.0" 719 | } 720 | } 721 | } 722 | }, 723 | "color-convert": { 724 | "version": "1.9.3", 725 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 726 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 727 | "dev": true, 728 | "requires": { 729 | "color-name": "1.1.3" 730 | } 731 | }, 732 | "color-name": { 733 | "version": "1.1.3", 734 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 735 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 736 | "dev": true 737 | }, 738 | "combined-stream": { 739 | "version": "1.0.8", 740 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 741 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 742 | "dev": true, 743 | "requires": { 744 | "delayed-stream": "~1.0.0" 745 | } 746 | }, 747 | "commander": { 748 | "version": "2.20.3", 749 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 750 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 751 | "dev": true 752 | }, 753 | "commondir": { 754 | "version": "1.0.1", 755 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 756 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 757 | "dev": true 758 | }, 759 | "concat-map": { 760 | "version": "0.0.1", 761 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 762 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 763 | "dev": true 764 | }, 765 | "convert-source-map": { 766 | "version": "1.7.0", 767 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 768 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 769 | "dev": true, 770 | "requires": { 771 | "safe-buffer": "~5.1.1" 772 | }, 773 | "dependencies": { 774 | "safe-buffer": { 775 | "version": "5.1.2", 776 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 777 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 778 | "dev": true 779 | } 780 | } 781 | }, 782 | "core-util-is": { 783 | "version": "1.0.2", 784 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 785 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 786 | "dev": true 787 | }, 788 | "coveralls": { 789 | "version": "3.0.11", 790 | "resolved": "https://registry.npmjs.org/coveralls/-/coveralls-3.0.11.tgz", 791 | "integrity": "sha512-LZPWPR2NyGKyaABnc49dR0fpeP6UqhvGq4B5nUrTQ1UBy55z96+ga7r+/ChMdMJUwBgyJDXBi88UBgz2rs9IiQ==", 792 | "dev": true, 793 | "requires": { 794 | "js-yaml": "^3.13.1", 795 | "lcov-parse": "^1.0.0", 796 | "log-driver": "^1.2.7", 797 | "minimist": "^1.2.5", 798 | "request": "^2.88.0" 799 | } 800 | }, 801 | "cross-spawn": { 802 | "version": "7.0.2", 803 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.2.tgz", 804 | "integrity": "sha512-PD6G8QG3S4FK/XCGFbEQrDqO2AnMMsy0meR7lerlIOHAAbkuavGU/pOqprrlvfTNjvowivTeBsjebAL0NSoMxw==", 805 | "dev": true, 806 | "requires": { 807 | "path-key": "^3.1.0", 808 | "shebang-command": "^2.0.0", 809 | "which": "^2.0.1" 810 | }, 811 | "dependencies": { 812 | "which": { 813 | "version": "2.0.2", 814 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 815 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 816 | "dev": true, 817 | "requires": { 818 | "isexe": "^2.0.0" 819 | } 820 | } 821 | } 822 | }, 823 | "dashdash": { 824 | "version": "1.14.1", 825 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 826 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 827 | "dev": true, 828 | "requires": { 829 | "assert-plus": "^1.0.0" 830 | } 831 | }, 832 | "debug": { 833 | "version": "3.2.6", 834 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 835 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 836 | "dev": true, 837 | "requires": { 838 | "ms": "^2.1.1" 839 | } 840 | }, 841 | "decamelize": { 842 | "version": "1.2.0", 843 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 844 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 845 | "dev": true 846 | }, 847 | "deep-eql": { 848 | "version": "3.0.1", 849 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 850 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 851 | "dev": true, 852 | "requires": { 853 | "type-detect": "^4.0.0" 854 | } 855 | }, 856 | "default-require-extensions": { 857 | "version": "3.0.0", 858 | "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-3.0.0.tgz", 859 | "integrity": "sha512-ek6DpXq/SCpvjhpFsLFRVtIxJCRw6fUR42lYMVZuUMK7n8eMz4Uh5clckdBjEpLhn/gEBZo7hDJnJcwdKLKQjg==", 860 | "dev": true, 861 | "requires": { 862 | "strip-bom": "^4.0.0" 863 | } 864 | }, 865 | "define-properties": { 866 | "version": "1.1.3", 867 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 868 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 869 | "dev": true, 870 | "requires": { 871 | "object-keys": "^1.0.12" 872 | } 873 | }, 874 | "delayed-stream": { 875 | "version": "1.0.0", 876 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 877 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 878 | "dev": true 879 | }, 880 | "diff": { 881 | "version": "3.5.0", 882 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 883 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 884 | "dev": true 885 | }, 886 | "ecc-jsbn": { 887 | "version": "0.1.2", 888 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 889 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 890 | "dev": true, 891 | "requires": { 892 | "jsbn": "~0.1.0", 893 | "safer-buffer": "^2.1.0" 894 | } 895 | }, 896 | "emoji-regex": { 897 | "version": "7.0.3", 898 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 899 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 900 | "dev": true 901 | }, 902 | "es-abstract": { 903 | "version": "1.17.5", 904 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.5.tgz", 905 | "integrity": "sha512-BR9auzDbySxOcfog0tLECW8l28eRGpDpU3Dm3Hp4q/N+VtLTmyj4EUN088XZWQDW/hzj6sYRDXeOFsaAODKvpg==", 906 | "dev": true, 907 | "requires": { 908 | "es-to-primitive": "^1.2.1", 909 | "function-bind": "^1.1.1", 910 | "has": "^1.0.3", 911 | "has-symbols": "^1.0.1", 912 | "is-callable": "^1.1.5", 913 | "is-regex": "^1.0.5", 914 | "object-inspect": "^1.7.0", 915 | "object-keys": "^1.1.1", 916 | "object.assign": "^4.1.0", 917 | "string.prototype.trimleft": "^2.1.1", 918 | "string.prototype.trimright": "^2.1.1" 919 | } 920 | }, 921 | "es-to-primitive": { 922 | "version": "1.2.1", 923 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 924 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 925 | "dev": true, 926 | "requires": { 927 | "is-callable": "^1.1.4", 928 | "is-date-object": "^1.0.1", 929 | "is-symbol": "^1.0.2" 930 | } 931 | }, 932 | "es6-error": { 933 | "version": "4.1.1", 934 | "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", 935 | "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", 936 | "dev": true 937 | }, 938 | "escape-string-regexp": { 939 | "version": "1.0.5", 940 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 941 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 942 | "dev": true 943 | }, 944 | "esprima": { 945 | "version": "4.0.1", 946 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 947 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 948 | "dev": true 949 | }, 950 | "extend": { 951 | "version": "3.0.2", 952 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 953 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 954 | "dev": true 955 | }, 956 | "extsprintf": { 957 | "version": "1.3.0", 958 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 959 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 960 | "dev": true 961 | }, 962 | "fast-deep-equal": { 963 | "version": "3.1.1", 964 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", 965 | "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==", 966 | "dev": true 967 | }, 968 | "fast-json-stable-stringify": { 969 | "version": "2.1.0", 970 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 971 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 972 | "dev": true 973 | }, 974 | "fill-range": { 975 | "version": "7.0.1", 976 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 977 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 978 | "dev": true, 979 | "requires": { 980 | "to-regex-range": "^5.0.1" 981 | } 982 | }, 983 | "find-cache-dir": { 984 | "version": "3.3.1", 985 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.1.tgz", 986 | "integrity": "sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ==", 987 | "dev": true, 988 | "requires": { 989 | "commondir": "^1.0.1", 990 | "make-dir": "^3.0.2", 991 | "pkg-dir": "^4.1.0" 992 | } 993 | }, 994 | "find-up": { 995 | "version": "3.0.0", 996 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 997 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 998 | "dev": true, 999 | "requires": { 1000 | "locate-path": "^3.0.0" 1001 | } 1002 | }, 1003 | "flat": { 1004 | "version": "4.1.0", 1005 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 1006 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 1007 | "dev": true, 1008 | "requires": { 1009 | "is-buffer": "~2.0.3" 1010 | } 1011 | }, 1012 | "foreground-child": { 1013 | "version": "2.0.0", 1014 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", 1015 | "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", 1016 | "dev": true, 1017 | "requires": { 1018 | "cross-spawn": "^7.0.0", 1019 | "signal-exit": "^3.0.2" 1020 | } 1021 | }, 1022 | "forever-agent": { 1023 | "version": "0.6.1", 1024 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 1025 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 1026 | "dev": true 1027 | }, 1028 | "form-data": { 1029 | "version": "2.3.3", 1030 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 1031 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 1032 | "dev": true, 1033 | "requires": { 1034 | "asynckit": "^0.4.0", 1035 | "combined-stream": "^1.0.6", 1036 | "mime-types": "^2.1.12" 1037 | } 1038 | }, 1039 | "fromentries": { 1040 | "version": "1.2.0", 1041 | "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.2.0.tgz", 1042 | "integrity": "sha512-33X7H/wdfO99GdRLLgkjUrD4geAFdq/Uv0kl3HD4da6HDixd2GUg8Mw7dahLCV9r/EARkmtYBB6Tch4EEokFTQ==", 1043 | "dev": true 1044 | }, 1045 | "fs.realpath": { 1046 | "version": "1.0.0", 1047 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1048 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1049 | "dev": true 1050 | }, 1051 | "fsevents": { 1052 | "version": "2.1.2", 1053 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.2.tgz", 1054 | "integrity": "sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA==", 1055 | "dev": true, 1056 | "optional": true 1057 | }, 1058 | "function-bind": { 1059 | "version": "1.1.1", 1060 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1061 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1062 | "dev": true 1063 | }, 1064 | "gensync": { 1065 | "version": "1.0.0-beta.1", 1066 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz", 1067 | "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==", 1068 | "dev": true 1069 | }, 1070 | "get-caller-file": { 1071 | "version": "2.0.5", 1072 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1073 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1074 | "dev": true 1075 | }, 1076 | "get-func-name": { 1077 | "version": "2.0.0", 1078 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1079 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1080 | "dev": true 1081 | }, 1082 | "getpass": { 1083 | "version": "0.1.7", 1084 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 1085 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 1086 | "dev": true, 1087 | "requires": { 1088 | "assert-plus": "^1.0.0" 1089 | } 1090 | }, 1091 | "glob": { 1092 | "version": "7.1.3", 1093 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1094 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1095 | "dev": true, 1096 | "requires": { 1097 | "fs.realpath": "^1.0.0", 1098 | "inflight": "^1.0.4", 1099 | "inherits": "2", 1100 | "minimatch": "^3.0.4", 1101 | "once": "^1.3.0", 1102 | "path-is-absolute": "^1.0.0" 1103 | } 1104 | }, 1105 | "glob-parent": { 1106 | "version": "5.1.1", 1107 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1108 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1109 | "dev": true, 1110 | "requires": { 1111 | "is-glob": "^4.0.1" 1112 | } 1113 | }, 1114 | "globals": { 1115 | "version": "11.12.0", 1116 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1117 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1118 | "dev": true 1119 | }, 1120 | "graceful-fs": { 1121 | "version": "4.2.3", 1122 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", 1123 | "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==", 1124 | "dev": true 1125 | }, 1126 | "growl": { 1127 | "version": "1.10.5", 1128 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1129 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1130 | "dev": true 1131 | }, 1132 | "har-schema": { 1133 | "version": "2.0.0", 1134 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1135 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 1136 | "dev": true 1137 | }, 1138 | "har-validator": { 1139 | "version": "5.1.3", 1140 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 1141 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 1142 | "dev": true, 1143 | "requires": { 1144 | "ajv": "^6.5.5", 1145 | "har-schema": "^2.0.0" 1146 | } 1147 | }, 1148 | "has": { 1149 | "version": "1.0.3", 1150 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1151 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1152 | "dev": true, 1153 | "requires": { 1154 | "function-bind": "^1.1.1" 1155 | } 1156 | }, 1157 | "has-flag": { 1158 | "version": "3.0.0", 1159 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1160 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1161 | "dev": true 1162 | }, 1163 | "has-symbols": { 1164 | "version": "1.0.1", 1165 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1166 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1167 | "dev": true 1168 | }, 1169 | "hasha": { 1170 | "version": "5.2.0", 1171 | "resolved": "https://registry.npmjs.org/hasha/-/hasha-5.2.0.tgz", 1172 | "integrity": "sha512-2W+jKdQbAdSIrggA8Q35Br8qKadTrqCTC8+XZvBWepKDK6m9XkX6Iz1a2yh2KP01kzAR/dpuMeUnocoLYDcskw==", 1173 | "dev": true, 1174 | "requires": { 1175 | "is-stream": "^2.0.0", 1176 | "type-fest": "^0.8.0" 1177 | } 1178 | }, 1179 | "he": { 1180 | "version": "1.2.0", 1181 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1182 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1183 | "dev": true 1184 | }, 1185 | "html-escaper": { 1186 | "version": "2.0.2", 1187 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1188 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1189 | "dev": true 1190 | }, 1191 | "http-signature": { 1192 | "version": "1.2.0", 1193 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 1194 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 1195 | "dev": true, 1196 | "requires": { 1197 | "assert-plus": "^1.0.0", 1198 | "jsprim": "^1.2.2", 1199 | "sshpk": "^1.7.0" 1200 | } 1201 | }, 1202 | "imurmurhash": { 1203 | "version": "0.1.4", 1204 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1205 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1206 | "dev": true 1207 | }, 1208 | "indent-string": { 1209 | "version": "4.0.0", 1210 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 1211 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 1212 | "dev": true 1213 | }, 1214 | "inflight": { 1215 | "version": "1.0.6", 1216 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1217 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1218 | "dev": true, 1219 | "requires": { 1220 | "once": "^1.3.0", 1221 | "wrappy": "1" 1222 | } 1223 | }, 1224 | "inherits": { 1225 | "version": "2.0.4", 1226 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1227 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1228 | "dev": true 1229 | }, 1230 | "is-binary-path": { 1231 | "version": "2.1.0", 1232 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1233 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1234 | "dev": true, 1235 | "requires": { 1236 | "binary-extensions": "^2.0.0" 1237 | } 1238 | }, 1239 | "is-buffer": { 1240 | "version": "2.0.4", 1241 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1242 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1243 | "dev": true 1244 | }, 1245 | "is-callable": { 1246 | "version": "1.1.5", 1247 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.5.tgz", 1248 | "integrity": "sha512-ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q==", 1249 | "dev": true 1250 | }, 1251 | "is-date-object": { 1252 | "version": "1.0.2", 1253 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1254 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1255 | "dev": true 1256 | }, 1257 | "is-extglob": { 1258 | "version": "2.1.1", 1259 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1260 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1261 | "dev": true 1262 | }, 1263 | "is-fullwidth-code-point": { 1264 | "version": "2.0.0", 1265 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1266 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1267 | "dev": true 1268 | }, 1269 | "is-glob": { 1270 | "version": "4.0.1", 1271 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1272 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1273 | "dev": true, 1274 | "requires": { 1275 | "is-extglob": "^2.1.1" 1276 | } 1277 | }, 1278 | "is-number": { 1279 | "version": "7.0.0", 1280 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1281 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1282 | "dev": true 1283 | }, 1284 | "is-regex": { 1285 | "version": "1.0.5", 1286 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.5.tgz", 1287 | "integrity": "sha512-vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ==", 1288 | "dev": true, 1289 | "requires": { 1290 | "has": "^1.0.3" 1291 | } 1292 | }, 1293 | "is-stream": { 1294 | "version": "2.0.0", 1295 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 1296 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 1297 | "dev": true 1298 | }, 1299 | "is-symbol": { 1300 | "version": "1.0.3", 1301 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1302 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1303 | "dev": true, 1304 | "requires": { 1305 | "has-symbols": "^1.0.1" 1306 | } 1307 | }, 1308 | "is-typedarray": { 1309 | "version": "1.0.0", 1310 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1311 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1312 | "dev": true 1313 | }, 1314 | "is-windows": { 1315 | "version": "1.0.2", 1316 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1317 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1318 | "dev": true 1319 | }, 1320 | "isexe": { 1321 | "version": "2.0.0", 1322 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1323 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1324 | "dev": true 1325 | }, 1326 | "isstream": { 1327 | "version": "0.1.2", 1328 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1329 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 1330 | "dev": true 1331 | }, 1332 | "istanbul-lib-coverage": { 1333 | "version": "3.0.0", 1334 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz", 1335 | "integrity": "sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg==", 1336 | "dev": true 1337 | }, 1338 | "istanbul-lib-hook": { 1339 | "version": "3.0.0", 1340 | "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-3.0.0.tgz", 1341 | "integrity": "sha512-Pt/uge1Q9s+5VAZ+pCo16TYMWPBIl+oaNIjgLQxcX0itS6ueeaA+pEfThZpH8WxhFgCiEb8sAJY6MdUKgiIWaQ==", 1342 | "dev": true, 1343 | "requires": { 1344 | "append-transform": "^2.0.0" 1345 | } 1346 | }, 1347 | "istanbul-lib-instrument": { 1348 | "version": "4.0.1", 1349 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.1.tgz", 1350 | "integrity": "sha512-imIchxnodll7pvQBYOqUu88EufLCU56LMeFPZZM/fJZ1irYcYdqroaV+ACK1Ila8ls09iEYArp+nqyC6lW1Vfg==", 1351 | "dev": true, 1352 | "requires": { 1353 | "@babel/core": "^7.7.5", 1354 | "@babel/parser": "^7.7.5", 1355 | "@babel/template": "^7.7.4", 1356 | "@babel/traverse": "^7.7.4", 1357 | "@istanbuljs/schema": "^0.1.2", 1358 | "istanbul-lib-coverage": "^3.0.0", 1359 | "semver": "^6.3.0" 1360 | }, 1361 | "dependencies": { 1362 | "semver": { 1363 | "version": "6.3.0", 1364 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1365 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1366 | "dev": true 1367 | } 1368 | } 1369 | }, 1370 | "istanbul-lib-processinfo": { 1371 | "version": "2.0.2", 1372 | "resolved": "https://registry.npmjs.org/istanbul-lib-processinfo/-/istanbul-lib-processinfo-2.0.2.tgz", 1373 | "integrity": "sha512-kOwpa7z9hme+IBPZMzQ5vdQj8srYgAtaRqeI48NGmAQ+/5yKiHLV0QbYqQpxsdEF0+w14SoB8YbnHKcXE2KnYw==", 1374 | "dev": true, 1375 | "requires": { 1376 | "archy": "^1.0.0", 1377 | "cross-spawn": "^7.0.0", 1378 | "istanbul-lib-coverage": "^3.0.0-alpha.1", 1379 | "make-dir": "^3.0.0", 1380 | "p-map": "^3.0.0", 1381 | "rimraf": "^3.0.0", 1382 | "uuid": "^3.3.3" 1383 | } 1384 | }, 1385 | "istanbul-lib-report": { 1386 | "version": "3.0.0", 1387 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1388 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1389 | "dev": true, 1390 | "requires": { 1391 | "istanbul-lib-coverage": "^3.0.0", 1392 | "make-dir": "^3.0.0", 1393 | "supports-color": "^7.1.0" 1394 | }, 1395 | "dependencies": { 1396 | "has-flag": { 1397 | "version": "4.0.0", 1398 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1399 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1400 | "dev": true 1401 | }, 1402 | "supports-color": { 1403 | "version": "7.1.0", 1404 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1405 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1406 | "dev": true, 1407 | "requires": { 1408 | "has-flag": "^4.0.0" 1409 | } 1410 | } 1411 | } 1412 | }, 1413 | "istanbul-lib-source-maps": { 1414 | "version": "4.0.0", 1415 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.0.tgz", 1416 | "integrity": "sha512-c16LpFRkR8vQXyHZ5nLpY35JZtzj1PQY1iZmesUbf1FZHbIupcWfjgOXBY9YHkLEQ6puz1u4Dgj6qmU/DisrZg==", 1417 | "dev": true, 1418 | "requires": { 1419 | "debug": "^4.1.1", 1420 | "istanbul-lib-coverage": "^3.0.0", 1421 | "source-map": "^0.6.1" 1422 | }, 1423 | "dependencies": { 1424 | "debug": { 1425 | "version": "4.1.1", 1426 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1427 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1428 | "dev": true, 1429 | "requires": { 1430 | "ms": "^2.1.1" 1431 | } 1432 | }, 1433 | "source-map": { 1434 | "version": "0.6.1", 1435 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1436 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1437 | "dev": true 1438 | } 1439 | } 1440 | }, 1441 | "istanbul-reports": { 1442 | "version": "3.0.2", 1443 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.0.2.tgz", 1444 | "integrity": "sha512-9tZvz7AiR3PEDNGiV9vIouQ/EAcqMXFmkcA1CDFTwOB98OZVDL0PH9glHotf5Ugp6GCOTypfzGWI/OqjWNCRUw==", 1445 | "dev": true, 1446 | "requires": { 1447 | "html-escaper": "^2.0.0", 1448 | "istanbul-lib-report": "^3.0.0" 1449 | } 1450 | }, 1451 | "js-tokens": { 1452 | "version": "4.0.0", 1453 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1454 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1455 | "dev": true 1456 | }, 1457 | "js-yaml": { 1458 | "version": "3.13.1", 1459 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1460 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1461 | "dev": true, 1462 | "requires": { 1463 | "argparse": "^1.0.7", 1464 | "esprima": "^4.0.0" 1465 | } 1466 | }, 1467 | "jsbn": { 1468 | "version": "0.1.1", 1469 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1470 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1471 | "dev": true 1472 | }, 1473 | "jsesc": { 1474 | "version": "2.5.2", 1475 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1476 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1477 | "dev": true 1478 | }, 1479 | "json-schema": { 1480 | "version": "0.2.3", 1481 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1482 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 1483 | "dev": true 1484 | }, 1485 | "json-schema-traverse": { 1486 | "version": "0.4.1", 1487 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1488 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1489 | "dev": true 1490 | }, 1491 | "json-stringify-safe": { 1492 | "version": "5.0.1", 1493 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1494 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 1495 | "dev": true 1496 | }, 1497 | "json5": { 1498 | "version": "2.1.3", 1499 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", 1500 | "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", 1501 | "dev": true, 1502 | "requires": { 1503 | "minimist": "^1.2.5" 1504 | } 1505 | }, 1506 | "jsprim": { 1507 | "version": "1.4.1", 1508 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1509 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1510 | "dev": true, 1511 | "requires": { 1512 | "assert-plus": "1.0.0", 1513 | "extsprintf": "1.3.0", 1514 | "json-schema": "0.2.3", 1515 | "verror": "1.10.0" 1516 | } 1517 | }, 1518 | "lcov-parse": { 1519 | "version": "1.0.0", 1520 | "resolved": "https://registry.npmjs.org/lcov-parse/-/lcov-parse-1.0.0.tgz", 1521 | "integrity": "sha1-6w1GtUER68VhrLTECO+TY73I9+A=", 1522 | "dev": true 1523 | }, 1524 | "locate-path": { 1525 | "version": "3.0.0", 1526 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1527 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1528 | "dev": true, 1529 | "requires": { 1530 | "p-locate": "^3.0.0", 1531 | "path-exists": "^3.0.0" 1532 | } 1533 | }, 1534 | "lodash": { 1535 | "version": "4.17.21", 1536 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1537 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1538 | "dev": true 1539 | }, 1540 | "lodash.flattendeep": { 1541 | "version": "4.4.0", 1542 | "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", 1543 | "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", 1544 | "dev": true 1545 | }, 1546 | "log-driver": { 1547 | "version": "1.2.7", 1548 | "resolved": "https://registry.npmjs.org/log-driver/-/log-driver-1.2.7.tgz", 1549 | "integrity": "sha512-U7KCmLdqsGHBLeWqYlFA0V0Sl6P08EE1ZrmA9cxjUE0WVqT9qnyVDPz1kzpFEP0jdJuFnasWIfSd7fsaNXkpbg==", 1550 | "dev": true 1551 | }, 1552 | "log-symbols": { 1553 | "version": "3.0.0", 1554 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 1555 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 1556 | "dev": true, 1557 | "requires": { 1558 | "chalk": "^2.4.2" 1559 | } 1560 | }, 1561 | "long": { 1562 | "version": "4.0.0", 1563 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1564 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==", 1565 | "dev": true 1566 | }, 1567 | "make-dir": { 1568 | "version": "3.0.2", 1569 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.0.2.tgz", 1570 | "integrity": "sha512-rYKABKutXa6vXTXhoV18cBE7PaewPXHe/Bdq4v+ZLMhxbWApkFFplT0LcbMW+6BbjnQXzZ/sAvSE/JdguApG5w==", 1571 | "dev": true, 1572 | "requires": { 1573 | "semver": "^6.0.0" 1574 | }, 1575 | "dependencies": { 1576 | "semver": { 1577 | "version": "6.3.0", 1578 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1579 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1580 | "dev": true 1581 | } 1582 | } 1583 | }, 1584 | "make-error": { 1585 | "version": "1.3.6", 1586 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1587 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1588 | "dev": true 1589 | }, 1590 | "mime-db": { 1591 | "version": "1.43.0", 1592 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", 1593 | "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==", 1594 | "dev": true 1595 | }, 1596 | "mime-types": { 1597 | "version": "2.1.26", 1598 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", 1599 | "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", 1600 | "dev": true, 1601 | "requires": { 1602 | "mime-db": "1.43.0" 1603 | } 1604 | }, 1605 | "minimatch": { 1606 | "version": "3.0.4", 1607 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1608 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1609 | "dev": true, 1610 | "requires": { 1611 | "brace-expansion": "^1.1.7" 1612 | } 1613 | }, 1614 | "minimist": { 1615 | "version": "1.2.5", 1616 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1617 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1618 | "dev": true 1619 | }, 1620 | "mkdirp": { 1621 | "version": "0.5.3", 1622 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.3.tgz", 1623 | "integrity": "sha512-P+2gwrFqx8lhew375MQHHeTlY8AuOJSrGf0R5ddkEndUkmwpgUob/vQuBD1V22/Cw1/lJr4x+EjllSezBThzBg==", 1624 | "dev": true, 1625 | "requires": { 1626 | "minimist": "^1.2.5" 1627 | } 1628 | }, 1629 | "mocha": { 1630 | "version": "7.1.1", 1631 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-7.1.1.tgz", 1632 | "integrity": "sha512-3qQsu3ijNS3GkWcccT5Zw0hf/rWvu1fTN9sPvEd81hlwsr30GX2GcDSSoBxo24IR8FelmrAydGC6/1J5QQP4WA==", 1633 | "dev": true, 1634 | "requires": { 1635 | "ansi-colors": "3.2.3", 1636 | "browser-stdout": "1.3.1", 1637 | "chokidar": "3.3.0", 1638 | "debug": "3.2.6", 1639 | "diff": "3.5.0", 1640 | "escape-string-regexp": "1.0.5", 1641 | "find-up": "3.0.0", 1642 | "glob": "7.1.3", 1643 | "growl": "1.10.5", 1644 | "he": "1.2.0", 1645 | "js-yaml": "3.13.1", 1646 | "log-symbols": "3.0.0", 1647 | "minimatch": "3.0.4", 1648 | "mkdirp": "0.5.3", 1649 | "ms": "2.1.1", 1650 | "node-environment-flags": "1.0.6", 1651 | "object.assign": "4.1.0", 1652 | "strip-json-comments": "2.0.1", 1653 | "supports-color": "6.0.0", 1654 | "which": "1.3.1", 1655 | "wide-align": "1.1.3", 1656 | "yargs": "13.3.2", 1657 | "yargs-parser": "13.1.2", 1658 | "yargs-unparser": "1.6.0" 1659 | } 1660 | }, 1661 | "ms": { 1662 | "version": "2.1.1", 1663 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1664 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1665 | "dev": true 1666 | }, 1667 | "node-environment-flags": { 1668 | "version": "1.0.6", 1669 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.6.tgz", 1670 | "integrity": "sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw==", 1671 | "dev": true, 1672 | "requires": { 1673 | "object.getownpropertydescriptors": "^2.0.3", 1674 | "semver": "^5.7.0" 1675 | } 1676 | }, 1677 | "node-preload": { 1678 | "version": "0.2.1", 1679 | "resolved": "https://registry.npmjs.org/node-preload/-/node-preload-0.2.1.tgz", 1680 | "integrity": "sha512-RM5oyBy45cLEoHqCeh+MNuFAxO0vTFBLskvQbOKnEE7YTTSN4tbN8QWDIPQ6L+WvKsB/qLEGpYe2ZZ9d4W9OIQ==", 1681 | "dev": true, 1682 | "requires": { 1683 | "process-on-spawn": "^1.0.0" 1684 | } 1685 | }, 1686 | "normalize-path": { 1687 | "version": "3.0.0", 1688 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1689 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1690 | "dev": true 1691 | }, 1692 | "nyc": { 1693 | "version": "15.0.1", 1694 | "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.0.1.tgz", 1695 | "integrity": "sha512-n0MBXYBYRqa67IVt62qW1r/d9UH/Qtr7SF1w/nQLJ9KxvWF6b2xCHImRAixHN9tnMMYHC2P14uo6KddNGwMgGg==", 1696 | "dev": true, 1697 | "requires": { 1698 | "@istanbuljs/load-nyc-config": "^1.0.0", 1699 | "@istanbuljs/schema": "^0.1.2", 1700 | "caching-transform": "^4.0.0", 1701 | "convert-source-map": "^1.7.0", 1702 | "decamelize": "^1.2.0", 1703 | "find-cache-dir": "^3.2.0", 1704 | "find-up": "^4.1.0", 1705 | "foreground-child": "^2.0.0", 1706 | "glob": "^7.1.6", 1707 | "istanbul-lib-coverage": "^3.0.0", 1708 | "istanbul-lib-hook": "^3.0.0", 1709 | "istanbul-lib-instrument": "^4.0.0", 1710 | "istanbul-lib-processinfo": "^2.0.2", 1711 | "istanbul-lib-report": "^3.0.0", 1712 | "istanbul-lib-source-maps": "^4.0.0", 1713 | "istanbul-reports": "^3.0.2", 1714 | "make-dir": "^3.0.0", 1715 | "node-preload": "^0.2.1", 1716 | "p-map": "^3.0.0", 1717 | "process-on-spawn": "^1.0.0", 1718 | "resolve-from": "^5.0.0", 1719 | "rimraf": "^3.0.0", 1720 | "signal-exit": "^3.0.2", 1721 | "spawn-wrap": "^2.0.0", 1722 | "test-exclude": "^6.0.0", 1723 | "yargs": "^15.0.2" 1724 | }, 1725 | "dependencies": { 1726 | "ansi-regex": { 1727 | "version": "5.0.0", 1728 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1729 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1730 | "dev": true 1731 | }, 1732 | "ansi-styles": { 1733 | "version": "4.2.1", 1734 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 1735 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1736 | "dev": true, 1737 | "requires": { 1738 | "@types/color-name": "^1.1.1", 1739 | "color-convert": "^2.0.1" 1740 | } 1741 | }, 1742 | "cliui": { 1743 | "version": "6.0.0", 1744 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 1745 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 1746 | "dev": true, 1747 | "requires": { 1748 | "string-width": "^4.2.0", 1749 | "strip-ansi": "^6.0.0", 1750 | "wrap-ansi": "^6.2.0" 1751 | } 1752 | }, 1753 | "color-convert": { 1754 | "version": "2.0.1", 1755 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1756 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1757 | "dev": true, 1758 | "requires": { 1759 | "color-name": "~1.1.4" 1760 | } 1761 | }, 1762 | "color-name": { 1763 | "version": "1.1.4", 1764 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1765 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1766 | "dev": true 1767 | }, 1768 | "emoji-regex": { 1769 | "version": "8.0.0", 1770 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1771 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1772 | "dev": true 1773 | }, 1774 | "find-up": { 1775 | "version": "4.1.0", 1776 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1777 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1778 | "dev": true, 1779 | "requires": { 1780 | "locate-path": "^5.0.0", 1781 | "path-exists": "^4.0.0" 1782 | } 1783 | }, 1784 | "glob": { 1785 | "version": "7.1.6", 1786 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1787 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1788 | "dev": true, 1789 | "requires": { 1790 | "fs.realpath": "^1.0.0", 1791 | "inflight": "^1.0.4", 1792 | "inherits": "2", 1793 | "minimatch": "^3.0.4", 1794 | "once": "^1.3.0", 1795 | "path-is-absolute": "^1.0.0" 1796 | } 1797 | }, 1798 | "is-fullwidth-code-point": { 1799 | "version": "3.0.0", 1800 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1801 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1802 | "dev": true 1803 | }, 1804 | "locate-path": { 1805 | "version": "5.0.0", 1806 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 1807 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1808 | "dev": true, 1809 | "requires": { 1810 | "p-locate": "^4.1.0" 1811 | } 1812 | }, 1813 | "p-locate": { 1814 | "version": "4.1.0", 1815 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 1816 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 1817 | "dev": true, 1818 | "requires": { 1819 | "p-limit": "^2.2.0" 1820 | } 1821 | }, 1822 | "path-exists": { 1823 | "version": "4.0.0", 1824 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1825 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1826 | "dev": true 1827 | }, 1828 | "string-width": { 1829 | "version": "4.2.0", 1830 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1831 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1832 | "dev": true, 1833 | "requires": { 1834 | "emoji-regex": "^8.0.0", 1835 | "is-fullwidth-code-point": "^3.0.0", 1836 | "strip-ansi": "^6.0.0" 1837 | } 1838 | }, 1839 | "strip-ansi": { 1840 | "version": "6.0.0", 1841 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1842 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1843 | "dev": true, 1844 | "requires": { 1845 | "ansi-regex": "^5.0.0" 1846 | } 1847 | }, 1848 | "wrap-ansi": { 1849 | "version": "6.2.0", 1850 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 1851 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 1852 | "dev": true, 1853 | "requires": { 1854 | "ansi-styles": "^4.0.0", 1855 | "string-width": "^4.1.0", 1856 | "strip-ansi": "^6.0.0" 1857 | } 1858 | }, 1859 | "yargs": { 1860 | "version": "15.3.1", 1861 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.3.1.tgz", 1862 | "integrity": "sha512-92O1HWEjw27sBfgmXiixJWT5hRBp2eobqXicLtPBIDBhYB+1HpwZlXmbW2luivBJHBzki+7VyCLRtAkScbTBQA==", 1863 | "dev": true, 1864 | "requires": { 1865 | "cliui": "^6.0.0", 1866 | "decamelize": "^1.2.0", 1867 | "find-up": "^4.1.0", 1868 | "get-caller-file": "^2.0.1", 1869 | "require-directory": "^2.1.1", 1870 | "require-main-filename": "^2.0.0", 1871 | "set-blocking": "^2.0.0", 1872 | "string-width": "^4.2.0", 1873 | "which-module": "^2.0.0", 1874 | "y18n": "^4.0.0", 1875 | "yargs-parser": "^18.1.1" 1876 | } 1877 | }, 1878 | "yargs-parser": { 1879 | "version": "18.1.2", 1880 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.2.tgz", 1881 | "integrity": "sha512-hlIPNR3IzC1YuL1c2UwwDKpXlNFBqD1Fswwh1khz5+d8Cq/8yc/Mn0i+rQXduu8hcrFKvO7Eryk+09NecTQAAQ==", 1882 | "dev": true, 1883 | "requires": { 1884 | "camelcase": "^5.0.0", 1885 | "decamelize": "^1.2.0" 1886 | } 1887 | } 1888 | } 1889 | }, 1890 | "oauth-sign": { 1891 | "version": "0.9.0", 1892 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1893 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1894 | "dev": true 1895 | }, 1896 | "object-inspect": { 1897 | "version": "1.7.0", 1898 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.7.0.tgz", 1899 | "integrity": "sha512-a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw==", 1900 | "dev": true 1901 | }, 1902 | "object-keys": { 1903 | "version": "1.1.1", 1904 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1905 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1906 | "dev": true 1907 | }, 1908 | "object.assign": { 1909 | "version": "4.1.0", 1910 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1911 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1912 | "dev": true, 1913 | "requires": { 1914 | "define-properties": "^1.1.2", 1915 | "function-bind": "^1.1.1", 1916 | "has-symbols": "^1.0.0", 1917 | "object-keys": "^1.0.11" 1918 | } 1919 | }, 1920 | "object.getownpropertydescriptors": { 1921 | "version": "2.1.0", 1922 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 1923 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 1924 | "dev": true, 1925 | "requires": { 1926 | "define-properties": "^1.1.3", 1927 | "es-abstract": "^1.17.0-next.1" 1928 | } 1929 | }, 1930 | "once": { 1931 | "version": "1.4.0", 1932 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1933 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1934 | "dev": true, 1935 | "requires": { 1936 | "wrappy": "1" 1937 | } 1938 | }, 1939 | "p-limit": { 1940 | "version": "2.3.0", 1941 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1942 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1943 | "dev": true, 1944 | "requires": { 1945 | "p-try": "^2.0.0" 1946 | } 1947 | }, 1948 | "p-locate": { 1949 | "version": "3.0.0", 1950 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1951 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1952 | "dev": true, 1953 | "requires": { 1954 | "p-limit": "^2.0.0" 1955 | } 1956 | }, 1957 | "p-map": { 1958 | "version": "3.0.0", 1959 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", 1960 | "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", 1961 | "dev": true, 1962 | "requires": { 1963 | "aggregate-error": "^3.0.0" 1964 | } 1965 | }, 1966 | "p-try": { 1967 | "version": "2.2.0", 1968 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1969 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1970 | "dev": true 1971 | }, 1972 | "package-hash": { 1973 | "version": "4.0.0", 1974 | "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-4.0.0.tgz", 1975 | "integrity": "sha512-whdkPIooSu/bASggZ96BWVvZTRMOFxnyUG5PnTSGKoJE2gd5mbVNmR2Nj20QFzxYYgAXpoqC+AiXzl+UMRh7zQ==", 1976 | "dev": true, 1977 | "requires": { 1978 | "graceful-fs": "^4.1.15", 1979 | "hasha": "^5.0.0", 1980 | "lodash.flattendeep": "^4.4.0", 1981 | "release-zalgo": "^1.0.0" 1982 | } 1983 | }, 1984 | "path-exists": { 1985 | "version": "3.0.0", 1986 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1987 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1988 | "dev": true 1989 | }, 1990 | "path-is-absolute": { 1991 | "version": "1.0.1", 1992 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1993 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1994 | "dev": true 1995 | }, 1996 | "path-key": { 1997 | "version": "3.1.1", 1998 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1999 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2000 | "dev": true 2001 | }, 2002 | "path-parse": { 2003 | "version": "1.0.6", 2004 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2005 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2006 | "dev": true 2007 | }, 2008 | "pathval": { 2009 | "version": "1.1.1", 2010 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 2011 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 2012 | "dev": true 2013 | }, 2014 | "performance-now": { 2015 | "version": "2.1.0", 2016 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 2017 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 2018 | "dev": true 2019 | }, 2020 | "picomatch": { 2021 | "version": "2.2.2", 2022 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 2023 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 2024 | "dev": true 2025 | }, 2026 | "pkg-dir": { 2027 | "version": "4.2.0", 2028 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2029 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2030 | "dev": true, 2031 | "requires": { 2032 | "find-up": "^4.0.0" 2033 | }, 2034 | "dependencies": { 2035 | "find-up": { 2036 | "version": "4.1.0", 2037 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2038 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2039 | "dev": true, 2040 | "requires": { 2041 | "locate-path": "^5.0.0", 2042 | "path-exists": "^4.0.0" 2043 | } 2044 | }, 2045 | "locate-path": { 2046 | "version": "5.0.0", 2047 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2048 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2049 | "dev": true, 2050 | "requires": { 2051 | "p-locate": "^4.1.0" 2052 | } 2053 | }, 2054 | "p-locate": { 2055 | "version": "4.1.0", 2056 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2057 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2058 | "dev": true, 2059 | "requires": { 2060 | "p-limit": "^2.2.0" 2061 | } 2062 | }, 2063 | "path-exists": { 2064 | "version": "4.0.0", 2065 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2066 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2067 | "dev": true 2068 | } 2069 | } 2070 | }, 2071 | "process-on-spawn": { 2072 | "version": "1.0.0", 2073 | "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", 2074 | "integrity": "sha512-1WsPDsUSMmZH5LeMLegqkPDrsGgsWwk1Exipy2hvB0o/F0ASzbpIctSCcZIK1ykJvtTJULEH+20WOFjMvGnCTg==", 2075 | "dev": true, 2076 | "requires": { 2077 | "fromentries": "^1.2.0" 2078 | } 2079 | }, 2080 | "protobufjs": { 2081 | "version": "6.8.9", 2082 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.8.9.tgz", 2083 | "integrity": "sha512-j2JlRdUeL/f4Z6x4aU4gj9I2LECglC+5qR2TrWb193Tla1qfdaNQTZ8I27Pt7K0Ajmvjjpft7O3KWTGciz4gpw==", 2084 | "dev": true, 2085 | "requires": { 2086 | "@protobufjs/aspromise": "^1.1.2", 2087 | "@protobufjs/base64": "^1.1.2", 2088 | "@protobufjs/codegen": "^2.0.4", 2089 | "@protobufjs/eventemitter": "^1.1.0", 2090 | "@protobufjs/fetch": "^1.1.0", 2091 | "@protobufjs/float": "^1.0.2", 2092 | "@protobufjs/inquire": "^1.1.0", 2093 | "@protobufjs/path": "^1.1.2", 2094 | "@protobufjs/pool": "^1.1.0", 2095 | "@protobufjs/utf8": "^1.1.0", 2096 | "@types/long": "^4.0.0", 2097 | "@types/node": "^10.1.0", 2098 | "long": "^4.0.0" 2099 | }, 2100 | "dependencies": { 2101 | "@types/node": { 2102 | "version": "10.17.19", 2103 | "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.19.tgz", 2104 | "integrity": "sha512-46/xThm3zvvc9t9/7M3AaLEqtOpqlYYYcCZbpYVAQHG20+oMZBkae/VMrn4BTi6AJ8cpack0mEXhGiKmDNbLrQ==", 2105 | "dev": true 2106 | } 2107 | } 2108 | }, 2109 | "psl": { 2110 | "version": "1.8.0", 2111 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", 2112 | "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", 2113 | "dev": true 2114 | }, 2115 | "punycode": { 2116 | "version": "2.1.1", 2117 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2118 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2119 | "dev": true 2120 | }, 2121 | "qs": { 2122 | "version": "6.5.2", 2123 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 2124 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 2125 | "dev": true 2126 | }, 2127 | "readdirp": { 2128 | "version": "3.2.0", 2129 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", 2130 | "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", 2131 | "dev": true, 2132 | "requires": { 2133 | "picomatch": "^2.0.4" 2134 | } 2135 | }, 2136 | "release-zalgo": { 2137 | "version": "1.0.0", 2138 | "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", 2139 | "integrity": "sha1-CXALflB0Mpc5Mw5TXFqQ+2eFFzA=", 2140 | "dev": true, 2141 | "requires": { 2142 | "es6-error": "^4.0.1" 2143 | } 2144 | }, 2145 | "request": { 2146 | "version": "2.88.2", 2147 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 2148 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 2149 | "dev": true, 2150 | "requires": { 2151 | "aws-sign2": "~0.7.0", 2152 | "aws4": "^1.8.0", 2153 | "caseless": "~0.12.0", 2154 | "combined-stream": "~1.0.6", 2155 | "extend": "~3.0.2", 2156 | "forever-agent": "~0.6.1", 2157 | "form-data": "~2.3.2", 2158 | "har-validator": "~5.1.3", 2159 | "http-signature": "~1.2.0", 2160 | "is-typedarray": "~1.0.0", 2161 | "isstream": "~0.1.2", 2162 | "json-stringify-safe": "~5.0.1", 2163 | "mime-types": "~2.1.19", 2164 | "oauth-sign": "~0.9.0", 2165 | "performance-now": "^2.1.0", 2166 | "qs": "~6.5.2", 2167 | "safe-buffer": "^5.1.2", 2168 | "tough-cookie": "~2.5.0", 2169 | "tunnel-agent": "^0.6.0", 2170 | "uuid": "^3.3.2" 2171 | } 2172 | }, 2173 | "require-directory": { 2174 | "version": "2.1.1", 2175 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2176 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2177 | "dev": true 2178 | }, 2179 | "require-main-filename": { 2180 | "version": "2.0.0", 2181 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2182 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 2183 | "dev": true 2184 | }, 2185 | "resolve": { 2186 | "version": "1.15.1", 2187 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.15.1.tgz", 2188 | "integrity": "sha512-84oo6ZTtoTUpjgNEr5SJyzQhzL72gaRodsSfyxC/AXRvwu0Yse9H8eF9IpGo7b8YetZhlI6v7ZQ6bKBFV/6S7w==", 2189 | "dev": true, 2190 | "requires": { 2191 | "path-parse": "^1.0.6" 2192 | } 2193 | }, 2194 | "resolve-from": { 2195 | "version": "5.0.0", 2196 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 2197 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 2198 | "dev": true 2199 | }, 2200 | "rethinkdb": { 2201 | "version": "2.4.2", 2202 | "resolved": "https://registry.npmjs.org/rethinkdb/-/rethinkdb-2.4.2.tgz", 2203 | "integrity": "sha512-6DzwqEpFc8cqesAdo07a845oBRxLiHvWzopTKBo/uY2ypGWIsJQFJk3wjRDtSEhczxJqLS0jnf37rwgzYAw8NQ==", 2204 | "requires": { 2205 | "bluebird": ">= 2.3.2 < 3" 2206 | } 2207 | }, 2208 | "rimraf": { 2209 | "version": "3.0.2", 2210 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2211 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2212 | "dev": true, 2213 | "requires": { 2214 | "glob": "^7.1.3" 2215 | } 2216 | }, 2217 | "safe-buffer": { 2218 | "version": "5.2.0", 2219 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", 2220 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", 2221 | "dev": true 2222 | }, 2223 | "safer-buffer": { 2224 | "version": "2.1.2", 2225 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2226 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2227 | "dev": true 2228 | }, 2229 | "semver": { 2230 | "version": "5.7.1", 2231 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2232 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 2233 | "dev": true 2234 | }, 2235 | "set-blocking": { 2236 | "version": "2.0.0", 2237 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2238 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 2239 | "dev": true 2240 | }, 2241 | "shebang-command": { 2242 | "version": "2.0.0", 2243 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2244 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2245 | "dev": true, 2246 | "requires": { 2247 | "shebang-regex": "^3.0.0" 2248 | } 2249 | }, 2250 | "shebang-regex": { 2251 | "version": "3.0.0", 2252 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2253 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2254 | "dev": true 2255 | }, 2256 | "signal-exit": { 2257 | "version": "3.0.3", 2258 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2259 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 2260 | "dev": true 2261 | }, 2262 | "source-map": { 2263 | "version": "0.5.7", 2264 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2265 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2266 | "dev": true 2267 | }, 2268 | "source-map-support": { 2269 | "version": "0.5.16", 2270 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.16.tgz", 2271 | "integrity": "sha512-efyLRJDr68D9hBBNIPWFjhpFzURh+KJykQwvMyW5UiZzYwoF6l4YMMDIJJEyFWxWCqfyxLzz6tSfUFR+kXXsVQ==", 2272 | "dev": true, 2273 | "requires": { 2274 | "buffer-from": "^1.0.0", 2275 | "source-map": "^0.6.0" 2276 | }, 2277 | "dependencies": { 2278 | "source-map": { 2279 | "version": "0.6.1", 2280 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2281 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2282 | "dev": true 2283 | } 2284 | } 2285 | }, 2286 | "spawn-wrap": { 2287 | "version": "2.0.0", 2288 | "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", 2289 | "integrity": "sha512-EeajNjfN9zMnULLwhZZQU3GWBoFNkbngTUPfaawT4RkMiviTxcX0qfhVbGey39mfctfDHkWtuecgQ8NJcyQWHg==", 2290 | "dev": true, 2291 | "requires": { 2292 | "foreground-child": "^2.0.0", 2293 | "is-windows": "^1.0.2", 2294 | "make-dir": "^3.0.0", 2295 | "rimraf": "^3.0.0", 2296 | "signal-exit": "^3.0.2", 2297 | "which": "^2.0.1" 2298 | }, 2299 | "dependencies": { 2300 | "which": { 2301 | "version": "2.0.2", 2302 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2303 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2304 | "dev": true, 2305 | "requires": { 2306 | "isexe": "^2.0.0" 2307 | } 2308 | } 2309 | } 2310 | }, 2311 | "sprintf-js": { 2312 | "version": "1.0.3", 2313 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2314 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2315 | "dev": true 2316 | }, 2317 | "sshpk": { 2318 | "version": "1.16.1", 2319 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 2320 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 2321 | "dev": true, 2322 | "requires": { 2323 | "asn1": "~0.2.3", 2324 | "assert-plus": "^1.0.0", 2325 | "bcrypt-pbkdf": "^1.0.0", 2326 | "dashdash": "^1.12.0", 2327 | "ecc-jsbn": "~0.1.1", 2328 | "getpass": "^0.1.1", 2329 | "jsbn": "~0.1.0", 2330 | "safer-buffer": "^2.0.2", 2331 | "tweetnacl": "~0.14.0" 2332 | } 2333 | }, 2334 | "string-width": { 2335 | "version": "2.1.1", 2336 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2337 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2338 | "dev": true, 2339 | "requires": { 2340 | "is-fullwidth-code-point": "^2.0.0", 2341 | "strip-ansi": "^4.0.0" 2342 | } 2343 | }, 2344 | "string.prototype.trimend": { 2345 | "version": "1.0.1", 2346 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 2347 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 2348 | "dev": true, 2349 | "requires": { 2350 | "define-properties": "^1.1.3", 2351 | "es-abstract": "^1.17.5" 2352 | } 2353 | }, 2354 | "string.prototype.trimleft": { 2355 | "version": "2.1.2", 2356 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.2.tgz", 2357 | "integrity": "sha512-gCA0tza1JBvqr3bfAIFJGqfdRTyPae82+KTnm3coDXkZN9wnuW3HjGgN386D7hfv5CHQYCI022/rJPVlqXyHSw==", 2358 | "dev": true, 2359 | "requires": { 2360 | "define-properties": "^1.1.3", 2361 | "es-abstract": "^1.17.5", 2362 | "string.prototype.trimstart": "^1.0.0" 2363 | } 2364 | }, 2365 | "string.prototype.trimright": { 2366 | "version": "2.1.2", 2367 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.2.tgz", 2368 | "integrity": "sha512-ZNRQ7sY3KroTaYjRS6EbNiiHrOkjihL9aQE/8gfQ4DtAC/aEBRHFJa44OmoWxGGqXuJlfKkZW4WcXErGr+9ZFg==", 2369 | "dev": true, 2370 | "requires": { 2371 | "define-properties": "^1.1.3", 2372 | "es-abstract": "^1.17.5", 2373 | "string.prototype.trimend": "^1.0.0" 2374 | } 2375 | }, 2376 | "string.prototype.trimstart": { 2377 | "version": "1.0.1", 2378 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 2379 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 2380 | "dev": true, 2381 | "requires": { 2382 | "define-properties": "^1.1.3", 2383 | "es-abstract": "^1.17.5" 2384 | } 2385 | }, 2386 | "strip-ansi": { 2387 | "version": "4.0.0", 2388 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2389 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2390 | "dev": true, 2391 | "requires": { 2392 | "ansi-regex": "^3.0.0" 2393 | } 2394 | }, 2395 | "strip-bom": { 2396 | "version": "4.0.0", 2397 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 2398 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 2399 | "dev": true 2400 | }, 2401 | "strip-json-comments": { 2402 | "version": "2.0.1", 2403 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2404 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2405 | "dev": true 2406 | }, 2407 | "supports-color": { 2408 | "version": "6.0.0", 2409 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 2410 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 2411 | "dev": true, 2412 | "requires": { 2413 | "has-flag": "^3.0.0" 2414 | } 2415 | }, 2416 | "test-exclude": { 2417 | "version": "6.0.0", 2418 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 2419 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 2420 | "dev": true, 2421 | "requires": { 2422 | "@istanbuljs/schema": "^0.1.2", 2423 | "glob": "^7.1.4", 2424 | "minimatch": "^3.0.4" 2425 | }, 2426 | "dependencies": { 2427 | "glob": { 2428 | "version": "7.1.6", 2429 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 2430 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 2431 | "dev": true, 2432 | "requires": { 2433 | "fs.realpath": "^1.0.0", 2434 | "inflight": "^1.0.4", 2435 | "inherits": "2", 2436 | "minimatch": "^3.0.4", 2437 | "once": "^1.3.0", 2438 | "path-is-absolute": "^1.0.0" 2439 | } 2440 | } 2441 | } 2442 | }, 2443 | "to-fast-properties": { 2444 | "version": "2.0.0", 2445 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2446 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 2447 | "dev": true 2448 | }, 2449 | "to-regex-range": { 2450 | "version": "5.0.1", 2451 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2452 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2453 | "dev": true, 2454 | "requires": { 2455 | "is-number": "^7.0.0" 2456 | } 2457 | }, 2458 | "tough-cookie": { 2459 | "version": "2.5.0", 2460 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 2461 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 2462 | "dev": true, 2463 | "requires": { 2464 | "psl": "^1.1.28", 2465 | "punycode": "^2.1.1" 2466 | } 2467 | }, 2468 | "ts-node": { 2469 | "version": "8.8.2", 2470 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.8.2.tgz", 2471 | "integrity": "sha512-duVj6BpSpUpD/oM4MfhO98ozgkp3Gt9qIp3jGxwU2DFvl/3IRaEAvbLa8G60uS7C77457e/m5TMowjedeRxI1Q==", 2472 | "dev": true, 2473 | "requires": { 2474 | "arg": "^4.1.0", 2475 | "diff": "^4.0.1", 2476 | "make-error": "^1.1.1", 2477 | "source-map-support": "^0.5.6", 2478 | "yn": "3.1.1" 2479 | }, 2480 | "dependencies": { 2481 | "diff": { 2482 | "version": "4.0.2", 2483 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2484 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2485 | "dev": true 2486 | } 2487 | } 2488 | }, 2489 | "tslib": { 2490 | "version": "1.11.1", 2491 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", 2492 | "integrity": "sha512-aZW88SY8kQbU7gpV19lN24LtXh/yD4ZZg6qieAJDDg+YBsJcSmLGK9QpnUjAKVG/xefmvJGd1WUmfpT/g6AJGA==", 2493 | "dev": true 2494 | }, 2495 | "tslint": { 2496 | "version": "6.1.1", 2497 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-6.1.1.tgz", 2498 | "integrity": "sha512-kd6AQ/IgPRpLn6g5TozqzPdGNZ0q0jtXW4//hRcj10qLYBaa3mTUU2y2MCG+RXZm8Zx+KZi0eA+YCrMyNlF4UA==", 2499 | "dev": true, 2500 | "requires": { 2501 | "@babel/code-frame": "^7.0.0", 2502 | "builtin-modules": "^1.1.1", 2503 | "chalk": "^2.3.0", 2504 | "commander": "^2.12.1", 2505 | "diff": "^4.0.1", 2506 | "glob": "^7.1.1", 2507 | "js-yaml": "^3.13.1", 2508 | "minimatch": "^3.0.4", 2509 | "mkdirp": "^0.5.3", 2510 | "resolve": "^1.3.2", 2511 | "semver": "^5.3.0", 2512 | "tslib": "^1.10.0", 2513 | "tsutils": "^2.29.0" 2514 | }, 2515 | "dependencies": { 2516 | "diff": { 2517 | "version": "4.0.2", 2518 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2519 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2520 | "dev": true 2521 | } 2522 | } 2523 | }, 2524 | "tsutils": { 2525 | "version": "2.29.0", 2526 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 2527 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 2528 | "dev": true, 2529 | "requires": { 2530 | "tslib": "^1.8.1" 2531 | } 2532 | }, 2533 | "tunnel-agent": { 2534 | "version": "0.6.0", 2535 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2536 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2537 | "dev": true, 2538 | "requires": { 2539 | "safe-buffer": "^5.0.1" 2540 | } 2541 | }, 2542 | "tweetnacl": { 2543 | "version": "0.14.5", 2544 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2545 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 2546 | "dev": true 2547 | }, 2548 | "type-detect": { 2549 | "version": "4.0.8", 2550 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2551 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2552 | "dev": true 2553 | }, 2554 | "type-fest": { 2555 | "version": "0.8.1", 2556 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2557 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2558 | "dev": true 2559 | }, 2560 | "typedarray-to-buffer": { 2561 | "version": "3.1.5", 2562 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 2563 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 2564 | "dev": true, 2565 | "requires": { 2566 | "is-typedarray": "^1.0.0" 2567 | } 2568 | }, 2569 | "typescript": { 2570 | "version": "3.8.3", 2571 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.8.3.tgz", 2572 | "integrity": "sha512-MYlEfn5VrLNsgudQTVJeNaQFUAI7DkhnOjdpAp4T+ku1TfQClewlbSuTVHiA+8skNBgaf02TL/kLOvig4y3G8w==", 2573 | "dev": true 2574 | }, 2575 | "uri-js": { 2576 | "version": "4.2.2", 2577 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2578 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2579 | "dev": true, 2580 | "requires": { 2581 | "punycode": "^2.1.0" 2582 | } 2583 | }, 2584 | "uuid": { 2585 | "version": "3.4.0", 2586 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 2587 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 2588 | "dev": true 2589 | }, 2590 | "verror": { 2591 | "version": "1.10.0", 2592 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2593 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2594 | "dev": true, 2595 | "requires": { 2596 | "assert-plus": "^1.0.0", 2597 | "core-util-is": "1.0.2", 2598 | "extsprintf": "^1.2.0" 2599 | } 2600 | }, 2601 | "which": { 2602 | "version": "1.3.1", 2603 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2604 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2605 | "dev": true, 2606 | "requires": { 2607 | "isexe": "^2.0.0" 2608 | } 2609 | }, 2610 | "which-module": { 2611 | "version": "2.0.0", 2612 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 2613 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 2614 | "dev": true 2615 | }, 2616 | "wide-align": { 2617 | "version": "1.1.3", 2618 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 2619 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 2620 | "dev": true, 2621 | "requires": { 2622 | "string-width": "^1.0.2 || 2" 2623 | } 2624 | }, 2625 | "wrap-ansi": { 2626 | "version": "5.1.0", 2627 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 2628 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 2629 | "dev": true, 2630 | "requires": { 2631 | "ansi-styles": "^3.2.0", 2632 | "string-width": "^3.0.0", 2633 | "strip-ansi": "^5.0.0" 2634 | }, 2635 | "dependencies": { 2636 | "ansi-regex": { 2637 | "version": "4.1.0", 2638 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2639 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2640 | "dev": true 2641 | }, 2642 | "string-width": { 2643 | "version": "3.1.0", 2644 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2645 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2646 | "dev": true, 2647 | "requires": { 2648 | "emoji-regex": "^7.0.1", 2649 | "is-fullwidth-code-point": "^2.0.0", 2650 | "strip-ansi": "^5.1.0" 2651 | } 2652 | }, 2653 | "strip-ansi": { 2654 | "version": "5.2.0", 2655 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2656 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2657 | "dev": true, 2658 | "requires": { 2659 | "ansi-regex": "^4.1.0" 2660 | } 2661 | } 2662 | } 2663 | }, 2664 | "wrappy": { 2665 | "version": "1.0.2", 2666 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2667 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2668 | "dev": true 2669 | }, 2670 | "write-file-atomic": { 2671 | "version": "3.0.3", 2672 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 2673 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 2674 | "dev": true, 2675 | "requires": { 2676 | "imurmurhash": "^0.1.4", 2677 | "is-typedarray": "^1.0.0", 2678 | "signal-exit": "^3.0.2", 2679 | "typedarray-to-buffer": "^3.1.5" 2680 | } 2681 | }, 2682 | "y18n": { 2683 | "version": "4.0.1", 2684 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", 2685 | "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", 2686 | "dev": true 2687 | }, 2688 | "yargs": { 2689 | "version": "13.3.2", 2690 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 2691 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 2692 | "dev": true, 2693 | "requires": { 2694 | "cliui": "^5.0.0", 2695 | "find-up": "^3.0.0", 2696 | "get-caller-file": "^2.0.1", 2697 | "require-directory": "^2.1.1", 2698 | "require-main-filename": "^2.0.0", 2699 | "set-blocking": "^2.0.0", 2700 | "string-width": "^3.0.0", 2701 | "which-module": "^2.0.0", 2702 | "y18n": "^4.0.0", 2703 | "yargs-parser": "^13.1.2" 2704 | }, 2705 | "dependencies": { 2706 | "ansi-regex": { 2707 | "version": "4.1.0", 2708 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2709 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2710 | "dev": true 2711 | }, 2712 | "string-width": { 2713 | "version": "3.1.0", 2714 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2715 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2716 | "dev": true, 2717 | "requires": { 2718 | "emoji-regex": "^7.0.1", 2719 | "is-fullwidth-code-point": "^2.0.0", 2720 | "strip-ansi": "^5.1.0" 2721 | } 2722 | }, 2723 | "strip-ansi": { 2724 | "version": "5.2.0", 2725 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2726 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2727 | "dev": true, 2728 | "requires": { 2729 | "ansi-regex": "^4.1.0" 2730 | } 2731 | } 2732 | } 2733 | }, 2734 | "yargs-parser": { 2735 | "version": "13.1.2", 2736 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2737 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2738 | "dev": true, 2739 | "requires": { 2740 | "camelcase": "^5.0.0", 2741 | "decamelize": "^1.2.0" 2742 | } 2743 | }, 2744 | "yargs-unparser": { 2745 | "version": "1.6.0", 2746 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 2747 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 2748 | "dev": true, 2749 | "requires": { 2750 | "flat": "^4.1.0", 2751 | "lodash": "^4.17.15", 2752 | "yargs": "^13.3.0" 2753 | } 2754 | }, 2755 | "yn": { 2756 | "version": "3.1.1", 2757 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 2758 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 2759 | "dev": true 2760 | } 2761 | } 2762 | } 2763 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "@deepstream/storage-rethinkdb", 3 | "version": "3.0.0", 4 | "description": "Connects deepstream.io to rethinkdb", 5 | "main": "dist/src/connector.js", 6 | "scripts": { 7 | "tsc": "tsc", 8 | "lint": "tslint --project .", 9 | "lint:fix": "npm run lint -- --fix", 10 | "test": "mocha --opts mocha.opts 'test/*.spec.ts'", 11 | "coverage": "nyc mocha 'test/*.spec.ts' --exit", 12 | "ci": "npm run tsc && npm run coverage", 13 | "docker": "docker run -p 28015:28015 rethinkdb:2.3.6" 14 | }, 15 | "repository": { 16 | "type": "git", 17 | "url": "https://github.com/deepstreamIO/deepstream.io-storage-rethinkdb.git" 18 | }, 19 | "author": "deepstreamHub GmbH", 20 | "license": "Apache-2.0", 21 | "bugs": { 22 | "url": "https://github.com/deepstreamIO/deepstream.io-storage-rethinkdb/issues" 23 | }, 24 | "homepage": "http://deepstream.io", 25 | "dependencies": { 26 | "@deepstream/types": "^2.0.9", 27 | "rethinkdb": "2.4.2" 28 | }, 29 | "devDependencies": { 30 | "@deepstream/protobuf": "^1.0.1", 31 | "@types/chai": "^4.2.11", 32 | "@types/mocha": "^7.0.2", 33 | "@types/node": "^13.11.1", 34 | "@types/rethinkdb": "^2.3.14", 35 | "chai": "^4.2.0", 36 | "coveralls": "^3.0.11", 37 | "mocha": "^7.1.1", 38 | "nyc": "^15.0.1", 39 | "ts-node": "^8.8.2", 40 | "tslint": "^6.1.1", 41 | "typescript": "^3.8.3" 42 | }, 43 | "nyc": { 44 | "include": [ 45 | "src/*.ts" 46 | ], 47 | "extension": [ 48 | ".ts" 49 | ], 50 | "require": [ 51 | "ts-node/register/transpile-only" 52 | ], 53 | "reporter": [ 54 | "lcov" 55 | ], 56 | "sourceMap": true, 57 | "instrument": true 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /src/connector.ts: -------------------------------------------------------------------------------- 1 | import * as rethinkdb from 'rethinkdb' 2 | import { TableManager } from './table-manager' 3 | 4 | import * as crypto from 'crypto' 5 | import { version as pluginVersion } from '../package.json' 6 | import { EventEmitter } from 'events' 7 | import { DeepstreamPlugin, DeepstreamStorage, StorageReadCallback, StorageWriteCallback, EVENT } from '@deepstream/types' 8 | 9 | interface RethinkDBOptions extends rethinkdb.ConnectionOptions { 10 | primaryKey: string, 11 | db: string, 12 | defaultTable: string, 13 | splitChar: string, 14 | host: string, 15 | port: number, 16 | versionKey?: string, 17 | readOnly: boolean 18 | } 19 | 20 | interface Params { 21 | fullKey?: string, 22 | table: string, 23 | id: string 24 | } 25 | 26 | export class Connector extends DeepstreamPlugin implements DeepstreamStorage { 27 | public apiVersion = 2 28 | public description = `Rethinkdb Storage Connector ${pluginVersion}` 29 | 30 | private connection!: rethinkdb.Connection 31 | private tableManager!: TableManager 32 | private defaultTable: string = this.options.defaultTable || 'deepstream_records' 33 | private splitChar: string | null = this.options.splitChar || null 34 | private tableMatch!: RegExp | null 35 | private primaryKey: string = this.options.primaryKey || 'ds_id' 36 | private emitter = new EventEmitter() 37 | private isReady: boolean = false 38 | private logger = this.services.logger.getNameSpace('RETHINDB') 39 | 40 | /** 41 | * Connects deepstream to a rethinkdb. RethinksDB is a great fit for deepstream due to its realtime capabilities. 42 | * 43 | * Similar to other storage connectors (e.g. MongoDB), this connector supports saving records to multiple tables. 44 | * In order to do this, specify a splitChar, e.g. '/' and use it in your record names. Naming your record 45 | * 46 | * user/i4vcg5j1-16n1qrnziuog 47 | * 48 | * for instance will create a user table and store it in it. This will allow for more sophisticated queries as 49 | * well as speed up read operations since there are less entries to look through 50 | * 51 | * @param {Object} options rethinkdb driver options. See rethinkdb.com/api/javascript/#connect 52 | * 53 | * e.g. 54 | * 55 | * { 56 | * host: 'localhost', 57 | * port: 28015, 58 | * authKey: 'someString' 59 | * database: 'deepstream', 60 | * defaultTable: 'deepstream_records', 61 | * splitChar: '/' 62 | * } 63 | * 64 | * Please note the three additional, optional keys: 65 | * 66 | * database specifies which database to use. Defaults to 'deepstream' 67 | * defaultTable specifies which table records will be stored in that don't specify a table. Defaults to deepstream_records 68 | * splitChar specifies a character that separates the record's id from the table it should be stored in. defaults to null 69 | */ 70 | constructor (private options: RethinkDBOptions, private services: any) { 71 | super () 72 | this.checkOptions(options) 73 | 74 | this.tableMatch = this.splitChar 75 | ? new RegExp('^(\\w+)' + this.escapeRegExp(this.splitChar)) 76 | : null 77 | 78 | options.db = options.db || 'deepstream' 79 | 80 | this.connect() 81 | } 82 | 83 | private async connect () { 84 | try { 85 | this.connection = await rethinkdb.connect(this.options) 86 | const dbList = await rethinkdb.dbList().run(this.connection) 87 | if (!dbList.includes(this.options.db)) { 88 | await rethinkdb.dbCreate(this.options.db).run(this.connection) 89 | } 90 | this.connection.use(this.options.db) 91 | this.tableManager = new TableManager(this.connection, this.options.db) 92 | await this.tableManager.refreshTables() 93 | this.isReady = true 94 | this.emitter.emit('ready') 95 | } catch (error) { 96 | this.logger.fatal('CONNECTION_ERROR', error.toString()) 97 | } 98 | } 99 | 100 | public async whenReady (): Promise { 101 | if (!this.isReady) { 102 | return new Promise(resolve => this.emitter.once('ready', resolve)) 103 | } 104 | } 105 | 106 | public async close () { 107 | await this.connection.close() 108 | } 109 | 110 | /** 111 | * Writes a value to the database. If the specified table doesn't exist yet, it will be created 112 | * before the write is excecuted. If a table creation is already in progress, create table will 113 | * only add the method to its array of callbacks 114 | */ 115 | public set (recordName: string, version: number, data: any, callback: StorageWriteCallback) { 116 | if (this.options.readOnly) { 117 | this.logger.error(EVENT.ERROR, 'Rethinkdb running in read-only mode, yet set was called') 118 | } 119 | 120 | const params = this.getParams(recordName) 121 | 122 | if (this.tableManager.hasTable(params.table)) { 123 | this.insert(params, version, data, callback) 124 | } else { 125 | this.tableManager.createTable(params.table, this.primaryKey) 126 | .then(() => { 127 | this.insert(params, version, data, callback) 128 | }) 129 | } 130 | } 131 | 132 | /** 133 | * Retrieves a value from the cache 134 | */ 135 | public get (key: string, callback: StorageReadCallback) { 136 | const params = this.getParams(key) 137 | 138 | if (this.tableManager.hasTable(params.table)) { 139 | rethinkdb 140 | .table(params.table) 141 | .get( params.id ) 142 | .run(this.connection, (error: Error | null, entry: any) => { 143 | if (error) { 144 | callback(error.toString()) 145 | return 146 | } 147 | if (!entry) { 148 | callback(null, -1, null) 149 | return 150 | } 151 | let version 152 | if (this.options.versionKey) { 153 | version = entry[this.options.versionKey] 154 | } else { 155 | version = entry.__ds._v 156 | } 157 | delete entry[this.primaryKey] 158 | delete entry.__ds // in case is set 159 | if (entry.__dsList) { 160 | callback(null, version, entry.__dsList) 161 | } else { 162 | callback(null, version, entry) 163 | } 164 | } ) 165 | } else { 166 | callback(null, -1, null) 167 | } 168 | } 169 | 170 | /** 171 | * Deletes an entry from the cache. 172 | */ 173 | public delete (key: string, callback: StorageWriteCallback) { 174 | if (this.options.readOnly) { 175 | this.logger.error(EVENT.ERROR, 'Rethinkdb running in read-only mode, yet set was called') 176 | } 177 | 178 | const params = this.getParams( key ) 179 | 180 | if (this.tableManager.hasTable(params.table) ) { 181 | rethinkdb 182 | .table(params.table) 183 | .get(params.id) 184 | .delete() 185 | .run(this.connection, callback as any) 186 | } else { 187 | callback(`Table '${params.table}' does not exist`) 188 | } 189 | } 190 | 191 | public deleteBulk (recordNames: string[], callback: StorageWriteCallback): void { 192 | throw new Error('Delete bulk only required in cache') 193 | } 194 | 195 | /** 196 | * Parses the provided record name and returns an object 197 | * containing a table name and a record name 198 | */ 199 | private getParams (recordName: string) { 200 | const table = this.tableMatch ? recordName.match(this.tableMatch) : null 201 | const params: Params = { table: this.defaultTable, id: recordName } 202 | 203 | if (table) { 204 | params.table = table[1] 205 | params.id = recordName.substr(table[1].length + 1) 206 | } 207 | 208 | // rethink can't have a key > 127 bytes; hash key and store alongside 209 | if (params.id.length > 127) { 210 | params.fullKey = params.id 211 | params.id = crypto.createHash('sha256').update(params.id).digest('hex') 212 | } 213 | 214 | return params 215 | } 216 | 217 | /** 218 | * Augments a value with a primary key and writes it to the database 219 | */ 220 | private insert (params: Params, version: number, data: any, callback: StorageWriteCallback) { 221 | let value 222 | if (data instanceof Array) { 223 | if (this.options.versionKey) { 224 | value = { __dsList: data, [this.options.versionKey]: version, [this.primaryKey]: params.id } 225 | } else { 226 | value = { __dsList: data, __ds: { _v: version }, [this.primaryKey]: params.id } 227 | } 228 | } else { 229 | if (this.options.versionKey) { 230 | value = { ...data, [this.options.versionKey]: version, [this.primaryKey]: params.id } 231 | } else { 232 | value = { ...data, __ds: { _v: version }, [this.primaryKey]: params.id } 233 | } 234 | } 235 | 236 | if (params.fullKey) { 237 | value.__ds.fullKey = params.fullKey 238 | } 239 | 240 | rethinkdb 241 | .table(params.table) 242 | .insert(value, { returnChanges: false, conflict: 'replace' } ) 243 | .run(this.connection, callback as any) 244 | } 245 | 246 | /** 247 | * Makes sure that the options object contains all mandatory 248 | * settings 249 | */ 250 | private checkOptions (options: RethinkDBOptions) { 251 | if ( typeof options.host !== 'string' ) { 252 | throw new Error( 'Missing option host' ) 253 | } 254 | if (isNaN(options.port)) { 255 | throw new Error( 'Missing option port' ) 256 | } 257 | } 258 | 259 | /** 260 | * Escapes user input for use in a regular expression 261 | */ 262 | private escapeRegExp (value: string) { 263 | return value.replace( /[.*+?^${}()|[\]\\]/g, '\\$&' ) // $& means the whole matched string 264 | } 265 | } 266 | 267 | export default Connector 268 | -------------------------------------------------------------------------------- /src/table-manager.ts: -------------------------------------------------------------------------------- 1 | import * as rethinkdb from 'rethinkdb' 2 | import { EventEmitter } from 'events' 3 | 4 | export class TableManager { 5 | private tables = new Set() 6 | private emitter = new EventEmitter() 7 | 8 | constructor (private connection: rethinkdb.Connection, private database: string) { 9 | this.emitter.setMaxListeners(0) 10 | } 11 | 12 | /** 13 | * Creates the table if it doesn't exist yet 14 | */ 15 | public async createTable (table: string, primaryKey: string) { 16 | if (this.emitter.listeners(table).length === 0) { 17 | this.emitter.once(table, () => {}) 18 | try { 19 | await rethinkdb 20 | .db(this.database) 21 | .tableCreate(table, { primary_key: primaryKey, durability: 'soft' }) 22 | .run(this.connection) 23 | 24 | await this.refreshTables() 25 | this.emitter.emit(table) 26 | } catch (e) { 27 | this.emitter.emit(table) 28 | if (this.isTableExistsError(e) === false) { 29 | throw e 30 | } 31 | } 32 | return 33 | } 34 | 35 | return new Promise((resolve) => this.emitter.once(table, resolve)) 36 | } 37 | 38 | /** 39 | * Checks if a specific table name exists. The list of tables is retrieved 40 | * on initialisation and can be updated at runtime using refreshTables 41 | */ 42 | public hasTable (table: string) { 43 | return this.tables.has(table) 44 | } 45 | 46 | /** 47 | * Called whenever the list of tables has gotten out of sync. E.g. after 48 | * receiving a "table exists" 49 | */ 50 | public async refreshTables () { 51 | const tables = await rethinkdb 52 | .db(this.database) 53 | .tableList() 54 | .run(this.connection) 55 | 56 | this.tables = new Set([...tables]) 57 | } 58 | 59 | /** 60 | * If tableCreate is called for an existing table, rethinkdb returns a 61 | * RqlRuntimeError. This error unfortunately doesn't come with a code or constant to check 62 | * its type, so this method tries to parse its error message instead 63 | */ 64 | private isTableExistsError (error: any) { 65 | return error.msg.indexOf('already exists') !== -1 66 | } 67 | } 68 | -------------------------------------------------------------------------------- /test/cache-connector.spec.ts: -------------------------------------------------------------------------------- 1 | import { expect } from 'chai' 2 | import { Connector } from '../src/connector' 3 | import { config } from './connection-params' 4 | 5 | describe('the storage connector has the correct structure', () => { 6 | let connector: Connector 7 | 8 | before('creates the connector', async () => { 9 | connector = new Connector(config, { logger: { getNameSpace: () => ({ 10 | fatal: (e: any, m: any) => { 11 | console.error('Fatal exception', e, m) 12 | } 13 | }) 14 | }}) 15 | await connector.whenReady() 16 | }) 17 | 18 | it('implements the cache/storage connector interface', () => { 19 | expect(typeof connector.description).to.equal('string') 20 | expect(typeof connector.deleteBulk).to.equal('function') 21 | // expect(typeof connector.head).to.equal('function') 22 | expect(typeof connector.get).to.equal('function') 23 | expect(typeof connector.set).to.equal('function') 24 | expect(typeof connector.delete).to.equal('function') 25 | }) 26 | 27 | it('retrieves a non existing value', (done) => { 28 | connector.get('someValue', (error, version, value) => { 29 | expect(error).to.equal(null) 30 | expect(version).to.equal(-1) 31 | expect(value).to.equal(null) 32 | done() 33 | }) 34 | }) 35 | 36 | it('sets a value', (done) => { 37 | connector.set('someValue', 2, { firstname: 'Wolfram' }, (error) => { 38 | expect(error).to.equal(null) 39 | done() 40 | }) 41 | }) 42 | 43 | it('retrieves an existing value', (done) => { 44 | connector.get('someValue', (error, version, value) => { 45 | expect(error).to.equal(null) 46 | expect(version).to.equal(2) 47 | expect(value).to.deep.equal({ firstname: 'Wolfram' }) 48 | done() 49 | }) 50 | }) 51 | 52 | it('deletes a value', (done) => { 53 | connector.delete('someValue', (error) => { 54 | expect(error).to.equal(null) 55 | done() 56 | }) 57 | }) 58 | 59 | it("Can't retrieve a deleted value", (done) => { 60 | connector.get('someValue', (error, version, value) => { 61 | expect(error).to.equal(null) 62 | expect(version).to.equal(-1) 63 | expect(value).to.equal(null) 64 | done() 65 | }) 66 | }) 67 | }) 68 | -------------------------------------------------------------------------------- /test/connection-params.ts: -------------------------------------------------------------------------------- 1 | export const config = { 2 | host: process.env.RETHINKDB_HOST || 'localhost', 3 | port: 28015, 4 | primaryKey: 'own_primary_key', 5 | db: 'rethinkdb_db_test', 6 | defaultTable: 'default', 7 | splitChar: '/', 8 | storageKey: null, 9 | readOnly: false 10 | } 11 | -------------------------------------------------------------------------------- /test/custom-version.spec.ts: -------------------------------------------------------------------------------- 1 | import { expect } from 'chai' 2 | import { Connector } from '../src/connector' 3 | import { config } from './connection-params' 4 | import * as rethinkdb from 'rethinkdb' 5 | 6 | describe('the storage connector uses a custom version key', () => { 7 | let connector: Connector 8 | let connection: rethinkdb.Connection 9 | 10 | before('creates the connector', async () => { 11 | connector = new Connector({ ...config, versionKey: '__v' }, { logger: { getNameSpace: () => ({ 12 | fatal: (e: any, m: any) => { 13 | console.error('Fatal exception', e, m) 14 | } 15 | }) 16 | }}) 17 | 18 | await connector.whenReady() 19 | connection = (connector as any).connection 20 | }) 21 | 22 | it('sets a value', (done) => { 23 | connector.set('someValueWithCustomVersion', 2, { firstname: 'Wolfram' }, (error) => { 24 | expect(error).to.equal(null) 25 | 26 | rethinkdb 27 | .table(config.defaultTable) 28 | .get('someValueWithCustomVersion') 29 | .run(connection) 30 | .then((result) => { 31 | expect(result).to.deep.equal({ __v: 2, firstname: 'Wolfram', own_primary_key: 'someValueWithCustomVersion' }) 32 | }) 33 | .then(() => done()) 34 | }) 35 | }) 36 | 37 | it('retrieves an existing value', (done) => { 38 | connector.get('someValueWithCustomVersion', (error, version, value) => { 39 | expect(error).to.equal(null) 40 | expect(version).to.equal(2) 41 | expect(value).to.deep.equal({ __v: 2, firstname: 'Wolfram' }) 42 | done() 43 | }) 44 | }) 45 | }) 46 | -------------------------------------------------------------------------------- /test/fast-insertion.spec.ts: -------------------------------------------------------------------------------- 1 | import { expect } from 'chai' 2 | import { Connector } from '../src/connector' 3 | import { config } from './connection-params' 4 | import * as rethinkdb from 'rethinkdb' 5 | 6 | describe( 'is able to insert a larger number of values in quick succession', () => { 7 | let storageConnector: Connector 8 | 9 | before(async () => { 10 | storageConnector = new Connector(config, { logger: { getNameSpace: () => ({ 11 | fatal: (e: any, m: any) => { 12 | console.error('Fatal exception', e, m) 13 | } 14 | }) 15 | }}) 16 | await storageConnector.whenReady() 17 | }) 18 | 19 | after(async () => { 20 | await rethinkdb 21 | .db(config.db) 22 | .tableDrop( 'quickInsertTestTable' ) 23 | .run((storageConnector as any).connection) 24 | }) 25 | 26 | it('inserts 20 values in quick succession', (done) => { 27 | const expected = 20 28 | let completed = 0 29 | 30 | const callback = (err: Error | null) => { 31 | completed++ 32 | expect(err).to.equal( null ) 33 | 34 | if (expected === completed) { 35 | done() 36 | } 37 | } 38 | 39 | expect(() => { 40 | for (let i = 0; i <= expected; i++) { 41 | storageConnector.set('quickInsertTestTable/key' + i, i, {}, callback as any) 42 | } 43 | }).not.to.throw() 44 | }) 45 | }) 46 | -------------------------------------------------------------------------------- /test/multi-table.spec.ts: -------------------------------------------------------------------------------- 1 | import { Connector } from '../src/connector' 2 | import { config } from './connection-params' 3 | import { expect } from 'chai' 4 | import * as rethinkdb from 'rethinkdb' 5 | 6 | describe('it distributes records between multiple tables', () => { 7 | let storageConnector: Connector 8 | let conn: rethinkdb.Connection 9 | 10 | before(async () => { 11 | storageConnector = new Connector(config, { logger: { getNameSpace: () => ({ 12 | fatal: (e: any, m: any) => { 13 | console.error('Fatal exception', e, m) 14 | } 15 | }) 16 | }}) 17 | await storageConnector.whenReady() 18 | 19 | conn = (storageConnector as any).connection 20 | 21 | try { 22 | await rethinkdb.db(config.db).tableDrop( 'dsTestA' ).run(conn) 23 | await rethinkdb.db(config.db).tableDrop( 'dsTestB' ).run(conn) 24 | await rethinkdb.db(config.db).tableDrop( 'dsTestDefault' ).run(conn) 25 | } catch (e) { 26 | 27 | } 28 | await (storageConnector as any).tableManager.refreshTables() 29 | }) 30 | 31 | // tslint:disable-next-line: no-unused-expression 32 | const tableNames = ['dsTestA', 'dsTestB'] 33 | for (let i = 0; i < tableNames.length; i++) { 34 | const tableName = tableNames[i] 35 | 36 | it(`sets a value for ${tableName}`, (done) => { 37 | storageConnector.set(`${tableName}/valueA`, 12, { isIn: tableName }, () => { done() } ) 38 | }) 39 | 40 | it(`has created ${tableName}`, async () => { 41 | const tableList = await rethinkdb.db(config.db).tableList().run(conn) 42 | expect( tableList.indexOf( tableName ) ).not.to.equal( -1 ) 43 | }) 44 | 45 | it(`has written the record to ${tableName}`, async () => { 46 | const record = await rethinkdb 47 | .table(tableName) 48 | .get('valueA') 49 | .run(conn) 50 | expect(record).to.deep.equal({ __ds: { _v: 12 }, own_primary_key: 'valueA', isIn: tableName }) 51 | }) 52 | 53 | it(`creates and immediatly updates a value for ${tableName}`, ( done ) => { 54 | let firstInsertionComplete = false 55 | 56 | storageConnector.set(`${tableName}/someTest`, 2, { state: 'A' }, ( error ) => { 57 | expect( firstInsertionComplete ).to.equal( false ) 58 | expect( error ).to.equal( null ) 59 | firstInsertionComplete = true 60 | }) 61 | 62 | storageConnector.set(`${tableName}/someTest`, 3, { state: 'B' }, ( error ) => { 63 | expect( firstInsertionComplete ).to.equal( true ) 64 | expect( error ).to.equal( null ) 65 | 66 | storageConnector.get(`${tableName}/someTest`, ( e, version, value ) => { 67 | expect( e ).to.equal( null ) 68 | expect( value ).to.deep.equal({ state: 'B' }) 69 | done() 70 | }) 71 | }) 72 | }) 73 | } 74 | }) 75 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES2018", 4 | "module": "commonjs", 5 | "outDir": "dist", 6 | "sourceMap": true, 7 | "allowJs": false, 8 | "resolveJsonModule": true, 9 | "noUnusedLocals": true, 10 | "strict": true, 11 | "types": [ 12 | "node", 13 | "mocha" 14 | ] 15 | }, 16 | "include": [ 17 | "src/**/*", 18 | "test/**/*", 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "defaultSeverity": "error", 3 | "extends": [ 4 | "tslint:recommended" 5 | ], 6 | "jsRules": {}, 7 | "rules": { 8 | "arrow-parens": [true], 9 | "ordered-imports": false, 10 | "trailing-comma": true, 11 | "array-type": [true, "array-simple"], 12 | "prefer-const": true, 13 | "new-parens": true, 14 | "no-consecutive-blank-lines": true, 15 | "no-trailing-whitespace": true, 16 | "no-unnecessary-initializer": true, 17 | "one-variable-per-declaration": true, 18 | "space-before-function-paren": [true, "always"], 19 | "interface-name": [true, "never-prefix"], 20 | "forin": false, 21 | "indent": [true, "spaces", 2], 22 | "jsdoc-format": false, 23 | "object-literal-sort-keys": false, 24 | "member-ordering": false, 25 | "prefer-for-of": false, 26 | "max-line-length": false, 27 | "only-arrow-functions": false, 28 | "ban-types": false, 29 | "no-console": false, 30 | "no-empty": false, 31 | "semicolon": [true, "never"], 32 | "no-var-requires": false, 33 | "quotemark": [true, "single", "avoid-escape", "avoid-template"] 34 | }, 35 | "rulesDirectory": [] 36 | } 37 | --------------------------------------------------------------------------------