├── .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 |
--------------------------------------------------------------------------------