Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

farm position functionality #760

Merged
merged 71 commits into from
Oct 2, 2023
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
4ad9758
farm position functionality
psorinionut Aug 14, 2023
b4c924c
updateTotalFarmPosition endpoint fix
psorinionut Aug 14, 2023
667c19a
clippy fix
psorinionut Aug 14, 2023
8348f52
fixes after review
psorinionut Aug 15, 2023
5d2d020
Fixes after review
CostinCarabas Aug 22, 2023
5e05e32
farm-staking: Fixed module dependencies
CostinCarabas Aug 22, 2023
4f6bbd3
farm-staking: farm position functionality
CostinCarabas Aug 23, 2023
97b52fa
farm_position: compilation dependencies
CostinCarabas Aug 23, 2023
6b47ab3
Merge branch 'main' into farm-position-functionality
CostinCarabas Aug 23, 2023
6502c5b
Merge branch 'main' into farm-position-functionality
CostinCarabas Aug 23, 2023
b70b0de
farm-staking: Fix tests
CostinCarabas Aug 23, 2023
8997f70
Remove farm-position code
CostinCarabas Aug 23, 2023
d37f593
farm-staking: Remove merge for dual staking
CostinCarabas Aug 24, 2023
872278b
Merge branch 'main' into farm-position-functionality
CostinCarabas Aug 28, 2023
6580dba
farm/farm-staking: Update energy after claim
CostinCarabas Aug 29, 2023
3c4ffe1
Merge remote-tracking branch 'origin/farm-position-functionality' int…
CostinCarabas Aug 29, 2023
5d7a848
fees-collector: Fixes after review
CostinCarabas Aug 29, 2023
b445da1
Clippy fixes and compiling dependencies
CostinCarabas Aug 29, 2023
e46c4d2
Update common/modules/farm/farm_base_impl/src/base_traits_impl.rs
CostinCarabas Aug 29, 2023
ea612c1
Fixes after review
CostinCarabas Aug 29, 2023
9bdf09c
Fixes after review
CostinCarabas Aug 30, 2023
07f41a3
Fix minor issue
CostinCarabas Aug 31, 2023
14baa0a
fees-collector:Add test for "claim for other user"
CostinCarabas Aug 31, 2023
63de49e
Clippy fixes
CostinCarabas Aug 31, 2023
0e7141c
farm: Add claim boosted for other user test
CostinCarabas Aug 31, 2023
f40d64a
farm-staking:Add test claim for other user
CostinCarabas Aug 31, 2023
ff3f040
Fixes after review
CostinCarabas Aug 31, 2023
f1496d5
farm: compound_rewards_base bug fix
CostinCarabas Aug 31, 2023
98aa836
Refactor clippy fix
CostinCarabas Aug 31, 2023
f371569
Clippy fix for test setup
CostinCarabas Aug 31, 2023
5b00a9c
Give boosted energy even after unlock xMEX
CostinCarabas Sep 4, 2023
4ff1b8a
Merge pull request #767 from multiversx/give-boosted-after-unlock
sasurobert Sep 4, 2023
00dc45d
Fixes after review
CostinCarabas Sep 4, 2023
0f87499
Merge branch 'main' into farm-position-functionality
CostinCarabas Sep 6, 2023
249c3ee
Fix clippy
CostinCarabas Sep 7, 2023
4b4e0b7
farm position first audit fixes
psorinionut Sep 13, 2023
c044821
metastaking refactor
psorinionut Sep 18, 2023
16576f1
readded claim progress check
psorinionut Sep 18, 2023
3fc935a
clippy fixes
psorinionut Sep 18, 2023
be142a3
dedicated migration function for old positions
psorinionut Sep 18, 2023
a77b760
remove caller check in migrate old position func
psorinionut Sep 19, 2023
3fe300e
remove exit amount parameter from farms
psorinionut Sep 19, 2023
37c9ebc
clippy fix
psorinionut Sep 19, 2023
9859e47
tests fixes
psorinionut Sep 19, 2023
d9fd841
remove metastaking ProxyMergePosModule
psorinionut Sep 20, 2023
65930ce
send rewards to user in claim_boosted_rewards
psorinionut Sep 20, 2023
ee6644c
claim boosted in merge endpoints
psorinionut Sep 20, 2023
1e9ec92
clippy and test fix
psorinionut Sep 20, 2023
bbff637
audit fixes (2)
psorinionut Sep 20, 2023
c609e42
Merge pull request #774 from multiversx/claim-boosted-in-merge-endpoints
psorinionut Sep 20, 2023
8ac9c19
Merge pull request #773 from multiversx/remove-exit-amount-parameter
psorinionut Sep 20, 2023
4303c0c
default migration nonce fix
psorinionut Sep 20, 2023
767f452
use GetCurrentESDTNFTNonce VM endpoint
psorinionut Sep 21, 2023
8100d57
try_set_farm_position_migration_nonce: code dup
CostinCarabas Sep 21, 2023
aba2e4e
fix farm_position_migration_nonce set function
psorinionut Sep 22, 2023
1d92432
Merge pull request #775 from multiversx/farm-position-audit-fixes-2
psorinionut Sep 26, 2023
494b301
farm position functionality tests
psorinionut Sep 26, 2023
772779a
allow_external_claim_rewards_setting extra check
psorinionut Sep 26, 2023
d790945
total_farm_position_claim_for_other extra check
psorinionut Sep 26, 2023
0ee2b42
farm position tests updates
psorinionut Sep 26, 2023
4262fa1
farm staking full position claim test
psorinionut Sep 28, 2023
a6e3e00
Merge pull request #776 from multiversx/farm-position-tests
sasurobert Sep 29, 2023
36be963
clippy fix
psorinionut Sep 29, 2023
ff4f6b1
Merge pull request #772 from multiversx/farm-position-fixes
psorinionut Sep 29, 2023
5acf5e4
build & cargo lock
psorinionut Sep 29, 2023
d1a9e72
github actions update
psorinionut Sep 29, 2023
75eba99
Merge branch 'main' into farm-position-functionality
psorinionut Sep 29, 2023
2e36524
clippy fix
psorinionut Sep 29, 2023
67a7d42
cargo lock fix
psorinionut Sep 29, 2023
4dc0203
farm with lock rewards cargo lock fix
psorinionut Sep 29, 2023
3cf4458
Merge branch 'main' into farm-position-functionality
psorinionut Oct 2, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions common/modules/farm/farm_base_impl/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,9 @@ path = "../config"
[dependencies.farm_token]
path = "../farm_token"

