Skip to content

Commit

Permalink
Merge dev
Browse files Browse the repository at this point in the history
  • Loading branch information
EquilateralDelta committed Dec 6, 2023
2 parents aa2587a + 9b69bb5 commit 43ace11
Show file tree
Hide file tree
Showing 65 changed files with 301 additions and 146 deletions.
94 changes: 94 additions & 0 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
Convergence General Source License

Introduction
-----------------------------------------------------------------------------

This license defines the terms and conditions under which all Convergence software can be used. Anyone that intends to use, modify, or distribute any Convergence software, in whole or in part, is subject to the terms set forth herein.
For example, this license allows for the free non-commercial use of Convergence software, provided that this license still remains applicable to the software. Any commercial use is only permissible with advanced written permission from Convergence. Modifications are likewise only permitted without commercial purpose, unless such modifications are pre-approved in advance in writing by Convergence.
Additional terms and conditions may apply to any Convergence software.

Summary of Parameters
-----------------------------------------------------------------------------

Licensor: Convergence Foundation
Licensed Work: Any code originally released by Convergence where this license appears, or any copy or derivative of such code
Date of License: December 4, 2023
Contact to seek permission: [email protected]

Definitions
-----------------------------------------------------------------------------

To "modify" a work means to copy from or adapt all or part of the work in a fashion requiring copyright permission, other than the making of an exact copy.

A "Licensed Work" includes any means that is protectable under applicable copyright law, including unmodified code or a work based on the code.

To "propagate" a work means to do anything with it that, without permission, would make you directly or secondarily liable for infringement under applicable copyright law, except executing it on a computer. Propagation includes copying, distribution (with or without modification), making available to the public, and in some countries other activities as well.

Basic Permissions
-----------------------------------------------------------------------------

The Licensor hereby grants you the right to copy, redistribute, and use the Licensed Work so long as the foregoing is done on a non-commercial and non-production basis. This License also requires that such uses provide notice of the original source of the Licensed Work as well as the continuing applicability of this License. The Licensor may make additional use grants for certain commercial and/or production use of the Licensed Work on a case-by-case basis by providing or publishing such permission in writing.
The Licensor also grants you the right to contribute to the Licensed Work by modifying it so long as such modifications are non-commercial and on a non-production basis, so long as the modifications are made publicly available for audit, with notice provided of the original source as well as the continuing applicability of this License. Except as specifically stated herein, the Licensor does not grant you the right to modify or create derivative works for any purpose without written permission from the Licensor.
Any other usage or propagation of the Licensed Work is prohibited and subject to copyright laws. If your actual or intended use or propagation of the Licensed Work does not comply with the permissible uses of the Licensed Work, you must refrain from such use unless and until permission is provided in writing by the Licensor. Such permission can be sought at the contact address provided above.

Seeking Additional Permissions
-----------------------------------------------------------------------------

To seek permission to propagate or use in any way the Licensed Work beyond the permissions granted herein, please contact the Licensor at the contact address provided above and specify the proposed additional permission sought. To the extent any such use is permitted, this License must continue to apply to any of the Licensed Work that is utilized. For example, where a portion of code is permitted to be utilized and modified to become part of a larger work, this License shall still apply to the portion of the code that has been modified. This license must be made available with the code, and the larger work must include a notice stating the original source of the code, and that it is released under and still subject to this license.

Applicability
-----------------------------------------------------------------------------

All copies of the original and modified Licensed Works, and any derivatives thereof, are subject to this License. This License applies separately to each version of a Licensed Work. This License must be conspicuously displayed on each original or modified copy of a Licensed Work. If you receive a Licensed Work in original or modified form from a third party, the terms and conditions set forth in this License apply to your use of that work.

Termination
-----------------------------------------------------------------------------

