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

Feat: Implement the function in the market_utils library #3 #463

Merged
merged 29 commits into from
Oct 5, 2023
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
0b97963
10 functions done
Tbelleng Sep 25, 2023
1eb1a09
almost finished, debug next
Tbelleng Sep 27, 2023
e32e69f
debug time
Tbelleng Sep 27, 2023
16cfa12
debuging
Tbelleng Sep 27, 2023
b50ef99
pushing recent changes/ still bug because missing functions
Tbelleng Sep 27, 2023
9331e30
Merge branch 'main' of https://github.com/keep-starknet-strange/sator…
Tbelleng Sep 27, 2023
0815f0c
debuging finished
Tbelleng Sep 27, 2023
d556216
adding comments on functions
Tbelleng Sep 28, 2023
30b0d20
almost clean
Tbelleng Sep 28, 2023
0741eb7
Emit bug
Tbelleng Sep 28, 2023
f1ee948
Merge branch 'main' of https://github.com/keep-starknet-strange/sator…
Tbelleng Sep 29, 2023
fd42dff
programm compile 🎉
Tbelleng Sep 29, 2023
a70ccf2
resolving last test
Tbelleng Sep 29, 2023
f394974
All test passed
Tbelleng Sep 29, 2023
fb76061
Remove Cache struct
Tbelleng Oct 1, 2023
211598f
Merge branch 'main' of https://github.com/keep-starknet-strange/sator…
Tbelleng Oct 2, 2023
3368add
Pull and update with main branch
Tbelleng Oct 2, 2023
66174d7
Merge branch 'main' of https://github.com/keep-starknet-strange/sator…
Tbelleng Oct 2, 2023
df07739
Merge branch 'main' into compare
Sk8erboi84 Oct 3, 2023
321f07f
Update version with Elevy pull request
Tbelleng Oct 3, 2023
b90bb16
Merge branch 'compare' of https://github.com/Tbelleng/satoru into com…
Tbelleng Oct 3, 2023
c7b651d
resolve request
Tbelleng Oct 3, 2023
5e6489d
Merge branch 'main' of https://github.com/keep-starknet-strange/sator…
Tbelleng Oct 3, 2023
4549e24
1 test failed because of max swap path lenght exceed test
Tbelleng Oct 3, 2023
ccaa9cc
resolving failed test
Tbelleng Oct 4, 2023
ce65b1f
resolve
Tbelleng Oct 4, 2023
2baaf1b
Merge branch 'main' of https://github.com/keep-starknet-strange/sator…
Tbelleng Oct 5, 2023
d801664
solving
Tbelleng Oct 5, 2023
9863418
compilation resolved
Tbelleng Oct 5, 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
9 changes: 9 additions & 0 deletions src/data/data_store.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ use satoru::order::order::Order;
use satoru::position::position::Position;
use satoru::withdrawal::withdrawal::Withdrawal;
use satoru::deposit::deposit::Deposit;
use satoru::utils::i128::{I128Store, I128Serde};

