Skip to main content

RawRequest

Struct RawRequest 

Source
pub struct RawRequest<'a> { /* private fields */ }
Expand description

Основные paginator-ы и scope-типы блокирующего API. Блокирующие HTTP-клиенты ISS API. Универсальный builder для произвольных ISS endpoint-ов.

Служит low-level escape hatch для endpoint-ов, которые не покрыты строгим high-level API.

Implementations§

Source§

impl<'a> RawIssRequestBuilder<'a>

Source

pub fn path(self, path: impl Into<String>) -> Self

Установить endpoint-path относительно /iss/.

Допускаются формы:

  • engines
  • engines.json
  • /iss/engines
Examples found in repository?
examples/actual_indexes_dump.rs (line 169)
153fn load_board_snapshots_all_pages(
154    moex_client: &Client,
155    engine: &str,
156    market: &str,
157    board: &str,
158) -> Result<Vec<SecuritySnapshot>, MoexError> {
159    let endpoint = format!("engines/{engine}/markets/{market}/boards/{board}/securities.json");
160    let mut start = 0_u32;
161    let mut snapshots = Vec::new();
162    let mut first_secid_on_previous_page = None;
163    let limit = BOARD_SNAPSHOTS_PAGE_LIMIT.to_string();
164
165    loop {
166        let payload = with_retry(retry_policy(), || {
167            moex_client
168                .raw()
169                .path(endpoint.as_str())
170                .only("securities,marketdata")
171                .columns("securities", "SECID,LOTSIZE")
172                .columns("marketdata", "SECID,LAST")
173                .param("start", start.to_string())
174                .param("limit", limit.as_str())
175                .send_payload()
176        })?;
177
178        let (page, first_secid_on_page) = parse_board_snapshots_page(&payload, endpoint.as_str())?;
179        if page.is_empty() {
180            break;
181        }
182
183        if let (Some(previous), Some(current)) =
184            (&first_secid_on_previous_page, &first_secid_on_page)
185            && previous == current
186        {
187            break;
188        }
189        first_secid_on_previous_page = first_secid_on_page;
190
191        let page_len = u32::try_from(page.len()).map_err(|_| MoexError::PaginationOverflow {
192            endpoint: endpoint.clone().into_boxed_str(),
193            start,
194            limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
195        })?;
196
197        snapshots.extend(page);
198        if page_len < BOARD_SNAPSHOTS_PAGE_LIMIT {
199            break;
200        }
201        start = start
202            .checked_add(page_len)
203            .ok_or_else(|| MoexError::PaginationOverflow {
204                endpoint: endpoint.clone().into_boxed_str(),
205                start,
206                limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
207            })?;
208    }
209
210    Ok(snapshots)
211}
Source

pub fn param(self, key: impl Into<String>, value: impl Into<String>) -> Self

Добавить query-параметр.

Examples found in repository?
examples/actual_indexes_dump.rs (line 173)
153fn load_board_snapshots_all_pages(
154    moex_client: &Client,
155    engine: &str,
156    market: &str,
157    board: &str,
158) -> Result<Vec<SecuritySnapshot>, MoexError> {
159    let endpoint = format!("engines/{engine}/markets/{market}/boards/{board}/securities.json");
160    let mut start = 0_u32;
161    let mut snapshots = Vec::new();
162    let mut first_secid_on_previous_page = None;
163    let limit = BOARD_SNAPSHOTS_PAGE_LIMIT.to_string();
164
165    loop {
166        let payload = with_retry(retry_policy(), || {
167            moex_client
168                .raw()
169                .path(endpoint.as_str())
170                .only("securities,marketdata")
171                .columns("securities", "SECID,LOTSIZE")
172                .columns("marketdata", "SECID,LAST")
173                .param("start", start.to_string())
174                .param("limit", limit.as_str())
175                .send_payload()
176        })?;
177
178        let (page, first_secid_on_page) = parse_board_snapshots_page(&payload, endpoint.as_str())?;
179        if page.is_empty() {
180            break;
181        }
182
183        if let (Some(previous), Some(current)) =
184            (&first_secid_on_previous_page, &first_secid_on_page)
185            && previous == current
186        {
187            break;
188        }
189        first_secid_on_previous_page = first_secid_on_page;
190
191        let page_len = u32::try_from(page.len()).map_err(|_| MoexError::PaginationOverflow {
192            endpoint: endpoint.clone().into_boxed_str(),
193            start,
194            limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
195        })?;
196
197        snapshots.extend(page);
198        if page_len < BOARD_SNAPSHOTS_PAGE_LIMIT {
199            break;
200        }
201        start = start
202            .checked_add(page_len)
203            .ok_or_else(|| MoexError::PaginationOverflow {
204                endpoint: endpoint.clone().into_boxed_str(),
205                start,
206                limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
207            })?;
208    }
209
210    Ok(snapshots)
211}
Source

