pub struct DNSSECKeySource {
pub secret_ref: Option<SecretReference>,
pub persistent_volume: Option<PersistentVolumeClaimSpec>,
}Expand description
DNSSEC key source configuration
Defines where DNSSEC keys are loaded from. Supports multiple patterns:
-
User-Supplied Secret (Production):
- Keys managed externally (
Vault,ExternalSecrets,sealed-secrets) - User controls rotation timing
GitOpsfriendly
- Keys managed externally (
-
Persistent Storage (Legacy):
- Keys stored in
PersistentVolume - Traditional BIND9 pattern
- Keys stored in
§Example: User-Supplied Keys
keysFrom:
secretRef:
name: "dnssec-keys-example-com"§Example: Persistent Storage
keysFrom:
persistentVolume:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 100MiFields§
§secret_ref: Option<SecretReference>Secret containing DNSSEC keys
Reference to a Kubernetes Secret with DNSSEC key files.
Secret data format:
K<zone>.+<alg>+<tag>.key- Public key fileK<zone>.+<alg>+<tag>.private- Private key file
Example: Kexample.com.+013+12345.key
persistent_volume: Option<PersistentVolumeClaimSpec>Persistent volume for DNSSEC keys (legacy/compatibility)
Note: Not cloud-native. Use secret_ref for production.
Trait Implementations§
Source§impl Clone for DNSSECKeySource
impl Clone for DNSSECKeySource
Source§fn clone(&self) -> DNSSECKeySource
fn clone(&self) -> DNSSECKeySource
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for DNSSECKeySource
impl Debug for DNSSECKeySource
Source§impl<'de> Deserialize<'de> for DNSSECKeySource
impl<'de> Deserialize<'de> for DNSSECKeySource
Source§fn 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
Source§impl JsonSchema for DNSSECKeySource
impl JsonSchema for DNSSECKeySource
Source§fn schema_id() -> Cow<'static, str>
fn schema_id() -> Cow<'static, str>
Returns a string that uniquely identifies the schema produced by this type. Read more
Source§fn json_schema(generator: &mut SchemaGenerator) -> Schema
fn json_schema(generator: &mut SchemaGenerator) -> Schema
Generates a JSON Schema for this type. Read more
Source§fn inline_schema() -> bool
fn inline_schema() -> bool
Whether JSON Schemas generated for this type should be included directly in parent schemas,
rather than being re-used where possible using the
$ref keyword. Read moreSource§impl PartialEq for DNSSECKeySource
impl PartialEq for DNSSECKeySource
Source§impl Serialize for DNSSECKeySource
impl Serialize for DNSSECKeySource
impl StructuralPartialEq for DNSSECKeySource
Auto Trait Implementations§
impl Freeze for DNSSECKeySource
impl RefUnwindSafe for DNSSECKeySource
impl Send for DNSSECKeySource
impl Sync for DNSSECKeySource
impl Unpin for DNSSECKeySource
impl UnwindSafe for DNSSECKeySource
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> ServiceExt for T
impl<T> ServiceExt for T
§fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
Self: Sized,
fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
Self: Sized,
Apply a transformation to the response body. Read more
§fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
Self: Sized,
fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
Self: Sized,
High level tracing that classifies responses using HTTP status codes. Read more
§fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
Self: Sized,
fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
Self: Sized,
High level tracing that classifies responses using gRPC headers. Read more