|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464 |
- var fs = require('fs');
- var stream = fs.createWriteStream("proglog.txt");
- var utils = require("./utils.js");
-
-
-
- var genesisCoinbaseTransactionTxid = "4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b";
- var genesisCoinbaseTransaction = {
- "hex": "01000000010000000000000000000000000000000000000000000000000000000000000000ffffffff0804ffff001d02fd04ffffffff0100f2052a01000000434104f5eeb2b10c944c6b9fbcfff94c35bdeecd93df977882babc7f3a2cf7f5c81d3b09a68db7f0e04f21de5d4230e75e6dbe7ad16eefe0d4325a62067dc6f369446aac00000000",
- "txid": "4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b",
- "hash": "4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b",
- "size": 204,
- "vsize": 204,
- "version": 1,
- "confirmations": 475000,
- "vin": [{
- "coinbase": "04ffff001d0104455468652054696d65732030332f4a616e2f32303039204368616e63656c6c6f72206f6e206272696e6b206f66207365636f6e64206261696c6f757420666f722062616e6b73",
- "sequence": 4294967295
- }],
- "vout": [{
- "value": 50,
- "n": 0,
- "scriptPubKey": {
- "asm": "04f5eeb2b10c944c6b9fbcfff94c35bdeecd93df977882babc7f3a2cf7f5c81d3b09a68db7f0e04f21de5d4230e75e6dbe7ad16eefe0d4325a62067dc6f369446a OP_CHECKSIG",
- "hex": "4104f5eeb2b10c944c6b9fbcfff94c35bdeecd93df977882babc7f3a2cf7f5c81d3b09a68db7f0e04f21de5d4230e75e6dbe7ad16eefe0d4325a62067dc6f369446aac",
- "reqSigs": 1,
- "type": "pubkey",
- "addresses": [
- "1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa"
- ]
- }
- }],
- "blockhash": "000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f",
- "time": 1230988505,
- "blocktime": 1230988505
- };
-
- function getInfo() {
- return new Promise(function(resolve, reject) {
- client.cmd('getinfo', function(err, result, resHeaders) {
- if (err) {
- console.log("Error 3207fh0f: " + err);
-
- reject(err);
-
- return;
- }
-
- resolve(result);
- });
- });
- }
-
- function getMiningInfo() {
- return new Promise(function(resolve, reject) {
- client.cmd('getmininginfo', function(err, result, resHeaders) {
- if (err) {
- console.log("Error 3207fh0f: " + err);
-
- reject(err);
-
- return;
- }
-
- resolve(result);
- });
- });
- }
-
- function getMempoolInfo() {
- return new Promise(function(resolve, reject) {
- client.cmd('getmempoolinfo', function(err, result, resHeaders) {
- if (err) {
- console.log("Error 23407rhwe07fg: " + err);
-
- reject(err);
-
- return;
- }
-
- resolve(result);
- });
- });
- }
-
- function getMempoolStats() {
- return new Promise(function(resolve, reject) {
- client.cmd('getrawmempool', true, function(err, result, resHeaders) {
- if (err) {
- console.log("Error 428thwre0ufg: " + err);
-
- reject(err);
-
- return;
- }
-
- var compiledResult = {};
- compiledResult.count = 0;
- compiledResult.fee_0_5 = 0;
- compiledResult.fee_6_10 = 0;
- compiledResult.fee_11_25 = 0;
- compiledResult.fee_26_50 = 0;
- compiledResult.fee_51_75 = 0;
- compiledResult.fee_76_100 = 0;
- compiledResult.fee_101_150 = 0;
- compiledResult.fee_151_max = 0;
-
- var totalFee = 0;
- for (var txid in result) {
- var txMempoolInfo = result[txid];
- totalFee += txMempoolInfo.modifiedfee;
- var feeRate = Math.round(txMempoolInfo.modifiedfee * 100000000 / txMempoolInfo.size);
-
- if (feeRate <= 5) {
- compiledResult.fee_0_5++;
-
- } else if (feeRate <= 10) {
- compiledResult.fee_6_10++;
-
- } else if (feeRate <= 25) {
- compiledResult.fee_11_25++;
-
- } else if (feeRate <= 50) {
- compiledResult.fee_26_50++;
-
- } else if (feeRate <= 75) {
- compiledResult.fee_51_75++;
-
- } else if (feeRate <= 100) {
- compiledResult.fee_76_100++;
-
- } else if (feeRate <= 150) {
- compiledResult.fee_101_150++;
-
- } else {
- compiledResult.fee_151_max++;
- }
-
- compiledResult.count++;
- }
-
- compiledResult.totalFee = totalFee;
-
- resolve(compiledResult);
- });
- });
- }
-
-
- function getBlockByHeight(blockHeight) {
- console.log("getBlockByHeightzz: " + blockHeight);
- console.log("xxxxxxxxxxxxxxxxxxxxxxxxxxxxx \n");
- //*************************************************************************************
-
- stream.write('block:' + blockHeight);
-
-
- return new Promise(function(resolve, reject) {
- var client = global.client;
-
- client.cmd('getblockhash', blockHeight, function(err, result, resHeaders) {
- if (err) {
- console.log("Error 0928317yr3w: " + err);
-
- reject(err);
-
- return;
- }
-
- client.cmd('getblock', result, function(err2, result2, resHeaders2) {
- if (err2) {
- console.log("Error 320fh7e0hg: " + err2);
-
- reject(err2);
-
- return;
- }
-
- resolve({ success: true, getblockhash: result, getblock: result2 });
- });
- });
- });
- }
-
-
-
- function getBlocksByHeight(blockHeights) {
- console.log("getBlocksByHeight: " + blockHeights);
-
-
- console.log("getBlockByHeightzz: " + blockHeights);
- console.log("xxxxxxxxxxxxxxxxxxxxxxxxxxxxx \n");
- //*************************************************************************************
-
- stream.write('block:' + blockHeights + "\n");
-
-
-
- return new Promise(function(resolve, reject) {
- var batch = [];
- for (var i = 0; i < blockHeights.length; i++) {
- batch.push({
- method: 'getblockhash',
- params: [blockHeights[i]]
- });
- }
-
- var blockHashes = [];
- client.cmd(batch, function(err, result, resHeaders) {
- blockHashes.push(result);
-
- if (blockHashes.length == batch.length) {
- var batch2 = [];
- for (var i = 0; i < blockHashes.length; i++) {
- batch2.push({
- method: 'getblock',
- params: [blockHashes[i]]
- });
- }
-
- var blocks = [];
- client.cmd(batch2, function(err2, result2, resHeaders2) {
- if (err2) {
- console.log("Error 138ryweufdf: " + err2);
- }
-
- blocks.push(result2);
- if (blocks.length == batch2.length) {
- resolve(blocks);
- }
- });
- }
- });
- });
- }
-
- function getBlockByHash(blockHash) {
- console.log("getBlockByHash: " + blockHash);
-
- return new Promise(function(resolve, reject) {
- var client = global.client;
-
- client.cmd('getblock', blockHash, function(err, result, resHeaders) {
- if (err) {
- console.log("Error 0u2fgewue: " + err);
-
- reject(err);
-
- return;
- }
-
- resolve(result);
- });
- });
- }
-
- function getTransactionInputs(rpcClient, transaction, inputLimit = 0) {
- console.log("getTransactionInputs: " + transaction.txid);
-
- return new Promise(function(resolve, reject) {
- var txids = [];
- for (var i = 0; i < transaction.vin.length; i++) {
- if (i < inputLimit || inputLimit == 0) {
- txids.push(transaction.vin[i].txid);
- }
- }
-
- getRawTransactions(txids).then(function(inputTransactions) {
- resolve({ txid: transaction.txid, inputTransactions: inputTransactions });
- });
- });
- }
-
- function getRawTransaction(txid) {
- return new Promise(function(resolve, reject) {
- if (txid == genesisCoinbaseTransactionTxid) {
- getBlockByHeight(0).then(function(blockZeroResult) {
- var result = genesisCoinbaseTransaction;
- result.confirmations = blockZeroResult.getblock.confirmations;
-
- resolve(result);
- });
-
- return;
- }
-
- client.cmd('getrawtransaction', txid, 1, function(err, result, resHeaders) {
- if (err) {
- console.log("Error 329813yre823: " + err);
-
- reject(err);
-
- return;
- }
-
- resolve(result);
- });
- });
- }
-
- function getRawTransactions(txids) {
- console.log("getRawTransactions: " + txids);
-
- return new Promise(function(resolve, reject) {
- if (!txids || txids.length == 0) {
- resolve([]);
-
- return;
- }
-
- if (txids.length == 1 && txids[0] == "4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b") {
- // copy the "confirmations" field from genesis block to the genesis-coinbase tx
- getBlockByHeight(0).then(function(blockZeroResult) {
- var result = genesisCoinbaseTransaction;
- result.confirmations = blockZeroResult.getblock.confirmations;
-
- resolve([result]);
-
- }).catch(function(err) {
- reject(err);
-
- return;
- });
-
- return;
- }
-
- var requests = [];
- for (var i = 0; i < txids.length; i++) {
- var txid = txids[i];
-
- if (txid) {
- requests.push({
- method: 'getrawtransaction',
- params: [txid, 1]
- });
- }
- }
-
- var requestBatches = utils.splitArrayIntoChunks(requests, 20);
-
- executeBatchesSequentially(requestBatches, function(results) {
- resolve(results);
- });
- });
- }
-
- function executeBatchesSequentially(batches, resultFunc) {
- var batchId = utils.getRandomString(20, 'aA#');
-
- console.log("Starting " + batches.length + "-item batch " + batchId + "...");
-
- executeBatchesSequentiallyInternal(batchId, batches, 0, [], resultFunc);
- }
-
- function executeBatchesSequentiallyInternal(batchId, batches, currentIndex, accumulatedResults, resultFunc) {
- if (currentIndex == batches.length) {
- console.log("Finishing batch " + batchId + "...");
-
- resultFunc(accumulatedResults);
-
- return;
- }
-
- console.log("Executing item #" + (currentIndex + 1) + " (of " + batches.length + ") for batch " + batchId);
-
- var count = batches[currentIndex].length;
-
- client.cmd(batches[currentIndex], function(err, result, resHeaders) {
- if (err) {
- console.log("Error f83024hf4: " + err);
- }
-
- accumulatedResults.push(result);
-
- count--;
-
- if (count == 0) {
- executeBatchesSequentiallyInternal(batchId, batches, currentIndex + 1, accumulatedResults, resultFunc);
- }
- });
- }
-
- function getBlockData(rpcClient, blockHash, txLimit, txOffset) {
- console.log("getBlockData: " + blockHash);
-
- return new Promise(function(resolve, reject) {
- client.cmd('getblock', blockHash, function(err2, result2, resHeaders2) {
- if (err2) {
- console.log("Error 3017hfwe0f: " + err2);
-
- reject(err2);
-
- return;
- }
-
- var txids = [];
- for (var i = txOffset; i < Math.min(txOffset + txLimit, result2.tx.length); i++) {
- txids.push(result2.tx[i]);
- }
-
- getRawTransactions(txids).then(function(transactions) {
- var txInputsByTransaction = {};
-
- var promises = [];
- for (var i = 0; i < transactions.length; i++) {
- var transaction = transactions[i];
-
- if (transaction) {
- promises.push(getTransactionInputs(client, transaction, 10));
- }
- }
-
- Promise.all(promises).then(function() {
- var results = arguments[0];
- for (var i = 0; i < results.length; i++) {
- var resultX = results[i];
-
- txInputsByTransaction[resultX.txid] = resultX.inputTransactions;
- }
-
- resolve({ getblock: result2, transactions: transactions, txInputsByTransaction: txInputsByTransaction });
- });
- });
- });
- });
- }
-
- function getBalanceFromAddress(rpcClient, address) {
- console.log("getBalanceFromAddress: " + address);
-
- return new Promise(function(resolve, reject) {
- client.cmd("getaddressbalance", "\'{\"addresses\": [\"" + address + "\"]}\'", function(err2, result2, resHeaders2) {
- if (err2) {
- console.log("Error 3017hfwe0f: " + err2);
-
- reject(err2);
-
- return;
- }
-
- resolve(result);
-
-
- });
- });
- }
-
-
-
- module.exports = {
- getInfo: getInfo,
- getMiningInfo: getMiningInfo,
- getMempoolInfo: getMempoolInfo,
- getBlockByHeight: getBlockByHeight,
- getBlocksByHeight: getBlocksByHeight,
- getBlockByHash: getBlockByHash,
- getBalanceFromAddress: getBalanceFromAddress,
- getTransactionInputs: getTransactionInputs,
- getBlockData: getBlockData,
- getRawTransaction: getRawTransaction,
- getRawTransactions: getRawTransactions,
- getMempoolStats: getMempoolStats
- };
|