pub fn only(self, tables: impl Into<String>) -> Self

Добавить параметр iss.only.

Examples found in repository?
examples/actual_indexes_dump.rs (line 170)
153fn load_board_snapshots_all_pages(
154    moex_client: &Client,
155    engine: &str,
156    market: &str,
157    board: &str,
158) -> Result<Vec<SecuritySnapshot>, MoexError> {
159    let endpoint = format!("engines/{engine}/markets/{market}/boards/{board}/securities.json");
160    let mut start = 0_u32;
161    let mut snapshots = Vec::new();
162    let mut first_secid_on_previous_page = None;
163    let limit = BOARD_SNAPSHOTS_PAGE_LIMIT.to_string();
164
165    loop {
166        let payload = with_retry(retry_policy(), || {
167            moex_client
168                .raw()
169                .path(endpoint.as_str())
170                .only("securities,marketdata")
171                .columns("securities", "SECID,LOTSIZE")
172                .columns("marketdata", "SECID,LAST")
173                .param("start", start.to_string())
174                .param("limit", limit.as_str())
175                .send_payload()
176        })?;
177
178        let (page, first_secid_on_page) = parse_board_snapshots_page(&payload, endpoint.as_str())?;
179        if page.is_empty() {
180            break;
181        }
182
183        if let (Some(previous), Some(current)) =
184            (&first_secid_on_previous_page, &first_secid_on_page)
185            && previous == current
186        {
187            break;
188        }
189        first_secid_on_previous_page = first_secid_on_page;
190
191        let page_len = u32::try_from(page.len()).map_err(|_| MoexError::PaginationOverflow {
192            endpoint: endpoint.clone().into_boxed_str(),
193            start,
194            limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
195        })?;
196
197        snapshots.extend(page);
198        if page_len < BOARD_SNAPSHOTS_PAGE_LIMIT {
199            break;
200        }
201        start = start
202            .checked_add(page_len)
203            .ok_or_else(|| MoexError::PaginationOverflow {
204                endpoint: endpoint.clone().into_boxed_str(),
205                start,
206                limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
207            })?;
208    }
209
210    Ok(snapshots)
211}
Source

pub fn columns( self, table: impl Into<String>, columns: impl Into<String>, ) -> Self

Добавить параметр <table>.columns.

Examples found in repository?
examples/actual_indexes_dump.rs (line 171)
153fn load_board_snapshots_all_pages(
154    moex_client: &Client,
155    engine: &str,
156    market: &str,
157    board: &str,
158) -> Result<Vec<SecuritySnapshot>, MoexError> {
159    let endpoint = format!("engines/{engine}/markets/{market}/boards/{board}/securities.json");
160    let mut start = 0_u32;
161    let mut snapshots = Vec::new();
162    let mut first_secid_on_previous_page = None;
163    let limit = BOARD_SNAPSHOTS_PAGE_LIMIT.to_string();
164
165    loop {
166        let payload = with_retry(retry_policy(), || {
167            moex_client
168                .raw()
169                .path(endpoint.as_str())
170                .only("securities,marketdata")
171                .columns("securities", "SECID,LOTSIZE")
172                .columns("marketdata", "SECID,LAST")
173                .param("start", start.to_string())
174                .param("limit", limit.as_str())
175                .send_payload()
176        })?;
177
178        let (page, first_secid_on_page) = parse_board_snapshots_page(&payload, endpoint.as_str())?;
179        if page.is_empty() {
180            break;
181        }
182
183        if let (Some(previous), Some(current)) =
184            (&first_secid_on_previous_page, &first_secid_on_page)
185            && previous == current
186        {
187            break;
188        }
189        first_secid_on_previous_page = first_secid_on_page;
190
191        let page_len = u32::try_from(page.len()).map_err(|_| MoexError::PaginationOverflow {
192            endpoint: endpoint.clone().into_boxed_str(),
193            start,
194            limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
195        })?;
196
197        snapshots.extend(page);
198        if page_len < BOARD_SNAPSHOTS_PAGE_LIMIT {
199            break;
200        }
201        start = start
202            .checked_add(page_len)
203            .ok_or_else(|| MoexError::PaginationOverflow {
204                endpoint: endpoint.clone().into_boxed_str(),
205                start,
206                limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
207            })?;
208    }
209
210    Ok(snapshots)
211}
Source

