2022-02-19 22:09:35 +09:00
|
|
|
import { Common } from '../api/common';
|
2022-02-19 20:45:02 +09:00
|
|
|
import { DB } from '../database';
|
|
|
|
import logger from '../logger';
|
|
|
|
|
|
|
|
class HashratesRepository {
|
|
|
|
/**
|
|
|
|
* Save indexed block data in the database
|
|
|
|
*/
|
2022-02-21 17:34:07 +09:00
|
|
|
public async $saveHashrates(hashrates: any) {
|
|
|
|
let query = `INSERT INTO
|
|
|
|
hashrates(hashrate_timestamp, avg_hashrate, pool_id) VALUES`;
|
2022-02-19 20:45:02 +09:00
|
|
|
|
2022-02-21 17:34:07 +09:00
|
|
|
for (const hashrate of hashrates) {
|
|
|
|
query += ` (FROM_UNIXTIME(${hashrate.hashrateTimestamp}), ${hashrate.avgHashrate}, ${hashrate.poolId}),`;
|
|
|
|
}
|
|
|
|
query = query.slice(0, -1);
|
2022-02-19 20:45:02 +09:00
|
|
|
|
2022-02-21 17:34:07 +09:00
|
|
|
const connection = await DB.pool.getConnection();
|
|
|
|
try {
|
2022-02-19 20:45:02 +09:00
|
|
|
// logger.debug(query);
|
2022-02-21 17:34:07 +09:00
|
|
|
await connection.query(query);
|
2022-02-19 20:45:02 +09:00
|
|
|
} catch (e: any) {
|
|
|
|
logger.err('$saveHashrateInDatabase() error' + (e instanceof Error ? e.message : e));
|
|
|
|
}
|
|
|
|
|
|
|
|
connection.release();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an array of all timestamp we've already indexed
|
|
|
|
*/
|
2022-02-19 22:09:35 +09:00
|
|
|
public async $get(interval: string | null): Promise<any[]> {
|
|
|
|
interval = Common.getSqlInterval(interval);
|
|
|
|
|
2022-02-19 20:45:02 +09:00
|
|
|
const connection = await DB.pool.getConnection();
|
2022-02-19 22:09:35 +09:00
|
|
|
|
|
|
|
let query = `SELECT UNIX_TIMESTAMP(hashrate_timestamp) as timestamp, avg_hashrate as avgHashrate
|
|
|
|
FROM hashrates`;
|
|
|
|
|
|
|
|
if (interval) {
|
|
|
|
query += ` WHERE hashrate_timestamp BETWEEN DATE_SUB(NOW(), INTERVAL ${interval}) AND NOW()`;
|
|
|
|
}
|
|
|
|
|
2022-02-22 00:17:41 +09:00
|
|
|
query += ` ORDER by hashrate_timestamp`;
|
2022-02-21 12:22:20 +09:00
|
|
|
|
2022-02-19 22:09:35 +09:00
|
|
|
const [rows]: any[] = await connection.query(query);
|
2022-02-19 20:45:02 +09:00
|
|
|
connection.release();
|
2022-02-19 22:09:35 +09:00
|
|
|
|
|
|
|
return rows;
|
2022-02-19 20:45:02 +09:00
|
|
|
}
|
2022-02-21 12:22:20 +09:00
|
|
|
|
|
|
|
public async $setLatestRunTimestamp() {
|
|
|
|
const connection = await DB.pool.getConnection();
|
|
|
|
const query = `UPDATE state SET number = ? WHERE name = 'last_hashrates_indexing'`;
|
|
|
|
await connection.query<any>(query, [Math.round(new Date().getTime() / 1000)]);
|
|
|
|
connection.release();
|
|
|
|
}
|
|
|
|
|
|
|
|
public async $getLatestRunTimestamp(): Promise<number> {
|
|
|
|
const connection = await DB.pool.getConnection();
|
|
|
|
const query = `SELECT number FROM state WHERE name = 'last_hashrates_indexing'`;
|
|
|
|
const [rows] = await connection.query<any>(query);
|
|
|
|
connection.release();
|
|
|
|
return rows[0]['number'];
|
|
|
|
}
|
2022-02-19 20:45:02 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
export default new HashratesRepository();
|