Skip to main content

PagesPager

Struct PagesPager 

Source
pub struct PagesPager<T, E, F, Fut>
where F: FnMut(ODataQuery) -> Fut, Fut: Future<Output = Result<Page<T>, E>>,
{ /* private fields */ }
Expand description

A cursor-based pager that implements Stream for pages.

This pager yields entire pages instead of individual items.

§Type Parameters

  • T - The item type
  • E - The error type
  • F - The fetcher function type
  • Fut - The future returned by the fetcher

Implementations§

Source§

impl<T, E, F, Fut> PagesPager<T, E, F, Fut>
where F: FnMut(ODataQuery) -> Fut, Fut: Future<Output = Result<Page<T>, E>>,

Source

pub fn new(base_query: ODataQuery, fetcher: F) -> Self

Create a new pages pager with the given base query and fetcher function.

§Arguments
  • base_query - The base OData query (without cursor)
  • fetcher - Function that fetches a page given an ODataQuery
§Example
let pager = PagesPager::new(query, |q| async move {
    client.list_users(q).await
});

Trait Implementations§

Source§

impl<T, E, F, Fut> Stream for PagesPager<T, E, F, Fut>
where F: FnMut(ODataQuery) -> Fut, Fut: Future<Output = Result<Page<T>, E>>,

Source§

type Item = Result<Page<T>, PagerError<E>>

Values yielded by the stream.
Source§

fn poll_next( self: Pin<&mut Self>, cx: &mut Context<'_>, ) -> Poll<Option<Self::Item>>

Attempt to pull out the next value of this stream, registering the current task for wakeup if the value is not yet available, and returning None if the stream is exhausted. Read more
Source§

fn size_hint(&self) -> (usize, Option<usize>)

Returns the bounds on the remaining length of the stream. Read more
Source§

impl<'__pin, T, E, F, Fut> Unpin for PagesPager<T, E, F, Fut>
where PinnedFieldsOf<__Origin<'__pin, T, E, F, Fut>>: Unpin, F: FnMut(ODataQuery) -> Fut, Fut: Future<Output = Result<Page<T>, E>>,

Auto Trait Implementations§

§

impl<T, E, F, Fut> Freeze for PagesPager<T, E, F, Fut>
where F: Freeze, Fut: Freeze,

§

impl<T, E, F, Fut> RefUnwindSafe for PagesPager<T, E, F, Fut>

§

impl<T, E, F, Fut> Send for PagesPager<T, E, F, Fut>
where F: Send, Fut: Send,

§

impl<T, E, F, Fut> Sync for PagesPager<T, E, F, Fut>
where F: Sync, Fut: Sync,

§

impl<T, E, F, Fut> UnsafeUnpin for PagesPager<T, E, F, Fut>
where F: UnsafeUnpin, Fut: UnsafeUnpin,

§

impl<T, E, F, Fut> UnwindSafe for PagesPager<T, E, F, Fut>
where F: UnwindSafe, Fut: UnwindSafe,

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, 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> Same for T

Source§

type Output = T

Should always be Self
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<S, T, E> TryStream for S
where S: Stream<Item = Result<T, E>> + ?Sized,

Source§

type Ok = T

The type of successful values yielded by this future
Source§

type Error = E

The type of failures yielded by this future
Source§

fn try_poll_next( self: Pin<&mut S>, cx: &mut Context<'_>, ) -> Poll<Option<Result<<S as TryStream>::Ok, <S as TryStream>::Error>>>

Poll this TryStream as if it were a Stream. Read more
Source§

impl<T> WithSecurityContext for T

Source§

fn security_ctx<'a>(&'a self, ctx: &'a SecurityContext) -> Secured<'a, T>

Binds a security context to this client, returning a Secured wrapper. Read more