aws-sdk-securityagent 1.2.0

AWS SDK for AWS Security Agent
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
#[allow(missing_docs)] // documentation missing in model
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct ListIntegrationsOutput {
    /// <p>The list of integration summaries.</p>
    pub integration_summaries: ::std::vec::Vec<crate::types::IntegrationSummary>,
    /// <p>A token to use for paginating results that are returned in the response. Set the value of this parameter to null for the first request. For subsequent calls, use the nextToken value returned from the previous request.</p>
    pub next_token: ::std::option::Option<::std::string::String>,
    _request_id: Option<String>,
}
impl ListIntegrationsOutput {
    /// <p>The list of integration summaries.</p>
    pub fn integration_summaries(&self) -> &[crate::types::IntegrationSummary] {
        use std::ops::Deref;
        self.integration_summaries.deref()
    }
    /// <p>A token to use for paginating results that are returned in the response. Set the value of this parameter to null for the first request. For subsequent calls, use the nextToken value returned from the previous request.</p>
    pub fn next_token(&self) -> ::std::option::Option<&str> {
        self.next_token.as_deref()
    }
}
impl ::aws_types::request_id::RequestId for ListIntegrationsOutput {
    fn request_id(&self) -> Option<&str> {
        self._request_id.as_deref()
    }
}
impl ListIntegrationsOutput {
    /// Creates a new builder-style object to manufacture [`ListIntegrationsOutput`](crate::operation::list_integrations::ListIntegrationsOutput).
    pub fn builder() -> crate::operation::list_integrations::builders::ListIntegrationsOutputBuilder {
        crate::operation::list_integrations::builders::ListIntegrationsOutputBuilder::default()
    }
}

/// A builder for [`ListIntegrationsOutput`](crate::operation::list_integrations::ListIntegrationsOutput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct ListIntegrationsOutputBuilder {
    pub(crate) integration_summaries: ::std::option::Option<::std::vec::Vec<crate::types::IntegrationSummary>>,
    pub(crate) next_token: ::std::option::Option<::std::string::String>,
    _request_id: Option<String>,
}
impl ListIntegrationsOutputBuilder {
    /// Appends an item to `integration_summaries`.
    ///
    /// To override the contents of this collection use [`set_integration_summaries`](Self::set_integration_summaries).
    ///
    /// <p>The list of integration summaries.</p>
    pub fn integration_summaries(mut self, input: crate::types::IntegrationSummary) -> Self {
        let mut v = self.integration_summaries.unwrap_or_default();
        v.push(input);
        self.integration_summaries = ::std::option::Option::Some(v);
        self
    }
    /// <p>The list of integration summaries.</p>
    pub fn set_integration_summaries(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::IntegrationSummary>>) -> Self {
        self.integration_summaries = input;
        self
    }
    /// <p>The list of integration summaries.</p>
    pub fn get_integration_summaries(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::IntegrationSummary>> {
        &self.integration_summaries
    }
    /// <p>A token to use for paginating results that are returned in the response. Set the value of this parameter to null for the first request. For subsequent calls, use the nextToken value returned from the previous request.</p>
    pub fn next_token(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.next_token = ::std::option::Option::Some(input.into());
        self
    }
    /// <p>A token to use for paginating results that are returned in the response. Set the value of this parameter to null for the first request. For subsequent calls, use the nextToken value returned from the previous request.</p>
    pub fn set_next_token(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.next_token = input;
        self
    }
    /// <p>A token to use for paginating results that are returned in the response. Set the value of this parameter to null for the first request. For subsequent calls, use the nextToken value returned from the previous request.</p>
    pub fn get_next_token(&self) -> &::std::option::Option<::std::string::String> {
        &self.next_token
    }
    pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
        self._request_id = Some(request_id.into());
        self
    }

    pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
        self._request_id = request_id;
        self
    }
    /// Consumes the builder and constructs a [`ListIntegrationsOutput`](crate::operation::list_integrations::ListIntegrationsOutput).
    /// This method will fail if any of the following fields are not set:
    /// - [`integration_summaries`](crate::operation::list_integrations::builders::ListIntegrationsOutputBuilder::integration_summaries)
    pub fn build(
        self,
    ) -> ::std::result::Result<crate::operation::list_integrations::ListIntegrationsOutput, ::aws_smithy_types::error::operation::BuildError> {
        ::std::result::Result::Ok(crate::operation::list_integrations::ListIntegrationsOutput {
            integration_summaries: self.integration_summaries.ok_or_else(|| {
                ::aws_smithy_types::error::operation::BuildError::missing_field(
                    "integration_summaries",
                    "integration_summaries was not specified but it is required when building ListIntegrationsOutput",
                )
            })?,
            next_token: self.next_token,
            _request_id: self._request_id,
        })
    }
}