aws-sdk-evidently 1.95.0

AWS SDK for Amazon CloudWatch Evidently
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 GetExperimentResultsOutput {
    /// <p>An array of structures that include experiment results including metric names and values.</p>
    pub results_data: ::std::option::Option<::std::vec::Vec<crate::types::ExperimentResultsData>>,
    /// <p>An array of structures that include the reports that you requested.</p>
    pub reports: ::std::option::Option<::std::vec::Vec<crate::types::ExperimentReport>>,
    /// <p>The timestamps of each result returned.</p>
    pub timestamps: ::std::option::Option<::std::vec::Vec<::aws_smithy_types::DateTime>>,
    /// <p>If the experiment doesn't yet have enough events to provide valid results, this field is returned with the message <code>Not enough events to generate results</code>. If there are enough events to provide valid results, this field is not returned.</p>
    pub details: ::std::option::Option<::std::string::String>,
    _request_id: Option<String>,
}
impl GetExperimentResultsOutput {
    /// <p>An array of structures that include experiment results including metric names and values.</p>
    ///
    /// If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use `.results_data.is_none()`.
    pub fn results_data(&self) -> &[crate::types::ExperimentResultsData] {
        self.results_data.as_deref().unwrap_or_default()
    }
    /// <p>An array of structures that include the reports that you requested.</p>
    ///
    /// If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use `.reports.is_none()`.
    pub fn reports(&self) -> &[crate::types::ExperimentReport] {
        self.reports.as_deref().unwrap_or_default()
    }
    /// <p>The timestamps of each result returned.</p>
    ///
    /// If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use `.timestamps.is_none()`.
    pub fn timestamps(&self) -> &[::aws_smithy_types::DateTime] {
        self.timestamps.as_deref().unwrap_or_default()
    }
    /// <p>If the experiment doesn't yet have enough events to provide valid results, this field is returned with the message <code>Not enough events to generate results</code>. If there are enough events to provide valid results, this field is not returned.</p>
    pub fn details(&self) -> ::std::option::Option<&str> {
        self.details.as_deref()
    }
}
impl ::aws_types::request_id::RequestId for GetExperimentResultsOutput {
    fn request_id(&self) -> Option<&str> {
        self._request_id.as_deref()
    }
}
impl GetExperimentResultsOutput {
    /// Creates a new builder-style object to manufacture [`GetExperimentResultsOutput`](crate::operation::get_experiment_results::GetExperimentResultsOutput).
    pub fn builder() -> crate::operation::get_experiment_results::builders::GetExperimentResultsOutputBuilder {
        crate::operation::get_experiment_results::builders::GetExperimentResultsOutputBuilder::default()
    }
}

/// A builder for [`GetExperimentResultsOutput`](crate::operation::get_experiment_results::GetExperimentResultsOutput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct GetExperimentResultsOutputBuilder {
    pub(crate) results_data: ::std::option::Option<::std::vec::Vec<crate::types::ExperimentResultsData>>,
    pub(crate) reports: ::std::option::Option<::std::vec::Vec<crate::types::ExperimentReport>>,
    pub(crate) timestamps: ::std::option::Option<::std::vec::Vec<::aws_smithy_types::DateTime>>,
    pub(crate) details: ::std::option::Option<::std::string::String>,
    _request_id: Option<String>,
}
impl GetExperimentResultsOutputBuilder {
    /// Appends an item to `results_data`.
    ///
    /// To override the contents of this collection use [`set_results_data`](Self::set_results_data).
    ///
    /// <p>An array of structures that include experiment results including metric names and values.</p>
    pub fn results_data(mut self, input: crate::types::ExperimentResultsData) -> Self {
        let mut v = self.results_data.unwrap_or_default();
        v.push(input);
        self.results_data = ::std::option::Option::Some(v);
        self
    }
    /// <p>An array of structures that include experiment results including metric names and values.</p>
    pub fn set_results_data(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::ExperimentResultsData>>) -> Self {
        self.results_data = input;
        self
    }
    /// <p>An array of structures that include experiment results including metric names and values.</p>
    pub fn get_results_data(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::ExperimentResultsData>> {
        &self.results_data
    }
    /// Appends an item to `reports`.
    ///
    /// To override the contents of this collection use [`set_reports`](Self::set_reports).
    ///
    /// <p>An array of structures that include the reports that you requested.</p>
    pub fn reports(mut self, input: crate::types::ExperimentReport) -> Self {
        let mut v = self.reports.unwrap_or_default();
        v.push(input);
        self.reports = ::std::option::Option::Some(v);
        self
    }
    /// <p>An array of structures that include the reports that you requested.</p>
    pub fn set_reports(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::ExperimentReport>>) -> Self {
        self.reports = input;
        self
    }
    /// <p>An array of structures that include the reports that you requested.</p>
    pub fn get_reports(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::ExperimentReport>> {
        &self.reports
    }
    /// Appends an item to `timestamps`.
    ///
    /// To override the contents of this collection use [`set_timestamps`](Self::set_timestamps).
    ///
    /// <p>The timestamps of each result returned.</p>
    pub fn timestamps(mut self, input: ::aws_smithy_types::DateTime) -> Self {
        let mut v = self.timestamps.unwrap_or_default();
        v.push(input);
        self.timestamps = ::std::option::Option::Some(v);
        self
    }
    /// <p>The timestamps of each result returned.</p>
    pub fn set_timestamps(mut self, input: ::std::option::Option<::std::vec::Vec<::aws_smithy_types::DateTime>>) -> Self {
        self.timestamps = input;
        self
    }
    /// <p>The timestamps of each result returned.</p>
    pub fn get_timestamps(&self) -> &::std::option::Option<::std::vec::Vec<::aws_smithy_types::DateTime>> {
        &self.timestamps
    }
    /// <p>If the experiment doesn't yet have enough events to provide valid results, this field is returned with the message <code>Not enough events to generate results</code>. If there are enough events to provide valid results, this field is not returned.</p>
    pub fn details(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.details = ::std::option::Option::Some(input.into());
        self
    }
    /// <p>If the experiment doesn't yet have enough events to provide valid results, this field is returned with the message <code>Not enough events to generate results</code>. If there are enough events to provide valid results, this field is not returned.</p>
    pub fn set_details(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.details = input;
        self
    }
    /// <p>If the experiment doesn't yet have enough events to provide valid results, this field is returned with the message <code>Not enough events to generate results</code>. If there are enough events to provide valid results, this field is not returned.</p>
    pub fn get_details(&self) -> &::std::option::Option<::std::string::String> {
        &self.details
    }
    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 [`GetExperimentResultsOutput`](crate::operation::get_experiment_results::GetExperimentResultsOutput).
    pub fn build(self) -> crate::operation::get_experiment_results::GetExperimentResultsOutput {
        crate::operation::get_experiment_results::GetExperimentResultsOutput {
            results_data: self.results_data,
            reports: self.reports,
            timestamps: self.timestamps,
            details: self.details,
            _request_id: self._request_id,
        }
    }
}