import { getConnection, AdvancedConsoleLogger } from "typeorm"; import { Global } from "../global"; import { async } from '@angular/core/testing'; const { promisify } = require('util'); const exec = promisify(require('child_process').exec) function convertMinsToHrmin (millseconds,insec) { var seconds = Math.floor(millseconds / 1000); if(insec){ let sec = Math.floor(millseconds / 1000); return sec; } var days = Math.floor(seconds / 86400); var hours = Math.floor((seconds % 86400) / 3600); var minutes = Math.floor(((seconds % 86400) % 3600) / 60); seconds = seconds % 60; var dateTimeDurationString = ''; if (days > 0 && (hours === 0 && minutes === 0)) dateTimeDurationString += days > 1 ? days + 'd ' : days + 'd '; if (days > 0 && (hours > 0 || minutes > 0)) dateTimeDurationString += days > 1 ? days + 'd ' : days + 'd '; if (hours > 0 && minutes > 0) dateTimeDurationString += hours > 1 ? hours + 'h ' : hours + 'h '; if (hours > 0 && minutes === 0) dateTimeDurationString += hours > 1 ? hours + 'h ' : hours + 'h '; if (minutes > 0) dateTimeDurationString += minutes > 1 ? minutes + 'm ' : minutes + 'm '; if (seconds > 0) dateTimeDurationString += seconds > 1 ? seconds + 's ' : seconds + 's '; return dateTimeDurationString; } function dateDiff(date2, insec = false) { var current_date = new Date(); // var current_date = new Date("Sat Apr 2 2018 15:04:00 GMT+0530 (IST)"); var enddaydif = Math.abs(date2.getTime() - current_date.getTime()) / (1000 * 60 * 60 * 24); var enddayrnd = Math.round(enddaydif); // if(enddayrnd < 1) { var time = convertMinsToHrmin( Math.abs(date2.getTime() - current_date.getTime()),insec ); return time; // } else if(enddayrnd == 1) { // return 'Ends in ' + enddayrnd + ' day'; // }else { // return 'Ends in ' + enddayrnd + ' days'; // } } /** * Function returns total coins based on height */ const getTotalRewardByHeight= async(height) => { var coin_existence; let DAY_HEIGHT = 1440 /// Height of the first epic block emission era const BLOCK_ERA_1 = DAY_HEIGHT * 334; /// Height of the second epic block emission era const BLOCK_ERA_2 = BLOCK_ERA_1 + (DAY_HEIGHT * 470); /// Height of the third epic block emission era const BLOCK_ERA_3 = BLOCK_ERA_2 + (DAY_HEIGHT * 601); /// Height of the fourth epic block emission era const BLOCK_ERA_4 = BLOCK_ERA_3 + (DAY_HEIGHT * 800); /// Height of the fifth epic block emission era const BLOCK_ERA_5 = BLOCK_ERA_4 + (DAY_HEIGHT * 1019); /// After the epic block emission era 6, each era will last 4 years (approximately 1460 days) const BLOCK_ERA_6_ONWARDS = DAY_HEIGHT * 1460; /// Block Reward that will be assigned after we change from era 5 to era 6. const BASE_REWARD_ERA_6_ONWARDS = 0.15625; let remaining_height = 0; let currentReward = 16; /// Compute the total reward generated by each block in a given height. if (height <= BLOCK_ERA_1) { coin_existence = height * 16; currentReward = 16; } else if (height <= BLOCK_ERA_2) { remaining_height = height - BLOCK_ERA_1; coin_existence = (16 * BLOCK_ERA_1) + 8 * remaining_height; currentReward = 8; } else if (height <= BLOCK_ERA_3) { remaining_height = height - BLOCK_ERA_2; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + 4 * remaining_height; currentReward = 4; } else if (height <= BLOCK_ERA_4) { remaining_height = height - BLOCK_ERA_3; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + 2 * remaining_height; currentReward = 2; } else if (height <= BLOCK_ERA_5) { remaining_height = height - BLOCK_ERA_4; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + (2 * BLOCK_ERA_4) +1 * remaining_height; currentReward = 1; } else { // After the era 6, we reduce the block rewards by half each 1460 days. // Minus 1 to include multiples in the same index // (i.e changes greater than to greater or equals to) let preious_circulation = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + (2 * BLOCK_ERA_4) + (1 * BLOCK_ERA_5); let height_with_offset = height - (BLOCK_ERA_5 - 1); let exp = height_with_offset / BLOCK_ERA_6_ONWARDS; let reward_emission = BASE_REWARD_ERA_6_ONWARDS / (1 << exp); coin_existence = preious_circulation + reward_emission ; currentReward = reward_emission; } return coin_existence; } // function returns foundation reward const circulationsupply = async(height) => { let first_duration = 1440 * 120; let year_height = 365 * 1440; let foundationpercentage = [8.8,7.7,6.6,5.5,4.4,3.3,2.2,1.1] let circulatingsuppy = 0 if(height < first_duration) { let coin = await getTotalRewardByHeight(height) circulatingsuppy = (coin / 100) * foundationpercentage[0] } else if(height < (first_duration + year_height) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] circulatingsuppy = firstyearcoin + secondyearcoin } else if(height < (first_duration + (2 * year_height)) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(first_duration + year_height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] let thirdyear = await getTotalRewardByHeight(height) let thirdyearcoin = ( (thirdyear -secondyear) / 100) * foundationpercentage[2] circulatingsuppy = firstyearcoin + secondyearcoin + thirdyearcoin } else if(height < (first_duration + (3 * year_height)) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(first_duration + year_height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] let thirdyear = await getTotalRewardByHeight(first_duration + (2 * year_height)) let thirdyearcoin = ( (thirdyear -secondyear) / 100) * foundationpercentage[2] let forthyear = await getTotalRewardByHeight(height) let forthyearcoin = ( (forthyear -thirdyear) / 100) * foundationpercentage[3] circulatingsuppy = firstyearcoin + secondyearcoin + thirdyearcoin + forthyearcoin } else if(height < (first_duration + (4 * year_height)) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(first_duration + year_height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] let thirdyear = await getTotalRewardByHeight(first_duration + (2 * year_height)) let thirdyearcoin = ( (thirdyear -secondyear) / 100) * foundationpercentage[2] let forthyear = await getTotalRewardByHeight(first_duration + (3 * year_height)) let forthyearcoin = ( (forthyear -thirdyear) / 100) * foundationpercentage[3] let fifthyear = await getTotalRewardByHeight(height) let fifthyearcoin = ( (fifthyear - forthyear) / 100) * foundationpercentage[4] circulatingsuppy = firstyearcoin + secondyearcoin + thirdyearcoin + forthyearcoin+fifthyearcoin } else if(height < (first_duration + (5 * year_height)) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(first_duration + year_height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] let thirdyear = await getTotalRewardByHeight(first_duration + (2 * year_height)) let thirdyearcoin = ( (thirdyear -secondyear) / 100) * foundationpercentage[2] let forthyear = await getTotalRewardByHeight(first_duration + (3 * year_height)) let forthyearcoin = ( (forthyear -thirdyear) / 100) * foundationpercentage[3] let fifthyear = await getTotalRewardByHeight(first_duration + (4 * year_height)) let fifthyearcoin = ( (fifthyear - forthyear) / 100) * foundationpercentage[4] let sixthyear = await getTotalRewardByHeight(height) let sixthyearcoin = ( (sixthyear - fifthyear) / 100) * foundationpercentage[5] circulatingsuppy = firstyearcoin + secondyearcoin + thirdyearcoin + forthyearcoin+fifthyearcoin+sixthyearcoin } else if(height < (first_duration + (6 * year_height)) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(first_duration + year_height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] let thirdyear = await getTotalRewardByHeight(first_duration + (2 * year_height)) let thirdyearcoin = ( (thirdyear -secondyear) / 100) * foundationpercentage[2] let forthyear = await getTotalRewardByHeight(first_duration + (3 * year_height)) let forthyearcoin = ( (forthyear -thirdyear) / 100) * foundationpercentage[3] let fifthyear = await getTotalRewardByHeight(first_duration + (4 * year_height)) let fifthyearcoin = ( (fifthyear - forthyear) / 100) * foundationpercentage[4] let sixthyear = await getTotalRewardByHeight(first_duration + (5 * year_height)) let sixthyearcoin = ( (sixthyear - fifthyear) / 100) * foundationpercentage[5] let seventhyear = await getTotalRewardByHeight(height) let seventhyearcoin = ( (seventhyear - sixthyear) / 100) * foundationpercentage[6] circulatingsuppy = firstyearcoin + secondyearcoin + thirdyearcoin + forthyearcoin+fifthyearcoin+sixthyearcoin+seventhyearcoin } else if(height < (first_duration + (7 * year_height)) ) { let firstyear = await getTotalRewardByHeight(first_duration) let firstyearcoin = (firstyear / 100) * foundationpercentage[0] let secondyear = await getTotalRewardByHeight(first_duration + year_height) let secondyearcoin = ( (secondyear -firstyear) / 100) * foundationpercentage[1] let thirdyear = await getTotalRewardByHeight(first_duration + (2 * year_height)) let thirdyearcoin = ( (thirdyear -secondyear) / 100) * foundationpercentage[2] let forthyear = await getTotalRewardByHeight(first_duration + (3 * year_height)) let forthyearcoin = ( (forthyear -thirdyear) / 100) * foundationpercentage[3] let fifthyear = await getTotalRewardByHeight(first_duration + (4 * year_height)) let fifthyearcoin = ( (fifthyear - forthyear) / 100) * foundationpercentage[4] let sixthyear = await getTotalRewardByHeight(first_duration + (5 * year_height)) let sixthyearcoin = ( (sixthyear - fifthyear) / 100) * foundationpercentage[5] let seventhyear = await getTotalRewardByHeight(first_duration + (6 * year_height)) let seventhyearcoin = ( (seventhyear - sixthyear) / 100) * foundationpercentage[6] let eigthyear = await getTotalRewardByHeight(height) let eigthyearcoin = ( (eigthyear - seventhyear) / 100) * foundationpercentage[7] circulatingsuppy = firstyearcoin + secondyearcoin + thirdyearcoin + forthyearcoin+fifthyearcoin+sixthyearcoin+seventhyearcoin + eigthyearcoin } return circulatingsuppy } // Last Block home page function const latestBlockDetails = async()=> { let block_height = '', letest_block, letest_block_num = '', letest_block_duration = ''; const BlockchainLatestBlockQuery = await getConnection(Global.network) .query( 'SELECT timestamp,height,edge_bits,hash,secondary_scaling, previous_id, total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block ORDER BY timestamp DESC LIMIT 1', ) .catch(err_msg => { return(err_msg); }); const BlockchainPreviousBlockQuery = await getConnection(Global.network) .query( 'SELECT total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block WHERE hash=' + "'" + BlockchainLatestBlockQuery[0].previous_id + "'", ).catch(err_msg => { return(err_msg); }); /* // const space = await exec('du -sh /root/.epic/main/chain_data/ --exclude=*.zip'); const space = "1.7G /var/www/html/" // let disk_space = space.stdout.split('\t')[0]; const disk_space = "1.7" // const space_new = await exec('du -sk /root/.epic/main/chain_data/ --exclude=*.zip'); const space_new = "1.7G /var/www/html/" //let disk_space_kb = space_new.stdout.split('\t')[0]; // let disk_space_kb = (space_new.stdout.split('\t')[0] / 1000000).toFixed(2)+"G"; let disk_space_kb = "1.7G" */ const space = await exec('du -sh /root/.epic/main/chain_data/ --exclude=*.zip'); let disk_space = space.stdout.split('\t')[0]; const space_new = await exec('du -sk /root/.epic/main/chain_data/ --exclude=*.zip'); //let disk_space_kb = space_new.stdout.split('\t')[0]; let disk_space_kb = (space_new.stdout.split('\t')[0] / 1000000).toFixed(2)+"G"; let height = BlockchainLatestBlockQuery[0].height; var coin_existence; let DAY_HEIGHT = 1440 /// Height of the first epic block emission era const BLOCK_ERA_1 = DAY_HEIGHT * 334; /// Height of the second epic block emission era const BLOCK_ERA_2 = BLOCK_ERA_1 + (DAY_HEIGHT * 470); /// Height of the third epic block emission era const BLOCK_ERA_3 = BLOCK_ERA_2 + (DAY_HEIGHT * 601); /// Height of the fourth epic block emission era const BLOCK_ERA_4 = BLOCK_ERA_3 + (DAY_HEIGHT * 800); /// Height of the fifth epic block emission era const BLOCK_ERA_5 = BLOCK_ERA_4 + (DAY_HEIGHT * 1019); /// After the epic block emission era 6, each era will last 4 years (approximately 1460 days) const BLOCK_ERA_6_ONWARDS = DAY_HEIGHT * 1460; /// Block Reward that will be assigned after we change from era 5 to era 6. const BASE_REWARD_ERA_6_ONWARDS = 0.15625; let remaining_height = 0; let currentReward = 16; /// Compute the total reward generated by each block in a given height. if (height <= BLOCK_ERA_1) { coin_existence = height * 16; currentReward = 16; } else if (height <= BLOCK_ERA_2) { remaining_height = height - BLOCK_ERA_1; coin_existence = (16 * BLOCK_ERA_1) + 8 * remaining_height; currentReward = 8; } else if (height <= BLOCK_ERA_3) { remaining_height = height - BLOCK_ERA_2; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + 4 * remaining_height; currentReward = 4; } else if (height <= BLOCK_ERA_4) { remaining_height = height - BLOCK_ERA_3; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + 2 * remaining_height; currentReward = 2; } else if (height <= BLOCK_ERA_5) { remaining_height = height - BLOCK_ERA_4; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + (2 * BLOCK_ERA_4) +1 * remaining_height; currentReward = 1; } else { // After the era 6, we reduce the block rewards by half each 1460 days. // Minus 1 to include multiples in the same index // (i.e changes greater than to greater or equals to) let preious_circulation = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + (2 * BLOCK_ERA_4) + (1 * BLOCK_ERA_5); let height_with_offset = height - (BLOCK_ERA_5 - 1); let exp = height_with_offset / BLOCK_ERA_6_ONWARDS; let reward_emission = BASE_REWARD_ERA_6_ONWARDS / (1 << exp); coin_existence = preious_circulation + reward_emission ; currentReward = reward_emission; } letest_block = dateDiff(BlockchainLatestBlockQuery[0].timestamp,true); letest_block_num = letest_block; // "72" letest_block_duration = letest_block == 1 ? 'second ago' : 'seconds ago'; const SECOND_POW_EDGE_BITS = 29; const BASE_EDGE_BITS = 24; if (BlockchainLatestBlockQuery[0].edge_bits == SECOND_POW_EDGE_BITS) { var hashvalue = BlockchainLatestBlockQuery[0].hash; var diff = (BlockchainLatestBlockQuery[0].secondary_scaling * 2 ** 64) / parseInt(hashvalue.substring(0, 16), 16); var result = Math.min(diff, 0xffffffffffffffff); var difficulty = Math.round(result); } else { var graph_weight = 2 * 2 ** (BlockchainLatestBlockQuery[0].edge_bits - BASE_EDGE_BITS) * BlockchainLatestBlockQuery[0].edge_bits; var hashvalue = BlockchainLatestBlockQuery[0].hash; var diff = (graph_weight * 2 ** 64) / parseInt(hashvalue.substring(0, 16), 16); var result = Math.min(diff, 0xffffffffffffffff); var difficulty = Math.round(result); } if (BlockchainLatestBlockQuery[0].previous_id) { var targetdifficultycuckaroo = BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo - BlockchainPreviousBlockQuery[0].total_difficulty_cuckaroo; var targetdifficultycuckatoo = BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo - BlockchainPreviousBlockQuery[0].total_difficulty_cuckatoo; var targetdifficultyprogpow = BlockchainLatestBlockQuery[0].total_difficulty_progpow - BlockchainPreviousBlockQuery[0].total_difficulty_progpow; var targetdifficultyrandomx = BlockchainLatestBlockQuery[0].total_difficulty_randomx - BlockchainPreviousBlockQuery[0].total_difficulty_randomx; } block_height = BlockchainLatestBlockQuery[0].height; var TotalCuckoo=parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo) + parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo); let FOUNDATION_LEVY_ERA_1 = DAY_HEIGHT * 120; /// After the first foundation levy era, we decrease the foundation levy each year let FOUNDATION_LEVY_ERA_2_ONWARDS = DAY_HEIGHT * 365; /// The foundation levy in each era let FOUNDATION_LEVY = [ 0.0888, 0.0777, 0.0666, 0.0555, 0.0444, 0.0333, 0.0222, 0.0111, 0.0111, ]; /// Compute the foundation levy for each block. let foundationReward = 16 * FOUNDATION_LEVY[0]; let userReward = 16 - (FOUNDATION_LEVY[0]); if (height <= 0) { foundationReward =0; userReward = 0; } else if (height <= FOUNDATION_LEVY_ERA_1) { foundationReward = currentReward * FOUNDATION_LEVY[0]; userReward = currentReward -foundationReward; } else { // We subtract 1 to include the last block of an era. let height_with_offset = height - FOUNDATION_LEVY_ERA_1 - 1; // We used the index 0 in the first era, therefore we offset the index by 1 let index = (height_with_offset / FOUNDATION_LEVY_ERA_2_ONWARDS) + 1; if (index < FOUNDATION_LEVY.length ) { foundationReward = currentReward * FOUNDATION_LEVY[index]; userReward = currentReward -foundationReward; } else { foundationReward = 0; userReward = 0; } } let cuckoohashrate = await network_hashrate(block_height,31,targetdifficultycuckatoo+targetdifficultycuckaroo,"Cuckoo"); let progpowhashrate = await network_hashrate(block_height,16,targetdifficultyprogpow,"ProgPow"); let randomxhashrate = await network_hashrate(block_height,16,targetdifficultyrandomx,"RandomX"); cuckoohashrate = Math.round(cuckoohashrate) progpowhashrate = Math.round(progpowhashrate) randomxhashrate = Math.round(randomxhashrate) let totalFoundationReward = await circulationsupply(height) return { block_height, letest_block, letest_block_num, letest_block_duration, coin_existence, difficulty, targetdifficultycuckaroo, targetdifficultycuckatoo, targetdifficultyprogpow, targetdifficultyrandomx, TotalCuckoo, TotalDifficultyCuckaroo:BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo, TotalDifficultyCuckatoo:BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo, TotalDifficultyProgpow:BlockchainLatestBlockQuery[0].total_difficulty_progpow, TotalDifficultyRandomx:BlockchainLatestBlockQuery[0].total_difficulty_randomx, currentReward, foundationReward, userReward, cuckoohashrate, progpowhashrate, randomxhashrate, totalFoundationReward, diskSpace:disk_space_kb, diskSpaceKb : disk_space_kb }; } // Previous Block home page function const previousBlockDetails = async() => { let block_height = '', letest_block, letest_block_num = '', letest_block_duration = ''; const CurrentBlock = await getConnection(Global.network) .query( 'SELECT timestamp,height,edge_bits,hash,secondary_scaling, previous_id, total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block ORDER BY timestamp DESC LIMIT 1', ).catch(err_msg => { return(err_msg); }); const BlockchainLatestBlockQuery = await getConnection(Global.network) .query( 'SELECT timestamp,height,edge_bits,hash,secondary_scaling, previous_id, total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block WHERE hash=' + "'" + CurrentBlock[0].previous_id + "'", ) .catch(err_msg => { return(err_msg); }); const BlockchainPreviousBlockQuery = await getConnection(Global.network) .query( 'SELECT total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block WHERE hash=' + "'" + BlockchainLatestBlockQuery[0].previous_id + "'", ).catch(err_msg => { return(err_msg); }); /* // const space = await exec('du -sh /root/.epic/main/chain_data/ --exclude=*.zip'); const space = "1.7G /var/www/html/" // let disk_space = space.stdout.split('\t')[0]; const disk_space = "1.7" // const space_new = await exec('du -sk /root/.epic/main/chain_data/ --exclude=*.zip'); const space_new = "1.7G /var/www/html/" //let disk_space_kb = space_new.stdout.split('\t')[0]; // let disk_space_kb = (space_new.stdout.split('\t')[0] / 1000000).toFixed(2)+"G"; let disk_space_kb = "1.7G" */ const space = await exec('du -sh /root/.epic/main/chain_data/ --exclude=*.zip'); let disk_space = space.stdout.split('\t')[0]; const space_new = await exec('du -sk /root/.epic/main/chain_data/ --exclude=*.zip'); //let disk_space_kb = space_new.stdout.split('\t')[0]; let disk_space_kb = (space_new.stdout.split('\t')[0] / 1000000).toFixed(2)+"G"; let height = BlockchainLatestBlockQuery[0].height; var coin_existence; let DAY_HEIGHT = 1440 /// Height of the first epic block emission era const BLOCK_ERA_1 = DAY_HEIGHT * 334; /// Height of the second epic block emission era const BLOCK_ERA_2 = BLOCK_ERA_1 + (DAY_HEIGHT * 470); /// Height of the third epic block emission era const BLOCK_ERA_3 = BLOCK_ERA_2 + (DAY_HEIGHT * 601); /// Height of the fourth epic block emission era const BLOCK_ERA_4 = BLOCK_ERA_3 + (DAY_HEIGHT * 800); /// Height of the fifth epic block emission era const BLOCK_ERA_5 = BLOCK_ERA_4 + (DAY_HEIGHT * 1019); /// After the epic block emission era 6, each era will last 4 years (approximately 1460 days) const BLOCK_ERA_6_ONWARDS = DAY_HEIGHT * 1460; /// Block Reward that will be assigned after we change from era 5 to era 6. const BASE_REWARD_ERA_6_ONWARDS = 0.15625; let remaining_height = 0; let currentReward = 16; /// Compute the total reward generated by each block in a given height. if (height <= BLOCK_ERA_1) { coin_existence = height * 16; currentReward = 16; } else if (height <= BLOCK_ERA_2) { remaining_height = height - BLOCK_ERA_1; coin_existence = (16 * BLOCK_ERA_1) + 8 * remaining_height; currentReward = 8; } else if (height <= BLOCK_ERA_3) { remaining_height = height - BLOCK_ERA_2; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + 4 * remaining_height; currentReward = 4; } else if (height <= BLOCK_ERA_4) { remaining_height = height - BLOCK_ERA_3; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + 2 * remaining_height; currentReward = 2; } else if (height <= BLOCK_ERA_5) { remaining_height = height - BLOCK_ERA_4; coin_existence = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + (2 * BLOCK_ERA_4) +1 * remaining_height; currentReward = 1; } else { // After the era 6, we reduce the block rewards by half each 1460 days. // Minus 1 to include multiples in the same index // (i.e changes greater than to greater or equals to) let preious_circulation = (16 * BLOCK_ERA_1) + (8 * BLOCK_ERA_2) + (4 * BLOCK_ERA_3) + (2 * BLOCK_ERA_4) + (1 * BLOCK_ERA_5); let height_with_offset = height - (BLOCK_ERA_5 - 1); let exp = height_with_offset / BLOCK_ERA_6_ONWARDS; let reward_emission = BASE_REWARD_ERA_6_ONWARDS / (1 << exp); coin_existence = preious_circulation + reward_emission ; currentReward = reward_emission; } letest_block = dateDiff(BlockchainLatestBlockQuery[0].timestamp,true); letest_block_num = letest_block; // "72" letest_block_duration = letest_block == 1 ? 'second ago' : 'seconds ago'; const SECOND_POW_EDGE_BITS = 29; const BASE_EDGE_BITS = 24; if (BlockchainLatestBlockQuery[0].edge_bits == SECOND_POW_EDGE_BITS) { var hashvalue = BlockchainLatestBlockQuery[0].hash; var diff = (BlockchainLatestBlockQuery[0].secondary_scaling * 2 ** 64) / parseInt(hashvalue.substring(0, 16), 16); var result = Math.min(diff, 0xffffffffffffffff); var difficulty = Math.round(result); } else { var graph_weight = 2 * 2 ** (BlockchainLatestBlockQuery[0].edge_bits - BASE_EDGE_BITS) * BlockchainLatestBlockQuery[0].edge_bits; var hashvalue = BlockchainLatestBlockQuery[0].hash; var diff = (graph_weight * 2 ** 64) / parseInt(hashvalue.substring(0, 16), 16); var result = Math.min(diff, 0xffffffffffffffff); var difficulty = Math.round(result); } if (BlockchainLatestBlockQuery[0].previous_id) { var targetdifficultycuckaroo = BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo - BlockchainPreviousBlockQuery[0].total_difficulty_cuckaroo; var targetdifficultycuckatoo = BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo - BlockchainPreviousBlockQuery[0].total_difficulty_cuckatoo; var targetdifficultyprogpow = BlockchainLatestBlockQuery[0].total_difficulty_progpow - BlockchainPreviousBlockQuery[0].total_difficulty_progpow; var targetdifficultyrandomx = BlockchainLatestBlockQuery[0].total_difficulty_randomx - BlockchainPreviousBlockQuery[0].total_difficulty_randomx; } block_height = BlockchainLatestBlockQuery[0].height; var TotalCuckoo=parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo) + parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo); let FOUNDATION_LEVY_ERA_1 = DAY_HEIGHT * 120; /// After the first foundation levy era, we decrease the foundation levy each year let FOUNDATION_LEVY_ERA_2_ONWARDS = DAY_HEIGHT * 365; /// The foundation levy in each era let FOUNDATION_LEVY = [ 0.0888, 0.0777, 0.0666, 0.0555, 0.0444, 0.0333, 0.0222, 0.0111, 0.0111, ]; /// Compute the foundation levy for each block. let foundationReward = 16 * FOUNDATION_LEVY[0]; let userReward = 16 - (FOUNDATION_LEVY[0]); if (height <= 0) { foundationReward =0; userReward = 0; } else if (height <= FOUNDATION_LEVY_ERA_1) { foundationReward = currentReward * FOUNDATION_LEVY[0]; userReward = currentReward -foundationReward; } else { // We subtract 1 to include the last block of an era. let height_with_offset = height - FOUNDATION_LEVY_ERA_1 - 1; // We used the index 0 in the first era, therefore we offset the index by 1 let index = (height_with_offset / FOUNDATION_LEVY_ERA_2_ONWARDS) + 1; if (index < FOUNDATION_LEVY.length ) { foundationReward = currentReward * FOUNDATION_LEVY[index]; userReward = currentReward -foundationReward; } else { foundationReward = 0; userReward = 0; } } let cuckoohashrate = await network_hashrate(block_height,31,targetdifficultycuckatoo+targetdifficultycuckaroo,"Cuckoo"); let progpowhashrate = await network_hashrate(block_height,16,targetdifficultyprogpow,"ProgPow"); let randomxhashrate = await network_hashrate(block_height,16,targetdifficultyrandomx,"RandomX"); cuckoohashrate = Math.round(cuckoohashrate) progpowhashrate = Math.round(progpowhashrate) randomxhashrate = Math.round(randomxhashrate) let totalFoundationReward = await circulationsupply(height) return { block_height, letest_block, letest_block_num, letest_block_duration, coin_existence, difficulty, targetdifficultycuckaroo, targetdifficultycuckatoo, targetdifficultyprogpow, targetdifficultyrandomx, TotalCuckoo, TotalDifficultyCuckaroo:BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo, TotalDifficultyCuckatoo:BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo, TotalDifficultyProgpow:BlockchainLatestBlockQuery[0].total_difficulty_progpow, TotalDifficultyRandomx:BlockchainLatestBlockQuery[0].total_difficulty_randomx, currentReward, foundationReward, userReward, cuckoohashrate, progpowhashrate, randomxhashrate, totalFoundationReward, diskSpace:disk_space_kb, diskSpaceKb : disk_space_kb }; } async function Details (height) { if(height){ const BlockchainLatestBlockQuery2 = await getConnection(Global.network) .query( "Select hash, height from blockchain_block Where height =" +height.replace(/[a-z]/gi, '')+" OR hash ='"+height+"'", ) .catch(err_msg => { return(err_msg); }); return BlockchainLatestBlockQuery2; } } async function GetBlocktime(height){ if(height){ // const BlockchainLatestBlockQuery3 = await getConnection(Global.network) // .query( // "SELECT coalesce(max(bb.alter), 0) as alter FROM (SELECT EXTRACT(EPOCH FROM (timestamp - LAG(timestamp) OVER (ORDER BY timestamp))) AS alter FROM blockchain_block where height="+height+" OR height="+(height-1)+") as bb", // ) // .catch(err_msg => { // return(err_msg); // }); const BlockchainLatestBlockQuery3 = await getConnection(Global.network) .query( "SELECT extract(epoch from timestamp at time zone '" +process.env.TIME_ZONE+ "') AS alter FROM blockchain_block where height="+height, ) .catch(err_msg => { return(err_msg); }); return BlockchainLatestBlockQuery3; } } const averageblockdifficulty = async() => { const BlockchainBlockPerSecondQuery = await getConnection(Global.network) .query( "select count(hash) as mhash, 86400/count(hash) as period \ from blockchain_block \ where height != 0 AND timestamp at time zone '" +process.env.TIME_ZONE+ "' > NOW() - INTERVAL '24 HOURS' " ) .catch(err_msg => { return(err_msg); }); return BlockchainBlockPerSecondQuery[0]['period']; } async function testavgBlockTime(height,proof) { // let query1 = "SELECT coalesce(avg(bb.alter), 0) as alter FROM (SELECT EXTRACT(EPOCH FROM (timestamp - LAG(timestamp) OVER (ORDER BY timestamp))) AS alter FROM blockchain_block where height > "+(height - 1440)+" AND height < "+height+" ) as bb" let query1 = "SELECT coalesce(avg(bb.alter), 0) as alter FROM (SELECT EXTRACT(EPOCH FROM (timestamp - LAG(timestamp) OVER (ORDER BY timestamp))) AS alter FROM blockchain_block where height > "+(height - 1440)+" AND height < "+height+" and proof = '"+proof+"' ) as bb" const blockaveragetime = await getConnection(Global.network) .query( query1, ) .catch(err_msg => { return(err_msg); }); return blockaveragetime[0]['alter'] } async function avgBlockTime(height,proof) { let query1 = "SELECT coalesce(avg(bb.alter), 0) as alter FROM (SELECT EXTRACT(EPOCH FROM (timestamp - LAG(timestamp) OVER (ORDER BY timestamp))) AS alter FROM blockchain_block where height > "+(height - 1440)+" AND height < "+height+" ) as bb" let query2 = "SELECT coalesce(avg(bb.alter), 0) as alter FROM (SELECT EXTRACT(EPOCH FROM (timestamp - LAG(timestamp) OVER (ORDER BY timestamp))) AS alter FROM blockchain_block where height > "+(height - 1440)+" AND height < "+height+" and proof = '"+proof+"' ) as bb" const blockaveragetime = await getConnection(Global.network) .query( query1, ) .catch(err_msg => { return(err_msg); }); return blockaveragetime[0]['alter'] } async function network_hashrate(height, edge_bits, difficulty,proof) { let graph_wight = await avgBlockTime(height,proof) return (difficulty / graph_wight); } async function network_hashrate_old(height, edge_bits, difficulty) { let graph_wight = await graph_weight(height, edge_bits) return (42.0 * (difficulty / graph_wight) / 60.0); } async function graph_weight(height, edge_bits) { let xpr_edge_bits = edge_bits; let min_edge_bits = 19; if(min_edge_bits == 19) { min_edge_bits += 12; } let bits_over_min =Math.max(0, (edge_bits - min_edge_bits)); let expiry_height = (1 << bits_over_min) * 524160; if(height >= expiry_height) { xpr_edge_bits = Math.max(0,(xpr_edge_bits-(1 + (height - expiry_height) / 10080))); } let final_val; if(edge_bits > 24) { final_val = edge_bits - 24; } else { final_val = 24 - edge_bits; } return (2 << final_val) * xpr_edge_bits; } export {network_hashrate}; export {averageblockdifficulty}; export {latestBlockDetails}; export {previousBlockDetails}; export {GetBlocktime}; export {Details};