Skip to content

Trade

FreeValueStandardPro

Fetch the trade at a specific time of day across a date range for an option.

  • Returns the last trade reported by OPRA at a specified millisecond of the day.
  • Trade condition mappings can be found here.
  • Extended trade conditions are not reported by OPRA for options, so they can be ignored.
  • The time_of_dayparameter represents the 00:00:00.000 ET that the trade should be provided for.
rust
pub fn option_at_time_trade(
    &self,
    symbol: &str,
    expiration: &str,
    start_date: &str,
    end_date: &str,
    time_of_day: &str,
) -> OptionAtTimeTradeBuilder<'_>

Optional parameters chain on the builder: .strike(&str), .right(&str), .max_dte(i32), .strike_range(i32). Execute with .awaitResult<Vec<TradeTick>, Error>, or decode chunk-by-chunk with .stream(handler).

Example

rust
let rows = tdx
    .option_at_time_trade("SPY", "20250321", "20250303", "20250306", "10:30:00.000")
    .strike("570")
    .right("C")
    .await?;
for t in &rows {
    println!("date={} ms_of_day={} price={} size={}", t.date, t.ms_of_day, t.price, t.size);
}

Parameters

NameTypeRequiredDefaultDescription
symbolstringyesTicker symbol (e.g. AAPL)
expirationdateyesExpiration date YYYYMMDD
start_datedateyesStart date YYYYMMDD
end_datedateyesEnd date YYYYMMDD
time_of_daystringyesET wall-clock time in HH:MM:SS.SSS (e.g. 09:30:00.000 for 9:30 AM ET; legacy 34200000 is also accepted)
strikestringno*Strike price in dollars as a string (e.g. 500 or 17.5). Use * for wildcard selection.
rightstringnobothOption side. Accepted values: call, put, both.
max_dteintnoMaximum days to expiration
strike_rangeintnoStrike range filter
timeout_msintnoPer-request deadline in milliseconds. 0 means no deadline.

Response

Rows of TradeTick:

FieldTypeDescription
ms_of_dayi32Milliseconds since midnight Eastern Time.
sequencei32Exchange-assigned trade sequence number.
ext_condition1i32Additional trade condition code.
ext_condition2i32Additional trade condition code.
ext_condition3i32Additional trade condition code.
ext_condition4i32Additional trade condition code.
conditioni32Trade condition code.
sizei32Number of contracts or shares traded.
exchangei32Exchange code where the trade executed.
pricef64Trade price.
condition_flagsi32Trade condition flags bitmap.
price_flagsi32Trade price flags bitmap.
volume_typei32Volume reporting mode: 0 = incremental, 1 = cumulative.
records_backi32Offset of this record behind the most recent record.
datei32Trading date as a YYYYMMDD integer.

Wildcard requests additionally populate expiration (YYYYMMDD), strike (dollars), and right ("C" / "P") on every row to identify the contract; on single-contract requests these are absent (None / null / undefined; the Rust and C rows carry the documented 0 / 0.0 / '\0' fills).

Released under the Apache-2.0 License.