1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
// 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 CreateTrialInput {
/// <p>The name of the trial. The name must be unique in your Amazon Web Services account and is not case-sensitive.</p>
#[doc(hidden)]
pub trial_name: std::option::Option<std::string::String>,
/// <p>The name of the trial as displayed. The name doesn't need to be unique. If <code>DisplayName</code> isn't specified, <code>TrialName</code> is displayed.</p>
#[doc(hidden)]
pub display_name: std::option::Option<std::string::String>,
/// <p>The name of the experiment to associate the trial with.</p>
#[doc(hidden)]
pub experiment_name: std::option::Option<std::string::String>,
/// <p>Metadata properties of the tracking entity, trial, or trial component.</p>
#[doc(hidden)]
pub metadata_properties: std::option::Option<crate::types::MetadataProperties>,
/// <p>A list of tags to associate with the trial. You can use <code>Search</code> API to search on the tags.</p>
#[doc(hidden)]
pub tags: std::option::Option<std::vec::Vec<crate::types::Tag>>,
}
impl CreateTrialInput {
/// <p>The name of the trial. The name must be unique in your Amazon Web Services account and is not case-sensitive.</p>
pub fn trial_name(&self) -> std::option::Option<&str> {
self.trial_name.as_deref()
}
/// <p>The name of the trial as displayed. The name doesn't need to be unique. If <code>DisplayName</code> isn't specified, <code>TrialName</code> is displayed.</p>
pub fn display_name(&self) -> std::option::Option<&str> {
self.display_name.as_deref()
}
/// <p>The name of the experiment to associate the trial with.</p>
pub fn experiment_name(&self) -> std::option::Option<&str> {
self.experiment_name.as_deref()
}
/// <p>Metadata properties of the tracking entity, trial, or trial component.</p>
pub fn metadata_properties(&self) -> std::option::Option<&crate::types::MetadataProperties> {
self.metadata_properties.as_ref()
}
/// <p>A list of tags to associate with the trial. You can use <code>Search</code> API to search on the tags.</p>
pub fn tags(&self) -> std::option::Option<&[crate::types::Tag]> {
self.tags.as_deref()
}
}
impl CreateTrialInput {
/// Creates a new builder-style object to manufacture [`CreateTrialInput`](crate::operation::create_trial::CreateTrialInput).
pub fn builder() -> crate::operation::create_trial::builders::CreateTrialInputBuilder {
crate::operation::create_trial::builders::CreateTrialInputBuilder::default()
}
}
/// A builder for [`CreateTrialInput`](crate::operation::create_trial::CreateTrialInput).
#[non_exhaustive]
#[derive(std::clone::Clone, std::cmp::PartialEq, std::default::Default, std::fmt::Debug)]
pub struct CreateTrialInputBuilder {
pub(crate) trial_name: std::option::Option<std::string::String>,
pub(crate) display_name: std::option::Option<std::string::String>,
pub(crate) experiment_name: std::option::Option<std::string::String>,
pub(crate) metadata_properties: std::option::Option<crate::types::MetadataProperties>,
pub(crate) tags: std::option::Option<std::vec::Vec<crate::types::Tag>>,
}
impl CreateTrialInputBuilder {
/// <p>The name of the trial. The name must be unique in your Amazon Web Services account and is not case-sensitive.</p>
pub fn trial_name(mut self, input: impl Into<std::string::String>) -> Self {
self.trial_name = Some(input.into());
self
}
/// <p>The name of the trial. The name must be unique in your Amazon Web Services account and is not case-sensitive.</p>
pub fn set_trial_name(mut self, input: std::option::Option<std::string::String>) -> Self {
self.trial_name = input;
self
}
/// <p>The name of the trial as displayed. The name doesn't need to be unique. If <code>DisplayName</code> isn't specified, <code>TrialName</code> is displayed.</p>
pub fn display_name(mut self, input: impl Into<std::string::String>) -> Self {
self.display_name = Some(input.into());
self
}
/// <p>The name of the trial as displayed. The name doesn't need to be unique. If <code>DisplayName</code> isn't specified, <code>TrialName</code> is displayed.</p>
pub fn set_display_name(mut self, input: std::option::Option<std::string::String>) -> Self {
self.display_name = input;
self
}
/// <p>The name of the experiment to associate the trial with.</p>
pub fn experiment_name(mut self, input: impl Into<std::string::String>) -> Self {
self.experiment_name = Some(input.into());
self
}
/// <p>The name of the experiment to associate the trial with.</p>
pub fn set_experiment_name(mut self, input: std::option::Option<std::string::String>) -> Self {
self.experiment_name = input;
self
}
/// <p>Metadata properties of the tracking entity, trial, or trial component.</p>
pub fn metadata_properties(mut self, input: crate::types::MetadataProperties) -> Self {
self.metadata_properties = Some(input);
self
}
/// <p>Metadata properties of the tracking entity, trial, or trial component.</p>
pub fn set_metadata_properties(
mut self,
input: std::option::Option<crate::types::MetadataProperties>,
) -> Self {
self.metadata_properties = input;
self
}
/// Appends an item to `tags`.
///
/// To override the contents of this collection use [`set_tags`](Self::set_tags).
///
/// <p>A list of tags to associate with the trial. You can use <code>Search</code> API to search on the tags.</p>
pub fn tags(mut self, input: crate::types::Tag) -> Self {
let mut v = self.tags.unwrap_or_default();
v.push(input);
self.tags = Some(v);
self
}
/// <p>A list of tags to associate with the trial. You can use <code>Search</code> API to search on the tags.</p>
pub fn set_tags(
mut self,
input: std::option::Option<std::vec::Vec<crate::types::Tag>>,
) -> Self {
self.tags = input;
self
}
/// Consumes the builder and constructs a [`CreateTrialInput`](crate::operation::create_trial::CreateTrialInput).
pub fn build(
self,
) -> Result<
crate::operation::create_trial::CreateTrialInput,
aws_smithy_http::operation::error::BuildError,
> {
Ok(crate::operation::create_trial::CreateTrialInput {
trial_name: self.trial_name,
display_name: self.display_name,
experiment_name: self.experiment_name,
metadata_properties: self.metadata_properties,
tags: self.tags,
})
}
}