[dependencies.farm_position]
path = "../farm_position"

[dependencies.rewards]
path = "../rewards"

Expand Down
5 changes: 4 additions & 1 deletion common/modules/farm/farm_base_impl/src/claim_rewards.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ pub trait BaseClaimRewardsModule:
+ config::ConfigModule
+ token_send::TokenSendModule
+ farm_token::FarmTokenModule
+ farm_position::FarmPositionModule
+ pausable::PausableModule
+ permissions_module::PermissionsModule
+ multiversx_sc_modules::default_issue_callbacks::DefaultIssueCallbacksModule
Expand Down Expand Up @@ -58,11 +59,13 @@ pub trait BaseClaimRewardsModule:
self.validate_contract_state(storage_cache.contract_state, &storage_cache.farm_token_id);

let claim_rewards_context = ClaimRewardsContext::<Self::Api, FC::AttributesType>::new(
payments,
payments.clone(),
&storage_cache.farm_token_id,
self.blockchain(),
);

self.check_and_update_user_farm_position(&caller, &payments);

FC::generate_aggregated_rewards(self, &mut storage_cache);

let farm_token_amount = &claim_rewards_context.first_farm_token.payment.amount;
Expand Down
5 changes: 4 additions & 1 deletion common/modules/farm/farm_base_impl/src/compound_rewards.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ pub trait BaseCompoundRewardsModule:
+ config::ConfigModule
+ token_send::TokenSendModule
+ farm_token::FarmTokenModule
+ farm_position::FarmPositionModule
+ pausable::PausableModule
+ permissions_module::PermissionsModule
+ multiversx_sc_modules::default_issue_callbacks::DefaultIssueCallbacksModule
Expand All @@ -46,11 +47,13 @@ pub trait BaseCompoundRewardsModule:
);

let compound_rewards_context = CompoundRewardsContext::<Self::Api, FC::AttributesType>::new(
payments,
payments.clone(),
&storage_cache.farm_token_id,
self.blockchain(),
);

self.check_and_update_user_farm_position(&caller, &payments);

FC::generate_aggregated_rewards(self, &mut storage_cache);

let farm_token_amount = &compound_rewards_context.first_farm_token.payment.amount;
Expand Down
8 changes: 8 additions & 0 deletions common/modules/farm/farm_base_impl/src/enter_farm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ pub trait BaseEnterFarmModule:
+ config::ConfigModule
+ token_send::TokenSendModule
+ farm_token::FarmTokenModule
+ farm_position::FarmPositionModule
+ pausable::PausableModule
+ permissions_module::PermissionsModule
+ multiversx_sc_modules::default_issue_callbacks::DefaultIssueCallbacksModule
Expand All @@ -44,6 +45,13 @@ pub trait BaseEnterFarmModule:
&storage_cache.farm_token_id,
);

