Struct Query

Source
pub struct Query {
    pub fields: Map<Key, Set>,
    pub filter: Map<Path, Value>,
    pub include: Set<Path>,
    pub page: Option<Page>,
    pub sort: Set<Sort>,
    /* private fields */
}
Expand description

Represents well-known query parameters.

Fields§

§fields: Map<Key, Set>

A map where each key is a type name and the value is set of field names that the client wishes to receive for the given type. If this is not present when decoding a query string, an empty map is used (no allocation is required).

It is recommeneded that consumers of this crate interpret a None value as the client specifying that they want all of the available fields for a given type. This behavior is already implemented when rendering a type that implements the Resource trait via the resource! macro.

For more information, check out the sparse fieldsets section of the JSON API specification.

§filter: Map<Path, Value>

A map where each key is a field path and the value is the value the client would like each item in the return document to have for the given field.

For more information, check out the [filter] section of the JSON API specification.

§include: Set<Path>

A set of relationship paths that specify included resources a client wishes to receive in addition to a document’s primary data.

For more information, check out the inclusion of related resources section of the JSON API specification.

§page: Option<Page>

Optional pagination parameters. To make life easier when this value is None, the Page struct implements a sensible default.

For more information, check out the pagination section of the JSON API specification.

§sort: Set<Sort>

A set of sort instructions. Each element in the set contains the field name, and the sort direction (ascending or descending).

When a client specifies a field to sort by, if it is prefixed with '-' (i.e sort=-created-at) the instruction is interpreted to mean “sort by the field ‘created-at’ in descending order”.

For more information, check out the sorting section of the JSON API specification.

Implementations§

Source§

impl Query

Source

pub fn new() -> Self

Returns the decoded equivalent of an empty query string. Does not require any allocations.

Source

pub fn builder() -> Builder

Returns a query builder that can be used to create a new query.

Trait Implementations§

Source§

impl Clone for Query

Source§

fn clone(&self) -> Query

Returns a copy 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 Debug for Query

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Query

Source§

fn default() -> Query

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for Query

Source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for Query

Source§

fn eq(&self, other: &Query) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for Query

Source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for Query

Auto Trait Implementations§

§

impl Freeze for Query

§

impl RefUnwindSafe for Query

§

impl Send for Query

§

impl Sync for Query

§

impl Unpin for Query

§

impl UnwindSafe for Query

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.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,