// *************************************************************************
// Interface of the `DataStore` contract.
Expand Down Expand Up @@ -104,6 +105,8 @@ trait IDataStore<TContractState> {
/// * `key` - The key to delete the value for.
fn remove_u128(ref self: TContractState, key: felt252);

fn apply_delta_to_u128(ref self: TContractState, key: felt252, value: u128) -> u128;

/// Add input to existing value.
/// # Arguments
/// * `key` - The key to add the value to.
Expand Down Expand Up @@ -474,6 +477,8 @@ mod DataStore {
use satoru::position::{position::Position, error::PositionError};
use satoru::withdrawal::{withdrawal::Withdrawal, error::WithdrawalError};
use satoru::deposit::{deposit::Deposit, error::DepositError};
use satoru::utils::calc;
use satoru::utils::i128::{I128Store, I128Serde};

// *************************************************************************
// STORAGE
Expand Down Expand Up @@ -643,6 +648,10 @@ mod DataStore {
self.u128_values.write(key, Default::default());
}

fn apply_delta_to_u128(ref self: ContractState, key: felt252, value: u128) -> u128 {
0
}

fn increment_u128(ref self: ContractState, key: felt252, value: u128) -> u128 {
// Check that the caller has permission to set the value.
self.role_store.read().assert_only_role(get_caller_address(), role::CONTROLLER);
Expand Down
12 changes: 11 additions & 1 deletion src/event/event_emitter.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -559,11 +559,15 @@ trait IEventEmitter<TContractState> {
next_pool_value: u128
);

/// Emits the `UiFeeFactorUpdated` event.
fn emit_ui_fee_factor_updated(
ref self: TContractState, account: ContractAddress, ui_fee_factor: u128
);

/// Emits the `UiFeeFactorUpdated` event.
fn emit_ui_fee_factor_updated_check(
ref self: TContractState, account: ContractAddress, ui_fee_factor: u128
);

Tbelleng marked this conversation as resolved.
Show resolved Hide resolved
/// Emits the `OraclePriceUpdate` event.
fn emit_oracle_price_update(
ref self: TContractState,
Expand Down Expand Up @@ -2623,6 +2627,12 @@ mod EventEmitter {
self.emit(UiFeeFactorUpdated { account, ui_fee_factor });
}

fn emit_ui_fee_factor_updated_check(
ref self: ContractState, account: ContractAddress, ui_fee_factor: u128
) {
self.emit(UiFeeFactorUpdated { account, ui_fee_factor });
}

/// Emits the `OraclePriceUpdate` event.
fn emit_oracle_price_update(
ref self: ContractState,
Expand Down
2 changes: 1 addition & 1 deletion src/exchange/adl_handler.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,7 @@ mod AdlHandler {
data_store, oracle, market_address, is_long, keys::max_pnl_factor_for_adl()
);
cache.should_allow_adl = should_allow_adl;
cache.pnl_to_pool_factor = pnl_to_pool_factor;
//cache.pnl_to_pool_factor = pnl_to_pool_factor; missing implementation, need u128 to i128 here
Tbelleng marked this conversation as resolved.
Show resolved Hide resolved
cache.max_pnl_factor_for_adl = max_pnl_factor_for_adl;

assert(cache.should_allow_adl, 'adl not required');
Expand Down
19 changes: 18 additions & 1 deletion src/market/error.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,24 @@ mod MarketError {
const INVALID_COLLATERAL_TOKEN_FOR_MARKET: felt252 = 'invalid_coll_token_for_market';

const EMPTY_MARKET: felt252 = 'empty_market';
const DISABLED_MARKET: felt252 = 'disabled_market';
const DISABLED_MARKET: felt252 = 'minumum position size';

const EMPTY_MARKET_TOKEN_SUPPLY: felt252 = 'empty_market_token_suppply';
const INVALID_MARKET_COLLATERAL_TOKEN: felt252 = 'invalid_market_collateral_token';
const UNABLE_TO_GET_FUNDING_FACTOR_EMPTY_OPEN_INTEREST: felt252 =
'unable_to_get_funding_factor';
const UNABLE_TO_GET_BORROWING_FACTOR_EMPTY_POOL_USD: felt252 = 'unable_to_get_borrowing_factor';
const MAX_SWAP_PATH_LENGTH_EXCEEDED: felt252 = 'max_swap_path_length_exceeded';
const PNL_EXCEEDED_FOR_LONGS: felt252 = 'pnl_exceeded_for_longs';
const PNL_EXCEEDED_FOR_SHORTS: felt252 = 'pnl_exceeded_for_shorts';
const UI_FEE_FACTOR_EXCEEDED: felt252 = 'ui_fee_factor_exceeded';
const EMPTY_ADDRESS_IN_MARKET_TOKEN_BALANCE_VALIDATION: felt252 =
'empty_address_in_market_token';
const INVALID_MARKET_TOKEN_BALANCE: felt252 = 'invalid_market_token_balance';
const INVALID_MARKET_TOKEN_BALANCE_FOR_COLLATERAL_AMOUNT: felt252 =
'invalid_market_token_balance';
const INVALID_MARKET_TOKEN_BALANCE_FOR_CLAIMABLE_FUNDING: felt252 =
'invalid_market_token_balance';

fn UNABLE_TO_GET_CACHED_TOKEN_PRICE(token_in: ContractAddress) {
let mut data = array!['invalid token in'];
Expand Down
Loading