Cursor

Struct Cursor 

Source
pub struct Cursor<T: FromStr + ToString> { /* private fields */ }
Expand description

A cursor implementation for use with GraphQL, implements async_graphql::connection::CursorType.

The Cursor consists of a prefix and a ID part. The prefix specifies what kind of object it refers to and the ID specifies which specific object it refers to.

let cursor = Cursor::new("Album", 1);

assert_eq!(cursor.encode_cursor(), "QWxidW06MQ=="); // Album:1

Implementations§

Source§

impl<T> Cursor<T>
where T: FromStr + ToString + Clone,

Source

pub fn new(prefix: &str, value: T) -> Cursor<T>

Create a new Cursor with the given prefix and value.

This can be used by server implementations to create the appropriate cursor.

Source

pub fn into_prefix(self, prefix: &str) -> Result<T, CursorError>

Deconstruct this cursor into the appropriate ID when its prefix matches.

This function can be used by the server to extract the contained ID. It returns Error when the cursor does not have the specified prefix.


let cursor = Cursor::new("MyPrefix", 10);

assert_eq!(cursor.into_prefix("MyPrefix"), Ok(10));
assert_eq!(cursor.into_prefix("OtherPrefix"), Err(CursorError::InvalidIdentifier));

Trait Implementations§

Source§

impl<T: Clone + FromStr + ToString> Clone for Cursor<T>

Source§

fn clone(&self) -> Cursor<T>

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl<T: FromStr + ToString> CursorType for Cursor<T>

Implementation for async_graphql cursors

Source§

fn decode_cursor(s: &str) -> Result<Self, Self::Error>

Decode the GraphQL input string into a Cursor

Source§

fn encode_cursor(&self) -> String

Encode the Cursor to a string for use in the GraphQL answer

Source§

type Error = CursorError

Error type for decode_cursor.

Auto Trait Implementations§

§

impl<T> Freeze for Cursor<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Cursor<T>
where T: RefUnwindSafe,

§

impl<T> Send for Cursor<T>
where T: Send,

§

impl<T> Sync for Cursor<T>
where T: Sync,

§

impl<T> Unpin for Cursor<T>
where T: Unpin,

§

impl<T> UnwindSafe for Cursor<T>
where 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> 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, 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> 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.