2020-02-16 16:15:07 +01:00
|
|
|
import projectedBlocks from './mempool-blocks';
|
2019-07-21 16:59:47 +02:00
|
|
|
import { DB } from '../database';
|
|
|
|
|
|
|
|
class FeeApi {
|
|
|
|
constructor() { }
|
|
|
|
|
|
|
|
public getRecommendedFee() {
|
2020-02-16 16:15:07 +01:00
|
|
|
const pBlocks = projectedBlocks.getMempoolBlocks();
|
2019-07-21 16:59:47 +02:00
|
|
|
if (!pBlocks.length) {
|
|
|
|
return {
|
|
|
|
'fastestFee': 0,
|
|
|
|
'halfHourFee': 0,
|
|
|
|
'hourFee': 0,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
let firstMedianFee = Math.ceil(pBlocks[0].medianFee);
|
|
|
|
|
2020-02-16 16:15:07 +01:00
|
|
|
if (pBlocks.length === 1 && pBlocks[0].blockVSize <= 500000) {
|
2019-07-21 16:59:47 +02:00
|
|
|
firstMedianFee = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
const secondMedianFee = pBlocks[1] ? Math.ceil(pBlocks[1].medianFee) : firstMedianFee;
|
|
|
|
const thirdMedianFee = pBlocks[2] ? Math.ceil(pBlocks[2].medianFee) : secondMedianFee;
|
|
|
|
|
|
|
|
return {
|
|
|
|
'fastestFee': firstMedianFee,
|
|
|
|
'halfHourFee': secondMedianFee,
|
|
|
|
'hourFee': thirdMedianFee,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
public async $getTransactionsForBlock(blockHeight: number): Promise<any[]> {
|
|
|
|
try {
|
|
|
|
const connection = await DB.pool.getConnection();
|
|
|
|
const query = `SELECT feePerVsize AS fpv FROM transactions WHERE blockheight = ? ORDER BY feePerVsize ASC`;
|
|
|
|
const [rows] = await connection.query<any>(query, [blockHeight]);
|
|
|
|
connection.release();
|
|
|
|
return rows;
|
|
|
|
} catch (e) {
|
|
|
|
console.log('$getTransactionsForBlock() error', e);
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export default new FeeApi();
|