Enum trust_dns_proto::rr::rdata::svcb::SvcParamValue
source · [−]pub enum SvcParamValue {
Mandatory(Mandatory),
Alpn(Alpn),
NoDefaultAlpn,
Port(u16),
Ipv4Hint(IpHint<Ipv4Addr>),
EchConfig(EchConfig),
Ipv6Hint(IpHint<Ipv6Addr>),
Unknown(Unknown),
}
Expand description
Warning, it is currently up to users of this type to validate the data against that expected by the key
* a 2 octet field containing the length of the SvcParamValue as an
integer between 0 and 65535 in network byte order (but constrained
by the RDATA and DNS message sizes).
* an octet string of this length whose contents are in a format
determined by the SvcParamKey.
Variants
Mandatory(Mandatory)
In a ServiceMode RR, a SvcParamKey is considered “mandatory” if the RR will not function correctly for clients that ignore this SvcParamKey. Each SVCB protocol mapping SHOULD specify a set of keys that are “automatically mandatory”, i.e. mandatory if they are present in an RR. The SvcParamKey “mandatory” is used to indicate any mandatory keys for this RR, in addition to any automatically mandatory keys that are present.
see Mandatory
Alpn(Alpn)
The “alpn” and “no-default-alpn” SvcParamKeys together indicate the set of Application Layer Protocol Negotiation (ALPN) protocol identifiers Alpn and associated transport protocols supported by this service endpoint.
NoDefaultAlpn
For “no-default-alpn”, the presentation and wire format values MUST
be empty.
See also Alpn
Port(u16)
6.2. "port"
The "port" SvcParamKey defines the TCP or UDP port that should be
used to reach this alternative endpoint. If this key is not present,
clients SHALL use the authority endpoint's port number.
The presentation "value" of the SvcParamValue is a single decimal
integer between 0 and 65535 in ASCII. Any other "value" (e.g. an
empty value) is a syntax error. To enable simpler parsing, this
SvcParam MUST NOT contain escape sequences.
The wire format of the SvcParamValue is the corresponding 2 octet
numeric value in network byte order.
If a port-restricting firewall is in place between some client and
the service endpoint, changing the port number might cause that
client to lose access to the service, so operators should exercise
caution when using this SvcParamKey to specify a non-default port.
Ipv4Hint(IpHint<Ipv4Addr>)
The “ipv4hint” and “ipv6hint” keys convey IP addresses that clients MAY use to reach the service. If A and AAAA records for TargetName are locally available, the client SHOULD ignore these hints. Otherwise, clients SHOULD perform A and/or AAAA queries for TargetName as in Section 3, and clients SHOULD use the IP address in those responses for future connections. Clients MAY opt to terminate any connections using the addresses in hints and instead switch to the addresses in response to the TargetName query. Failure to use A and/or AAAA response addresses could negatively impact load balancing or other geo-aware features and thereby degrade client performance.
see IpHint
EchConfig(EchConfig)
6.3. "echconfig"
The SvcParamKey to enable Encrypted ClientHello (ECH) is "echconfig".
Its value is defined in Section 9. It is applicable to most TLS-
based protocols.
When publishing a record containing an "echconfig" parameter, the
publisher MUST ensure that all IP addresses of TargetName correspond
to servers that have access to the corresponding private key or are
authoritative for the public name. (See Section 7.2.2 of [ECH] for
more details about the public name.) This yields an anonymity set of
cardinality equal to the number of ECH-enabled server domains
supported by a given client-facing server. Thus, even with an
encrypted ClientHello, an attacker who can enumerate the set of ECH-
enabled domains supported by a client-facing server can guess the
correct SNI with probability at least 1/K, where K is the size of
this ECH-enabled server anonymity set. This probability may be
increased via traffic analysis or other mechanisms.
Ipv6Hint(IpHint<Ipv6Addr>)
See IpHint
Unknown(Unknown)
Unparsed network data. Refer to documents on the associated key value
This will be left as is when read off the wire, and encoded in bas64 for presentation.
Implementations
sourceimpl SvcParamValue
impl SvcParamValue
sourcepub fn as_mandatory_mut(&mut self) -> Option<&mut Mandatory>
pub fn as_mandatory_mut(&mut self) -> Option<&mut Mandatory>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::Mandatory
, otherwise None
sourcepub fn as_mandatory(&self) -> Option<&Mandatory>
pub fn as_mandatory(&self) -> Option<&Mandatory>
Optionally returns references to the inner fields if this is a SvcParamValue::Mandatory
, otherwise None
sourcepub fn into_mandatory(self) -> Result<Mandatory, Self>
pub fn into_mandatory(self) -> Result<Mandatory, Self>
Returns the inner fields if this is a SvcParamValue::Mandatory
, otherwise returns back the enum in the Err
case of the result
sourcepub fn as_alpn_mut(&mut self) -> Option<&mut Alpn>
pub fn as_alpn_mut(&mut self) -> Option<&mut Alpn>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::Alpn
, otherwise None
sourcepub fn as_alpn(&self) -> Option<&Alpn>
pub fn as_alpn(&self) -> Option<&Alpn>
Optionally returns references to the inner fields if this is a SvcParamValue::Alpn
, otherwise None
sourcepub fn into_alpn(self) -> Result<Alpn, Self>
pub fn into_alpn(self) -> Result<Alpn, Self>
Returns the inner fields if this is a SvcParamValue::Alpn
, otherwise returns back the enum in the Err
case of the result
sourcepub fn is_no_default_alpn(&self) -> bool
pub fn is_no_default_alpn(&self) -> bool
Returns true if this is a SvcParamValue::NoDefaultAlpn
, otherwise false
sourcepub fn as_port_mut(&mut self) -> Option<&mut u16>
pub fn as_port_mut(&mut self) -> Option<&mut u16>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::Port
, otherwise None
sourcepub fn as_port(&self) -> Option<&u16>
pub fn as_port(&self) -> Option<&u16>
Optionally returns references to the inner fields if this is a SvcParamValue::Port
, otherwise None
sourcepub fn into_port(self) -> Result<u16, Self>
pub fn into_port(self) -> Result<u16, Self>
Returns the inner fields if this is a SvcParamValue::Port
, otherwise returns back the enum in the Err
case of the result
sourcepub fn as_ipv4_hint_mut(&mut self) -> Option<&mut IpHint<Ipv4Addr>>
pub fn as_ipv4_hint_mut(&mut self) -> Option<&mut IpHint<Ipv4Addr>>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::Ipv4Hint
, otherwise None
sourcepub fn as_ipv4_hint(&self) -> Option<&IpHint<Ipv4Addr>>
pub fn as_ipv4_hint(&self) -> Option<&IpHint<Ipv4Addr>>
Optionally returns references to the inner fields if this is a SvcParamValue::Ipv4Hint
, otherwise None
sourcepub fn into_ipv4_hint(self) -> Result<IpHint<Ipv4Addr>, Self>
pub fn into_ipv4_hint(self) -> Result<IpHint<Ipv4Addr>, Self>
Returns the inner fields if this is a SvcParamValue::Ipv4Hint
, otherwise returns back the enum in the Err
case of the result
sourcepub fn as_ech_config_mut(&mut self) -> Option<&mut EchConfig>
pub fn as_ech_config_mut(&mut self) -> Option<&mut EchConfig>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::EchConfig
, otherwise None
sourcepub fn as_ech_config(&self) -> Option<&EchConfig>
pub fn as_ech_config(&self) -> Option<&EchConfig>
Optionally returns references to the inner fields if this is a SvcParamValue::EchConfig
, otherwise None
sourcepub fn into_ech_config(self) -> Result<EchConfig, Self>
pub fn into_ech_config(self) -> Result<EchConfig, Self>
Returns the inner fields if this is a SvcParamValue::EchConfig
, otherwise returns back the enum in the Err
case of the result
sourcepub fn as_ipv6_hint_mut(&mut self) -> Option<&mut IpHint<Ipv6Addr>>
pub fn as_ipv6_hint_mut(&mut self) -> Option<&mut IpHint<Ipv6Addr>>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::Ipv6Hint
, otherwise None
sourcepub fn as_ipv6_hint(&self) -> Option<&IpHint<Ipv6Addr>>
pub fn as_ipv6_hint(&self) -> Option<&IpHint<Ipv6Addr>>
Optionally returns references to the inner fields if this is a SvcParamValue::Ipv6Hint
, otherwise None
sourcepub fn into_ipv6_hint(self) -> Result<IpHint<Ipv6Addr>, Self>
pub fn into_ipv6_hint(self) -> Result<IpHint<Ipv6Addr>, Self>
Returns the inner fields if this is a SvcParamValue::Ipv6Hint
, otherwise returns back the enum in the Err
case of the result
sourcepub fn as_unknown_mut(&mut self) -> Option<&mut Unknown>
pub fn as_unknown_mut(&mut self) -> Option<&mut Unknown>
Optionally returns mutable references to the inner fields if this is a SvcParamValue::Unknown
, otherwise None
sourcepub fn as_unknown(&self) -> Option<&Unknown>
pub fn as_unknown(&self) -> Option<&Unknown>
Optionally returns references to the inner fields if this is a SvcParamValue::Unknown
, otherwise None
sourcepub fn into_unknown(self) -> Result<Unknown, Self>
pub fn into_unknown(self) -> Result<Unknown, Self>
Returns the inner fields if this is a SvcParamValue::Unknown
, otherwise returns back the enum in the Err
case of the result
Trait Implementations
sourceimpl BinEncodable for SvcParamValue
impl BinEncodable for SvcParamValue
sourcefn emit(&self, encoder: &mut BinEncoder<'_>) -> ProtoResult<()>
fn emit(&self, encoder: &mut BinEncoder<'_>) -> ProtoResult<()>
Write the type to the stream
sourcefn to_bytes(&self) -> ProtoResult<Vec<u8>>
fn to_bytes(&self) -> ProtoResult<Vec<u8>>
Returns the object in binary form
sourceimpl Clone for SvcParamValue
impl Clone for SvcParamValue
sourcefn clone(&self) -> SvcParamValue
fn clone(&self) -> SvcParamValue
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl Debug for SvcParamValue
impl Debug for SvcParamValue
sourceimpl<'de> Deserialize<'de> for SvcParamValue
impl<'de> Deserialize<'de> for SvcParamValue
sourcefn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
sourceimpl Display for SvcParamValue
impl Display for SvcParamValue
sourceimpl Hash for SvcParamValue
impl Hash for SvcParamValue
sourceimpl PartialEq<SvcParamValue> for SvcParamValue
impl PartialEq<SvcParamValue> for SvcParamValue
sourcefn eq(&self, other: &SvcParamValue) -> bool
fn eq(&self, other: &SvcParamValue) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &SvcParamValue) -> bool
fn ne(&self, other: &SvcParamValue) -> bool
This method tests for !=
.
sourceimpl Serialize for SvcParamValue
impl Serialize for SvcParamValue
impl Eq for SvcParamValue
impl StructuralEq for SvcParamValue
impl StructuralPartialEq for SvcParamValue
Auto Trait Implementations
impl RefUnwindSafe for SvcParamValue
impl Send for SvcParamValue
impl Sync for SvcParamValue
impl Unpin for SvcParamValue
impl UnwindSafe for SvcParamValue
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<Q, K> Equivalent<K> for Q where
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Q where
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
sourcefn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to key
and return true
if they are equal.
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
fn vzip(self) -> V
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
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
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more