Skip to main content

Trader

Struct Trader 

Source
pub struct Trader {
    pub client: Client,
}
Expand description

Manages trading operations: order creation, cancellation, status lookup, orderbook access, historical prices, and user-specific order/market data.

Most endpoints require authentication via scoped HMAC token or legacy API key.

§Convenience Methods

For the most common trading workflows, use the high-level methods:

Fields§

§client: Client

Implementations§

Source§

impl Trader

Source

pub async fn create_order( &self, order_request: &str, ) -> Result<CreateOrderResponse, LimitlessError>

Create a new order on a prediction market.

Supports GTC (Good Till Cancelled) and FOK (Fill or Kill) order types. CLOB orders require EIP-712 signatures; AMM orders use a different flow.

§Arguments
  • order_request — Serialized JSON body matching the Create Order schema.
Source

pub async fn order_status_batch( &self, request_body: &str, ) -> Result<OrderStatusBatchResponse, LimitlessError>

Fetch statuses for multiple orders in batch.

Look up by orderId or clientOrderId (provide exactly one per item). Accepts up to 50 items per request.

Source

pub async fn cancel_combined( &self, request_body: &str, ) -> Result<CancelOrderResponse, LimitlessError>

Cancel a single order by orderId or clientOrderId (combined endpoint).

Source

pub async fn cancel_batch( &self, request_body: &str, ) -> Result<CancelBatchResponse, LimitlessError>

Cancel multiple orders by internal orderIds (batch).

Source

pub async fn cancel_order_by_id( &self, order_id: &str, ) -> Result<CancelOrderResponse, LimitlessError>

Cancel a single order by internal orderId (legacy endpoint).

Source

pub async fn cancel_all_in_market( &self, slug: &str, ) -> Result<CancelAllResponse, LimitlessError>

Cancel all orders for the authenticated user in a specific market.

Source

pub async fn get_orderbook( &self, slug: &str, ) -> Result<OrderbookResponse, LimitlessError>

Get the current orderbook for a market.

Source

pub async fn get_historical_prices( &self, slug: &str, interval: Option<&str>, ) -> Result<Vec<HistoricalPriceData>, LimitlessError>

Get historical price data for a market.

Source

pub async fn get_locked_balance( &self, slug: &str, ) -> Result<LockedBalanceResponse, LimitlessError>

Get the amount of funds locked in open orders for the authenticated user.

Source

pub async fn get_user_orders( &self, slug: &str, statuses: Option<&[&str]>, limit: Option<u64>, ) -> Result<UserOrdersResponse, LimitlessError>

Get all orders placed by the authenticated user for a specific market.

Source

pub async fn get_market_events( &self, slug: &str, page: Option<u64>, limit: Option<u64>, ) -> Result<MarketEventsResponse, LimitlessError>

Get recent market events (trades, orders, liquidity changes).

Source

pub async fn buy_gtc( &self, private_key: &str, market_slug: &str, token_id: &str, price: f64, size: f64, owner_id: u64, ) -> Result<CreateOrderResponse, LimitlessError>

Place a GTC buy limit order — the simplest way to buy YES/NO shares.

Handles: fetch venue contract → validate → build EIP-712 order → sign → submit.

§Arguments
  • private_key — 0x-prefixed hex private key for signing
  • market_slug — Market identifier (e.g., “btc-above-100k-jul-4”)
  • token_id — The outcome token ID as a decimal string (e.g., from market.outcomes[0].token_id)
  • price — Price between 0 and 1 (e.g., 0.55 for $0.55)
  • size — Number of shares to buy
  • owner_id — Your profile ID (from GET /profiles/:address)
Source

pub async fn sell_gtc( &self, private_key: &str, market_slug: &str, token_id: &str, price: f64, size: f64, owner_id: u64, ) -> Result<CreateOrderResponse, LimitlessError>

Place a GTC sell limit order — the simplest way to sell YES/NO shares.

Source

pub async fn buy_fok( &self, private_key: &str, market_slug: &str, token_id: &str, usdc_amount: f64, owner_id: u64, ) -> Result<CreateOrderResponse, LimitlessError>

Place a FOK buy market order — buy shares at market price.

Source

pub async fn sell_fok( &self, private_key: &str, market_slug: &str, token_id: &str, share_amount: f64, owner_id: u64, ) -> Result<CreateOrderResponse, LimitlessError>

Place a FOK sell market order — sell shares at market price.

Source

pub async fn cancel_all( &self, slug: &str, ) -> Result<CancelAllResponse, LimitlessError>

Cancel all open orders in a market (convenience alias).

Trait Implementations§

Source§

impl Clone for Trader

Source§

fn clone(&self) -> Trader

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Limitless for Trader

Source§

fn new(api_key: Option<String>, secret: Option<String>) -> Self

Create a new manager instance with optional API key and secret. Read more
Source§

fn new_with_config( config: &Config, api_key: Option<String>, secret: Option<String>, ) -> Self

Create a new manager instance with a custom Config.

Auto Trait Implementations§

Blanket Implementations§

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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<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