Skip to main content

HttpKeyStore

Struct HttpKeyStore 

Source
pub struct HttpKeyStore { /* private fields */ }
Available on crate feature http only.
Expand description

A key store that fetches from an HTTP endpoint on every request.

This implementation does not cache keys. Every call to get_key or get_keyset will make an HTTP request.

For production use with high request volumes, wrap this in CachedKeyStore with MokaKeyCache:

use jwk_simple::jwks::{CachedKeyStore, HttpKeyStore, MokaKeyCache};
use std::time::Duration;

let remote = HttpKeyStore::new("https://example.com/.well-known/jwks.json")?;
let cache = MokaKeyCache::new(Duration::from_secs(300));
let cached = CachedKeyStore::new(cache, remote);

§Examples

use jwk_simple::jwks::{HttpKeyStore, KeyStore};

let store = HttpKeyStore::new("https://example.com/.well-known/jwks.json")?;
let key = store.get_key("my-key-id").await?;

§Custom HTTP Client

You can provide a custom reqwest::Client for full control over HTTP behavior:

use jwk_simple::jwks::HttpKeyStore;
use std::time::Duration;

let client = reqwest::Client::builder()
    .timeout(Duration::from_secs(10))
    .user_agent("my-app/1.0")
    .build()
    .unwrap();

let store = HttpKeyStore::new_with_client(
    "https://example.com/.well-known/jwks.json",
    client,
);

Implementations§

Source§

impl HttpKeyStore

Source

pub fn new(url: impl AsRef<str>) -> Result<Self>

Creates a new HttpKeyStore from a URL.

The URL must use the https scheme. To allow plain HTTP (e.g. in local development or testing), use new_insecure.

On native targets, uses a default HTTP client with a 30-second timeout. On wasm32, reqwest uses the browser/Fetch backend where client-level timeout configuration is not available. To customize the client, use new_with_client.

Source

pub fn new_with_client(url: impl AsRef<str>, client: Client) -> Result<Self>

Creates a new HttpKeyStore with a custom HTTP client.

The URL must use the https scheme. To allow plain HTTP, use new_with_client_insecure.

Use this to configure custom headers, proxies, TLS settings, and (on native targets) custom timeouts.

On wasm32, reqwest uses the browser/Fetch backend where client-level timeout configuration is not available.

§Examples
use jwk_simple::jwks::HttpKeyStore;
use std::time::Duration;

let client = reqwest::Client::builder()
    .timeout(Duration::from_secs(10))
    .build()
    .unwrap();

let store = HttpKeyStore::new_with_client(
    "https://example.com/.well-known/jwks.json",
    client,
)?;
Source

pub fn new_insecure(url: impl AsRef<str>) -> Result<Self>

Creates a new HttpKeyStore without enforcing HTTPS.

§Warning

This constructor skips the HTTPS scheme check and is intended only for local development or testing where HTTPS is not available. Do not use this in production — plain HTTP connections allow network attackers to tamper with JWKS responses and inject attacker-controlled keys.

Source

pub fn new_with_client_insecure( url: impl AsRef<str>, client: Client, ) -> Result<Self>

Creates a new HttpKeyStore with a custom HTTP client, without enforcing HTTPS.

§Warning

This constructor skips the HTTPS scheme check and is intended only for local development or testing where HTTPS is not available. Do not use this in production — plain HTTP connections allow network attackers to tamper with JWKS responses and inject attacker-controlled keys.

Trait Implementations§

Source§

impl Clone for HttpKeyStore

Source§

fn clone(&self) -> HttpKeyStore

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 Debug for HttpKeyStore

Source§

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

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

impl KeyStore for HttpKeyStore

Source§

fn get_keyset<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<KeySet>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Gets all available keys as a KeySet. Read more
Source§

fn get_key<'life0, 'life1, 'async_trait>( &'life0 self, kid: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<Option<Key>>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Gets a key by its key ID (kid). Read more

Auto Trait Implementations§

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<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
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> 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<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