Struct TransactionBuilder

Source
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>

Source

pub fn new<'b>( program_data: &'b ProgramData, sub_account: Pubkey, user: Cow<'b, User>, delegated: bool, ) -> Self
where 'b: 'a,

Initialize a new TransactionBuilder for default signer

  • program_data - program data from chain
  • sub_account - drift sub-account address
  • user - drift sub-account data
  • delegated - set true to build tx for delegated signing
Source

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)

Source

pub fn legacy(self) -> Self

Use legacy tx mode

Source

pub fn lookup_tables(self, lookup_tables: &[AddressLookupTableAccount]) -> Self

Extend the tx lookup tables (always includes the defacto drift LUTs)

Source

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
Source

pub fn add_ix(self, ix: Instruction) -> Self

Append an ix to the Tx

Source

pub fn deposit( self, amount: u64, spot_market_index: u16, user_token_account: Pubkey, reduce_only: Option<bool>, ) -> Self

Deposit collateral into account

Source

pub fn withdraw( self, amount: u64, spot_market_index: u16, user_token_account: Pubkey, reduce_only: Option<bool>, ) -> Self

Withdraw collateral from the account

Source

pub fn place_orders(self, orders: Vec<OrderParams>) -> Self

Place new orders for account

  • orders list of orders to place
Source

pub fn cancel_all_orders(self) -> Self

Cancel all orders for account

Source

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
Source

pub fn cancel_orders_by_id(self, order_ids: Vec<u32>) -> Self

Cancel orders given ids

Source

pub fn cancel_orders_by_user_id(self, user_order_ids: Vec<u8>) -> Self

Cancel orders by given user ids

Source

pub fn modify_orders(self, orders: &[(u32, ModifyOrderParams)]) -> Self

Modify existing order(s) by order id

Source

pub fn modify_orders_by_user_id( self, orders: &[(u8, ModifyOrderParams)], ) -> Self

Modify existing order(s) by user order id

Source

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 place
  • taker_info - taker account address and data
  • taker_order_id - the id of the taker’s order to match with
  • referrer - pubkey of the taker’s referrer account, if any
  • fulfillment_type - type of fill for spot orders, ignored for perp orders
Source

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 place
  • maker_info - pubkey of the maker/counter-party to take against and account data
  • referrer - pubkey of the maker’s referrer account, if any
  • fulfillment_type - type of fill for spot orders, ignored for perp orders
Source

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 fill
  • signed_order_info - the signed swift order info (i.e from taker)
  • taker_account - taker account data
  • taker_account_referrer - taker account referrer key
Source

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 info
  • taker_account - taker subaccount data
Source

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 subaccount
  • margin_ratio - new margin ratio in MARGIN_PRECISION

MARGIN_PRECISION => 1x leverage MARGIN_PRECISION * 10 => .1x leverage MARGIN_PRECISION / 10 => 10x leverage

Source

pub fn build(self) -> VersionedMessage

Build the transaction message ready for signing and sending

Source

pub fn program_data(&self) -> &ProgramData

Source

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

Source§

type Aligner = AlignTo1<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<1024> for T

Source§

type Aligner = AlignTo1024<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<128> for T

Source§

type Aligner = AlignTo128<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<16> for T

Source§

type Aligner = AlignTo16<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<16384> for T

Source§

type Aligner = AlignTo16384<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<2> for T

Source§

type Aligner = AlignTo2<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<2048> for T

Source§

type Aligner = AlignTo2048<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<256> for T

Source§

type Aligner = AlignTo256<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<32> for T

Source§

type Aligner = AlignTo32<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<32768> for T

Source§

type Aligner = AlignTo32768<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<4> for T

Source§

type Aligner = AlignTo4<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<4096> for T

Source§

type Aligner = AlignTo4096<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<512> for T

Source§

type Aligner = AlignTo512<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<64> for T

Source§

type Aligner = AlignTo64<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<8> for T

Source§

type Aligner = AlignTo8<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<8192> for T

Source§

type Aligner = AlignTo8192<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<S> ROExtAcc for S

Source§

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
Source§

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
Source§

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
Source§

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
Source§

impl<S> ROExtOps<Aligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<S> ROExtOps<Unaligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> SelfOps for T
where T: ?Sized,

Source§

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
Source§

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
Source§

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
Source§

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as 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
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
Source§

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
Source§

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
Source§

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
Source§

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
Source§

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
Source§

impl<This> TransmuteElement for This
where This: ?Sized,

Source§

unsafe fn transmute_element<T>(self) -> Self::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> TypeIdentity for T
where T: ?Sized,

Source§

type Type = T

This is always Self.
Source§

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
Source§

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
Source§

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
Source§

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
Source§

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
Source§

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
Source§

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
Source§

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
Source§

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
Source§

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,