diff --git a/src/constants.cairo b/src/constants.cairo index 1e75463b..7930d5a8 100644 --- a/src/constants.cairo +++ b/src/constants.cairo @@ -1,6 +1,6 @@ const NEW_PROPOSAL_QUORUM: u128 = 200; // 1/200 of totalSupply required to propose an upgrade. Quorums don't take into account investors. at all, they don't count into total eligible voters, but do vote -const PROPOSAL_VOTING_TIME_BLOCKS: u64 = 2000; +const PROPOSAL_VOTING_TIME_BLOCKS: u64 = 2500; const QUORUM: u128 = 10; // 1/10 of totalSupply required to participate to pass const MINUS_ONE: felt252 = 0x800000000000011000000000000000000000000000000000000000000000000; const TEAM_TOKEN_BALANCE: u128 = 1000000000000000000; diff --git a/src/contract.cairo b/src/contract.cairo index 85f1686b..0136cec4 100644 --- a/src/contract.cairo +++ b/src/contract.cairo @@ -30,7 +30,7 @@ trait IGovernance { // OPTIONS - fn add_0911_1611_options(ref self: TContractState); + fn add_0712_1412_options(ref self: TContractState); } @@ -153,8 +153,8 @@ mod Governance { Airdrop::claim(address, amount, proof) } - fn add_0911_1611_options(ref self: ContractState) { - Options::run_add_0911_1611_options() + fn add_0712_1412_options(ref self: ContractState) { + Options::run_add_0712_1412_options() } } } diff --git a/src/options.cairo b/src/options.cairo index e734b62d..16be0ab3 100644 --- a/src/options.cairo +++ b/src/options.cairo @@ -53,11 +53,16 @@ mod Options { const VOLATILITY_46: Math64x61_ = 106068778423829921792; const VOLATILITY_46_5: Math64x61_ = 107221699928436768768; const VOLATILITY_47: Math64x61_ = consteval_int!(47 * 2305843009213693952); + const VOLATILITY_48: Math64x61_ = consteval_int!(48 * 2305843009213693952); const VOLATILITY_48_5: Math64x61_ = 111833385946864156672; + const VOLATILITY_49: Math64x61_ = consteval_int!(49 * 2305843009213693952); + const VOLATILITY_49_5: Math64x61_ = 114139228956077850624; + const VOLATILITY_50: Math64x61_ = consteval_int!(50 * 2305843009213693952); const VOLATILITY_51: Math64x61_ = consteval_int!(51 * 2305843009213693952); const VOLATILITY_52: Math64x61_ = consteval_int!(52 * 2305843009213693952); const VOLATILITY_53: Math64x61_ = consteval_int!(53 * 2305843009213693952); const VOLATILITY_55: Math64x61_ = 126821365506753167360; + const VOLATILITY_57: Math64x61_ = consteval_int!(57 * 2305843009213693952); const VOLATILITY_59: Math64x61_ = consteval_int!(59 * 2305843009213693952); const VOLATILITY_60: Math64x61_ = 138350580552821637120; @@ -68,6 +73,9 @@ mod Options { const STRIKE_PRICE_1800: Math64x61_ = consteval_int!(1800 * 2305843009213693952); const STRIKE_PRICE_1900: Math64x61_ = consteval_int!(1900 * 2305843009213693952); const STRIKE_PRICE_2000: Math64x61_ = consteval_int!(2000 * 2305843009213693952); + const STRIKE_PRICE_2100: Math64x61_ = consteval_int!(2100 * 2305843009213693952); + const STRIKE_PRICE_2200: Math64x61_ = consteval_int!(2200 * 2305843009213693952); + const STRIKE_PRICE_2300: Math64x61_ = consteval_int!(2300 * 2305843009213693952); fn add_options(salt: felt252, mut options: Span) { // TODO use block hash from block_hash syscall as salt // actually doable with the new syscall @@ -211,24 +219,24 @@ mod Options { res } - fn run_add_0911_1611_options() { + fn run_add_0712_1412_options() { let mut state = Governance::unsafe_new_contract_state(); assert( !proposal_initializer_run::InternalContractStateTrait::read( - @state.proposal_initializer_run, 36 + @state.proposal_initializer_run, 41 ), - 'prop36 initializer called again' + 'prop41 initializer called again' ); proposal_initializer_run::InternalContractStateTrait::write( - ref state.proposal_initializer_run, 36, true + ref state.proposal_initializer_run, 41, true ); - add_0911_options(); - add_1611_options(); + add_1412_options(); + add_0712_options(); } - fn add_0911_options() { - let MATURITY: felt252 = 1699574399; + fn add_1412_options() { + let MATURITY: felt252 = 1702598399; let eth_lpt_addr: ContractAddress = 0x7aba50fdb4e024c1ba63e2c60565d0fd32566ff4b18aa5818fc80c30e749024 @@ -243,70 +251,70 @@ mod Options { to_add .append( FutureOption { - name_long: 'ETHUSDC-09NOV23-1800-LONG-CALL', - name_short: 'ETHUSDC-09NOV23-1800-SHORT-CALL', + name_long: 'ETHUSDC-14DEC23-2100-LONG-CALL', + name_short: 'ETHUSDC-14DEC23-2100-SHORT-CALL', maturity: MATURITY, - strike_price: STRIKE_PRICE_1800, + strike_price: STRIKE_PRICE_2100, option_type: OPTION_CALL, lptoken_address: eth_lpt_addr, - initial_volatility: VOLATILITY_41 + initial_volatility: VOLATILITY_46 } ); to_add .append( FutureOption { - name_long: 'ETHUSDC-09NOV23-1900-LONG-CALL', - name_short: 'ETHUSDC-09NOV23-1900-SHORT-CALL', + name_long: 'ETHUSDC-14DEC23-2200-LONG-CALL', + name_short: 'ETHUSDC-14DEC23-2200-SHORT-CALL', maturity: MATURITY, - strike_price: STRIKE_PRICE_1900, + strike_price: STRIKE_PRICE_2200, option_type: OPTION_CALL, lptoken_address: eth_lpt_addr, - initial_volatility: VOLATILITY_45 + initial_volatility: VOLATILITY_48 } ); to_add .append( FutureOption { - name_long: 'ETHUSDC-09NOV23-2000-LONG-CALL', - name_short: 'ETHUSDC-09NOV23-2000-SHORT-CALL', + name_long: 'ETHUSDC-14DEC23-2300-LONG-CALL', + name_short: 'ETHUSDC-14DEC23-2300-SHORT-CALL', maturity: MATURITY, - strike_price: STRIKE_PRICE_2000, + strike_price: STRIKE_PRICE_2300, option_type: OPTION_CALL, lptoken_address: eth_lpt_addr, - initial_volatility: VOLATILITY_53 + initial_volatility: VOLATILITY_51 } ); to_add .append( FutureOption { - name_long: 'ETHUSDC-09NOV23-1700-LONG-PUT', - name_short: 'ETHUSDC-09NOV23-1700-SHORT-PUT', + name_long: 'ETHUSDC-14DEC23-2000-LONG-PUT', + name_short: 'ETHUSDC-14DEC23-2000-SHORT-PUT', maturity: MATURITY, - strike_price: STRIKE_PRICE_1700, + strike_price: STRIKE_PRICE_2000, option_type: OPTION_PUT, lptoken_address: usdc_lpt_addr, - initial_volatility: VOLATILITY_42 + initial_volatility: VOLATILITY_45 } ); to_add .append( FutureOption { - name_long: 'ETHUSDC-09NOV23-1600-LONG-PUT', - name_short: 'ETHUSDC-09NOV23-1600-SHORT-PUT', + name_long: 'ETHUSDC-14DEC23-1900-LONG-PUT', + name_short: 'ETHUSDC-14DEC23-1900-SHORT-PUT', maturity: MATURITY, - strike_price: STRIKE_PRICE_1600, + strike_price: STRIKE_PRICE_1900, option_type: OPTION_PUT, lptoken_address: usdc_lpt_addr, - initial_volatility: VOLATILITY_52 + initial_volatility: VOLATILITY_47 } ); - add_options(1011238812, to_add.span()) + add_options(141223881242, to_add.span()) } - fn add_1611_options() { - let MATURITY: felt252 = 1700179199; + fn add_0712_options() { + let MATURITY: felt252 = 1701993599; let eth_lpt_addr: ContractAddress = 0x7aba50fdb4e024c1ba63e2c60565d0fd32566ff4b18aa5818fc80c30e749024 @@ -321,52 +329,52 @@ mod Options { to_add .append( FutureOption { - name_long: 'ETHUSDC-16NOV23-1800-LONG-CALL', - name_short: 'ETHUSDC-16NOV23-1800-SHORT-CALL', + name_long: 'ETHUSDC-07DEC23-2100-LONG-CALL', + name_short: 'ETHUSDC-07DEC23-2100-SHORT-CALL', maturity: MATURITY, - strike_price: STRIKE_PRICE_1800, + strike_price: STRIKE_PRICE_2100, option_type: OPTION_CALL, lptoken_address: eth_lpt_addr, - initial_volatility: VOLATILITY_44 + initial_volatility: VOLATILITY_45 } ); to_add // purposefully only two call strikes to be conservative about future volatility spikes .append( FutureOption { - name_long: 'ETHUSDC-16NOV23-1900-LONG-CALL', - name_short: 'ETHUSDC-16NOV23-1900-SHORT-CALL', + name_long: 'ETHUSDC-07DEC23-2200-LONG-CALL', + name_short: 'ETHUSDC-07DEC23-2200-SHORT-CALL', maturity: MATURITY, - strike_price: STRIKE_PRICE_1900, + strike_price: STRIKE_PRICE_2200, option_type: OPTION_CALL, lptoken_address: eth_lpt_addr, - initial_volatility: VOLATILITY_46 + initial_volatility: VOLATILITY_50 } ); to_add .append( FutureOption { - name_long: 'ETHUSDC-16NOV23-1700-LONG-PUT', - name_short: 'ETHUSDC-16NOV23-1700-SHORT-PUT', + name_long: 'ETHUSDC-07DEC23-2000-LONG-PUT', + name_short: 'ETHUSDC-07DEC23-2000-SHORT-PUT', maturity: MATURITY, - strike_price: STRIKE_PRICE_1700, + strike_price: STRIKE_PRICE_2000, option_type: OPTION_PUT, lptoken_address: usdc_lpt_addr, - initial_volatility: VOLATILITY_43_5 + initial_volatility: VOLATILITY_45 } ); to_add .append( FutureOption { - name_long: 'ETHUSDC-16NOV23-1600-LONG-PUT', - name_short: 'ETHUSDC-16NOV23-1600-SHORT-PUT', + name_long: 'ETHUSDC-07DEC23-1900-LONG-PUT', + name_short: 'ETHUSDC-07DEC23-1900-SHORT-PUT', maturity: MATURITY, - strike_price: STRIKE_PRICE_1600, + strike_price: STRIKE_PRICE_1900, option_type: OPTION_PUT, lptoken_address: usdc_lpt_addr, - initial_volatility: VOLATILITY_48_5 + initial_volatility: VOLATILITY_49_5 } ); - add_options(16112383681242, to_add.span()) + add_options(07122383681242, to_add.span()) } }