Skip to main content

QueryBuilder

Struct QueryBuilder 

Source
pub struct QueryBuilder<'a> { /* private fields */ }
Available on crate feature export-azure only.
Expand description

A builder for setting query parameters on a URL.

This builder allows you to set multiple query parameters, overwriting any existing values with the same key. Call build() to apply the changes.

Implementations§

Source§

impl<'a> QueryBuilder<'a>

Source

pub fn append_key_only( &mut self, key: impl Into<Cow<'a, str>>, ) -> &mut QueryBuilder<'a>

Appends a key without a value to the URL query string.

This is useful for boolean flags or markers in query strings that don’t require a value.

Returns &mut Self to allow chaining multiple calls.

§Examples
use typespec_client_core::http::{Url, UrlExt as _};

let mut url: Url = "https://contoso.com".parse().unwrap();
let mut query_builder = url.query_builder();
query_builder
    .append_key_only("debug")
    .append_pair("a", "1");
query_builder.build();
let params: Vec<_> = url.query_pairs().collect();
assert!(params.contains(&("debug".into(), "".into())));
assert!(params.contains(&("a".into(), "1".into())));
Source

pub fn append_pair( &mut self, key: impl Into<Cow<'a, str>>, value: impl Into<Cow<'a, str>>, ) -> &mut QueryBuilder<'a>

Appends a query parameter to the URL.

If the key already exists, this adds an additional value for that key (allowing duplicates). Use set_pair to overwrite existing values instead.

Both key and value accept types that can be converted to Cow<'a, str>, which includes &'a str, String, and Cow<'a, str>. This avoids unnecessary allocations when using string literals.

Returns &mut Self to allow chaining multiple calls.

§Examples
use typespec_client_core::http::{Url, UrlExt as _};

let mut url: Url = "https://contoso.com?a=1".parse().unwrap();
let mut query_builder = url.query_builder();
query_builder
    .append_pair("a", "2")
    .append_pair("b", "3");
query_builder.build();
let params: Vec<_> = url.query_pairs().collect();
assert!(params.contains(&("a".into(), "1".into())));
assert!(params.contains(&("a".into(), "2".into())));
assert!(params.contains(&("b".into(), "3".into())));
Source

pub fn set_pair( &mut self, key: impl Into<Cow<'a, str>>, value: impl Into<Cow<'a, str>>, ) -> &mut QueryBuilder<'a>

Sets a query parameter, overwriting any existing value with the same key.

If the key already exists, all existing values for that key are replaced with the new value. If the key doesn’t exist, it’s added to the end of the query parameters. Use append_pair to add additional values without replacing existing ones.

Both key and value accept types that can be converted to Cow<'a, str>, which includes &'a str, String, and Cow<'a, str>. This avoids unnecessary allocations when using string literals.

Returns &mut Self to allow chaining multiple calls.

§Examples
use typespec_client_core::http::{Url, UrlExt as _};

let mut url: Url = "https://contoso.com?a=1&b=2".parse().unwrap();
let mut query_builder = url.query_builder();
query_builder
    .set_pair("a", "new_value")
    .set_pair("c", "3");
query_builder.build();
let params: Vec<_> = url.query_pairs().collect();
assert!(params.contains(&("a".into(), "new_value".into())));
assert!(params.contains(&("b".into(), "2".into())));
assert!(params.contains(&("c".into(), "3".into())));
Source

pub fn build(self)

Applies all the query parameter changes to the URL.

Auto Trait Implementations§

§

impl<'a> Freeze for QueryBuilder<'a>

§

impl<'a> RefUnwindSafe for QueryBuilder<'a>

§

impl<'a> Send for QueryBuilder<'a>

§

impl<'a> Sync for QueryBuilder<'a>

§

impl<'a> Unpin for QueryBuilder<'a>

§

impl<'a> UnsafeUnpin for QueryBuilder<'a>

§

impl<'a> !UnwindSafe for QueryBuilder<'a>

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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more