Compare commits
No commits in common. "77967881db869e7a022fb927898131da3891f958" and "a730487c717d2075b18e715e70f8a909945c12a5" have entirely different histories.
77967881db
...
a730487c71
@ -44,7 +44,7 @@ class InfuraMonitor:
|
|||||||
to_name = address_names.get(to_address, to_address)
|
to_name = address_names.get(to_address, to_address)
|
||||||
|
|
||||||
if from_address in self.addresses or to_address in self.addresses:
|
if from_address in self.addresses or to_address in self.addresses:
|
||||||
logger.info(f"#{block_num}: {from_name} -> {to_name}")
|
logger.info(f"TX detected in block #{block_num}: {from_name} -> {to_name}")
|
||||||
logger.debug(f"Transaction details: {tx}")
|
logger.debug(f"Transaction details: {tx}")
|
||||||
|
|
||||||
def start_monitor(self, addresses: Dict[str, str]):
|
def start_monitor(self, addresses: Dict[str, str]):
|
||||||
|
@ -1,121 +0,0 @@
|
|||||||
from decimal import Decimal, getcontext
|
|
||||||
|
|
||||||
# Set precision context if needed
|
|
||||||
getcontext().prec = 28
|
|
||||||
|
|
||||||
|
|
||||||
class StakingContract:
|
|
||||||
def __init__(self):
|
|
||||||
self.rewards_pct = Decimal('0.7')
|
|
||||||
self.community_pct = Decimal('0.2')
|
|
||||||
self.developer_pct = Decimal('0.1')
|
|
||||||
|
|
||||||
self.balances = {
|
|
||||||
"stakes": Decimal('0.0'),
|
|
||||||
"developer": Decimal('0.0'),
|
|
||||||
"community": Decimal('0.0'),
|
|
||||||
}
|
|
||||||
|
|
||||||
self.users = {}
|
|
||||||
|
|
||||||
def deposit(self, user: str, amount: float):
|
|
||||||
amount = Decimal(amount) # Convert to Decimal
|
|
||||||
stake, reward, community, developer = self.calc_fee(amount)
|
|
||||||
print(f'{user} staked {amount} ($JENNER)')
|
|
||||||
|
|
||||||
# Distribute reward to existing users first
|
|
||||||
self.distribute_reward(reward)
|
|
||||||
|
|
||||||
self.add_fees_to_balances(stake, community, developer)
|
|
||||||
self.add_stake_to_user(user, stake)
|
|
||||||
|
|
||||||
def withdraw(self, user: str):
|
|
||||||
if user not in self.users:
|
|
||||||
print(f"No staked amount found for user {user}.")
|
|
||||||
return Decimal('0.0')
|
|
||||||
|
|
||||||
initial_stake = self.users[user]
|
|
||||||
|
|
||||||
total_withdrawal = initial_stake
|
|
||||||
|
|
||||||
# Update balances
|
|
||||||
self.balances['stakes'] -= initial_stake
|
|
||||||
|
|
||||||
# Reset user's stake to 0
|
|
||||||
del self.users[user]
|
|
||||||
|
|
||||||
print(f'{user} withdrew {total_withdrawal:.4f} ($JENNER)')
|
|
||||||
return total_withdrawal
|
|
||||||
|
|
||||||
def calc_fee(self, amount):
|
|
||||||
fee = amount * Decimal('0.03')
|
|
||||||
stake_amount = amount - fee
|
|
||||||
|
|
||||||
rewards = fee * self.rewards_pct
|
|
||||||
community = fee * self.community_pct
|
|
||||||
developer = fee * self.developer_pct
|
|
||||||
|
|
||||||
return stake_amount, rewards, community, developer
|
|
||||||
|
|
||||||
def show_stats(self):
|
|
||||||
print('\n--- POOL STATS ---')
|
|
||||||
for k, v in self.balances.items():
|
|
||||||
print(f'{k}: {v}')
|
|
||||||
print('')
|
|
||||||
print('--- USERS IN POOL ---')
|
|
||||||
for k, v in self.users.items():
|
|
||||||
print(f'{k}: {v}')
|
|
||||||
print('')
|
|
||||||
|
|
||||||
def add_stake_to_user(self, user: str, stake: Decimal):
|
|
||||||
if user in self.users:
|
|
||||||
self.users[user] += stake
|
|
||||||
else:
|
|
||||||
self.users[user] = stake
|
|
||||||
|
|
||||||
def add_fees_to_balances(self, stake: Decimal, community: Decimal, developer: Decimal):
|
|
||||||
self.balances['stakes'] += stake
|
|
||||||
self.balances['developer'] += developer
|
|
||||||
self.balances['community'] += community
|
|
||||||
|
|
||||||
def distribute_reward(self, reward: Decimal):
|
|
||||||
total_stakes = self.balances['stakes']
|
|
||||||
if total_stakes > Decimal('0.0'):
|
|
||||||
for user in self.users:
|
|
||||||
user_stake = self.users[user]
|
|
||||||
reward_share = (user_stake / total_stakes) * reward
|
|
||||||
self.users[user] += reward_share
|
|
||||||
|
|
||||||
def user_total_balance(self, user: str):
|
|
||||||
if user in self.users:
|
|
||||||
return self.users[user]
|
|
||||||
return Decimal('0.0')
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
pool = StakingContract()
|
|
||||||
|
|
||||||
pool.deposit("owner", 50000)
|
|
||||||
pool.deposit("user1", 10000)
|
|
||||||
pool.deposit("user2", 10000)
|
|
||||||
pool.deposit("user3", 10000)
|
|
||||||
pool.deposit("user4", 10000)
|
|
||||||
pool.deposit("user5", 10000)
|
|
||||||
pool.deposit("user6", 10000)
|
|
||||||
|
|
||||||
pool.show_stats()
|
|
||||||
|
|
||||||
pool.withdraw("user1")
|
|
||||||
pool.withdraw("user2")
|
|
||||||
pool.withdraw("user3")
|
|
||||||
pool.withdraw("user4")
|
|
||||||
pool.withdraw("user5")
|
|
||||||
pool.withdraw("user6")
|
|
||||||
|
|
||||||
pool.withdraw("owner")
|
|
||||||
|
|
||||||
pool.show_stats()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
@ -5,8 +5,8 @@ getcontext().prec = 28
|
|||||||
|
|
||||||
class StakingContract:
|
class StakingContract:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.rewards_pct = Decimal('0.7')
|
self.rewards_pct = Decimal('0.6')
|
||||||
self.community_pct = Decimal('0.2')
|
self.community_pct = Decimal('0.3')
|
||||||
self.developer_pct = Decimal('0.1')
|
self.developer_pct = Decimal('0.1')
|
||||||
|
|
||||||
self.balances = {
|
self.balances = {
|
||||||
@ -21,7 +21,7 @@ class StakingContract:
|
|||||||
def deposit(self, user: str, amount: float):
|
def deposit(self, user: str, amount: float):
|
||||||
amount = Decimal(amount) # Convert to Decimal
|
amount = Decimal(amount) # Convert to Decimal
|
||||||
stake, reward, community, developer = self.calc_fee(amount)
|
stake, reward, community, developer = self.calc_fee(amount)
|
||||||
print(f'{user} staked {amount} ($JENNER)')
|
print(f'User {user} staked {amount} ($JENNER)')
|
||||||
|
|
||||||
self.add_fees_to_balances(stake, reward, community, developer)
|
self.add_fees_to_balances(stake, reward, community, developer)
|
||||||
self.add_stake_to_user(user, stake)
|
self.add_stake_to_user(user, stake)
|
||||||
@ -39,34 +39,13 @@ class StakingContract:
|
|||||||
self.balances['reward'] -= reward_share
|
self.balances['reward'] -= reward_share
|
||||||
|
|
||||||
# Reset user stake to 0
|
# Reset user stake to 0
|
||||||
del self.users[user]
|
self.users[user] = Decimal('0.0')
|
||||||
|
|
||||||
# Total amount returned to the user
|
# Total amount returned to the user
|
||||||
total_withdrawal = initial_stake + reward_share
|
total_withdrawal = initial_stake + reward_share
|
||||||
print(f'{user} withdrew {total_withdrawal:.4f} ($JENNER) - (reward: {reward_share:.4f})')
|
print(f'User {user} withdrew {total_withdrawal} ($JENNER)')
|
||||||
return total_withdrawal
|
return total_withdrawal
|
||||||
|
|
||||||
# def withdraw(self, user: str):
|
|
||||||
# if user not in self.users:
|
|
||||||
# print(f"No staked amount found for user {user}.")
|
|
||||||
# return Decimal('0.0')
|
|
||||||
#
|
|
||||||
# initial_stake = self.users[user]
|
|
||||||
# reward_share = self.calculate_reward_share(user)
|
|
||||||
#
|
|
||||||
# # Update balances
|
|
||||||
# self.balances['stakes'] -= initial_stake
|
|
||||||
# self.balances['reward'] -= reward_share
|
|
||||||
#
|
|
||||||
# # Reset user stake to 0
|
|
||||||
# # self.users[user] = Decimal('0.0')
|
|
||||||
# del self.users[user]
|
|
||||||
#
|
|
||||||
# # Total amount returned to the user
|
|
||||||
# total_withdrawal = initial_stake + reward_share
|
|
||||||
# print(f'{user} withdrew {total_withdrawal:.4f} ($JENNER) - (reward: {reward_share:.4f})')
|
|
||||||
# return total_withdrawal
|
|
||||||
|
|
||||||
def calculate_reward_share(self, user):
|
def calculate_reward_share(self, user):
|
||||||
total_stakes = sum(self.users.values())
|
total_stakes = sum(self.users.values())
|
||||||
if total_stakes == 0: # Avoid division by zero
|
if total_stakes == 0: # Avoid division by zero
|
||||||
@ -111,53 +90,23 @@ class StakingContract:
|
|||||||
def main():
|
def main():
|
||||||
pool = StakingContract()
|
pool = StakingContract()
|
||||||
|
|
||||||
pool.deposit("owner", 50000)
|
pool.deposit("owner", 1)
|
||||||
pool.deposit("user1", 50000)
|
pool.deposit("user5", 1000000)
|
||||||
pool.deposit("user2", 50000)
|
pool.deposit("user1", 1000)
|
||||||
|
pool.deposit("user2", 200000)
|
||||||
|
pool.deposit("user3", 90283)
|
||||||
|
pool.deposit("user4", 1000)
|
||||||
pool.show_stats()
|
pool.show_stats()
|
||||||
|
|
||||||
pool.withdraw("user1")
|
pool.withdraw("user1")
|
||||||
pool.withdraw("user2")
|
pool.withdraw("user2")
|
||||||
|
pool.withdraw("user3")
|
||||||
|
pool.withdraw("user4")
|
||||||
|
pool.withdraw("user5")
|
||||||
pool.withdraw("owner")
|
pool.withdraw("owner")
|
||||||
|
|
||||||
pool.show_stats()
|
pool.show_stats()
|
||||||
|
|
||||||
# pool = StakingContract()
|
|
||||||
#
|
|
||||||
# pool.deposit("owner", 50000)
|
|
||||||
# pool.deposit("user5", 10000000)
|
|
||||||
# pool.deposit("user1", 1000)
|
|
||||||
# pool.deposit("user2", 200000)
|
|
||||||
# pool.deposit("user3", 90283)
|
|
||||||
# pool.deposit("user4", 1000)
|
|
||||||
# pool.deposit("user5", 1000000)
|
|
||||||
# pool.deposit("user6", 1000000)
|
|
||||||
# # pool.deposit("user5", 1000000)
|
|
||||||
# # pool.deposit("user5", 1000000)
|
|
||||||
# # pool.deposit("user5", 1000000)
|
|
||||||
# #
|
|
||||||
# # for n in range(200):
|
|
||||||
# # pool.deposit(f"user{n+6}", 5000)
|
|
||||||
# #
|
|
||||||
# # pool.deposit("user5", 1000000)
|
|
||||||
#
|
|
||||||
# pool.show_stats()
|
|
||||||
#
|
|
||||||
# pool.withdraw("user1")
|
|
||||||
# pool.withdraw("user2")
|
|
||||||
# pool.withdraw("user3")
|
|
||||||
# pool.withdraw("user4")
|
|
||||||
# pool.withdraw("user5")
|
|
||||||
# pool.withdraw("user6")
|
|
||||||
# #
|
|
||||||
# # for n in range(200):
|
|
||||||
# # pool.withdraw(f"user{n+6}")
|
|
||||||
#
|
|
||||||
# pool.withdraw("owner")
|
|
||||||
#
|
|
||||||
# pool.show_stats()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
@ -1,56 +0,0 @@
|
|||||||
class StakingPool:
|
|
||||||
def __init__(self):
|
|
||||||
# TODO: Add mutex
|
|
||||||
# self.mutex = None
|
|
||||||
|
|
||||||
self.fee_rate = 0.03
|
|
||||||
|
|
||||||
self.share_pct = 0.6
|
|
||||||
self.community_pct = 0.3
|
|
||||||
self.developer_pct = 0.1
|
|
||||||
|
|
||||||
self.contract_fund = 0.0
|
|
||||||
self.community_fund = 0.0
|
|
||||||
self.developer_fund = 0.0
|
|
||||||
|
|
||||||
self.user_balances = {}
|
|
||||||
|
|
||||||
def deposit(self, user: str, amount: float):
|
|
||||||
# Calculate fee
|
|
||||||
|
|
||||||
# Distribute fee
|
|
||||||
# TODO: Handle edge case where pool has no initial users == Community funds gets the reward
|
|
||||||
# 1. Community funds
|
|
||||||
# 2. Developer funds
|
|
||||||
# 3. Reward stakers
|
|
||||||
|
|
||||||
# Update user_balances with new deposit
|
|
||||||
pass
|
|
||||||
|
|
||||||
def withdraw(self, user: str):
|
|
||||||
# Fetch amount from user_balances
|
|
||||||
|
|
||||||
# Remove user from pool to prevent self-reward leaving a hanging balance
|
|
||||||
|
|
||||||
# Calculate fee
|
|
||||||
|
|
||||||
# Distribute fee
|
|
||||||
# TODO: User needs to be removed from the pool first to avoid hanging balances after rewarding stakers
|
|
||||||
# 1. Community funds
|
|
||||||
# 2. Developer funds
|
|
||||||
# 3. Reward stakers
|
|
||||||
pass
|
|
||||||
|
|
||||||
def __distribute_reward(self, amount):
|
|
||||||
# # # #
|
|
||||||
# Lock user_balances mutex
|
|
||||||
# # # #
|
|
||||||
|
|
||||||
# Get total staked amount
|
|
||||||
# Determine distribution amongst users
|
|
||||||
# Update self.user_balances
|
|
||||||
|
|
||||||
# # # #
|
|
||||||
# Unlock user_balances mutex
|
|
||||||
# # # #
|
|
||||||
pass
|
|
Loading…
Reference in New Issue
Block a user