Fix GENX masternode payments (#39)
It looks like some copy+paste didn't get updated causing the same variable to be re-used. This should fix genx blocks post mn activation height.
This commit is contained in:
parent
97c65b0a41
commit
217250995c
|
@ -149,117 +149,64 @@ exports.createGeneration = (rpcData, blockReward, feeReward, recipients, poolAdd
|
|||
)
|
||||
} else if (coin.payAllFounders === true) {
|
||||
// SafeCash / Genx
|
||||
if (!rpcData.masternode_payments_started)
|
||||
// Calculate and do the pool fee deduction
|
||||
var poolFeeDeductionTotalPercent = 0;
|
||||
// Calculate the total pool fee deduction
|
||||
recipients.forEach(function (recipient) {
|
||||
poolFeeDeductionTotalPercent += recipient.percent;
|
||||
});
|
||||
|
||||
var poolDeductionAmount = Math.round(blockReward.total * (poolFeeDeductionTotalPercent / 100));
|
||||
|
||||
txb.addOutput(
|
||||
scriptCompile(poolAddrHash),
|
||||
blockReward.miner - poolDeductionAmount + feeReward
|
||||
);
|
||||
|
||||
// Infrastructure
|
||||
if (rpcData.infrastructure && rpcData.infrastructure > 0)
|
||||
{
|
||||
// Pre masternodes
|
||||
// SafeCash Addresses
|
||||
// Founders
|
||||
// Chris
|
||||
let chrisAddrHash = bitcoin.address.fromBase58Check(coin.foundersRewardAddresses[0]).hash
|
||||
// Jimmy
|
||||
let jimmyAddrHash = bitcoin.address.fromBase58Check(coin.foundersRewardAddresses[1]).hash
|
||||
// Scott
|
||||
let scottAddrHash = bitcoin.address.fromBase58Check(coin.foundersRewardAddresses[2]).hash
|
||||
// Shelby
|
||||
let shelbyAddrHash = bitcoin.address.fromBase58Check(coin.foundersRewardAddresses[3]).hash
|
||||
// Loki
|
||||
let lokiAddrHash = bitcoin.address.fromBase58Check(coin.foundersRewardAddresses[4]).hash
|
||||
// Infrastructure
|
||||
let infrastructureAddrHash = bitcoin.address.fromBase58Check(coin.infrastructureAddresses[0]).hash
|
||||
// Giveaways
|
||||
let giveawaysAddrHash = bitcoin.address.fromBase58Check(coin.giveawayAddresses[0]).hash
|
||||
// Add Pool (miner coinbase) transaction
|
||||
//console.log(`PoolReward: ${blockReward.miner}`)
|
||||
|
||||
// Calculate and do the pool fee deduction
|
||||
var poolFeeDeductionTotalPercent = 0;
|
||||
// Calculate the total pool fee deduction
|
||||
recipients.forEach(function (recipient) {
|
||||
poolFeeDeductionTotalPercent += recipient.percent;
|
||||
});
|
||||
var poolDeductionAmount = Math.round(blockReward.total * (poolFeeDeductionTotalPercent / 100));
|
||||
console.log('Block Value: ' + blockReward.total);
|
||||
console.log('Pool Fee Deduction Total Percent: ' + poolFeeDeductionTotalPercent);
|
||||
console.log('Pool Fee Deduction Total Amount: ' + poolDeductionAmount);
|
||||
|
||||
txb.addOutput(
|
||||
scriptCompile(poolAddrHash),
|
||||
blockReward.miner - poolDeductionAmount + feeReward
|
||||
);
|
||||
|
||||
// Add founders txs
|
||||
txb.addOutput(scriptFoundersCompile(chrisAddrHash), blockReward.founderSplit);
|
||||
txb.addOutput(scriptFoundersCompile(jimmyAddrHash), blockReward.founderSplit);
|
||||
txb.addOutput(scriptFoundersCompile(scottAddrHash), blockReward.founderSplit);
|
||||
txb.addOutput(scriptFoundersCompile(shelbyAddrHash), blockReward.founderSplit);
|
||||
txb.addOutput(scriptFoundersCompile(lokiAddrHash), blockReward.founderSplit);
|
||||
// Infrastructure
|
||||
txb.addOutput(scriptFoundersCompile(infrastructureAddrHash), blockReward.infrastructure);
|
||||
// Giveaways
|
||||
}
|
||||
// Giveaways
|
||||
if (rpcData.giveaways && rpcData.giveaways > 0)
|
||||
{
|
||||
let giveawaysAddrHash = bitcoin.address.fromBase58Check(coin.giveawayAddresses[0]).hash
|
||||
txb.addOutput(scriptFoundersCompile(giveawaysAddrHash), blockReward.giveaways);
|
||||
}
|
||||
else
|
||||
// Add founders
|
||||
if (rpcData.founders && rpcData.founders.length > 0)
|
||||
{
|
||||
// Masternodes active
|
||||
// Calculate and do the pool fee deduction
|
||||
var poolFeeDeductionTotalPercent = 0;
|
||||
// Calculate the total pool fee deduction
|
||||
recipients.forEach(function (recipient) {
|
||||
poolFeeDeductionTotalPercent += recipient.percent;
|
||||
});
|
||||
|
||||
var poolDeductionAmount = Math.round(blockReward.total * (poolFeeDeductionTotalPercent / 100));
|
||||
|
||||
txb.addOutput(
|
||||
scriptCompile(poolAddrHash),
|
||||
blockReward.miner - poolDeductionAmount + feeReward
|
||||
// loop through founders and add them to our coinbase transaction
|
||||
rpcData.founders.map((founderItem) => {
|
||||
txb.addOutput(
|
||||
new Buffer(founderItem.script, 'hex'),
|
||||
founderItem.amount
|
||||
);
|
||||
|
||||
// Infrastructure
|
||||
if (rpcData.infrastructure && rpcData.infrastructure > 0)
|
||||
{
|
||||
let infrastructureAddrHash = bitcoin.address.fromBase58Check(coin.infrastructureAddresses[0]).hash
|
||||
txb.addOutput(scriptFoundersCompile(infrastructureAddrHash), blockReward.infrastructure);
|
||||
}
|
||||
// Giveaways
|
||||
if (rpcData.giveaways && rpcData.giveaways > 0)
|
||||
{
|
||||
let giveawaysAddrHash = bitcoin.address.fromBase58Check(coin.giveawayAddresses[0]).hash
|
||||
txb.addOutput(scriptFoundersCompile(giveawaysAddrHash), blockReward.giveaways);
|
||||
}
|
||||
// Add founders
|
||||
if (rpcData.founders && rpcData.founders.length > 0)
|
||||
{
|
||||
// loop through founders and add them to our coinbase transaction
|
||||
rpcData.founders.map((founderItem) => {
|
||||
txb.addOutput(
|
||||
new Buffer(founderItem.script, 'hex'),
|
||||
founderItem.amount
|
||||
);
|
||||
});
|
||||
}
|
||||
// Add masternode payments
|
||||
if (rpcData.masternodes && rpcData.masternodes.length > 0)
|
||||
{
|
||||
// loop through masternodes and add them to our coinbase transaction
|
||||
rpcData.founders.map((masternodeItem) => {
|
||||
txb.addOutput(
|
||||
new Buffer(masternodeItem.script, 'hex'),
|
||||
masternodeItem.amount
|
||||
);
|
||||
});
|
||||
}
|
||||
// Add governance payments
|
||||
if (rpcData.governanceblock && rpcData.governanceblock.length > 0)
|
||||
{
|
||||
// loop through governance items and add them to our coinbase transaction
|
||||
rpcData.founders.map((governanceItem) => {
|
||||
txb.addOutput(
|
||||
new Buffer(governanceItem.script, 'hex'),
|
||||
governanceItem.amount
|
||||
);
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
// Add masternode payments
|
||||
if (rpcData.masternodes && rpcData.masternodes.length > 0)
|
||||
{
|
||||
// loop through masternodes and add them to our coinbase transaction
|
||||
rpcData.masternodes.map((masternodeItem) => {
|
||||
txb.addOutput(
|
||||
new Buffer(masternodeItem.script, 'hex'),
|
||||
masternodeItem.amount
|
||||
);
|
||||
});
|
||||
}
|
||||
// Add governance payments
|
||||
if (rpcData.governanceblock && rpcData.governanceblock.length > 0)
|
||||
{
|
||||
// loop through governance items and add them to our coinbase transaction
|
||||
rpcData.governanceblock.map((governanceItem) => {
|
||||
txb.addOutput(
|
||||
new Buffer(governanceItem.script, 'hex'),
|
||||
governanceItem.amount
|
||||
);
|
||||
});
|
||||
}
|
||||
} else {
|
||||
// founders reward
|
||||
|
|
Loading…
Reference in New Issue