// The order is important - first check and update, then increase position
self.check_and_update_user_farm_position(
&caller,
&enter_farm_context.additional_farm_tokens,
);
self.increase_user_farm_position(&caller, &enter_farm_context.farming_token_payment.amount);

FC::generate_aggregated_rewards(self, &mut storage_cache);

storage_cache.farm_token_supply += &enter_farm_context.farming_token_payment.amount;
Expand Down
5 changes: 4 additions & 1 deletion common/modules/farm/farm_base_impl/src/exit_farm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ pub trait BaseExitFarmModule:
+ config::ConfigModule
+ token_send::TokenSendModule
+ farm_token::FarmTokenModule
+ farm_position::FarmPositionModule
+ pausable::PausableModule
+ permissions_module::PermissionsModule
+ multiversx_sc_modules::default_issue_callbacks::DefaultIssueCallbacksModule
Expand All @@ -39,11 +40,13 @@ pub trait BaseExitFarmModule:
self.validate_contract_state(storage_cache.contract_state, &storage_cache.farm_token_id);

let exit_farm_context = ExitFarmContext::<Self::Api, FC::AttributesType>::new(
payment,
payment.clone(),
&storage_cache.farm_token_id,
self.blockchain(),
);

self.decrease_user_farm_position(&payment);

FC::generate_aggregated_rewards(self, &mut storage_cache);

let farm_token_amount = &exit_farm_context.farm_token.payment.amount;
Expand Down
1 change: 1 addition & 0 deletions common/modules/farm/farm_base_impl/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ pub trait FarmBaseImpl:
+ config::ConfigModule
+ token_send::TokenSendModule
+ farm_token::FarmTokenModule
+ farm_position::FarmPositionModule
+ pausable::PausableModule
+ permissions_module::PermissionsModule
+ events::EventsModule
Expand Down
27 changes: 27 additions & 0 deletions common/modules/farm/farm_position/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
[package]
name = "farm_position"
version = "0.0.0"
authors = ["MultiversX <[email protected]>"]
edition = "2021"

[lib]
path = "src/farm_position.rs"

[dependencies.multiversx-sc]
version = "=0.39.4"
features = ["esdt-token-payment-legacy-decode"]

[dependencies.multiversx-sc-modules]
version = "=0.39.4"

[dependencies.farm_token]
path = "../farm_token"

[dependencies.utils]
path = "../../utils"

[dependencies.permissions_module]
path = "../../permissions_module"

[dependencies.common_structs]
path = "../../../common_structs"
121 changes: 121 additions & 0 deletions common/modules/farm/farm_position/src/farm_position.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
#![no_std]

multiversx_sc::imports!();
multiversx_sc::derive_imports!();

use common_structs::{FarmTokenAttributes, PaymentsVec};

