Compare commits

...

4 Commits

Author SHA1 Message Date
MoneroOcean 8c944e469c Adds kcn dev reward to bt 2024-05-31 18:17:08 +03:00
MoneroOcean dae35d962a Added KCN coin support 2024-05-28 00:24:26 +03:00
MoneroOcean 89fc132363 Updated for Ubuntu 24.04 2024-05-05 18:57:31 +03:00
MoneroOcean af3cc3e902 Removed unused field 2024-05-05 18:53:34 +03:00
2 changed files with 24 additions and 8 deletions
+2 -2
View File
@@ -1,7 +1,6 @@
{
"name": "cryptoforknote-util",
"version": "15.2.1",
"main": "cryptoforknote-util",
"version": "15.3.3",
"author": {
"name": "LucasJones",
"email": "lucasjonesdev@hotmail.co.uk"
@@ -17,6 +16,7 @@
"bignum": "^0.13.1",
"sha3": "*",
"base58-native": "*",
"bech32": "*",
"varuint-bitcoin": "^1.0.4",
"merkle-lib": "^2.0.10",
"bitcoinjs-lib": "git+https://github.com/MoneroOcean/bitcoinjs-lib.git"
+22 -6
View File
@@ -1,5 +1,6 @@
const bignum = require('bignum');
const base58 = require('base58-native');
const bech32 = require('bech32');
const bitcoin = require('bitcoinjs-lib');
const diff1 = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF;
@@ -149,8 +150,11 @@ function getTransactionBuffers(txs) {
function addressToScript(addr) {
const decoded = base58.decode(addr);
if (decoded.length != 25) throw new Error('Invalid address length for ' + addr);
if (!decoded) throw new Error('Base58 decode failed for ' + addr);
if (!decoded || decoded.length != 25) {
const decoded2 = Buffer.from(bech32.bech32.fromWords(bech32.bech32.decode(addr).words.slice(1)));
if (decoded2.length != 20) throw new Error('Invalid address ' + addr);
return Buffer.concat([Buffer.from([0x0, 0x14]), decoded2]);
}
const pubkey = decoded.slice(1, -4);
return Buffer.concat([Buffer.from([0x76, 0xa9, 0x14]), pubkey, Buffer.from([0x88, 0xac])]);
}
@@ -171,6 +175,12 @@ function generateOutputTransactions(rpcData, poolAddress) {
let rewardToPool = reward;
let txOutputBuffers = [];
if (rpcData.coinbasedevreward) {
const rewards = createOutputTransaction(rpcData.coinbasedevreward.value, rpcData.coinbasedevreward.address, rewardToPool, reward, txOutputBuffers);
reward = rewards.reward;
rewardToPool = rewards.rewardToPool;
}
if (rpcData.smartnode) {
if (rpcData.smartnode.payee) {
const rewards = createOutputTransaction(rpcData.smartnode.amount, rpcData.smartnode.payee, rewardToPool, reward, txOutputBuffers);
@@ -220,7 +230,7 @@ module.exports.RtmBlockTemplate = function(rpcData, poolAddress) {
const scriptSigPart1 = Buffer.concat([
serializeNumber(rpcData.height),
Buffer.from(rpcData.coinbaseaux.flags, 'hex'),
Buffer.from(rpcData.coinbaseaux.flags ? rpcData.coinbaseaux.flags : "", 'hex'),
serializeNumber(Date.now() / 1000 | 0),
Buffer.from([extraNoncePlaceholderLength])
]);
@@ -244,11 +254,17 @@ module.exports.RtmBlockTemplate = function(rpcData, poolAddress) {
// transaction output
generateOutputTransactions(rpcData, poolAddress),
// end transaction ouput
packUInt32LE(0), // txLockTime
varIntBuffer(rpcData.coinbase_payload.length / 2),
Buffer.from(rpcData.coinbase_payload, 'hex')
packUInt32LE(0) // txLockTime
]);
if (rpcData.coinbase_payload) {
blob2 = Buffer.concat([
blob2,
varIntBuffer(rpcData.coinbase_payload.length / 2),
Buffer.from(rpcData.coinbase_payload, 'hex')
]);
}
const prev_hash = reverseBuffer(Buffer.from(rpcData.previousblockhash, 'hex')).toString('hex');
const version = packInt32LE(rpcData.version).toString('hex');
const curtime = packUInt32LE(rpcData.curtime).toString('hex');