pub fn metadata(self, metadata: IssToggle) -> Self

Явно задать iss.meta для текущего raw-запроса.

Source

pub fn data(self, data: IssToggle) -> Self

Добавить параметр iss.data.

Source

pub fn json(self, json: impl Into<String>) -> Self

Добавить параметр iss.json.

Source

pub fn version(self, version: IssToggle) -> Self

Добавить параметр iss.version.

Source

pub fn options(self, options: IssRequestOptions) -> Self

Применить пакет системных iss.*-опций.

Source

pub fn send_response(self) -> Result<RawIssResponse, MoexError>

Выполнить raw-запрос и вернуть полный HTTP-ответ.

В отличие от send_payload, метод не проверяет 2xx и JSON-формат.

Source

pub fn send_payload(self) -> Result<String, MoexError>

Выполнить raw-запрос и вернуть тело ответа как строку.

Examples found in repository?
examples/actual_indexes_dump.rs (line 175)
153fn load_board_snapshots_all_pages(
154    moex_client: &Client,
155    engine: &str,
156    market: &str,
157    board: &str,
158) -> Result<Vec<SecuritySnapshot>, MoexError> {
159    let endpoint = format!("engines/{engine}/markets/{market}/boards/{board}/securities.json");
160    let mut start = 0_u32;
161    let mut snapshots = Vec::new();
162    let mut first_secid_on_previous_page = None;
163    let limit = BOARD_SNAPSHOTS_PAGE_LIMIT.to_string();
164
165    loop {
166        let payload = with_retry(retry_policy(), || {
167            moex_client
168                .raw()
169                .path(endpoint.as_str())
170                .only("securities,marketdata")
171                .columns("securities", "SECID,LOTSIZE")
172                .columns("marketdata", "SECID,LAST")
173                .param("start", start.to_string())
174                .param("limit", limit.as_str())
175                .send_payload()
176        })?;
177
178        let (page, first_secid_on_page) = parse_board_snapshots_page(&payload, endpoint.as_str())?;
179        if page.is_empty() {
180            break;
181        }
182
183        if let (Some(previous), Some(current)) =
184            (&first_secid_on_previous_page, &first_secid_on_page)
185            && previous == current
186        {
187            break;
188        }
189        first_secid_on_previous_page = first_secid_on_page;
190
191        let page_len = u32::try_from(page.len()).map_err(|_| MoexError::PaginationOverflow {
192            endpoint: endpoint.clone().into_boxed_str(),
193            start,
194            limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
195        })?;
196
197        snapshots.extend(page);
198        if page_len < BOARD_SNAPSHOTS_PAGE_LIMIT {
199            break;
200        }
201        start = start
202            .checked_add(page_len)
203            .ok_or_else(|| MoexError::PaginationOverflow {
204                endpoint: endpoint.clone().into_boxed_str(),
205                start,
206                limit: BOARD_SNAPSHOTS_PAGE_LIMIT,
207            })?;
208    }
209
210    Ok(snapshots)
211}
Source

pub fn send_json<T>(self) -> Result<T, MoexError>

Выполнить raw-запрос и декодировать JSON в пользовательский тип.

Source

pub fn send_table<T>( self, table: impl Into<String>, ) -> Result<Vec<T>, MoexError>

Выполнить raw-запрос и декодировать строки выбранной ISS-таблицы в пользовательский тип.

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