From 09443b4e6c6bfca410c1b194a5fa1ec20b92ebc5 Mon Sep 17 00:00:00 2001 From: Matt Date: Tue, 11 Mar 2014 22:57:03 -0600 Subject: [PATCH] More comments on how to to payment processing and also stats for API --- libs/paymentProcessor.js | 33 ++++++++++++++++----------------- libs/shareProcessor.js | 7 +++++++ 2 files changed, 23 insertions(+), 17 deletions(-) diff --git a/libs/paymentProcessor.js b/libs/paymentProcessor.js index 2908494..47e995a 100644 --- a/libs/paymentProcessor.js +++ b/libs/paymentProcessor.js @@ -90,6 +90,7 @@ function SetupForPool(logger, poolOptions){ } */ function(callback){ + redisClient.smembers(coin + '_blocks', function(error, results){ if (error){ @@ -113,6 +114,7 @@ function SetupForPool(logger, poolOptions){ }); }, + /* Receives txs object with key, checks each key (the transHash) with block batch rpc call to daemon. Each confirmed on get the amount added to transHash object as {amount: amount}, Non confirmed txHashes get deleted from obj. Then remaining txHashes are passed along @@ -153,7 +155,6 @@ function SetupForPool(logger, poolOptions){ /* Use height from each txHash to get worker shares from each round and pass along */ function(txs, callback){ - var shareLooksup = []; for (var hash in txs){ var height = txs[hash].height; @@ -176,14 +177,13 @@ function SetupForPool(logger, poolOptions){ balancesForRounds[worker] = sharesAdded; } }); - callback(null, balancesForRounds); + callback(null, balancesForRounds, txs); }); - }, /* Get worker existing balances from coin_balances hashset in redis*/ - function(balancesForRounds, callback){ + function(balancesForRounds, txs, callback){ var workerAddress = Object.keys(balancesForRounds); @@ -200,18 +200,18 @@ function SetupForPool(logger, poolOptions){ } - callback(null, balancesForRounds) + callback(null, txs, balancesForRounds) }); - - }, /* Calculate if any payments are ready to be sent and trigger them sending - Get remaining balances for each address and pass it along as object of latest balances - such as {worker1: balance1, worker2, balance2} */ - function(fullBalance, callback){ - + Get balance different for each address and pass it along as object of latest balances such as + {worker1: balance1, worker2, balance2} + when deciding the sent balance, it the difference should be -1*amount they had in db, + if not sending the balance, the differnce should be +(the amount they earned this round) + */ + function(fullBalance, txs, callback){ /* if payments dont succeed (likely because daemon isnt responding to rpc), then cancel here so that all of this can be tried again when the daemon is working. otherwise we will consider @@ -220,16 +220,15 @@ function SetupForPool(logger, poolOptions){ }, - /* clean DB: update remaining balances in coin_balance hashset in redis */ - function(remainingBalance, callback){ - }, + /* clean DB: update remaining balances in coin_balance hashset in redis + */ + function(balanceDifference, txs, callback){ - /* clean DB: move this block entry to coin_processedBlocks so payments are not resent */ - function (none, callback){ + //SMOVE each tx key from coin_blocks to coin_processedBlocks + //HINCRBY to apply balance different for coin_balances worker1 } - ], function(error, result){ //log error completion }); diff --git a/libs/shareProcessor.js b/libs/shareProcessor.js index 369b9d1..2d9f19a 100644 --- a/libs/shareProcessor.js +++ b/libs/shareProcessor.js @@ -52,6 +52,13 @@ module.exports = function(logger, poolConfig){ if (!isValidShare) return; + /*use http://redis.io/commands/zrangebyscore to store shares with timestamps + so we can use the min-max to get shares from the last x minutes to determine hash rate :) + also use a hash like coin_stats:{ invalidShares, validShares, invalidBlocks, validBlocks, etc } + for more efficient stats + */ + + connection.hincrby([coin + '_shares:roundCurrent', shareData.worker, shareData.difficulty], function(error, result){ if (error) logger.error('redis', 'Could not store worker share')