├── .gitignore ├── LICENSE ├── README.md ├── api └── v1.api.history.js ├── build_indexes.sh ├── cache ├── cache.daemon.js └── init.cache.js ├── config.example.js ├── html └── index.html ├── index.js ├── nodejs_restclient.log ├── package-lock.json ├── package.json ├── start.sh └── stop.sh /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | config.js -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 Cryptolions.io 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # mongo_history_plugin has been deprecated !!! 2 | 3 | ## API Documentation https://history.cryptolions.io 4 | 5 | ## API url - https://history.cryptolions.io 6 | 7 | ## add to your nodeos config.ini 8 | plugin = eosio::mongo_db_plugin 9 | mongodb-uri = mongodb://127.0.0.1:27017/EOS 10 | mongodb-filter-on = * 11 | #mongodb-filter-out = spammer:: 12 | mongodb-filter-out = eosio:onblock: 13 | mongodb-filter-out = gu2tembqgage:: 14 | mongodb-filter-out = blocktwitter:: 15 | mongodb-queue-size = 2048 16 | abi-serializer-max-time-ms = 5000 17 | mongodb-block-start = 1 18 | mongodb-store-block-states = false 19 | mongodb-store-blocks = false 20 | mongodb-store-transactions = false 21 | mongodb-store-transaction-traces = true 22 | mongodb-store-action-traces = true 23 | 24 | read-mode = read-only 25 | 26 | 27 | ## indexing fields for get_actions (collection - action_traces) 28 | 29 | Use build_indexes.sh script to create indexes (the best is to run on start syncronisation) 30 | 31 | ``` 32 | mongo EOS --eval 'db.action_traces.createIndex({"act.account": 1, "createdAt":1},{background: true, sparse: true})' 33 | mongo EOS --eval 'db.action_traces.createIndex({"act.name": 1, "createdAt":1},{background: true, sparse: true})' 34 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.receiver": 1, "createdAt":1},{background: true, sparse: true})' 35 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.from": 1, "createdAt":1},{background: true, sparse: true})' 36 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.to": 1, "createdAt":1},{background: true, sparse: true})' 37 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.name": 1, "createdAt":1},{background: true, sparse: true})' 38 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.voter": 1, "createdAt":1},{background: true, sparse: true})' 39 | mongo EOS --eval 'db.action_traces.createIndex({"act.authorization.actor": 1, "createdAt":1},{background: true, sparse: true})' 40 | mongo EOS --eval 'db.action_traces.createIndex({"account_ram_deltas.account": 1, "createdAt":1},{background: true, sparse: true})' 41 | ``` 42 | ## Other Indexes 43 | ``` 44 | mongo EOS --eval 'db.account_controls.createIndex({"controlling_account": 1},{background: true, sparse: true})' 45 | mongo EOS --eval 'db.pub_keys.createIndex({"public_key": 1},{background: true, sparse: true})' 46 | mongo EOS --eval 'db.accounts.createIndex({"name": 1},{background: true, sparse: true})' 47 | ``` 48 | ## Change Log 49 | 50 | v1.0.0: 51 | - Get account history with possibility filtering by actions also pagenation and ASC/DESC sorting 52 | - support only GET && POST requests 53 | - get all accounts 54 | - get voters for producer 55 | 56 | v1.0.1: 57 | - Proxy all chain RPC endpoints (POST requests) 58 | 59 | v1.0.2: 60 | - support of all requests from eosjs 61 | 62 | v1.0.3: 63 | - ?filter=buyram,... for get_actions/account_name request 64 | - get_actions_delta - actions that have field - account_ram_deltas.account 65 | -------------------------------------------------------------------------------- /api/v1.api.history.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const MAX_ELEMENTS = 1000; 4 | const async = require('async'); 5 | const request = require('request'); 6 | const config = require('../config'); 7 | 8 | const MAX_SKIP = config.maxSkip; 9 | 10 | module.exports = (app, DB, swaggerSpec, ObjectId) => { 11 | 12 | app.get('/api-docs.json', (req, res) => { 13 | res.setHeader('Content-Type', 'application/json'); 14 | res.send(swaggerSpec); 15 | }); 16 | 17 | /** 18 | * @swagger 19 | * 20 | * /v1/history/get_accounts?counter=on: 21 | * get: 22 | * description: get_accounts 23 | * produces: 24 | * - application/json 25 | * parameters: 26 | * - in: query 27 | * name: counter 28 | * description: Counter of all EOS Accounts (default off). 29 | * required: false 30 | * type: string 31 | * - in: query 32 | * name: skip 33 | * description: Skip elements (default 0). 34 | * required: false 35 | * type: number 36 | * - in: query 37 | * name: limit 38 | * description: Limit elements (default 10). 39 | * required: false 40 | * type: number 41 | */ 42 | app.get('/v1/history/get_accounts', getAccounts); 43 | 44 | /** 45 | * @swagger 46 | * 47 | * /v1/history/get_voters/cryptolions1: 48 | * get: 49 | * description: get_voters 50 | * produces: 51 | * - application/json 52 | * parameters: 53 | * - in: query 54 | * name: skip 55 | * description: Skip elements (default 0). 56 | * required: false 57 | * type: number 58 | * - in: query 59 | * name: limit 60 | * description: Limit elements (default 100). 61 | * required: false 62 | * type: number 63 | */ 64 | app.get('/v1/history/get_voters/:account', getVoters); 65 | 66 | /** 67 | * @swagger 68 | * 69 | * /v1/history/get_actions: 70 | * post: 71 | * description: get_actions 72 | * requestBody: 73 | * content: 74 | * application/json: 75 | * schema: 76 | * type: object 77 | * properties: 78 | * pos: 79 | * type: number 80 | * default: -1 81 | * offset: 82 | * type: number 83 | * default: 10 84 | * account_name: 85 | * type: string 86 | * default: cryptolions1 87 | * action_name: 88 | * type: string 89 | * default: all 90 | * counter: 91 | * type: number 92 | * default: 0 93 | */ 94 | app.post('/v1/history/get_actions', getActionsPOST); 95 | 96 | /** 97 | * @swagger 98 | * 99 | * /v1/history/get_actions/cryptolions1: 100 | * get: 101 | * description: get_actions 102 | * produces: 103 | * - application/json 104 | * parameters: 105 | * - in: query 106 | * name: skip 107 | * description: Skip elements default (0). 108 | * required: false 109 | * type: number 110 | * - in: query 111 | * name: limit 112 | * description: Limit elements default (10). 113 | * required: false 114 | * type: number 115 | * - in: query 116 | * name: sort 117 | * description: Sort elements default (-1). 118 | * required: false 119 | * type: number 120 | * - in: query 121 | * name: counter 122 | * description: Enable counter if you need actionsTotal (?counter=1). 123 | * required: false 124 | * type: number 125 | * - in: query 126 | * name: filter 127 | * description: Filter actions by action name. 128 | * required: false 129 | * type: string 130 | */ 131 | app.get('/v1/history/get_actions/:account', getActions); 132 | 133 | /** 134 | * @swagger 135 | * 136 | * /v1/history/get_actions_delta/cryptolions1: 137 | * get: 138 | * description: get_actions_delta 139 | * produces: 140 | * - application/json 141 | */ 142 | app.get('/v1/history/get_actions_delta/:account', getActionsDelta); 143 | 144 | // Heavy mongo operation (disabled) 145 | app.get('/v1/history/get_actions_unique/:account', getActionsDistinct); 146 | 147 | /** 148 | * @swagger 149 | * 150 | * /v1/history/get_actions/cryptolions1/sethash: 151 | * get: 152 | * description: get_actions by action name 153 | * produces: 154 | * - application/json 155 | * parameters: 156 | * - in: query 157 | * name: skip 158 | * description: Skip elements default (0). 159 | * required: false 160 | * type: number 161 | * - in: query 162 | * name: limit 163 | * description: Limit elements default (10). 164 | * required: false 165 | * type: number 166 | * - in: query 167 | * name: sort 168 | * description: Sort elements default (-1). 169 | * required: false 170 | * type: number 171 | */ 172 | app.get('/v1/history/get_actions/:account/:action', getActions); 173 | 174 | /** 175 | * @swagger 176 | * 177 | * /v1/history/get_transaction: 178 | * post: 179 | * description: get_transaction 180 | * requestBody: 181 | * content: 182 | * application/json: 183 | * schema: 184 | * type: object 185 | * properties: 186 | * id: 187 | * type: string 188 | */ 189 | app.post('/v1/history/get_transaction', getTransactionPOST); 190 | 191 | /** 192 | * @swagger 193 | * 194 | * /v1/history/get_transaction/${id}: 195 | * get: 196 | * description: get_transaction 197 | * produces: 198 | * - application/json 199 | */ 200 | app.get('/v1/history/get_transaction/:id', getTransaction); 201 | 202 | /** 203 | * @swagger 204 | * 205 | * /v1/history/get_controlled_accounts: 206 | * post: 207 | * description: get_controlled_accounts 208 | * requestBody: 209 | * content: 210 | * application/json: 211 | * schema: 212 | * type: object 213 | * properties: 214 | * controlling_account: 215 | * type: string 216 | */ 217 | app.post('/v1/history/get_controlled_accounts', getControlledAccountsPOST); 218 | 219 | /** 220 | * @swagger 221 | * 222 | * /v1/history/get_controlled_accounts/${controlling_account}: 223 | * get: 224 | * description: get_controlled_accounts 225 | * produces: 226 | * - application/json 227 | */ 228 | app.get('/v1/history/get_controlled_accounts/:controlling_account', getControlledAccounts); 229 | 230 | /** 231 | * @swagger 232 | * 233 | * /v1/history/get_key_accounts: 234 | * post: 235 | * description: get_key_accounts 236 | * requestBody: 237 | * content: 238 | * application/json: 239 | * schema: 240 | * type: object 241 | * properties: 242 | * public_key: 243 | * type: string 244 | */ 245 | app.post('/v1/history/get_key_accounts', getKeyAccountsPOST); 246 | 247 | /** 248 | * @swagger 249 | * 250 | * /v1/history/get_key_accounts/${public_key}: 251 | * get: 252 | * description: get_key_accounts 253 | * produces: 254 | * - application/json 255 | */ 256 | app.get('/v1/history/get_key_accounts/:public_key', getKeyAccounts); 257 | 258 | /** 259 | * @swagger 260 | * 261 | * /v1/chain/${chain_rpc_method_name}: 262 | * post: 263 | * description: Proxy for chain RPC endpoints 264 | * produces: 265 | * - application/json 266 | */ 267 | app.post('/v1/chain/*', (req, res) => { 268 | request.post({ url: `${config.chainUrl}${req.originalUrl}`, json: req.body }).pipe(res); 269 | }); 270 | 271 | app.get('/v1/chain/get_info', (req, res) => { 272 | request.get(`${config.chainUrl}${req.originalUrl}`).pipe(res); 273 | }); 274 | 275 | app.get('/v1/history/get_actions_transactions', getActionsTransactions); 276 | 277 | app.get('/health', (req, res) => { 278 | DB.collection("action_traces").find({ $or: [ 279 | {"act.account": "cryptolions1"}, 280 | {"act.data.receiver": "cryptolions1"}, 281 | {"act.data.from": "cryptolions1"}, 282 | {"act.data.to": "cryptolions1"}, 283 | {"act.data.name": "cryptolions1"}, 284 | {"act.data.voter": "cryptolions1"}, 285 | {"act.authorization.actor": "cryptolions1"} 286 | ]}).limit(1).toArray((err, result) => { 287 | if (err){ 288 | console.log(err); 289 | return res.status(403).end(); 290 | } 291 | res.status(200).end(); 292 | }); 293 | }); 294 | 295 | // ========= Custom functions 296 | let latencySkip = {}; 297 | function getActions(req, res){ 298 | // default values 299 | let skip = (isNaN(Number(req.query.skip))) ? 0 : Number(req.query.skip); 300 | let limit = (isNaN(Number(req.query.limit))) ? 10 : Number(req.query.limit); 301 | let sort = (isNaN(Number(req.query.sort))) ? -1 : Number(req.query.sort); 302 | 303 | if (limit > MAX_ELEMENTS){ 304 | return res.status(401).send(`Max elements ${MAX_ELEMENTS}!`); 305 | } 306 | if (skip < 0 || limit <= 0){ 307 | return res.status(401).send(`Skip (${skip}) || (${limit}) limit <= 0`); 308 | } 309 | if (sort !== -1 && sort !== 1){ 310 | return res.status(401).send(`Sort param must be 1 or -1`); 311 | } 312 | if (skip > MAX_SKIP){ 313 | return res.status(500).send("Large skip for account! Max skip per request " + MAX_SKIP); 314 | } 315 | 316 | let accountName = String(req.params.account); 317 | let action = String(req.params.action); 318 | let counter = Number(req.query.counter); 319 | let actionsNamesArr = (typeof req.query.filter === "string") ? req.query.filter.split(","): null; 320 | 321 | /*if (latencySkip[accountName] > +new Date()){ 322 | return res.status(500).send("Large skip for account, please wait until previous request will end! Max skip per request " + MAX_SKIP); 323 | } 324 | if (!latencySkip[accountName] && skip > MAX_SKIP){ 325 | latencySkip[accountName] = +new Date() + 60000; 326 | }*/ 327 | 328 | let query = { $or: [ 329 | {"act.account": accountName}, 330 | {"act.data.receiver": accountName}, 331 | {"act.data.from": accountName}, 332 | {"act.data.to": accountName}, 333 | {"act.data.name": accountName}, 334 | {"act.data.voter": accountName}, 335 | {"act.authorization.actor": accountName} 336 | ]}; 337 | if (action !== "undefined" && action !== "all"){ 338 | query["act.name"] = action; 339 | } 340 | if (actionsNamesArr){ 341 | query['act.name'] = { $in : [query['act.name']]}; 342 | actionsNamesArr.forEach(elem => { 343 | query['act.name']['$in'].push(elem); 344 | }); 345 | } 346 | 347 | let parallelObject = { 348 | actions: (callback) => { 349 | DB.collection("action_traces").find(query).sort({ "createdAt": sort }).skip(skip).limit(limit).toArray(callback); 350 | } 351 | }; 352 | 353 | if (counter === 1){ 354 | parallelObject["actionsTotal"] = (callback) => { 355 | callback(null, 'Under construction'); 356 | } 357 | } 358 | 359 | async.parallel(parallelObject, (err, result) => { 360 | if (err){ 361 | console.error(err); 362 | return res.status(500).end(); 363 | } 364 | /*if (latencySkip[accountName] && skip > MAX_SKIP){ 365 | delete latencySkip[accountName]; 366 | }*/ 367 | res.json(result) 368 | }); 369 | } 370 | 371 | function getActionsPOST(req, res){ 372 | // default values 373 | let skip = 0; 374 | let limit = 10; 375 | let sort = -1; 376 | let accountName = String(req.body.account_name); 377 | let action = String(req.body.action_name); 378 | let counter = Number(req.body.counter); 379 | 380 | let query = { $or: [ 381 | {"act.account": accountName}, 382 | {"act.data.receiver": accountName}, 383 | {"act.data.from": accountName}, 384 | {"act.data.to": accountName}, 385 | {"act.data.name": accountName}, 386 | {"act.data.voter": accountName}, 387 | {"act.authorization.actor": accountName} 388 | ]}; 389 | if (action !== "undefined"){ 390 | query["act.name"] = action; 391 | } 392 | 393 | let pos = Number(req.body.pos); 394 | let offset = Number(req.body.offset); 395 | if (!isNaN(pos) && !isNaN(offset)){ 396 | sort = (pos < 0) ? -1: 1; 397 | limit = Math.abs(offset); 398 | skip = Math.abs(pos); 399 | } 400 | 401 | if (limit > MAX_ELEMENTS){ 402 | return res.status(401).send(`Max elements ${MAX_ELEMENTS}!`); 403 | } 404 | if (skip < 0 || limit <= 0){ 405 | return res.status(401).send(`Skip (${skip}) || (${limit}) limit <= 0`); 406 | } 407 | if (sort !== -1 && sort !== 1){ 408 | return res.status(401).send(`Sort param must be 1 or -1`); 409 | } 410 | if (skip > MAX_SKIP){ 411 | return res.status(500).send("Large skip for account! Max skip per request " + MAX_SKIP); 412 | } 413 | 414 | /*if (latencySkip[accountName] > +new Date()){ 415 | return res.status(500).send("Large skip for account, please wait until previous request will end! Max skip per request " + MAX_SKIP); 416 | } 417 | if (!latencySkip[accountName] && skip > MAX_SKIP){ 418 | latencySkip[accountName] = +new Date() + 60000; 419 | }*/ 420 | 421 | let parallelObject = { 422 | actions: (callback) => { 423 | DB.collection("action_traces").find(query).sort({ "createdAt": sort }).skip(skip).limit(limit).toArray(callback); 424 | } 425 | }; 426 | 427 | if (counter === 1){ 428 | parallelObject["actionsTotal"] = (callback) => { 429 | callback(null, 'Under construction'); 430 | } 431 | } 432 | 433 | async.parallel(parallelObject, (err, result) => { 434 | if (err){ 435 | console.error(err); 436 | return res.status(500).end(); 437 | } 438 | /*if (latencySkip[accountName] && skip > MAX_SKIP){ 439 | delete latencySkip[accountName]; 440 | }*/ 441 | res.json(result) 442 | }); 443 | } 444 | 445 | // ========= Get actions by multiple filet or actions names 446 | function getActionsDelta(req, res){ 447 | // default values 448 | let skip = (isNaN(Number(req.query.skip))) ? 0 : Number(req.query.skip); 449 | let limit = (isNaN(Number(req.query.limit))) ? 10 : Number(req.query.limit); 450 | let sort = (isNaN(Number(req.query.sort))) ? -1 : Number(req.query.sort); 451 | 452 | if (limit > MAX_ELEMENTS){ 453 | return res.status(401).send(`Max elements ${MAX_ELEMENTS}!`); 454 | } 455 | if (skip < 0 || limit < 0){ 456 | return res.status(401).send(`Skip (${skip}) || (${limit}) limit < 0`); 457 | } 458 | if (sort !== -1 && sort !== 1){ 459 | return res.status(401).send(`Sort param must be 1 or -1`); 460 | } 461 | let accountName = String(req.params.account); 462 | 463 | let query = { $or: [ 464 | {"act.account": accountName}, 465 | {"act.data.receiver": accountName}, 466 | {"act.data.from": accountName}, 467 | {"act.data.to": accountName}, 468 | {"act.data.name": accountName}, 469 | {"act.data.voter": accountName}, 470 | {"act.authorization.actor": accountName} 471 | ], "account_ram_deltas.account": { $exists: true } }; 472 | 473 | DB.collection("action_traces").find(query).sort({"createdAt": sort}).skip(skip).limit(limit).toArray((err, result) => { 474 | if (err){ 475 | console.error(err); 476 | return res.status(500).end(); 477 | } 478 | res.json({ actions: result }) 479 | }); 480 | } 481 | 482 | function getActionsDistinct(req, res){ 483 | // default values 484 | let accountName = String(req.params.account); 485 | let query = { $or: [ 486 | {"act.account": accountName}, 487 | {"act.data.receiver": accountName}, 488 | {"act.data.from": accountName}, 489 | {"act.data.to": accountName}, 490 | {"act.data.name": accountName}, 491 | {"act.data.voter": accountName}, 492 | {"act.authorization.actor": accountName} 493 | ]}; 494 | 495 | DB.collection("action_traces").distinct("act.name", query, (err, result) => { 496 | if (err){ 497 | console.error(err); 498 | return res.status(500).end(); 499 | }; 500 | res.json(result); 501 | }); 502 | } 503 | 504 | function getTransactionPOST(req, res){ 505 | let key = String(req.body.id); 506 | if (key === "undefined"){ 507 | return res.status(401).send("Wrong transactions ID!"); 508 | } 509 | let query = { id: key }; 510 | DB.collection("transaction_traces").findOne(query, (err, result) => { 511 | if (err){ 512 | console.error(err); 513 | return res.status(500).end(); 514 | }; 515 | res.json(result); 516 | }); 517 | } 518 | 519 | function getTransaction(req, res){ 520 | let key = String(req.params.id); 521 | if (key === "undefined"){ 522 | return res.status(401).send("Wrong transactions ID!"); 523 | } 524 | let query = { id: key }; 525 | DB.collection("transaction_traces").findOne(query, (err, result) => { 526 | if (err){ 527 | console.error(err); 528 | return res.status(500).end(); 529 | }; 530 | res.json(result); 531 | }); 532 | } 533 | 534 | function getControlledAccountsPOST(req, res){ 535 | let key = String(req.body.controlling_account); 536 | if (key === "undefined"){ 537 | return res.status(401).send("Wrong transactions ID!"); 538 | } 539 | let query = { controlling_account: key }; 540 | DB.collection("account_controls").find(query).toArray((err, result) => { 541 | if (err){ 542 | console.error(err); 543 | return res.status(500).end(); 544 | }; 545 | res.json(result); 546 | }); 547 | } 548 | 549 | function getControlledAccounts(req, res){ 550 | let key = String(req.params.controlling_account); 551 | if (key === "undefined"){ 552 | return res.status(401).send("Wrong transactions ID!"); 553 | } 554 | let query = { controlling_account: key }; 555 | DB.collection("account_controls").find(query).toArray((err, result) => { 556 | if (err){ 557 | console.error(err); 558 | return res.status(500).end(); 559 | }; 560 | res.json(result); 561 | }); 562 | } 563 | 564 | function getKeyAccountsPOST(req, res){ 565 | let key = String(req.body.public_key); 566 | if (key === "undefined"){ 567 | return res.status(401).send("Wrong transactions ID!"); 568 | } 569 | let query = [ 570 | {'$match': { 571 | public_key: key 572 | }}, 573 | {'$group': { 574 | '_id': '$public_key', 575 | 'account_names': { '$addToSet': '$account' } 576 | }}, 577 | {'$project': { 578 | '_id': 0, 579 | 'account_names': 1 580 | }} 581 | ]; 582 | DB.collection("pub_keys").aggregate(query).toArray((err, result) => { 583 | if (err){ 584 | console.error(err); 585 | return res.status(500).end(); 586 | }; 587 | if (result.length > 0) { 588 | res.json(result[0]); 589 | } else { 590 | res.json({"account_names": []}); 591 | } 592 | }); 593 | } 594 | 595 | function getKeyAccounts(req, res){ 596 | let key = String(req.params.public_key); 597 | if (key === "undefined"){ 598 | return res.status(401).send("Wrong transactions ID!"); 599 | } 600 | let query = { public_key: key }; 601 | DB.collection("pub_keys").find(query).toArray((err, result) => { 602 | if (err){ 603 | console.error(err); 604 | return res.status(500).end(); 605 | }; 606 | res.json(result); 607 | }); 608 | } 609 | 610 | function getAccounts(req, res){ 611 | let skip = 0; 612 | let limit = 10; 613 | let counterAccounts = false; 614 | let accountName = String(req.query.account); 615 | 616 | let query = {}; 617 | if (accountName !== "undefined"){ 618 | query.name = accountName; 619 | } 620 | 621 | skip = (isNaN(Number(req.query.skip))) ? skip : Number(req.query.skip); 622 | limit = (isNaN(Number(req.query.limit))) ? limit : Number(req.query.limit); 623 | counterAccounts = (req.query.counter === "on") ? true : false; 624 | 625 | if (limit > MAX_ELEMENTS){ 626 | return res.status(401).send(`Max limit accounts per query = ${MAX_ELEMENTS}`); 627 | } 628 | if (skip < 0 || limit < 0){ 629 | return res.status(401).send(`Skip (${skip}) || (${limit}) limit < 0`); 630 | } 631 | 632 | let queryObject = { 633 | accounts: (callback) => { 634 | DB.collection("accounts").find(query).skip(skip).limit(limit).toArray(callback); 635 | } 636 | }; 637 | 638 | if (counterAccounts){ 639 | queryObject['allEosAccounts'] = (callback) => { 640 | DB.collection("accounts").estimatedDocumentCount(callback); 641 | }; 642 | } 643 | 644 | async.parallel(queryObject, (err, result) => { 645 | if (err){ 646 | console.error(err); 647 | return res.status(500).end(); 648 | } 649 | res.json(result) 650 | }); 651 | } 652 | 653 | function getVoters(req, res){ 654 | // default values 655 | let skip = 0; 656 | let limit = 100; 657 | let sort = -1; 658 | let accountName = String(req.params.account); 659 | 660 | let query = { "act.name": "voteproducer", "act.data.producers": { $in: [accountName] } }; 661 | 662 | skip = (isNaN(Number(req.query.skip))) ? skip : Number(req.query.skip); 663 | limit = (isNaN(Number(req.query.limit))) ? limit : Number(req.query.limit); 664 | sort = (isNaN(Number(req.query.sort))) ? sort : Number(req.query.sort); 665 | 666 | if (limit > MAX_ELEMENTS){ 667 | return res.status(401).send(`Max elements ${MAX_ELEMENTS}!`); 668 | } 669 | if (skip < 0 || limit < 0){ 670 | return res.status(401).send(`Skip (${skip}) || (${limit}) limit < 0`); 671 | } 672 | if (sort !== -1 && sort !== 1){ 673 | return res.status(401).send(`Sort param must be 1 or -1`); 674 | } 675 | 676 | async.parallel({ 677 | votesCounter: (callback) => { 678 | DB.collection("action_traces").countDocuments(query, callback); 679 | }, 680 | voters: (callback) => { 681 | DB.collection("action_traces").find(query).sort({"createdAt": sort}).skip(skip).limit(limit).toArray(callback); 682 | } 683 | }, (err, result) => { 684 | if (err){ 685 | console.error(err); 686 | return res.status(500).end(); 687 | } 688 | res.json(result) 689 | }); 690 | } 691 | 692 | function getActionsTransactions(req, res){ 693 | async.parallel({ 694 | actions: (callback) => { 695 | DB.collection("action_traces").estimatedDocumentCount(callback); 696 | }, 697 | transactions: (callback) => { 698 | DB.collection("transaction_traces").estimatedDocumentCount(callback); 699 | } 700 | }, (err, result) => { 701 | if (err){ 702 | console.error(err); 703 | return res.status(500).end(); 704 | } 705 | res.json(result) 706 | }); 707 | } 708 | 709 | // clear slow mongo operations 710 | function clearSlowOperations(){ 711 | DB.admin().command({ currentOp: 1, microsecs_running: { $gte: config.maxTimeForOperetion }, "command.find": { $exists: true } }, (err, result) => { 712 | if (err){ 713 | console.error(err); 714 | return setTimeout(clearSlowOperations, config.clearOperationsTimer); 715 | } 716 | if(result && result.inprog && result.inprog.length){ 717 | result.inprog.forEach((elem) => { 718 | console.log('Kill operation: ', elem.opid, elem.command.filter, 'skip', elem.command.skip); 719 | DB.admin().command({ killOp: 1, op: elem.opid }); 720 | }); 721 | } 722 | setTimeout(clearSlowOperations, config.clearOperationsTimer); 723 | }); 724 | } 725 | clearSlowOperations(); 726 | //========= end Custom Functions 727 | } 728 | 729 | 730 | 731 | -------------------------------------------------------------------------------- /build_indexes.sh: -------------------------------------------------------------------------------- 1 | echo "IDX 1/12: action_traces: act.account + createdAt" 2 | mongo EOS --eval 'db.action_traces.createIndex({"act.account": 1, "createdAt":1},{background: true, sparse: true})' 3 | 4 | echo "IDX 2/12: action_traces: act.name + createdAt" 5 | mongo EOS --eval 'db.action_traces.createIndex({"act.name": 1, "createdAt":1},{background: true, sparse: true})' 6 | 7 | echo "IDX 3/12: action_traces: act.data.receiver + createdAt" 8 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.receiver": 1, "createdAt":1},{background: true, sparse: true})' 9 | 10 | echo "IDX 4/12: action_traces: act.data.from + createdAt" 11 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.from": 1, "createdAt":1},{background: true, sparse: true})' 12 | 13 | echo "IDX 5/12: action_traces: act.data.to + createdAt" 14 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.to": 1, "createdAt":1},{background: true, sparse: true})' 15 | 16 | echo "IDX 6/12: action_traces: act.data.name + createdAt" 17 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.name": 1, "createdAt":1},{background: true, sparse: true})' 18 | 19 | echo "IDX 7/12: action_traces: act.data.voter + createdAt" 20 | mongo EOS --eval 'db.action_traces.createIndex({"act.data.voter": 1, "createdAt":1},{background: true, sparse: true})' 21 | 22 | echo "IDX 8/12: action_traces: act.authorization.actor + createdAt" 23 | mongo EOS --eval 'db.action_traces.createIndex({"act.authorization.actor": 1, "createdAt":1},{background: true, sparse: true})' 24 | 25 | echo "IDX 10/12: account_controls: controlling_account" 26 | mongo EOS --eval 'db.account_controls.createIndex({"controlling_account": 1},{background: true, sparse: true})' 27 | 28 | echo "IDX 11/12: pub_keys: public_key " 29 | mongo EOS --eval 'db.pub_keys.createIndex({"public_key": 1},{background: true, sparse: true})' 30 | 31 | echo "IDX 12/12: accounts: name" 32 | mongo EOS --eval 'db.accounts.createIndex({"name": 1},{background: true, sparse: true})' 33 | -------------------------------------------------------------------------------- /cache/cache.daemon.js: -------------------------------------------------------------------------------- 1 | /* 2 | Cache accounts with actions > 500k 3 | */ 4 | const MongoClient = require('mongodb').MongoClient; 5 | const CONFIG = require('../config.js'); 6 | const async = require('async'); 7 | 8 | const MONGO_OPTIONS = { 9 | socketTimeoutMS: 10000, 10 | keepAlive: true, 11 | reconnectTries: 30000, 12 | useNewUrlParser: true 13 | }; 14 | const MAX_ACTIONS = 500000; 15 | const MAX_ELEMS = 50000; 16 | 17 | process.on('uncaughtException', (err) => { 18 | console.error(`======= UncaughtException Cache : ${err}`); 19 | }); 20 | 21 | MongoClient.connect( CONFIG.mongoURL, MONGO_OPTIONS, (err, db) => { 22 | if (err){ 23 | return console.error("Database error !!!", err); 24 | } 25 | console.log("=== Database Connected!"); 26 | let DBO = db.db(CONFIG.mongoDB); 27 | 28 | // Start cache daemon ===== 29 | getAccounts(); 30 | 31 | // clear slow operations 32 | clearSlowOperations(); 33 | 34 | function clearSlowOperations(){ 35 | DBO.admin().command({ currentOp: 1, microsecs_running: { $gte: 15000 }, "command.aggregate": { $exists: true } }, (err, result) => { 36 | if (err){ 37 | console.error(err); 38 | return setTimeout(clearSlowOperations, 10000); 39 | } 40 | console.log(result); 41 | if(result && result.inprog && result.inprog.length){ 42 | result.inprog.forEach((elem) => { 43 | console.log('Kill operation: ', elem.opid, elem.command.aggregate); 44 | DBO.admin().command({ killOp: 1, op: elem.opid }); 45 | }); 46 | } 47 | setTimeout(clearSlowOperations, 10000); 48 | }); 49 | } 50 | 51 | // Cache logic ===== 52 | let cursor = 0; 53 | let counter = 0; 54 | 55 | function getAccounts(){ 56 | async.waterfall([ 57 | (callback) => { 58 | DBO.collection("accounts").count(callback); 59 | }, 60 | (accounts, callback) => { 61 | console.log('All Accounts -', accounts); 62 | let skip = (cursor === 0) ? 0 : cursor; 63 | let elements = Array.from({length: MAX_ELEMS }, (v, k) => k); 64 | 65 | cursor += MAX_ELEMS; 66 | 67 | console.log('skip =', skip, 'limit =', MAX_ELEMS); 68 | DBO.collection("accounts").find({}).skip(skip).limit(MAX_ELEMS).toArray((err, accountsArr) => { 69 | if (err){ 70 | return callback(err); 71 | }; 72 | if (!accountsArr || !accountsArr.length){ 73 | return callback(null, 'FINISH'); 74 | } 75 | accountActionCount(accountsArr, callback); 76 | }); 77 | } 78 | ], (err, result) => { 79 | if (err){ 80 | console.error('getAccounts callback error', err); 81 | getAccounts(); 82 | return; 83 | //process.exit(1); 84 | } 85 | if (result === 'FINISH'){ 86 | console.log(`Scanned ${counter} accounts :)`); 87 | process.exit(); 88 | } 89 | getAccounts(); 90 | }); 91 | } 92 | 93 | 94 | function accountActionCount(accountsArr, callback){ 95 | async.eachLimit(accountsArr, CONFIG.limitAsync, (elem, cb) => { 96 | let query = { $or: [ 97 | {"act.account": elem.name }, 98 | {"act.data.receiver": elem.name }, 99 | {"act.data.from": elem.name }, 100 | {"act.data.to": elem.name }, 101 | {"act.data.name": elem.name }, 102 | {"act.data.voter": elem.name }, 103 | {"act.authorization.actor": elem.name } 104 | ]}; 105 | console.log(counter+=1, ' Account -', elem.name); 106 | DBO.collection("action_traces").aggregate([ 107 | { $match: query }, 108 | { $group: { _id: null, sum: { $sum: 1 } } } 109 | ]).toArray((err, result) => { 110 | if (err){ 111 | if(err.name === 'MongoNetworkError'){ 112 | console.log('MongoNetworkError ---- ', elem.name); 113 | let query = { name: elem.name }; 114 | DBO.collection("smart_cache").update(query, query, { upsert: true }); 115 | } 116 | return cb(); 117 | } 118 | if (!result || !result[0] || !result[0].sum){ 119 | console.log('counter error') 120 | return cb(); 121 | } 122 | console.log('Account -', elem.name, ' Actions -', result[0].sum); 123 | if (result[0].sum > MAX_ACTIONS){ 124 | DBO.collection("smart_cache").update({ name: elem.name }, { name: elem.name, actions: result[0].sum }, { upsert: true }); 125 | } 126 | cb(); 127 | }); 128 | }, (error) => { 129 | if (error){ 130 | return callback(error) 131 | } 132 | callback(null); 133 | }); 134 | } 135 | }); 136 | 137 | 138 | 139 | 140 | 141 | -------------------------------------------------------------------------------- /cache/init.cache.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/CryptoLions/EOS-mongo-history-API/074186571e2f90012a334b44489b24c421ee46fb/cache/init.cache.js -------------------------------------------------------------------------------- /config.example.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | serverPort: 3333, 3 | mongoURL: "mongodb://localhost:27017/EOS", 4 | mongoDB: "EOS", 5 | chainUrl: "https://bp.cryptolions.io", 6 | saveRequestsMetrics: true, 7 | maxSkip: 500000, 8 | maxTimeForOperetion: 60000, // 60sec 9 | clearOperationsTimer: 10000, // 10sec 10 | } 11 | -------------------------------------------------------------------------------- /html/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | EOS Mongo History by Cryptolions 5 | 6 | 7 | 8 | 9 | 10 | 11 | 14 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 36 | 37 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | /*############################################################################### 2 | # 3 | # EOS Mongo History API 4 | # API to get actions using EOS mongo plugin (similar to history plugin) 5 | # 6 | # Examples: 7 | # https://history.cryptolions.io/v1/history/get_actions/cryptolions1 8 | # https://history.cryptolions.io/v1/history/get_actions/cryptolions1/sethash 9 | # https://history.cryptolions.io/v1/history/get_actions/cryptolions1/sethash?limit=2&skip=1&sort=-1 10 | # 11 | # Git Hub: https://github.com/CryptoLions/EOS-mongo-history-API 12 | # 13 | # Created by http://CryptoLions.io 14 | # 15 | ############################################################################### */ 16 | //require('appmetrics-dash').monitor(); old metrics 17 | const MongoClient = require('mongodb').MongoClient; 18 | const ObjectId = require('mongodb').ObjectID; 19 | const swaggerJSDoc = require('swagger-jsdoc'); 20 | const bodyparser = require('body-parser'); 21 | const CONFIG = require('./config.js'); 22 | const swStats = require('swagger-stats-lions'); 23 | const cors = require('cors'); 24 | 25 | const MONGO_OPTIONS = { 26 | socketTimeoutMS: 60000, 27 | keepAlive: true, 28 | reconnectTries: 30000, 29 | useNewUrlParser: true 30 | }; 31 | 32 | process.on('uncaughtException', (err) => { 33 | console.error(`======= UncaughtException API Server : ${err}`); 34 | }); 35 | 36 | const swaggerSpec = swaggerJSDoc({ 37 | definition: { 38 | info: { 39 | title: 'EOS history API by Cryptolions', 40 | version: '1.0.0', 41 | }, 42 | }, 43 | apis: ['./api/v1.api.history.js'], 44 | }); 45 | 46 | const express = require('express'); 47 | const app = express(); 48 | 49 | app.use(cors()); 50 | app.use(swStats.getMiddleware({ 51 | saveRequests: CONFIG.saveRequestsMetrics, 52 | timelineBucketDuration: 2000, 53 | uriPath: "/metrics", 54 | name : "History nodes API", 55 | swaggerSpec: {} 56 | })); 57 | 58 | // parse requests from eosjs (v16.0.0 - 16.0.9) 59 | app.use((req, res, next) => { 60 | if (req.method !== 'POST' || req.headers['content-type'] === 'application/json'){ 61 | return next(); 62 | } 63 | let body = ''; 64 | req.on('data', chunk => { 65 | body += chunk.toString(); 66 | }); 67 | req.on('end', () => { 68 | try{ 69 | req.body = JSON.parse(body); 70 | } catch(e){ 71 | console.error('JSON POST request parse error - ', e); 72 | } 73 | next(); 74 | }); 75 | }); 76 | app.use(bodyparser.json()); 77 | 78 | app.use('/', express.static(__dirname + '/html')); 79 | 80 | MongoClient.connect( CONFIG.mongoURL, MONGO_OPTIONS, (err, db) => { 81 | if (err){ 82 | return console.error("Database error !!!", err); 83 | } 84 | console.log("=== Database Connected!"); 85 | let dbo = db.db(CONFIG.mongoDB); 86 | require('./api/v1.api.history')(app, dbo, swaggerSpec, ObjectId); 87 | }); 88 | 89 | const http = require('http').Server(app); 90 | http.listen(CONFIG.serverPort, () => { 91 | console.log('=== Listening on port:', CONFIG.serverPort); 92 | }); 93 | http.on('error', (err) => { 94 | console.error('=== Http server error', err); 95 | }); 96 | -------------------------------------------------------------------------------- /nodejs_restclient.log: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/CryptoLions/EOS-mongo-history-API/074186571e2f90012a334b44489b24c421ee46fb/nodejs_restclient.log -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "EOS-history-mongo-api", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abbrev": { 8 | "version": "1.1.1", 9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 11 | }, 12 | "accepts": { 13 | "version": "1.3.5", 14 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 15 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 16 | "requires": { 17 | "mime-types": "~2.1.18", 18 | "negotiator": "0.6.1" 19 | } 20 | }, 21 | "ajv": { 22 | "version": "5.5.2", 23 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", 24 | "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", 25 | "requires": { 26 | "co": "^4.6.0", 27 | "fast-deep-equal": "^1.0.0", 28 | "fast-json-stable-stringify": "^2.0.0", 29 | "json-schema-traverse": "^0.3.0" 30 | } 31 | }, 32 | "ansi-regex": { 33 | "version": "2.1.1", 34 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 35 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 36 | }, 37 | "aproba": { 38 | "version": "1.2.0", 39 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 40 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 41 | }, 42 | "are-we-there-yet": { 43 | "version": "1.1.5", 44 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 45 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 46 | "requires": { 47 | "delegates": "^1.0.0", 48 | "readable-stream": "^2.0.6" 49 | }, 50 | "dependencies": { 51 | "isarray": { 52 | "version": "1.0.0", 53 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 54 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 55 | }, 56 | "readable-stream": { 57 | "version": "2.3.6", 58 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 59 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 60 | "requires": { 61 | "core-util-is": "~1.0.0", 62 | "inherits": "~2.0.3", 63 | "isarray": "~1.0.0", 64 | "process-nextick-args": "~2.0.0", 65 | "safe-buffer": "~5.1.1", 66 | "string_decoder": "~1.1.1", 67 | "util-deprecate": "~1.0.1" 68 | } 69 | }, 70 | "string_decoder": { 71 | "version": "1.1.1", 72 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 73 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 74 | "requires": { 75 | "safe-buffer": "~5.1.0" 76 | } 77 | } 78 | } 79 | }, 80 | "argparse": { 81 | "version": "1.0.10", 82 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 83 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 84 | "requires": { 85 | "sprintf-js": "~1.0.2" 86 | } 87 | }, 88 | "array-flatten": { 89 | "version": "1.1.1", 90 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 91 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 92 | }, 93 | "asn1": { 94 | "version": "0.2.4", 95 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 96 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 97 | "requires": { 98 | "safer-buffer": "~2.1.0" 99 | } 100 | }, 101 | "assert-plus": { 102 | "version": "1.0.0", 103 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 104 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 105 | }, 106 | "async": { 107 | "version": "2.6.1", 108 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz", 109 | "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==", 110 | "requires": { 111 | "lodash": "^4.17.10" 112 | } 113 | }, 114 | "asynckit": { 115 | "version": "0.4.0", 116 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 117 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 118 | }, 119 | "aws-sign2": { 120 | "version": "0.7.0", 121 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 122 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 123 | }, 124 | "aws4": { 125 | "version": "1.8.0", 126 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 127 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==" 128 | }, 129 | "balanced-match": { 130 | "version": "1.0.0", 131 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 132 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 133 | }, 134 | "basic-auth": { 135 | "version": "2.0.1", 136 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 137 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 138 | "requires": { 139 | "safe-buffer": "5.1.2" 140 | }, 141 | "dependencies": { 142 | "safe-buffer": { 143 | "version": "5.1.2", 144 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 145 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 146 | } 147 | } 148 | }, 149 | "bcrypt-pbkdf": { 150 | "version": "1.0.2", 151 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 152 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 153 | "requires": { 154 | "tweetnacl": "^0.14.3" 155 | } 156 | }, 157 | "bintrees": { 158 | "version": "1.0.1", 159 | "resolved": "https://registry.npmjs.org/bintrees/-/bintrees-1.0.1.tgz", 160 | "integrity": "sha1-DmVcm5wkNeqraL9AJyJtK1WjRSQ=" 161 | }, 162 | "block-stream": { 163 | "version": "0.0.9", 164 | "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", 165 | "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", 166 | "requires": { 167 | "inherits": "~2.0.0" 168 | } 169 | }, 170 | "body-parser": { 171 | "version": "1.18.3", 172 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz", 173 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=", 174 | "requires": { 175 | "bytes": "3.0.0", 176 | "content-type": "~1.0.4", 177 | "debug": "2.6.9", 178 | "depd": "~1.1.2", 179 | "http-errors": "~1.6.3", 180 | "iconv-lite": "0.4.23", 181 | "on-finished": "~2.3.0", 182 | "qs": "6.5.2", 183 | "raw-body": "2.3.3", 184 | "type-is": "~1.6.16" 185 | }, 186 | "dependencies": { 187 | "qs": { 188 | "version": "6.5.2", 189 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 190 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 191 | } 192 | } 193 | }, 194 | "brace-expansion": { 195 | "version": "1.1.11", 196 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 197 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 198 | "requires": { 199 | "balanced-match": "^1.0.0", 200 | "concat-map": "0.0.1" 201 | } 202 | }, 203 | "bson": { 204 | "version": "1.1.0", 205 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.0.tgz", 206 | "integrity": "sha512-9Aeai9TacfNtWXOYarkFJRW2CWo+dRon+fuLZYJmvLV3+MiUp0bEI6IAZfXEIg7/Pl/7IWlLaDnhzTsD81etQA==" 207 | }, 208 | "bytes": { 209 | "version": "3.0.0", 210 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 211 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 212 | }, 213 | "call-me-maybe": { 214 | "version": "1.0.1", 215 | "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", 216 | "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=" 217 | }, 218 | "caseless": { 219 | "version": "0.12.0", 220 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 221 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 222 | }, 223 | "co": { 224 | "version": "4.6.0", 225 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 226 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" 227 | }, 228 | "code-point-at": { 229 | "version": "1.1.0", 230 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 231 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 232 | }, 233 | "combined-stream": { 234 | "version": "1.0.7", 235 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", 236 | "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", 237 | "requires": { 238 | "delayed-stream": "~1.0.0" 239 | } 240 | }, 241 | "commander": { 242 | "version": "2.17.1", 243 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", 244 | "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==" 245 | }, 246 | "concat-map": { 247 | "version": "0.0.1", 248 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 249 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 250 | }, 251 | "console-control-strings": { 252 | "version": "1.1.0", 253 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 254 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 255 | }, 256 | "content-disposition": { 257 | "version": "0.5.2", 258 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 259 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 260 | }, 261 | "content-type": { 262 | "version": "1.0.4", 263 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 264 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 265 | }, 266 | "cookie": { 267 | "version": "0.3.1", 268 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 269 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 270 | }, 271 | "cookie-signature": { 272 | "version": "1.0.6", 273 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 274 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 275 | }, 276 | "cookies": { 277 | "version": "0.7.3", 278 | "resolved": "https://registry.npmjs.org/cookies/-/cookies-0.7.3.tgz", 279 | "integrity": "sha512-+gixgxYSgQLTaTIilDHAdlNPZDENDQernEMiIcZpYYP14zgHsCt4Ce1FEjFtcp6GefhozebB6orvhAAWx/IS0A==", 280 | "requires": { 281 | "depd": "~1.1.2", 282 | "keygrip": "~1.0.3" 283 | } 284 | }, 285 | "core-js": { 286 | "version": "2.5.7", 287 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.7.tgz", 288 | "integrity": "sha512-RszJCAxg/PP6uzXVXL6BsxSXx/B05oJAQ2vkJRjyjrEcNVycaqOmNb5OTxZPE3xa5gwZduqza6L9JOCenh/Ecw==" 289 | }, 290 | "core-util-is": { 291 | "version": "1.0.2", 292 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 293 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 294 | }, 295 | "cors": { 296 | "version": "2.8.5", 297 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 298 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 299 | "requires": { 300 | "object-assign": "^4", 301 | "vary": "^1" 302 | } 303 | }, 304 | "cpu-stat": { 305 | "version": "2.0.1", 306 | "resolved": "https://registry.npmjs.org/cpu-stat/-/cpu-stat-2.0.1.tgz", 307 | "integrity": "sha1-UB6NbdLUTO9dhCk5w40YIsB4/Kw=" 308 | }, 309 | "dashdash": { 310 | "version": "1.14.1", 311 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 312 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 313 | "requires": { 314 | "assert-plus": "^1.0.0" 315 | } 316 | }, 317 | "debug": { 318 | "version": "2.6.9", 319 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 320 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 321 | "requires": { 322 | "ms": "2.0.0" 323 | } 324 | }, 325 | "delayed-stream": { 326 | "version": "1.0.0", 327 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 328 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 329 | }, 330 | "delegates": { 331 | "version": "1.0.0", 332 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 333 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 334 | }, 335 | "depd": { 336 | "version": "1.1.2", 337 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 338 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 339 | }, 340 | "destroy": { 341 | "version": "1.0.4", 342 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 343 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 344 | }, 345 | "doctrine": { 346 | "version": "2.1.0", 347 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 348 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 349 | "requires": { 350 | "esutils": "^2.0.2" 351 | } 352 | }, 353 | "ecc-jsbn": { 354 | "version": "0.1.2", 355 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 356 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 357 | "requires": { 358 | "jsbn": "~0.1.0", 359 | "safer-buffer": "^2.1.0" 360 | } 361 | }, 362 | "ee-first": { 363 | "version": "1.1.1", 364 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 365 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 366 | }, 367 | "encodeurl": { 368 | "version": "1.0.2", 369 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 370 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 371 | }, 372 | "eosio-mongodb-queries": { 373 | "version": "0.9.0", 374 | "resolved": "https://registry.npmjs.org/eosio-mongodb-queries/-/eosio-mongodb-queries-0.9.0.tgz", 375 | "integrity": "sha512-BANaRnlhYY5W922tpFZ878J5+xijmHEA6kty464KmWvGChrLGzWC29ReOmV2jT5DO3sxOKaTKgFXORc/YPf30w==" 376 | }, 377 | "escape-html": { 378 | "version": "1.0.3", 379 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 380 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 381 | }, 382 | "esprima": { 383 | "version": "4.0.1", 384 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 385 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 386 | }, 387 | "esutils": { 388 | "version": "2.0.2", 389 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 390 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" 391 | }, 392 | "etag": { 393 | "version": "1.8.1", 394 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 395 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 396 | }, 397 | "express": { 398 | "version": "4.16.3", 399 | "resolved": "http://registry.npmjs.org/express/-/express-4.16.3.tgz", 400 | "integrity": "sha1-avilAjUNsyRuzEvs9rWjTSL37VM=", 401 | "requires": { 402 | "accepts": "~1.3.5", 403 | "array-flatten": "1.1.1", 404 | "body-parser": "1.18.2", 405 | "content-disposition": "0.5.2", 406 | "content-type": "~1.0.4", 407 | "cookie": "0.3.1", 408 | "cookie-signature": "1.0.6", 409 | "debug": "2.6.9", 410 | "depd": "~1.1.2", 411 | "encodeurl": "~1.0.2", 412 | "escape-html": "~1.0.3", 413 | "etag": "~1.8.1", 414 | "finalhandler": "1.1.1", 415 | "fresh": "0.5.2", 416 | "merge-descriptors": "1.0.1", 417 | "methods": "~1.1.2", 418 | "on-finished": "~2.3.0", 419 | "parseurl": "~1.3.2", 420 | "path-to-regexp": "0.1.7", 421 | "proxy-addr": "~2.0.3", 422 | "qs": "6.5.1", 423 | "range-parser": "~1.2.0", 424 | "safe-buffer": "5.1.1", 425 | "send": "0.16.2", 426 | "serve-static": "1.13.2", 427 | "setprototypeof": "1.1.0", 428 | "statuses": "~1.4.0", 429 | "type-is": "~1.6.16", 430 | "utils-merge": "1.0.1", 431 | "vary": "~1.1.2" 432 | }, 433 | "dependencies": { 434 | "body-parser": { 435 | "version": "1.18.2", 436 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz", 437 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", 438 | "requires": { 439 | "bytes": "3.0.0", 440 | "content-type": "~1.0.4", 441 | "debug": "2.6.9", 442 | "depd": "~1.1.1", 443 | "http-errors": "~1.6.2", 444 | "iconv-lite": "0.4.19", 445 | "on-finished": "~2.3.0", 446 | "qs": "6.5.1", 447 | "raw-body": "2.3.2", 448 | "type-is": "~1.6.15" 449 | } 450 | }, 451 | "iconv-lite": { 452 | "version": "0.4.19", 453 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 454 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 455 | }, 456 | "raw-body": { 457 | "version": "2.3.2", 458 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz", 459 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", 460 | "requires": { 461 | "bytes": "3.0.0", 462 | "http-errors": "1.6.2", 463 | "iconv-lite": "0.4.19", 464 | "unpipe": "1.0.0" 465 | }, 466 | "dependencies": { 467 | "depd": { 468 | "version": "1.1.1", 469 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz", 470 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=" 471 | }, 472 | "http-errors": { 473 | "version": "1.6.2", 474 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz", 475 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", 476 | "requires": { 477 | "depd": "1.1.1", 478 | "inherits": "2.0.3", 479 | "setprototypeof": "1.0.3", 480 | "statuses": ">= 1.3.1 < 2" 481 | } 482 | }, 483 | "setprototypeof": { 484 | "version": "1.0.3", 485 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 486 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 487 | } 488 | } 489 | } 490 | } 491 | }, 492 | "extend": { 493 | "version": "3.0.2", 494 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 495 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 496 | }, 497 | "extsprintf": { 498 | "version": "1.3.0", 499 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 500 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 501 | }, 502 | "fast-deep-equal": { 503 | "version": "1.1.0", 504 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", 505 | "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=" 506 | }, 507 | "fast-json-stable-stringify": { 508 | "version": "2.0.0", 509 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 510 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 511 | }, 512 | "finalhandler": { 513 | "version": "1.1.1", 514 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 515 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 516 | "requires": { 517 | "debug": "2.6.9", 518 | "encodeurl": "~1.0.2", 519 | "escape-html": "~1.0.3", 520 | "on-finished": "~2.3.0", 521 | "parseurl": "~1.3.2", 522 | "statuses": "~1.4.0", 523 | "unpipe": "~1.0.0" 524 | } 525 | }, 526 | "forever-agent": { 527 | "version": "0.6.1", 528 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 529 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 530 | }, 531 | "form-data": { 532 | "version": "2.3.3", 533 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 534 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 535 | "requires": { 536 | "asynckit": "^0.4.0", 537 | "combined-stream": "^1.0.6", 538 | "mime-types": "^2.1.12" 539 | } 540 | }, 541 | "format-util": { 542 | "version": "1.0.3", 543 | "resolved": "https://registry.npmjs.org/format-util/-/format-util-1.0.3.tgz", 544 | "integrity": "sha1-Ay3KShFiYqEsQ/TD7IVmQWxbLZU=" 545 | }, 546 | "forwarded": { 547 | "version": "0.1.2", 548 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 549 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 550 | }, 551 | "fresh": { 552 | "version": "0.5.2", 553 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 554 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 555 | }, 556 | "fs": { 557 | "version": "0.0.1-security", 558 | "resolved": "https://registry.npmjs.org/fs/-/fs-0.0.1-security.tgz", 559 | "integrity": "sha1-invTcYa23d84E/I4WLV+yq9eQdQ=" 560 | }, 561 | "fs.realpath": { 562 | "version": "1.0.0", 563 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 564 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 565 | }, 566 | "fstream": { 567 | "version": "1.0.11", 568 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", 569 | "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", 570 | "requires": { 571 | "graceful-fs": "^4.1.2", 572 | "inherits": "~2.0.0", 573 | "mkdirp": ">=0.5 0", 574 | "rimraf": "2" 575 | } 576 | }, 577 | "gauge": { 578 | "version": "2.7.4", 579 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 580 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 581 | "requires": { 582 | "aproba": "^1.0.3", 583 | "console-control-strings": "^1.0.0", 584 | "has-unicode": "^2.0.0", 585 | "object-assign": "^4.1.0", 586 | "signal-exit": "^3.0.0", 587 | "string-width": "^1.0.1", 588 | "strip-ansi": "^3.0.1", 589 | "wide-align": "^1.1.0" 590 | } 591 | }, 592 | "getpass": { 593 | "version": "0.1.7", 594 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 595 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 596 | "requires": { 597 | "assert-plus": "^1.0.0" 598 | } 599 | }, 600 | "glob": { 601 | "version": "7.1.3", 602 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 603 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 604 | "requires": { 605 | "fs.realpath": "^1.0.0", 606 | "inflight": "^1.0.4", 607 | "inherits": "2", 608 | "minimatch": "^3.0.4", 609 | "once": "^1.3.0", 610 | "path-is-absolute": "^1.0.0" 611 | } 612 | }, 613 | "graceful-fs": { 614 | "version": "4.1.11", 615 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 616 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" 617 | }, 618 | "har-schema": { 619 | "version": "2.0.0", 620 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 621 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 622 | }, 623 | "har-validator": { 624 | "version": "5.1.0", 625 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.0.tgz", 626 | "integrity": "sha512-+qnmNjI4OfH2ipQ9VQOw23bBd/ibtfbVdK2fYbY4acTDqKTW/YDp9McimZdDbG8iV9fZizUqQMD5xvriB146TA==", 627 | "requires": { 628 | "ajv": "^5.3.0", 629 | "har-schema": "^2.0.0" 630 | } 631 | }, 632 | "has-unicode": { 633 | "version": "2.0.1", 634 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 635 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 636 | }, 637 | "http": { 638 | "version": "0.0.0", 639 | "resolved": "https://registry.npmjs.org/http/-/http-0.0.0.tgz", 640 | "integrity": "sha1-huYybSnF0Dnen6xYSkVon5KfT3I=" 641 | }, 642 | "http-errors": { 643 | "version": "1.6.3", 644 | "resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 645 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 646 | "requires": { 647 | "depd": "~1.1.2", 648 | "inherits": "2.0.3", 649 | "setprototypeof": "1.1.0", 650 | "statuses": ">= 1.4.0 < 2" 651 | } 652 | }, 653 | "http-signature": { 654 | "version": "1.2.0", 655 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 656 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 657 | "requires": { 658 | "assert-plus": "^1.0.0", 659 | "jsprim": "^1.2.2", 660 | "sshpk": "^1.7.0" 661 | } 662 | }, 663 | "iconv-lite": { 664 | "version": "0.4.23", 665 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 666 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 667 | "requires": { 668 | "safer-buffer": ">= 2.1.2 < 3" 669 | } 670 | }, 671 | "inflight": { 672 | "version": "1.0.6", 673 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 674 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 675 | "requires": { 676 | "once": "^1.3.0", 677 | "wrappy": "1" 678 | } 679 | }, 680 | "inherits": { 681 | "version": "2.0.3", 682 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 683 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 684 | }, 685 | "ipaddr.js": { 686 | "version": "1.8.0", 687 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz", 688 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4=" 689 | }, 690 | "is-fullwidth-code-point": { 691 | "version": "1.0.0", 692 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 693 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 694 | "requires": { 695 | "number-is-nan": "^1.0.0" 696 | } 697 | }, 698 | "is-typedarray": { 699 | "version": "1.0.0", 700 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 701 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 702 | }, 703 | "isexe": { 704 | "version": "2.0.0", 705 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 706 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 707 | }, 708 | "isstream": { 709 | "version": "0.1.2", 710 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 711 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 712 | }, 713 | "js-yaml": { 714 | "version": "3.12.0", 715 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 716 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 717 | "requires": { 718 | "argparse": "^1.0.7", 719 | "esprima": "^4.0.0" 720 | } 721 | }, 722 | "jsbn": { 723 | "version": "0.1.1", 724 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 725 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 726 | }, 727 | "json-schema": { 728 | "version": "0.2.3", 729 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 730 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 731 | }, 732 | "json-schema-ref-parser": { 733 | "version": "5.1.3", 734 | "resolved": "https://registry.npmjs.org/json-schema-ref-parser/-/json-schema-ref-parser-5.1.3.tgz", 735 | "integrity": "sha512-CpDFlBwz/6la78hZxyB9FECVKGYjIIl3Ms3KLqFj99W7IIb7D00/RDgc++IGB4BBALl0QRhh5m4q5WNSopvLtQ==", 736 | "requires": { 737 | "call-me-maybe": "^1.0.1", 738 | "debug": "^3.1.0", 739 | "js-yaml": "^3.12.0", 740 | "ono": "^4.0.6" 741 | }, 742 | "dependencies": { 743 | "debug": { 744 | "version": "3.2.5", 745 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.5.tgz", 746 | "integrity": "sha512-D61LaDQPQkxJ5AUM2mbSJRbPkNs/TmdmOeLAi1hgDkpDfIfetSrjmWhccwtuResSwMbACjx/xXQofvM9CE/aeg==", 747 | "requires": { 748 | "ms": "^2.1.1" 749 | } 750 | }, 751 | "ms": { 752 | "version": "2.1.1", 753 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 754 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 755 | } 756 | } 757 | }, 758 | "json-schema-traverse": { 759 | "version": "0.3.1", 760 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 761 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=" 762 | }, 763 | "json-stringify-safe": { 764 | "version": "5.0.1", 765 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 766 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 767 | }, 768 | "jsonschema": { 769 | "version": "1.2.4", 770 | "resolved": "https://registry.npmjs.org/jsonschema/-/jsonschema-1.2.4.tgz", 771 | "integrity": "sha512-lz1nOH69GbsVHeVgEdvyavc/33oymY1AZwtePMiMj4HZPMbP5OIKK3zT9INMWjwua/V4Z4yq7wSlBbSG+g4AEw==" 772 | }, 773 | "jsonschema-draft4": { 774 | "version": "1.0.0", 775 | "resolved": "https://registry.npmjs.org/jsonschema-draft4/-/jsonschema-draft4-1.0.0.tgz", 776 | "integrity": "sha1-8K8gBQVPDwrefqIRhhS2ncUS2GU=" 777 | }, 778 | "jsprim": { 779 | "version": "1.4.1", 780 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 781 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 782 | "requires": { 783 | "assert-plus": "1.0.0", 784 | "extsprintf": "1.3.0", 785 | "json-schema": "0.2.3", 786 | "verror": "1.10.0" 787 | } 788 | }, 789 | "keygrip": { 790 | "version": "1.0.3", 791 | "resolved": "https://registry.npmjs.org/keygrip/-/keygrip-1.0.3.tgz", 792 | "integrity": "sha512-/PpesirAIfaklxUzp4Yb7xBper9MwP6hNRA6BGGUFCgbJ+BM5CKBtsoxinNXkLHAr+GXS1/lSlF2rP7cv5Fl+g==" 793 | }, 794 | "lodash": { 795 | "version": "4.17.11", 796 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 797 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 798 | }, 799 | "lodash.get": { 800 | "version": "4.4.2", 801 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 802 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 803 | }, 804 | "lodash.isequal": { 805 | "version": "4.5.0", 806 | "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", 807 | "integrity": "sha1-QVxEePK8wwEgwizhDtMib30+GOA=" 808 | }, 809 | "media-typer": { 810 | "version": "0.3.0", 811 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 812 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 813 | }, 814 | "memory-pager": { 815 | "version": "1.1.0", 816 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.1.0.tgz", 817 | "integrity": "sha512-Mf9OHV/Y7h6YWDxTzX/b4ZZ4oh9NSXblQL8dtPCOomOtZciEHxePR78+uHFLLlsk01A6jVHhHsQZZ/WcIPpnzg==", 818 | "optional": true 819 | }, 820 | "merge-descriptors": { 821 | "version": "1.0.1", 822 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 823 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 824 | }, 825 | "methods": { 826 | "version": "1.1.2", 827 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 828 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 829 | }, 830 | "mime": { 831 | "version": "1.4.1", 832 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 833 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 834 | }, 835 | "mime-db": { 836 | "version": "1.36.0", 837 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.36.0.tgz", 838 | "integrity": "sha512-L+xvyD9MkoYMXb1jAmzI/lWYAxAMCPvIBSWur0PZ5nOf5euahRLVqH//FKW9mWp2lkqUgYiXPgkzfMUFi4zVDw==" 839 | }, 840 | "mime-types": { 841 | "version": "2.1.20", 842 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.20.tgz", 843 | "integrity": "sha512-HrkrPaP9vGuWbLK1B1FfgAkbqNjIuy4eHlIYnFi7kamZyLLrGlo2mpcx0bBmNpKqBtYtAfGbodDddIgddSJC2A==", 844 | "requires": { 845 | "mime-db": "~1.36.0" 846 | } 847 | }, 848 | "minimatch": { 849 | "version": "3.0.4", 850 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 851 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 852 | "requires": { 853 | "brace-expansion": "^1.1.7" 854 | } 855 | }, 856 | "minimist": { 857 | "version": "0.0.8", 858 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 859 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 860 | }, 861 | "mkdirp": { 862 | "version": "0.5.1", 863 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 864 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 865 | "requires": { 866 | "minimist": "0.0.8" 867 | } 868 | }, 869 | "moment": { 870 | "version": "2.22.2", 871 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.22.2.tgz", 872 | "integrity": "sha1-PCV/mDn8DpP/UxSWMiOeuQeD/2Y=" 873 | }, 874 | "mongodb": { 875 | "version": "3.1.6", 876 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.1.6.tgz", 877 | "integrity": "sha512-E5QJuXQoMlT7KyCYqNNMfAkhfQD79AT4F8Xd+6x37OX+8BL17GyXyWvfm6wuyx4wnzCCPoCSLeMeUN2S7dU9yw==", 878 | "requires": { 879 | "mongodb-core": "3.1.5", 880 | "safe-buffer": "^5.1.2" 881 | }, 882 | "dependencies": { 883 | "safe-buffer": { 884 | "version": "5.1.2", 885 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 886 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 887 | } 888 | } 889 | }, 890 | "mongodb-core": { 891 | "version": "3.1.5", 892 | "resolved": "https://registry.npmjs.org/mongodb-core/-/mongodb-core-3.1.5.tgz", 893 | "integrity": "sha512-emT/tM4ZBinqd6RZok+EzDdtN4LjYJIckv71qQVOEFmvXgT5cperZegVmTgox/1cx4XQu6LJ5ZuIwipP/eKdQg==", 894 | "requires": { 895 | "bson": "^1.1.0", 896 | "require_optional": "^1.0.1", 897 | "safe-buffer": "^5.1.2", 898 | "saslprep": "^1.0.0" 899 | }, 900 | "dependencies": { 901 | "safe-buffer": { 902 | "version": "5.1.2", 903 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 904 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 905 | } 906 | } 907 | }, 908 | "ms": { 909 | "version": "2.0.0", 910 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 911 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 912 | }, 913 | "negotiator": { 914 | "version": "0.6.1", 915 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 916 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 917 | }, 918 | "node-gyp": { 919 | "version": "3.8.0", 920 | "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-3.8.0.tgz", 921 | "integrity": "sha512-3g8lYefrRRzvGeSowdJKAKyks8oUpLEd/DyPV4eMhVlhJ0aNaZqIrNUIPuEWWTAoPqyFkfGrM67MC69baqn6vA==", 922 | "requires": { 923 | "fstream": "^1.0.0", 924 | "glob": "^7.0.3", 925 | "graceful-fs": "^4.1.2", 926 | "mkdirp": "^0.5.0", 927 | "nopt": "2 || 3", 928 | "npmlog": "0 || 1 || 2 || 3 || 4", 929 | "osenv": "0", 930 | "request": "^2.87.0", 931 | "rimraf": "2", 932 | "semver": "~5.3.0", 933 | "tar": "^2.0.0", 934 | "which": "1" 935 | }, 936 | "dependencies": { 937 | "semver": { 938 | "version": "5.3.0", 939 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 940 | "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=" 941 | } 942 | } 943 | }, 944 | "nopt": { 945 | "version": "3.0.6", 946 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 947 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 948 | "requires": { 949 | "abbrev": "1" 950 | } 951 | }, 952 | "npmlog": { 953 | "version": "4.1.2", 954 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 955 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 956 | "requires": { 957 | "are-we-there-yet": "~1.1.2", 958 | "console-control-strings": "~1.1.0", 959 | "gauge": "~2.7.3", 960 | "set-blocking": "~2.0.0" 961 | } 962 | }, 963 | "number-is-nan": { 964 | "version": "1.0.1", 965 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 966 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 967 | }, 968 | "oauth-sign": { 969 | "version": "0.9.0", 970 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 971 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" 972 | }, 973 | "object-assign": { 974 | "version": "4.1.1", 975 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 976 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 977 | }, 978 | "on-finished": { 979 | "version": "2.3.0", 980 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 981 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 982 | "requires": { 983 | "ee-first": "1.1.1" 984 | } 985 | }, 986 | "once": { 987 | "version": "1.4.0", 988 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 989 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 990 | "requires": { 991 | "wrappy": "1" 992 | } 993 | }, 994 | "ono": { 995 | "version": "4.0.9", 996 | "resolved": "https://registry.npmjs.org/ono/-/ono-4.0.9.tgz", 997 | "integrity": "sha512-HuSv0Z//JsX3246ykva50NDq2dw2UOaUKRK/CrD3UN96FQ3kr9msI5wR0lMezAIKgfN9+utK+iDfWzj1df3TZg==", 998 | "requires": { 999 | "format-util": "^1.0.3" 1000 | } 1001 | }, 1002 | "openapi-schema-validation": { 1003 | "version": "0.4.2", 1004 | "resolved": "https://registry.npmjs.org/openapi-schema-validation/-/openapi-schema-validation-0.4.2.tgz", 1005 | "integrity": "sha512-K8LqLpkUf2S04p2Nphq9L+3bGFh/kJypxIG2NVGKX0ffzT4NQI9HirhiY6Iurfej9lCu7y4Ndm4tv+lm86Ck7w==", 1006 | "requires": { 1007 | "jsonschema": "1.2.4", 1008 | "jsonschema-draft4": "^1.0.0", 1009 | "swagger-schema-official": "2.0.0-bab6bed" 1010 | } 1011 | }, 1012 | "os-homedir": { 1013 | "version": "1.0.2", 1014 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1015 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1016 | }, 1017 | "os-tmpdir": { 1018 | "version": "1.0.2", 1019 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1020 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1021 | }, 1022 | "os-utils": { 1023 | "version": "0.0.14", 1024 | "resolved": "https://registry.npmjs.org/os-utils/-/os-utils-0.0.14.tgz", 1025 | "integrity": "sha1-KeURaXsZgrjGJ3Ihdf45eX72QVY=" 1026 | }, 1027 | "osenv": { 1028 | "version": "0.1.5", 1029 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1030 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1031 | "requires": { 1032 | "os-homedir": "^1.0.0", 1033 | "os-tmpdir": "^1.0.0" 1034 | } 1035 | }, 1036 | "parseurl": { 1037 | "version": "1.3.2", 1038 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1039 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 1040 | }, 1041 | "path-is-absolute": { 1042 | "version": "1.0.1", 1043 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1044 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1045 | }, 1046 | "path-to-regexp": { 1047 | "version": "0.1.7", 1048 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1049 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1050 | }, 1051 | "performance-now": { 1052 | "version": "2.1.0", 1053 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1054 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 1055 | }, 1056 | "process-nextick-args": { 1057 | "version": "2.0.0", 1058 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1059 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==" 1060 | }, 1061 | "prom-client": { 1062 | "version": "11.2.0", 1063 | "resolved": "https://registry.npmjs.org/prom-client/-/prom-client-11.2.0.tgz", 1064 | "integrity": "sha512-4gUAq/GR5C8q5eWxOa7tA60AtmkMpbyBd/2btCayvd3h/7HzS0p/kESKRwggJgbFrfdhTCBpOwPAwKiI01Q0VQ==", 1065 | "requires": { 1066 | "tdigest": "^0.1.1" 1067 | } 1068 | }, 1069 | "proxy-addr": { 1070 | "version": "2.0.4", 1071 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz", 1072 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==", 1073 | "requires": { 1074 | "forwarded": "~0.1.2", 1075 | "ipaddr.js": "1.8.0" 1076 | } 1077 | }, 1078 | "psl": { 1079 | "version": "1.1.29", 1080 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", 1081 | "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==" 1082 | }, 1083 | "punycode": { 1084 | "version": "1.4.1", 1085 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1086 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" 1087 | }, 1088 | "qs": { 1089 | "version": "6.5.1", 1090 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 1091 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 1092 | }, 1093 | "range-parser": { 1094 | "version": "1.2.0", 1095 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1096 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 1097 | }, 1098 | "raw-body": { 1099 | "version": "2.3.3", 1100 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 1101 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 1102 | "requires": { 1103 | "bytes": "3.0.0", 1104 | "http-errors": "1.6.3", 1105 | "iconv-lite": "0.4.23", 1106 | "unpipe": "1.0.0" 1107 | } 1108 | }, 1109 | "request": { 1110 | "version": "2.88.0", 1111 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 1112 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 1113 | "requires": { 1114 | "aws-sign2": "~0.7.0", 1115 | "aws4": "^1.8.0", 1116 | "caseless": "~0.12.0", 1117 | "combined-stream": "~1.0.6", 1118 | "extend": "~3.0.2", 1119 | "forever-agent": "~0.6.1", 1120 | "form-data": "~2.3.2", 1121 | "har-validator": "~5.1.0", 1122 | "http-signature": "~1.2.0", 1123 | "is-typedarray": "~1.0.0", 1124 | "isstream": "~0.1.2", 1125 | "json-stringify-safe": "~5.0.1", 1126 | "mime-types": "~2.1.19", 1127 | "oauth-sign": "~0.9.0", 1128 | "performance-now": "^2.1.0", 1129 | "qs": "~6.5.2", 1130 | "safe-buffer": "^5.1.2", 1131 | "tough-cookie": "~2.4.3", 1132 | "tunnel-agent": "^0.6.0", 1133 | "uuid": "^3.3.2" 1134 | }, 1135 | "dependencies": { 1136 | "qs": { 1137 | "version": "6.5.2", 1138 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1139 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 1140 | }, 1141 | "safe-buffer": { 1142 | "version": "5.1.2", 1143 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1144 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1145 | }, 1146 | "uuid": { 1147 | "version": "3.3.2", 1148 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1149 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 1150 | } 1151 | } 1152 | }, 1153 | "require_optional": { 1154 | "version": "1.0.1", 1155 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1156 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1157 | "requires": { 1158 | "resolve-from": "^2.0.0", 1159 | "semver": "^5.1.0" 1160 | } 1161 | }, 1162 | "resolve-from": { 1163 | "version": "2.0.0", 1164 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1165 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 1166 | }, 1167 | "rimraf": { 1168 | "version": "2.6.2", 1169 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1170 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1171 | "requires": { 1172 | "glob": "^7.0.5" 1173 | } 1174 | }, 1175 | "safe-buffer": { 1176 | "version": "5.1.1", 1177 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1178 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 1179 | }, 1180 | "safer-buffer": { 1181 | "version": "2.1.2", 1182 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1183 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1184 | }, 1185 | "saslprep": { 1186 | "version": "1.0.2", 1187 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.2.tgz", 1188 | "integrity": "sha512-4cDsYuAjXssUSjxHKRe4DTZC0agDwsCqcMqtJAQPzC74nJ7LfAJflAtC1Zed5hMzEQKj82d3tuzqdGNRsLJ4Gw==", 1189 | "optional": true, 1190 | "requires": { 1191 | "sparse-bitfield": "^3.0.3" 1192 | } 1193 | }, 1194 | "semver": { 1195 | "version": "5.5.1", 1196 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.1.tgz", 1197 | "integrity": "sha512-PqpAxfrEhlSUWge8dwIp4tZnQ25DIOthpiaHNIthsjEFQD6EvqUKUDM7L8O2rShkFccYo1VjJR0coWfNkCubRw==" 1198 | }, 1199 | "send": { 1200 | "version": "0.16.2", 1201 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 1202 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 1203 | "requires": { 1204 | "debug": "2.6.9", 1205 | "depd": "~1.1.2", 1206 | "destroy": "~1.0.4", 1207 | "encodeurl": "~1.0.2", 1208 | "escape-html": "~1.0.3", 1209 | "etag": "~1.8.1", 1210 | "fresh": "0.5.2", 1211 | "http-errors": "~1.6.2", 1212 | "mime": "1.4.1", 1213 | "ms": "2.0.0", 1214 | "on-finished": "~2.3.0", 1215 | "range-parser": "~1.2.0", 1216 | "statuses": "~1.4.0" 1217 | } 1218 | }, 1219 | "serve-static": { 1220 | "version": "1.13.2", 1221 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 1222 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 1223 | "requires": { 1224 | "encodeurl": "~1.0.2", 1225 | "escape-html": "~1.0.3", 1226 | "parseurl": "~1.3.2", 1227 | "send": "0.16.2" 1228 | } 1229 | }, 1230 | "set-blocking": { 1231 | "version": "2.0.0", 1232 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1233 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1234 | }, 1235 | "setprototypeof": { 1236 | "version": "1.1.0", 1237 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 1238 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 1239 | }, 1240 | "signal-exit": { 1241 | "version": "3.0.2", 1242 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1243 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 1244 | }, 1245 | "sparse-bitfield": { 1246 | "version": "3.0.3", 1247 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1248 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 1249 | "optional": true, 1250 | "requires": { 1251 | "memory-pager": "^1.0.2" 1252 | } 1253 | }, 1254 | "sprintf-js": { 1255 | "version": "1.0.3", 1256 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1257 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 1258 | }, 1259 | "sshpk": { 1260 | "version": "1.15.2", 1261 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.15.2.tgz", 1262 | "integrity": "sha512-Ra/OXQtuh0/enyl4ETZAfTaeksa6BXks5ZcjpSUNrjBr0DvrJKX+1fsKDPpT9TBXgHAFsa4510aNVgI8g/+SzA==", 1263 | "requires": { 1264 | "asn1": "~0.2.3", 1265 | "assert-plus": "^1.0.0", 1266 | "bcrypt-pbkdf": "^1.0.0", 1267 | "dashdash": "^1.12.0", 1268 | "ecc-jsbn": "~0.1.1", 1269 | "getpass": "^0.1.1", 1270 | "jsbn": "~0.1.0", 1271 | "safer-buffer": "^2.0.2", 1272 | "tweetnacl": "~0.14.0" 1273 | } 1274 | }, 1275 | "statuses": { 1276 | "version": "1.4.0", 1277 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 1278 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 1279 | }, 1280 | "string-width": { 1281 | "version": "1.0.2", 1282 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1283 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1284 | "requires": { 1285 | "code-point-at": "^1.0.0", 1286 | "is-fullwidth-code-point": "^1.0.0", 1287 | "strip-ansi": "^3.0.0" 1288 | } 1289 | }, 1290 | "strip-ansi": { 1291 | "version": "3.0.1", 1292 | "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1293 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1294 | "requires": { 1295 | "ansi-regex": "^2.0.0" 1296 | } 1297 | }, 1298 | "swagger-jsdoc": { 1299 | "version": "3.2.3", 1300 | "resolved": "https://registry.npmjs.org/swagger-jsdoc/-/swagger-jsdoc-3.2.3.tgz", 1301 | "integrity": "sha512-vwOLoZOFnS7XUkDz1QG7Bt4GcJDo1jx0WGhBlJegPyPqCLaQi3WuadCX5bAyfx20ycCGceY5PD2o7q1NY8+ICg==", 1302 | "requires": { 1303 | "commander": "2.17.1", 1304 | "doctrine": "2.1.0", 1305 | "glob": "7.1.3", 1306 | "js-yaml": "3.12.0", 1307 | "swagger-parser": "5.0.5" 1308 | } 1309 | }, 1310 | "swagger-methods": { 1311 | "version": "1.0.4", 1312 | "resolved": "https://registry.npmjs.org/swagger-methods/-/swagger-methods-1.0.4.tgz", 1313 | "integrity": "sha512-xrKFLbrZ6VxRsg+M3uJozJtsEpNI/aPfZsOkoEjXw8vhAqdMIqwTYGj1f4dmUgvJvCdZhV5iArgtqXgs403ltg==" 1314 | }, 1315 | "swagger-parser": { 1316 | "version": "5.0.5", 1317 | "resolved": "https://registry.npmjs.org/swagger-parser/-/swagger-parser-5.0.5.tgz", 1318 | "integrity": "sha512-6UiaUT9nH5nEzvxDvwZpTfhCs2VOwxrP9neZ83QpsTA3mMGHdun4x8vSXiqjaGQzLh2LG8ND5TRhmVNG1hRUqA==", 1319 | "requires": { 1320 | "call-me-maybe": "^1.0.1", 1321 | "debug": "^3.1.0", 1322 | "json-schema-ref-parser": "^5.1.3", 1323 | "ono": "^4.0.6", 1324 | "openapi-schema-validation": "^0.4.2", 1325 | "swagger-methods": "^1.0.4", 1326 | "swagger-schema-official": "2.0.0-bab6bed", 1327 | "z-schema": "^3.23.0" 1328 | }, 1329 | "dependencies": { 1330 | "debug": { 1331 | "version": "3.2.5", 1332 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.5.tgz", 1333 | "integrity": "sha512-D61LaDQPQkxJ5AUM2mbSJRbPkNs/TmdmOeLAi1hgDkpDfIfetSrjmWhccwtuResSwMbACjx/xXQofvM9CE/aeg==", 1334 | "requires": { 1335 | "ms": "^2.1.1" 1336 | } 1337 | }, 1338 | "ms": { 1339 | "version": "2.1.1", 1340 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1341 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1342 | } 1343 | } 1344 | }, 1345 | "swagger-schema-official": { 1346 | "version": "2.0.0-bab6bed", 1347 | "resolved": "https://registry.npmjs.org/swagger-schema-official/-/swagger-schema-official-2.0.0-bab6bed.tgz", 1348 | "integrity": "sha1-cAcEaNbSl3ylI3suUZyn0Gouo/0=" 1349 | }, 1350 | "swagger-stats-lions": { 1351 | "version": "0.0.4", 1352 | "resolved": "https://registry.npmjs.org/swagger-stats-lions/-/swagger-stats-lions-0.0.4.tgz", 1353 | "integrity": "sha512-HknL8eQG2Sq3JBJk/lKWIuYjjb7hW1QcZk5zKlaB9xwzUB+MV9jAUH9Jsj9e3UZMlxjsp4ZHesumGlJspCg3yA==", 1354 | "requires": { 1355 | "basic-auth": "^2.0.0", 1356 | "cookies": "^0.7.1", 1357 | "cpu-stat": "^2.0.1", 1358 | "debug": "^3.1.0", 1359 | "fs": "0.0.1-security", 1360 | "moment": "^2.19.3", 1361 | "os-utils": "0.0.14", 1362 | "path-to-regexp": "^2.1.0", 1363 | "prom-client": "^11.0.0", 1364 | "request": "^2.85.0", 1365 | "uuid": "^3.1.0" 1366 | }, 1367 | "dependencies": { 1368 | "debug": { 1369 | "version": "3.2.6", 1370 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1371 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1372 | "requires": { 1373 | "ms": "^2.1.1" 1374 | } 1375 | }, 1376 | "ms": { 1377 | "version": "2.1.1", 1378 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1379 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1380 | }, 1381 | "path-to-regexp": { 1382 | "version": "2.4.0", 1383 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-2.4.0.tgz", 1384 | "integrity": "sha512-G6zHoVqC6GGTQkZwF4lkuEyMbVOjoBKAEybQUypI1WTkqinCOrq2x6U2+phkJ1XsEMTy4LjtwPI7HW+NVrRR2w==" 1385 | }, 1386 | "uuid": { 1387 | "version": "3.3.2", 1388 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1389 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 1390 | } 1391 | } 1392 | }, 1393 | "tar": { 1394 | "version": "2.2.1", 1395 | "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", 1396 | "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", 1397 | "requires": { 1398 | "block-stream": "*", 1399 | "fstream": "^1.0.2", 1400 | "inherits": "2" 1401 | } 1402 | }, 1403 | "tdigest": { 1404 | "version": "0.1.1", 1405 | "resolved": "https://registry.npmjs.org/tdigest/-/tdigest-0.1.1.tgz", 1406 | "integrity": "sha1-Ljyyw56kSeVdHmzZEReszKRYgCE=", 1407 | "requires": { 1408 | "bintrees": "1.0.1" 1409 | } 1410 | }, 1411 | "tough-cookie": { 1412 | "version": "2.4.3", 1413 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 1414 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 1415 | "requires": { 1416 | "psl": "^1.1.24", 1417 | "punycode": "^1.4.1" 1418 | } 1419 | }, 1420 | "tunnel-agent": { 1421 | "version": "0.6.0", 1422 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1423 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1424 | "requires": { 1425 | "safe-buffer": "^5.0.1" 1426 | } 1427 | }, 1428 | "tweetnacl": { 1429 | "version": "0.14.5", 1430 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1431 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 1432 | }, 1433 | "type-is": { 1434 | "version": "1.6.16", 1435 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz", 1436 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", 1437 | "requires": { 1438 | "media-typer": "0.3.0", 1439 | "mime-types": "~2.1.18" 1440 | } 1441 | }, 1442 | "unpipe": { 1443 | "version": "1.0.0", 1444 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1445 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1446 | }, 1447 | "util-deprecate": { 1448 | "version": "1.0.2", 1449 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1450 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1451 | }, 1452 | "utils-merge": { 1453 | "version": "1.0.1", 1454 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1455 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1456 | }, 1457 | "validator": { 1458 | "version": "10.8.0", 1459 | "resolved": "https://registry.npmjs.org/validator/-/validator-10.8.0.tgz", 1460 | "integrity": "sha512-mXqMxfCh5NLsVgYVKl9WvnHNDPCcbNppHSPPowu0VjtSsGWVY+z8hJF44edLR1nbLNzi3jYoYsIl8KZpioIk6g==" 1461 | }, 1462 | "vary": { 1463 | "version": "1.1.2", 1464 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1465 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1466 | }, 1467 | "verror": { 1468 | "version": "1.10.0", 1469 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1470 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1471 | "requires": { 1472 | "assert-plus": "^1.0.0", 1473 | "core-util-is": "1.0.2", 1474 | "extsprintf": "^1.2.0" 1475 | } 1476 | }, 1477 | "which": { 1478 | "version": "1.3.1", 1479 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1480 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1481 | "requires": { 1482 | "isexe": "^2.0.0" 1483 | } 1484 | }, 1485 | "wide-align": { 1486 | "version": "1.1.3", 1487 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1488 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1489 | "requires": { 1490 | "string-width": "^1.0.2 || 2" 1491 | } 1492 | }, 1493 | "wrappy": { 1494 | "version": "1.0.2", 1495 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1496 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1497 | }, 1498 | "z-schema": { 1499 | "version": "3.24.1", 1500 | "resolved": "https://registry.npmjs.org/z-schema/-/z-schema-3.24.1.tgz", 1501 | "integrity": "sha512-2eR8eq/v1coNqyBc5HzswEcoLbw+S33RMnR326uiuOIr97ve5vwPNMDrKS1IRCB12bZ3a8BrfGxrRwuSXUyPvw==", 1502 | "requires": { 1503 | "commander": "^2.7.1", 1504 | "core-js": "^2.5.7", 1505 | "lodash.get": "^4.0.0", 1506 | "lodash.isequal": "^4.0.0", 1507 | "validator": "^10.0.0" 1508 | } 1509 | } 1510 | } 1511 | } 1512 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "EOS-history-mongo-api", 3 | "version": "0.0.1", 4 | "description": "API to get actions using EOS mongo plugin (similar to history plugin)", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "CryptoLions.io", 10 | "license": "ISC", 11 | "dependencies": { 12 | "async": "^2.6.1", 13 | "body-parser": "^1.18.3", 14 | "cors": "^2.8.5", 15 | "eosio-mongodb-queries": "^0.9.0", 16 | "express": "^4.16.3", 17 | "http": "0.0.0", 18 | "mongodb": "^3.1.6", 19 | "node-gyp": "^3.8.0", 20 | "request": "^2.88.0", 21 | "swagger-jsdoc": "^3.2.3", 22 | "swagger-stats-lions": "^0.0.4" 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /start.sh: -------------------------------------------------------------------------------- 1 | # /* ############################################################################### 2 | # 3 | # EOS Mongo History API 4 | # API to get actions using EOS mongo plugin (similar to history plugin) 5 | # 6 | # Git Hub: https://github.com/CryptoLions/EOS-mongo-history-API 7 | # 8 | # Created by http://CryptoLions.io 9 | # 10 | ############################################################################### */ 11 | 12 | 13 | #!/bin/bash 14 | DATADIR="./" 15 | 16 | ./stop.sh 17 | node index.js > $DATADIR/mongo-out.log 2> $DATADIR/mongo-err.log & echo $! > $DATADIR/mongo.pid 18 | -------------------------------------------------------------------------------- /stop.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | ################################################################################ 3 | # 4 | # Scrip Created by http://CryptoLions.io 5 | # 6 | ############################################################################### 7 | 8 | DIR="./" 9 | 10 | 11 | if [ -f $DIR"/mongo.pid" ]; then 12 | pid=`cat $DIR"/mongo.pid"` 13 | echo $pid 14 | kill $pid 15 | rm -r $DIR"/mongo.pid" 16 | 17 | echo -ne "Stoping Daemon" 18 | 19 | while true; do 20 | [ ! -d "/proc/$pid/fd" ] && break 21 | echo -ne "." 22 | sleep 1 23 | done 24 | echo -ne "\rDaemon Stopped. \n" 25 | fi 26 | --------------------------------------------------------------------------------