Any use of a Licensed Work in violation of this License will automatically terminate your rights under this License for the current and all other versions of the Licensed Work.
You may not propagate or modify a Licensed Work except as expressly provided under this License. Any attempt otherwise to propagate or modify it is void, and will automatically terminate your rights under this License.
The Licensor also retains the right to cancel this License at any time in its sole discretion for any individual or entity that it believes has not acted in compliance with the License, or is utilizing the Licensed Work for an improper purpose.

Disclaimer of Warranty
-----------------------------------------------------------------------------

THERE IS NO WARRANTY FOR THE LICENSED WORK, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE LICENSOR, COPYRIGHT HOLDER OR OTHER PARTIES PROVIDE THE LICENSED WORK "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE LICENSED WORK IS WITH YOU. SHOULD THE LICENSED WORK PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.

Limitation of Liability
-----------------------------------------------------------------------------

IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY LICENSOR, COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS THE LICENSED WORK AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE LICENSED WORK (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE LICENSED WORK TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

No Ownership Rights
-----------------------------------------------------------------------------

Use or propagation of the Licensed Work, regardless of whether permissible under this License, does not give you any ownership rights in any of the Licensed Works. Except as explicitly stated herein, all other right, title, and interest in the Licensed Works is exclusively the property of the Licensor.

Licensor’s Trademark
-----------------------------------------------------------------------------

This License does not grant anyone any right in the name, logo, or other trademark of Licensor or any affiliate, except as needed to reprint this License.

Modifications
-----------------------------------------------------------------------------

The Licensor reserves the right to make changes to this License from time to time without specifically notifying you. The Licensor will make the latest version publicly available. If you continue to use or propagate a Licensed Work, this means that you have accepted any changes to the License.

Your Responsibility to Comply with Local Law
-----------------------------------------------------------------------------

It is the responsibility of you and each user to inform yourself of and to observe all applicable laws and regulations of any relevant jurisdictions when using or propagating any of the Licensed Works. Prospective users should inform themselves as to the legal requirements and tax consequence within the jurisdictions of their citizenship, residence, domicile, and place of business, and seek professional advise where appropriate.

Survivability
-----------------------------------------------------------------------------

The terms of this License shall survive even if any particular term is deemed not to be enforceable. Any remaining terms shall remain enforceable to the maximum extent permitted by applicable law. To the extent permissible, any terms deemed not enforceable shall be rewritten so as to be enforceable to the maximum extent permissible by applicable law.

No Waiver
-----------------------------------------------------------------------------

Any failure by Licensor to exercise or enforce any legal right or to take any action concerning any breach of this License shall not constitute a waiver of any rights or remedies otherwise available to Licensor.

Choice of Law and Venue
-----------------------------------------------------------------------------

If there is any dispute arising out of this License or any of the Licensed Works, including any dispute concerning any of the terms of this License, you expressly agree that any such dispute shall be governed by the laws of the State of Delaware in the United States, without regard to the conflict of law provisions of any jurisdiction, and you expressly agree and consent to the exclusive jurisdiction and venue of the state and federal courts of the State of New York, and waive any personal jurisdictional challenge thereto, for the resolution of any such dispute.
14 changes: 7 additions & 7 deletions psyoptions-american-instrument/program/src/instructions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ const ESCROW_SEED: &str = "escrow";
pub struct ValidateData<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,

/// user provided
pub american_meta: Account<'info, OptionMarket>,
Expand All @@ -27,7 +27,7 @@ pub struct PrepareToSettle<'info> {
#[account(signer)]
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,
pub response: Box<Account<'info, Response>>,

/// user provided
#[account(mut)]
Expand All @@ -50,8 +50,8 @@ pub struct PrepareToSettle<'info> {
pub struct Settle<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub rfq: Account<'info, Rfq>,
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,

/// user provided
Expand All @@ -68,8 +68,8 @@ pub struct Settle<'info> {
pub struct RevertPreparation<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub rfq: Account<'info, Rfq>,
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,

/// user provided
Expand All @@ -86,7 +86,7 @@ pub struct RevertPreparation<'info> {
pub struct CleanUp<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,

Expand Down
10 changes: 5 additions & 5 deletions psyoptions-european-instrument/program/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -325,7 +325,7 @@ fn close_escrow_account<'info>(
pub struct ValidateData<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,

/// user provided
pub euro_meta: Account<'info, EuroMeta>,
Expand All @@ -340,7 +340,7 @@ pub struct PrepareToSettle<'info> {
#[account(signer)]
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,
pub response: Box<Account<'info, Response>>,

/// user provided
#[account(mut)]
Expand All @@ -364,7 +364,7 @@ pub struct PrepareToSettle<'info> {
pub struct Settle<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,

Expand All @@ -382,7 +382,7 @@ pub struct Settle<'info> {
pub struct RevertPreparation<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,

Expand All @@ -400,7 +400,7 @@ pub struct RevertPreparation<'info> {
pub struct CleanUp<'info> {
/// protocol provided
#[account(signer)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
pub rfq: Box<Account<'info, Rfq>>,
pub response: Account<'info, Response>,

Expand Down
10 changes: 5 additions & 5 deletions rfq/program/src/common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use crate::{
interfaces::instrument::validate_leg_instrument_data,
seeds::COLLATERAL_SEED,
state::{
AuthoritySide, BaseAssetInfo, CollateralInfo, Leg, ProtocolState, Response, Rfq,
ApiLeg, AuthoritySide, BaseAssetInfo, CollateralInfo, ProtocolState, Response, Rfq,
SettlementTypeMetadata, StoredResponseState,
},
};
Expand Down Expand Up @@ -88,7 +88,7 @@ pub fn update_state_after_escrow_preparation(
}

pub fn validate_legs<'a, 'info: 'a>(
legs: &[Leg],
legs: &[ApiLeg],
protocol: &Account<'info, ProtocolState>,
remaining_accounts: &mut impl Iterator<Item = &'a AccountInfo<'info>>,
is_settled_as_print_trade: bool,
Expand All @@ -104,7 +104,7 @@ pub fn validate_legs<'a, 'info: 'a>(
}

