From f589348b3d0ddeadf606bd1d9dac5035483d728a Mon Sep 17 00:00:00 2001 From: ethzoomer Date: Mon, 13 Nov 2023 18:57:34 -0600 Subject: [PATCH] feat: add voting weight and earned reward amount of Relay deposits --- contracts/RelaySugar.vy | 26 ++++++++++++++++++++++---- readme.md | 2 +- 2 files changed, 23 insertions(+), 5 deletions(-) diff --git a/contracts/RelaySugar.vy b/contracts/RelaySugar.vy index 2286c01..e37dda8 100644 --- a/contracts/RelaySugar.vy +++ b/contracts/RelaySugar.vy @@ -14,6 +14,11 @@ struct LpVotes: lp: address weight: uint256 +struct ManagedVenft: + id: uint256 + amount: uint256 + earned: uint256 + struct Relay: venft_id: uint256 decimals: uint8 @@ -30,7 +35,7 @@ struct Relay: relay: address inactive: bool name: String[100] - account_venft_ids: DynArray[uint256, MAX_RESULTS] + account_venfts: DynArray[ManagedVenft, MAX_RESULTS] interface IERC20: @@ -53,6 +58,11 @@ interface IVotingEscrow: def locked(_venft_id: uint256) -> (uint128, uint256, bool): view def ownerToNFTokenIdList(_account: address, _index: uint256) -> uint256: view def voted(_venft_id: uint256) -> bool: view + def managedToLocked(_managed_venft_id: uint256) -> address: view + def weights(_venft_id: uint256, _managed_venft_id: uint256) -> uint256: view + +interface IReward: + def earned(_token: address, _venft_id: uint256) -> uint256: view interface IRelayRegistry: def getAll() -> DynArray[address, MAX_RELAYS]: view @@ -134,7 +144,7 @@ def _byAddress(_relay: address, _account: address) -> Relay: relay: IRelay = IRelay(_relay) managed_id: uint256 = relay.mTokenId() - account_venft_ids: DynArray[uint256, MAX_RESULTS] = empty(DynArray[uint256, MAX_RESULTS]) + account_venfts: DynArray[ManagedVenft, MAX_RESULTS] = empty(DynArray[ManagedVenft, MAX_RESULTS]) for venft_index in range(MAX_RESULTS): account_venft_id: uint256 = self.ve.ownerToNFTokenIdList(_account, venft_index) @@ -144,7 +154,15 @@ def _byAddress(_relay: address, _account: address) -> Relay: account_venft_manager_id: uint256 = self.ve.idToManaged(account_venft_id) if account_venft_manager_id == managed_id: - account_venft_ids.append(account_venft_id) + locked_reward: IReward = IReward(self.ve.managedToLocked(account_venft_manager_id)) + venft_weight: uint256 = self.ve.weights(account_venft_id, account_venft_manager_id) + earned: uint256 = locked_reward.earned(self.token, account_venft_id) + + account_venfts.append(ManagedVenft({ + id: account_venft_id, + amount: venft_weight, + earned: earned + })) votes: DynArray[LpVotes, MAX_PAIRS] = [] amount: uint128 = self.ve.locked(managed_id)[0] @@ -207,5 +225,5 @@ def _byAddress(_relay: address, _account: address) -> Relay: relay: _relay, inactive: inactive, name: relay.name(), - account_venft_ids: account_venft_ids + account_venfts: account_venfts }) diff --git a/readme.md b/readme.md index 3e56736..0413f65 100644 --- a/readme.md +++ b/readme.md @@ -189,7 +189,7 @@ The returned data/struct of type `Relay` values represent: * `relay` - Relay address * `inactive` - Relay active/inactive status * `name` - Relay name - * `account_venft_ids` - token IDs of the account's deposits into this Relay + * `account_venfts` - List of veNFTs deposited into this Relay by the account in the form of `ManagedVenft` ---