Skip to main content

CursorPager

Struct CursorPager 

Source
pub struct CursorPager<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 paginated items.

This pager manages cursor state internally and fetches pages on-demand, yielding individual items from the stream.

§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> CursorPager<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 cursor 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 = CursorPager::new(query, |q| async move {
    client.list_users(q).await
});

Trait Implementations§

Source§

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

Source§

type Item = Result<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 CursorPager<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 CursorPager<T, E, F, Fut>
where F: Freeze, Fut: Freeze,

§

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

§

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

§

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

§

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

§

impl<T, E, F, Fut> UnwindSafe for CursorPager<T, E, F, Fut>
where F: UnwindSafe, Fut: UnwindSafe, T: 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