fn validate_legs_base_asset<'a, 'info: 'a>(
legs: &[Leg],
legs: &[ApiLeg],
remaining_accounts: &mut impl Iterator<Item = &'a AccountInfo<'info>>,
) -> Result<()> {
for leg in legs.iter() {
Expand All @@ -122,7 +122,7 @@ fn validate_legs_base_asset<'a, 'info: 'a>(
Ok(())
}

fn validate_legs_settlement_type(legs: &[Leg], is_settled_as_print_trade: bool) -> Result<()> {
fn validate_legs_settlement_type(legs: &[ApiLeg], is_settled_as_print_trade: bool) -> Result<()> {
for leg in legs.iter() {
validate_settlement_type_metadata(
&leg.settlement_type_metadata,
Expand Down Expand Up @@ -161,7 +161,7 @@ pub fn validate_settlement_type_metadata(
}

fn validate_instrument_legs<'a, 'info: 'a>(
legs: &[Leg],
legs: &[ApiLeg],
protocol: &Account<'info, ProtocolState>,
remaining_accounts: &mut impl Iterator<Item = &'a AccountInfo<'info>>,
) -> Result<()> {
Expand Down
2 changes: 1 addition & 1 deletion rfq/program/src/instructions/collateral/fund_collateral.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ pub struct FundCollateralAccounts<'info> {
pub user_tokens: Account<'info, TokenAccount>,

#[account(seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
#[account(seeds = [COLLATERAL_SEED.as_bytes(), user.key().as_ref()], bump = collateral_info.bump)]
pub collateral_info: Account<'info, CollateralInfo>,
#[account(mut, seeds = [COLLATERAL_TOKEN_SEED.as_bytes(), user.key().as_ref()],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ pub struct InitializeCollateralAccounts<'info> {
pub user: Signer<'info>,

#[account(seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
#[account(init, payer = user, space = 8 + mem::size_of::<CollateralInfo>(),
seeds = [COLLATERAL_SEED.as_bytes(), user.key().as_ref()], bump)]
pub collateral_info: Account<'info, CollateralInfo>,
Expand Down Expand Up @@ -43,6 +43,7 @@ pub fn initialize_collateral_instruction(ctx: Context<InitializeCollateralAccoun
user: user.key(),
token_account_bump: *ctx.bumps.get("collateral_token").unwrap(),
locked_tokens_amount: 0,
reserved: [0; 256],
});

Ok(())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ pub struct WithdrawCollateralAccounts<'info> {
pub user_tokens: Account<'info, TokenAccount>,

#[account(seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
#[account(seeds = [COLLATERAL_SEED.as_bytes(), user.key().as_ref()], bump = collateral_info.bump)]
pub collateral_info: Account<'info, CollateralInfo>,
#[account(mut, seeds = [COLLATERAL_TOKEN_SEED.as_bytes(), user.key().as_ref()],
Expand Down
2 changes: 1 addition & 1 deletion rfq/program/src/instructions/protocol/add_base_asset.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ pub struct AddBaseAssetAccounts<'info> {
#[account(mut, constraint = protocol.authority == authority.key() @ ProtocolError::NotAProtocolAuthority)]
pub authority: Signer<'info>,
#[account(seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
#[account(init, payer = authority, space = 8 + mem::size_of::<BaseAssetInfo>() + ticker.as_bytes().len(),
seeds = [BASE_ASSET_INFO_SEED.as_bytes(), &u16::from(index).to_le_bytes()], bump)]
pub base_asset: Account<'info, BaseAssetInfo>,
Expand Down
3 changes: 2 additions & 1 deletion rfq/program/src/instructions/protocol/add_instrument.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct AddInstrumentAccounts<'info> {
#[account(constraint = protocol.authority == authority.key() @ ProtocolError::NotAProtocolAuthority)]
pub authority: Signer<'info>,
#[account(mut, seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
/// CHECK: is a valid instrument program id
#[account(executable)]
pub instrument_program: UncheckedAccount<'info>,
Expand Down Expand Up @@ -65,6 +65,7 @@ pub fn add_instrument_instruction(
settle_account_amount,
revert_preparation_account_amount,
clean_up_account_amount,
reserved: [0; 32],
});

