Blocks DB API up
This commit is contained in:
parent
1777be323c
commit
d278dbdb7c
@ -1,7 +1,10 @@
|
||||
const Block = require('../../models/block.js');
|
||||
const logger = require('../logger');
|
||||
const Block = require('../../models/block.js');
|
||||
const logger = require('../logger');
|
||||
const request = require('request');
|
||||
const config = require('../../config');
|
||||
const config = require('../../config');
|
||||
const db = require('../db');
|
||||
|
||||
console.log(db);
|
||||
|
||||
const MAX_BLOCKS = 200;
|
||||
|
||||
|
||||
57
server/lib/db/blocks.js
Normal file
57
server/lib/db/blocks.js
Normal file
@ -0,0 +1,57 @@
|
||||
const Block = require('../../models/block.js');
|
||||
const logger = require('../logger');
|
||||
const config = require('../../config');
|
||||
|
||||
// move to config
|
||||
const MAX_BLOCKS = 200;
|
||||
const blockTemplate = new Block();
|
||||
|
||||
function getBlocks(params, options, limit, cb) {
|
||||
const defaultOptions = { _id: 0 };
|
||||
|
||||
Object.assign(defaultOptions, options);
|
||||
|
||||
if (!Number.isInteger(limit)) {
|
||||
limit = MAX_BLOCKS;
|
||||
}
|
||||
|
||||
if (limit > MAX_BLOCKS) {
|
||||
limit = MAX_BLOCKS;
|
||||
}
|
||||
|
||||
Block.find(
|
||||
params,
|
||||
defaultOptions,
|
||||
(err, blocks) => {
|
||||
if (err) {
|
||||
logger.log('error',
|
||||
`getBlocks: ${err}`);
|
||||
return cb(err);
|
||||
}
|
||||
if (blocks.length > 0) {
|
||||
return cb(null, blocks);
|
||||
}
|
||||
return cb(null, [blockTemplate]);
|
||||
})
|
||||
.sort({ height: -1 })
|
||||
.limit(limit);
|
||||
}
|
||||
|
||||
function getBlock(params, options, limit, cb) {
|
||||
getBlocks(params, options, limit, (err, blocks) => {
|
||||
if (err) {
|
||||
logger.log('error',
|
||||
`getBlock: ${err}`);
|
||||
return cb(err);
|
||||
}
|
||||
if (blocks.length > 0) {
|
||||
return cb(null, blocks[0]);
|
||||
}
|
||||
return cb(null, blockTemplate);
|
||||
});
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
getBlock,
|
||||
getBlocks,
|
||||
};
|
||||
@ -1,5 +1,6 @@
|
||||
const mongoose = require('mongoose');
|
||||
const logger = require('../logger');
|
||||
const Blocks = require('./blocks');
|
||||
|
||||
mongoose.connection.on('error', (err) => {
|
||||
logger.log('error',
|
||||
@ -7,4 +8,8 @@ mongoose.connection.on('error', (err) => {
|
||||
${err}`);
|
||||
});
|
||||
|
||||
module.exports = mongoose;
|
||||
module.exports = {
|
||||
connect: mongoose.connect,
|
||||
connection: mongoose.connection,
|
||||
Blocks,
|
||||
};
|
||||
|
||||
Loading…
Reference in New Issue
Block a user