#[multiversx_sc::module]
pub trait FarmPositionModule:
farm_token::FarmTokenModule
+ utils::UtilsModule
+ permissions_module::PermissionsModule
+ multiversx_sc_modules::default_issue_callbacks::DefaultIssueCallbacksModule
{
#[payable("*")]
#[endpoint(updateTotalFarmPosition)]
CostinCarabas marked this conversation as resolved.
Show resolved Hide resolved
fn update_total_farm_position(&self) {
let caller = self.blockchain().get_caller();
let payments = self.get_non_empty_payments();
let farm_token_mapper = self.farm_token();
let farm_token_id = farm_token_mapper.get_token_id();
let mut new_total_farm_position = BigUint::zero();
for farm_position in &payments {
require!(
farm_position.token_identifier == farm_token_id,
"Bad payment token"
);
let token_attributes: FarmTokenAttributes<Self::Api> =
farm_token_mapper.get_token_attributes(farm_position.token_nonce);

if token_attributes.original_owner != caller {
self.user_total_farm_position(&token_attributes.original_owner)
CostinCarabas marked this conversation as resolved.
Show resolved Hide resolved
.update(|user_farm_position| {
if *user_farm_position > farm_position.amount {
*user_farm_position -= &farm_position.amount;
} else {
*user_farm_position = BigUint::zero();
}
});
}

new_total_farm_position += farm_position.amount;
}

let user_current_farm_position = self.user_total_farm_position(&caller).get();
if new_total_farm_position > user_current_farm_position {
self.user_total_farm_position(&caller)
.set(new_total_farm_position)
}

self.send().direct_multi(&caller, &payments);
}

#[endpoint(setAllowExternalClaimBoostedRewards)]
fn set_allow_external_claim_boosted_rewards(&self, allow: bool) {
let caller = self.blockchain().get_caller();
self.allow_external_claim_boosted_rewards(&caller)
.set(allow);
}

fn check_and_update_user_farm_position(
CostinCarabas marked this conversation as resolved.
Show resolved Hide resolved
&self,
user: &ManagedAddress,
farm_positions: &PaymentsVec<Self::Api>,
) {
let farm_token_mapper = self.farm_token();
let mut total_farm_position = BigUint::zero();
let mut farm_position_increase = BigUint::zero();
for farm_position in farm_positions {
total_farm_position += &farm_position.amount;
CostinCarabas marked this conversation as resolved.
Show resolved Hide resolved
let token_attributes: FarmTokenAttributes<Self::Api> =
farm_token_mapper.get_token_attributes(farm_position.token_nonce);

if &token_attributes.original_owner != user {
self.decrease_user_farm_position(&farm_position);
farm_position_increase += &farm_position.amount;
}
}

if self.user_total_farm_position(user).get() == 0 {
self.increase_user_farm_position(user, &total_farm_position);
} else if farm_position_increase > 0 {
self.increase_user_farm_position(user, &farm_position_increase);
}
}

fn increase_user_farm_position(
&self,
user: &ManagedAddress,
new_farm_position_amount: &BigUint,
) {
self.user_total_farm_position(user)
.update(|user_farm_position| *user_farm_position += new_farm_position_amount);
}

fn decrease_user_farm_position(&self, farm_position: &EsdtTokenPayment) {
let farm_token_mapper = self.farm_token();
let token_attributes: FarmTokenAttributes<Self::Api> =
farm_token_mapper.get_token_attributes(farm_position.token_nonce);

self.user_total_farm_position(&token_attributes.original_owner)
.update(|user_farm_position| {
if *user_farm_position > farm_position.amount {
*user_farm_position -= &farm_position.amount;
} else {
*user_farm_position = BigUint::zero();
}
});
}

#[view(getUserTotalFarmPosition)]
#[storage_mapper("userTotalFarmPosition")]
fn user_total_farm_position(&self, user: &ManagedAddress) -> SingleValueMapper<BigUint>;

#[view(getAllowExternalClaimBoostedRewards)]
#[storage_mapper("allowExternalClaimBoostedRewards")]
fn allow_external_claim_boosted_rewards(
&self,
user: &ManagedAddress,
) -> SingleValueMapper<bool>;
}
3 changes: 3 additions & 0 deletions dex/farm-with-locked-rewards/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,9 @@ path = "../../common/modules/farm/config"
[dependencies.farm_token]
path = "../../common/modules/farm/farm_token"

[dependencies.farm_position]
path = "../../common/modules/farm/farm_position"

[dependencies.rewards]
path = "../../common/modules/farm/rewards"

Expand Down
3 changes: 0 additions & 3 deletions dex/farm-with-locked-rewards/elrond.json

This file was deleted.

1 change: 1 addition & 0 deletions dex/farm-with-locked-rewards/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ pub trait Farm:
+ token_send::TokenSendModule
+ locking_module::lock_with_energy_module::LockWithEnergyModule
+ farm_token::FarmTokenModule
+ farm_position::FarmPositionModule
+ utils::UtilsModule
+ pausable::PausableModule
+ permissions_module::PermissionsModule
Expand Down
15 changes: 15 additions & 0 deletions dex/farm-with-locked-rewards/wasm/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 7 additions & 2 deletions dex/farm-with-locked-rewards/wasm/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@
////////////////////////////////////////////////////

// Init: 1
// Endpoints: 62
// Endpoints: 67
// Async Callback: 1
// Total number of exported functions: 64
// Total number of exported functions: 69

#![no_std]
#![feature(alloc_error_handler, lang_items)]
Expand Down Expand Up @@ -40,6 +40,10 @@ multiversx_sc_wasm_adapter::endpoints! {
registerFarmToken
getFarmTokenId
getFarmTokenSupply
updateTotalFarmPosition
setAllowExternalClaimBoostedRewards
getUserTotalFarmPosition
getAllowExternalClaimBoostedRewards
addToPauseWhitelist
removeFromPauseWhitelist
pause
Expand All @@ -59,6 +63,7 @@ multiversx_sc_wasm_adapter::endpoints! {
getMinimumFarmingEpoch
getBurnGasLimit
getPairContractManagedAddress
claimBoostedRewards
setBoostedYieldsRewardsPercentage
collectUndistributedBoostedRewards
getBoostedYieldsRewardsPercentage
Expand Down
3 changes: 3 additions & 0 deletions dex/farm/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,9 @@ path = "../../common/modules/farm/config"
[dependencies.farm_token]
path = "../../common/modules/farm/farm_token"

[dependencies.farm_position]
path = "../../common/modules/farm/farm_position"

[dependencies.rewards]
path = "../../common/modules/farm/rewards"

Expand Down
Loading