Skip to content

Commit

Permalink
Merge pull request tezos-reward-distributor-organization#109 from hab…
Browse files Browse the repository at this point in the history
…anoz/development

Development
  • Loading branch information
habanoz authored Oct 16, 2019
2 parents 7c15b52 + f3622d0 commit 5df4449
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 19 deletions.
4 changes: 2 additions & 2 deletions src/api/provider_factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,10 @@ def __init__(self, provider, verbose=False):

def newRewardApi(self, network_config, baking_address, wllt_clnt_mngr, node_url):
if self.provider == 'rpc':
return LRpcRewardApiImpl(network_config, baking_address, node_url, wllt_clnt_mngr, verbose=self.verbose)
return LRpcRewardApiImpl(network_config, baking_address, node_url, wllt_clnt_mngr, validate=False, verbose=self.verbose)
elif self.provider == 'prpc':
url_prefix = self.url_prefixes[network_config['NAME']]
return PRpcRewardApiImpl(network_config, baking_address, self.URL.format(url_prefix), verbose=self.verbose)
return PRpcRewardApiImpl(network_config, baking_address, self.URL.format(url_prefix), validate=False, verbose=self.verbose)
elif self.provider == 'tzscan':
if not self.mirror_selector:
self.init_mirror_selector(network_config)
Expand Down
19 changes: 11 additions & 8 deletions src/rpc/lrpc_reward_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ def get_rewards_for_cycle_map(self, cycle):

return reward_model

def __get_unfrozen_rewards(self, level_of_last_block_in_unfreeze_cycle):
def __get_unfrozen_rewards(self, level_of_last_block_in_unfreeze_cycle, cycle):
request_metadata = self.COMM_BLOCK.format(self.node_url, level_of_last_block_in_unfreeze_cycle) + '/metadata'
metadata = self.do_rpc_request(request_metadata)
balance_updates = metadata["balance_updates"]
Expand All @@ -93,14 +93,17 @@ def __get_unfrozen_rewards(self, level_of_last_block_in_unfreeze_cycle):
balance_update = balance_updates[i]
if balance_update["kind"] == "freezer":
if balance_update["delegate"] == self.baking_address:
if balance_update["category"] == "rewards":
unfrozen_rewards = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for reward {}".format(balance_update))
elif balance_update["category"] == "fees":
unfrozen_fees = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for fee {}".format(balance_update))
if int(balance_update["cycle"]) == cycle or int(balance_update["change"])<0:
if balance_update["category"] == "rewards":
unfrozen_rewards = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for reward {}".format(balance_update))
elif balance_update["category"] == "fees":
unfrozen_fees = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for fee {}".format(balance_update))
else:
logger.debug("[__get_unfrozen_rewards] Found balance update, not including: {}".format(balance_update))
else:
logger.debug("[__get_unfrozen_rewards] Found balance update, not including: {}".format(balance_update))
logger.debug("[__get_unfrozen_rewards] Found balance update, cycle does not match or change is non-zero, not including: {}".format(balance_update))

return unfrozen_fees + unfrozen_rewards

Expand Down
21 changes: 12 additions & 9 deletions src/rpc/prpc_reward_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ def get_rewards_for_cycle_map(self, cycle):
logger.debug("Cycle {}, preserved cycles {}, blocks per cycle {}, last_block_cycle {}".format(cycle, self.preserved_cycles, self.blocks_per_cycle, level_of_last_block_in_unfreeze_cycle))

if current_level - level_of_last_block_in_unfreeze_cycle >= 0:
unfrozen_rewards = self.__get_unfrozen_rewards(level_of_last_block_in_unfreeze_cycle)
unfrozen_rewards = self.__get_unfrozen_rewards(level_of_last_block_in_unfreeze_cycle, cycle)
reward_data["total_rewards"] = unfrozen_rewards

else:
Expand All @@ -82,7 +82,7 @@ def get_rewards_for_cycle_map(self, cycle):

return reward_model

def __get_unfrozen_rewards(self, level_of_last_block_in_unfreeze_cycle):
def __get_unfrozen_rewards(self, level_of_last_block_in_unfreeze_cycle, cycle):
request_metadata = self.COMM_BLOCK.format(self.node_url, level_of_last_block_in_unfreeze_cycle) + '/metadata'
metadata = self.do_rpc_request(request_metadata)
balance_updates = metadata["balance_updates"]
Expand All @@ -92,14 +92,17 @@ def __get_unfrozen_rewards(self, level_of_last_block_in_unfreeze_cycle):
balance_update = balance_updates[i]
if balance_update["kind"] == "freezer":
if balance_update["delegate"] == self.baking_address:
if balance_update["category"] == "rewards":
unfrozen_rewards = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for reward {}".format(balance_update))
elif balance_update["category"] == "fees":
unfrozen_fees = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for fee {}".format(balance_update))
if int(balance_update["cycle"]) == cycle or int(balance_update["change"]) < 0:
if balance_update["category"] == "rewards":
unfrozen_rewards = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for reward {}".format(balance_update))
elif balance_update["category"] == "fees":
unfrozen_fees = -int(balance_update["change"])
logger.debug("[__get_unfrozen_rewards] Found balance update for fee {}".format(balance_update))
else:
logger.debug("[__get_unfrozen_rewards] Found balance update, not including: {}".format(balance_update))
else:
logger.debug("[__get_unfrozen_rewards] Found balance update, not including: {}".format(balance_update))
logger.debug("[__get_unfrozen_rewards] Found balance update, cycle does not match or change is non-zero, not including: {}".format(balance_update))

return unfrozen_fees + unfrozen_rewards

Expand Down

0 comments on commit 5df4449

Please sign in to comment.