pub struct VhostMatcher { /* private fields */ }Expand description
Virtual host matcher with O(1) exact matching and wildcard fallback.
Security features:
- Limits wildcard complexity (max 3 wildcards, 253 char limit)
- Sanitizes host headers (rejects null bytes, invalid chars)
- Case-insensitive matching via pre-normalization
Performance features (Phase 1):
- Uses
Ascii<String>for case-insensitive keys (zero-allocation lookups) - Uses
ahash::RandomStatefor 2-3x faster HashMap operations
Implementations§
Source§impl VhostMatcher
impl VhostMatcher
Sourcepub fn new(sites: Vec<SiteConfig>) -> Result<Self, VhostError>
pub fn new(sites: Vec<SiteConfig>) -> Result<Self, VhostError>
Creates a new VhostMatcher from site configurations.
§Errors
Returns an error if:
- A wildcard pattern has too many wildcards
- A hostname exceeds the maximum length
- A wildcard pattern fails to compile
Sourcepub fn sanitize_host(host: &str) -> Result<String, VhostError>
pub fn sanitize_host(host: &str) -> Result<String, VhostError>
Sanitizes and validates a host header value.
§Security
- Rejects null bytes
- Rejects non-ASCII characters
- Strips port numbers
- Normalizes to lowercase
Sourcepub fn match_host(&self, host: &str) -> Option<&SiteConfig>
pub fn match_host(&self, host: &str) -> Option<&SiteConfig>
Sourcepub fn sites(&self) -> &[SiteConfig]
pub fn sites(&self) -> &[SiteConfig]
Returns all configured sites.
Sourcepub fn site_count(&self) -> usize
pub fn site_count(&self) -> usize
Returns the number of configured sites.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for VhostMatcher
impl RefUnwindSafe for VhostMatcher
impl Send for VhostMatcher
impl Sync for VhostMatcher
impl Unpin for VhostMatcher
impl UnsafeUnpin for VhostMatcher
impl UnwindSafe for VhostMatcher
Blanket Implementations§
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<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more