pub struct TransactionBuilder<'a> { /* private fields */ }Expand description
Composable Tx builder for Drift program
Alternatively, use DriftClient::init_tx for simpler instantiation.
use drift_rs::{types::Context, TransactionBuilder, Wallet};
let wallet = Wallet::from_seed_bs58("seed");
let client = DriftClient::new(Context::DevNet, "api.example.com", wallet).await.unwrap();
let account_data = client.get_account(wallet.default_sub_account()).await.unwrap();
let tx = TransactionBuilder::new(client.program_data, wallet.default_sub_account(), account_data.into())
.cancel_all_orders()
.place_orders(&[
NewOrder::default().build(),
NewOrder::default().build(),
])
.legacy()
.build();
let signature = client.sign_and_send(tx, &wallet).await?;Implementations§
Source§impl<'a> TransactionBuilder<'a>
impl<'a> TransactionBuilder<'a>
Sourcepub fn new<'b>(
program_data: &'b ProgramData,
sub_account: Pubkey,
user: Cow<'b, User>,
delegated: bool,
) -> Selfwhere
'b: 'a,
pub fn new<'b>(
program_data: &'b ProgramData,
sub_account: Pubkey,
user: Cow<'b, User>,
delegated: bool,
) -> Selfwhere
'b: 'a,
Initialize a new TransactionBuilder for default signer
program_data- program data from chainsub_account- drift sub-account addressuser- drift sub-account datadelegated- set true to build tx for delegated signing
Sourcepub fn force_include_markets(
&mut self,
readable: &[MarketId],
writeable: &[MarketId],
)
pub fn force_include_markets( &mut self, readable: &[MarketId], writeable: &[MarketId], )
force given markets to be included in the final tx accounts list (ensure to call before building ixs)
Sourcepub fn lookup_tables(self, lookup_tables: &[AddressLookupTableAccount]) -> Self
pub fn lookup_tables(self, lookup_tables: &[AddressLookupTableAccount]) -> Self
Extend the tx lookup tables (always includes the defacto drift LUTs)
Sourcepub fn with_priority_fee(
self,
microlamports_per_cu: u64,
cu_limit: Option<u32>,
) -> Self
pub fn with_priority_fee( self, microlamports_per_cu: u64, cu_limit: Option<u32>, ) -> Self
Set the priority fee of the tx
microlamports_per_cu- the price per unit of compute in µ-lamports
Sourcepub fn add_ix(self, ix: Instruction) -> Self
pub fn add_ix(self, ix: Instruction) -> Self
Append an ix to the Tx
Sourcepub fn deposit(
self,
amount: u64,
spot_market_index: u16,
user_token_account: Pubkey,
reduce_only: Option<bool>,
) -> Self
pub fn deposit( self, amount: u64, spot_market_index: u16, user_token_account: Pubkey, reduce_only: Option<bool>, ) -> Self
Deposit collateral into account
Sourcepub fn withdraw(
self,
amount: u64,
spot_market_index: u16,
user_token_account: Pubkey,
reduce_only: Option<bool>,
) -> Self
pub fn withdraw( self, amount: u64, spot_market_index: u16, user_token_account: Pubkey, reduce_only: Option<bool>, ) -> Self
Withdraw collateral from the account
Sourcepub fn place_orders(self, orders: Vec<OrderParams>) -> Self
pub fn place_orders(self, orders: Vec<OrderParams>) -> Self
Place new orders for account
orderslist of orders to place
Sourcepub fn cancel_all_orders(self) -> Self
pub fn cancel_all_orders(self) -> Self
Cancel all orders for account
Sourcepub fn cancel_orders(
self,
market: (u16, MarketType),
direction: Option<PositionDirection>,
) -> Self
pub fn cancel_orders( self, market: (u16, MarketType), direction: Option<PositionDirection>, ) -> Self
Cancel account’s orders matching some criteria
market- tuple of market index and type (spot or perp)direction- long or short
Sourcepub fn cancel_orders_by_id(self, order_ids: Vec<u32>) -> Self
pub fn cancel_orders_by_id(self, order_ids: Vec<u32>) -> Self
Cancel orders given ids
Sourcepub fn cancel_orders_by_user_id(self, user_order_ids: Vec<u8>) -> Self
pub fn cancel_orders_by_user_id(self, user_order_ids: Vec<u8>) -> Self
Cancel orders by given user ids
Sourcepub fn modify_orders(self, orders: &[(u32, ModifyOrderParams)]) -> Self
pub fn modify_orders(self, orders: &[(u32, ModifyOrderParams)]) -> Self
Modify existing order(s) by order id
Sourcepub fn modify_orders_by_user_id(
self,
orders: &[(u8, ModifyOrderParams)],
) -> Self
pub fn modify_orders_by_user_id( self, orders: &[(u8, ModifyOrderParams)], ) -> Self
Modify existing order(s) by user order id
Sourcepub fn place_and_make(
self,
order: OrderParams,
taker_info: &(Pubkey, User),
taker_order_id: u32,
referrer: Option<Pubkey>,
fulfillment_type: Option<SpotFulfillmentType>,
) -> Self
pub fn place_and_make( self, order: OrderParams, taker_info: &(Pubkey, User), taker_order_id: u32, referrer: Option<Pubkey>, fulfillment_type: Option<SpotFulfillmentType>, ) -> Self
Add a place and make instruction
order- the order to placetaker_info- taker account address and datataker_order_id- the id of the taker’s order to match withreferrer- pubkey of the taker’s referrer account, if anyfulfillment_type- type of fill for spot orders, ignored for perp orders
Sourcepub fn place_and_take(
self,
order: OrderParams,
maker_info: Option<(Pubkey, User)>,
referrer: Option<Pubkey>,
fulfillment_type: Option<SpotFulfillmentType>,
success_condition: Option<u32>,
) -> Self
pub fn place_and_take( self, order: OrderParams, maker_info: Option<(Pubkey, User)>, referrer: Option<Pubkey>, fulfillment_type: Option<SpotFulfillmentType>, success_condition: Option<u32>, ) -> Self
Add a place and take instruction
order- the order to placemaker_info- pubkey of the maker/counter-party to take against and account datareferrer- pubkey of the maker’s referrer account, if anyfulfillment_type- type of fill for spot orders, ignored for perp orders
Sourcepub fn place_and_make_swift_order(
self,
maker_order: OrderParams,
signed_order_info: &SignedOrderInfo,
taker_account: &User,
taker_account_referrer: &Pubkey,
) -> Self
pub fn place_and_make_swift_order( self, maker_order: OrderParams, signed_order_info: &SignedOrderInfo, taker_account: &User, taker_account_referrer: &Pubkey, ) -> Self
Place and try to fill (make) against the swift order (Perps only)
maker_order- order params defined by the maker, e.g. partial or full fillsigned_order_info- the signed swift order info (i.e from taker)taker_account- taker account datataker_account_referrer- taker account referrer key
Sourcepub fn place_swift_order(
self,
signed_order_info: &SignedOrderInfo,
taker_account: &User,
) -> Self
pub fn place_swift_order( self, signed_order_info: &SignedOrderInfo, taker_account: &User, ) -> Self
Place a swift order (Perps only)
☢️ this Ix will not fill by itself. The caller should add a subsequent Ix
e.g. with JIT proxy, to atomically place and fill the order
or see place_and_make_swift_order
signed_order_info- the signed swift order infotaker_account- taker subaccount data
Sourcepub fn set_max_initial_margin_ratio(
self,
margin_ratio: u32,
sub_account_id: u16,
) -> Self
pub fn set_max_initial_margin_ratio( self, margin_ratio: u32, sub_account_id: u16, ) -> Self
Set the subaccount’s max initial margin ratio.
sub_account_id- index of the subaccountmargin_ratio- new margin ratio in MARGIN_PRECISION
MARGIN_PRECISION => 1x leverage MARGIN_PRECISION * 10 => .1x leverage MARGIN_PRECISION / 10 => 10x leverage
Sourcepub fn build(self) -> VersionedMessage
pub fn build(self) -> VersionedMessage
Build the transaction message ready for signing and sending
pub fn program_data(&self) -> &ProgramData
pub fn account_data(&self) -> &Cow<'_, User>
Auto Trait Implementations§
impl<'a> Freeze for TransactionBuilder<'a>
impl<'a> RefUnwindSafe for TransactionBuilder<'a>
impl<'a> Send for TransactionBuilder<'a>
impl<'a> Sync for TransactionBuilder<'a>
impl<'a> Unpin for TransactionBuilder<'a>
impl<'a> UnwindSafe for TransactionBuilder<'a>
Blanket Implementations§
Source§impl<T> AlignerFor<1> for T
impl<T> AlignerFor<1> for T
Source§impl<T> AlignerFor<1024> for T
impl<T> AlignerFor<1024> for T
Source§type Aligner = AlignTo1024<T>
type Aligner = AlignTo1024<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<128> for T
impl<T> AlignerFor<128> for T
Source§type Aligner = AlignTo128<T>
type Aligner = AlignTo128<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<16> for T
impl<T> AlignerFor<16> for T
Source§impl<T> AlignerFor<16384> for T
impl<T> AlignerFor<16384> for T
Source§type Aligner = AlignTo16384<T>
type Aligner = AlignTo16384<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<2> for T
impl<T> AlignerFor<2> for T
Source§impl<T> AlignerFor<2048> for T
impl<T> AlignerFor<2048> for T
Source§type Aligner = AlignTo2048<T>
type Aligner = AlignTo2048<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<256> for T
impl<T> AlignerFor<256> for T
Source§type Aligner = AlignTo256<T>
type Aligner = AlignTo256<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<32> for T
impl<T> AlignerFor<32> for T
Source§impl<T> AlignerFor<32768> for T
impl<T> AlignerFor<32768> for T
Source§type Aligner = AlignTo32768<T>
type Aligner = AlignTo32768<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<4> for T
impl<T> AlignerFor<4> for T
Source§impl<T> AlignerFor<4096> for T
impl<T> AlignerFor<4096> for T
Source§type Aligner = AlignTo4096<T>
type Aligner = AlignTo4096<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<512> for T
impl<T> AlignerFor<512> for T
Source§type Aligner = AlignTo512<T>
type Aligner = AlignTo512<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<64> for T
impl<T> AlignerFor<64> for T
Source§impl<T> AlignerFor<8> for T
impl<T> AlignerFor<8> for T
Source§impl<T> AlignerFor<8192> for T
impl<T> AlignerFor<8192> for T
Source§type Aligner = AlignTo8192<T>
type Aligner = AlignTo8192<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T, W> HasTypeWitness<W> for Twhere
W: MakeTypeWitness<Arg = T>,
T: ?Sized,
impl<T, W> HasTypeWitness<W> for Twhere
W: MakeTypeWitness<Arg = T>,
T: ?Sized,
Source§impl<T> Identity for Twhere
T: ?Sized,
impl<T> Identity for Twhere
T: ?Sized,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::RequestSource§impl<S> ROExtAcc for S
impl<S> ROExtAcc for S
Source§fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
offset. Read moreSource§fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
offset. Read moreSource§fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
offset. Read moreSource§fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
offset. Read moreSource§impl<S> ROExtOps<Aligned> for S
impl<S> ROExtOps<Aligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
F: Copy,
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
F: Copy,
Source§impl<S> ROExtOps<Unaligned> for S
impl<S> ROExtOps<Unaligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
F: Copy,
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
F: Copy,
Source§impl<T> SelfOps for Twhere
T: ?Sized,
impl<T> SelfOps for Twhere
T: ?Sized,
Source§fn piped<F, U>(self, f: F) -> U
fn piped<F, U>(self, f: F) -> U
Source§fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
F: FnOnce(&'a Self) -> U,
fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
F: FnOnce(&'a Self) -> U,
piped except that the function takes &Self
Useful for functions that take &Self instead of Self. Read moreSource§fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
F: FnOnce(&'a mut Self) -> U,
fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
F: FnOnce(&'a mut Self) -> U,
piped, except that the function takes &mut Self.
Useful for functions that take &mut Self instead of Self.Source§fn mutated<F>(self, f: F) -> Self
fn mutated<F>(self, f: F) -> Self
Source§fn observe<F>(self, f: F) -> Self
fn observe<F>(self, f: F) -> Self
Source§fn as_ref_<T>(&self) -> &T
fn as_ref_<T>(&self) -> &T
AsRef,
using the turbofish .as_ref_::<_>() syntax. Read more