aws_sdk_route53/operation/get_dnssec/
_get_dnssec_output.rs1#[allow(missing_docs)] #[non_exhaustive]
4#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
5pub struct GetDnssecOutput {
6 pub status: ::std::option::Option<crate::types::DnssecStatus>,
8 pub key_signing_keys: ::std::vec::Vec<crate::types::KeySigningKey>,
10 _request_id: Option<String>,
11}
12impl GetDnssecOutput {
13 pub fn status(&self) -> ::std::option::Option<&crate::types::DnssecStatus> {
15 self.status.as_ref()
16 }
17 pub fn key_signing_keys(&self) -> &[crate::types::KeySigningKey] {
19 use std::ops::Deref;
20 self.key_signing_keys.deref()
21 }
22}
23impl ::aws_types::request_id::RequestId for GetDnssecOutput {
24 fn request_id(&self) -> Option<&str> {
25 self._request_id.as_deref()
26 }
27}
28impl GetDnssecOutput {
29 pub fn builder() -> crate::operation::get_dnssec::builders::GetDnssecOutputBuilder {
31 crate::operation::get_dnssec::builders::GetDnssecOutputBuilder::default()
32 }
33}
34
35#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
37#[non_exhaustive]
38pub struct GetDnssecOutputBuilder {
39 pub(crate) status: ::std::option::Option<crate::types::DnssecStatus>,
40 pub(crate) key_signing_keys: ::std::option::Option<::std::vec::Vec<crate::types::KeySigningKey>>,
41 _request_id: Option<String>,
42}
43impl GetDnssecOutputBuilder {
44 pub fn status(mut self, input: crate::types::DnssecStatus) -> Self {
47 self.status = ::std::option::Option::Some(input);
48 self
49 }
50 pub fn set_status(mut self, input: ::std::option::Option<crate::types::DnssecStatus>) -> Self {
52 self.status = input;
53 self
54 }
55 pub fn get_status(&self) -> &::std::option::Option<crate::types::DnssecStatus> {
57 &self.status
58 }
59 pub fn key_signing_keys(mut self, input: crate::types::KeySigningKey) -> Self {
65 let mut v = self.key_signing_keys.unwrap_or_default();
66 v.push(input);
67 self.key_signing_keys = ::std::option::Option::Some(v);
68 self
69 }
70 pub fn set_key_signing_keys(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::KeySigningKey>>) -> Self {
72 self.key_signing_keys = input;
73 self
74 }
75 pub fn get_key_signing_keys(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::KeySigningKey>> {
77 &self.key_signing_keys
78 }
79 pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
80 self._request_id = Some(request_id.into());
81 self
82 }
83
84 pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
85 self._request_id = request_id;
86 self
87 }
88 pub fn build(self) -> ::std::result::Result<crate::operation::get_dnssec::GetDnssecOutput, ::aws_smithy_types::error::operation::BuildError> {
92 ::std::result::Result::Ok(crate::operation::get_dnssec::GetDnssecOutput {
93 status: self.status,
94 key_signing_keys: self.key_signing_keys.ok_or_else(|| {
95 ::aws_smithy_types::error::operation::BuildError::missing_field(
96 "key_signing_keys",
97 "key_signing_keys was not specified but it is required when building GetDnssecOutput",
98 )
99 })?,
100 _request_id: self._request_id,
101 })
102 }
103}