Ok(())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct ChangeBaseAssetParametersAccounts<'info> {
#[account(constraint = protocol.authority == authority.key() @ ProtocolError::NotAProtocolAuthority)]
pub authority: Signer<'info>,
#[account(seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
#[account(mut)]
pub base_asset: Account<'info, BaseAssetInfo>,
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct ChangeProtocolFeesAccounts<'info> {
#[account(constraint = protocol.authority == authority.key() @ ProtocolError::NotAProtocolAuthority)]
pub authority: Signer<'info>,
#[account(mut, seeds = [PROTOCOL_SEED.as_bytes()], bump = protocol.bump)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
}

fn validate(settle_fees: Option<FeeParameters>, default_fees: Option<FeeParameters>) -> Result<()> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,5 @@ pub struct CloseProtocolStateAccounts<'info> {
seeds = [PROTOCOL_SEED.as_bytes()],
bump
)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
}
3 changes: 2 additions & 1 deletion rfq/program/src/instructions/protocol/initialize_protocol.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ pub struct InitializeProtocolAccounts<'info> {
space = ProtocolState::get_allocated_size(),
bump
)]
pub protocol: Account<'info, ProtocolState>,
pub protocol: Box<Account<'info, ProtocolState>>,
/// CHECK: is a valid risk engine program id
#[account(executable)]
pub risk_engine: AccountInfo<'info>,
Expand Down Expand Up @@ -54,6 +54,7 @@ pub fn initialize_protocol_instruction(
collateral_mint: collateral_mint.key(),
print_trade_providers: Default::default(),
instruments: Default::default(),
reserved: [0; 1024],
});

Ok(())
Expand Down
Loading

0 comments on commit 43ace11

Please sign in to comment.