pub struct Query<P> {
pub operation: Operation,
/* private fields */
}Expand description
A predicate that matches requests by query parameters.
Returns Cacheable when the query parameter
satisfies the operation, NonCacheable otherwise.
§Type Parameters
P- The inner predicate to chain with. UseQuery::newto start a new predicate chain (usesNeutralinternally), or use theQueryPredicateextension trait to chain onto an existing predicate.
§Examples
use hitbox_http::predicates::request::query::{Query, Operation};
// Cache only when "format" query parameter is "json"
let predicate = Query::new(Operation::Eq("format".into(), "json".into()));Fields§
§operation: OperationThe operation to perform on the query parameter.
Implementations§
Source§impl<S> Query<Neutral<S>>
impl<S> Query<Neutral<S>>
Sourcepub fn new(operation: Operation) -> Self
pub fn new(operation: Operation) -> Self
Creates a predicate that matches query parameters against the operation.
Returns Cacheable when
the query parameter satisfies the operation, NonCacheable otherwise.
Chain onto existing predicates using QueryPredicate::query instead
if you already have a predicate chain.
Trait Implementations§
Auto Trait Implementations§
impl<P> Freeze for Query<P>where
P: Freeze,
impl<P> RefUnwindSafe for Query<P>where
P: RefUnwindSafe,
impl<P> Send for Query<P>where
P: Send,
impl<P> Sync for Query<P>where
P: Sync,
impl<P> Unpin for Query<P>where
P: Unpin,
impl<P> UnwindSafe for Query<P>where
P: UnwindSafe,
Blanket Implementations§
Source§impl<P> BodyPredicate for Pwhere
P: Predicate,
impl<P> BodyPredicate for Pwhere
P: Predicate,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<P> HeaderPredicate for Pwhere
P: Predicate,
impl<P> HeaderPredicate for Pwhere
P: Predicate,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<P> MethodPredicate for Pwhere
P: Predicate,
impl<P> MethodPredicate for Pwhere
P: Predicate,
Source§impl<P> PathPredicate for Pwhere
P: Predicate,
impl<P> PathPredicate for Pwhere
P: Predicate,
Source§impl<T> PredicateExt for Twhere
T: Predicate,
impl<T> PredicateExt for Twhere
T: Predicate,
Source§impl<P> QueryPredicate for Pwhere
P: Predicate,
impl<P> QueryPredicate for Pwhere
P: Predicate,
Source§impl<P> StatusCodePredicate for Pwhere
P: Predicate,
impl<P> StatusCodePredicate for Pwhere
P: Predicate,
Source§fn status_code(self, status_code: StatusCode) -> StatusCode<P>
fn status_code(self, status_code: StatusCode) -> StatusCode<P>
Matches an exact status code.
Source§fn status_code_in(self, codes: Vec<StatusCode>) -> StatusCode<P>
fn status_code_in(self, codes: Vec<StatusCode>) -> StatusCode<P>
Matches any of the specified status codes.
Source§fn status_code_range(self, start: StatusCode, end: StatusCode) -> StatusCode<P>
fn status_code_range(self, start: StatusCode, end: StatusCode) -> StatusCode<P>
Matches status codes within a range (inclusive).
Source§fn status_code_class(self, class: StatusClass) -> StatusCode<P>
fn status_code_class(self, class: StatusClass) -> StatusCode<P>
Matches all status codes in a class (e.g., all 2xx).
Source§impl<P> VersionPredicate for Pwhere
P: Predicate,
impl<P> VersionPredicate for Pwhere
P: Predicate,
Source§fn version(self, operation: Operation) -> HttpVersion<P>
fn version(self, operation: Operation) -> HttpVersion<P>
Adds a version match to this predicate chain.