Struct aws_sdk_cleanroomsml::client::Client

source ·
pub struct Client { /* private fields */ }
Expand description

Client for AWS Clean Rooms ML

Client for invoking operations on AWS Clean Rooms ML. Each operation on AWS Clean Rooms ML is a method on this this struct. .send() MUST be invoked on the generated operations to dispatch the request to the service.

§Constructing a Client

A Config is required to construct a client. For most use cases, the aws-config crate should be used to automatically resolve this config using aws_config::load_from_env(), since this will resolve an SdkConfig which can be shared across multiple different AWS SDK clients. This config resolution process can be customized by calling aws_config::from_env() instead, which returns a ConfigLoader that uses the builder pattern to customize the default config.

In the simplest case, creating a client looks as follows:

let config = aws_config::load_from_env().await;
let client = aws_sdk_cleanroomsml::Client::new(&config);

Occasionally, SDKs may have additional service-specific values that can be set on the Config that is absent from SdkConfig, or slightly different settings for a specific client may be desired. The Config struct implements From<&SdkConfig>, so setting these specific settings can be done as follows:

let sdk_config = ::aws_config::load_from_env().await;
let config = aws_sdk_cleanroomsml::config::Builder::from(&sdk_config)
    .some_service_specific_setting("value")
    .build();

See the aws-config docs and Config for more information on customizing configuration.

Note: Client construction is expensive due to connection thread pool initialization, and should be done once at application start-up.

§Using the Client

A client has a function for every operation that can be performed by the service. For example, the ListTagsForResource operation has a Client::list_tags_for_resource, function which returns a builder for that operation. The fluent builder ultimately has a send() function that returns an async future that returns a result, as illustrated below:

let result = client.list_tags_for_resource()
    .resource_arn("example")
    .send()
    .await;

The underlying HTTP requests that get made by this can be modified with the customize_operation function on the fluent builder. See the customize module for more information.

Implementations§

source§

impl Client

source

pub fn create_audience_model(&self) -> CreateAudienceModelFluentBuilder

Constructs a fluent builder for the CreateAudienceModel operation.

source§

impl Client

source

pub fn create_configured_audience_model( &self ) -> CreateConfiguredAudienceModelFluentBuilder

Constructs a fluent builder for the CreateConfiguredAudienceModel operation.

source§

impl Client

source

pub fn create_training_dataset(&self) -> CreateTrainingDatasetFluentBuilder

Constructs a fluent builder for the CreateTrainingDataset operation.

  • The fluent builder is configurable:
    • name(impl Into<String>) / set_name(Option<String>):
      required: true

      The name of the training dataset. This name must be unique in your account and region.


    • role_arn(impl Into<String>) / set_role_arn(Option<String>):
      required: true

      The ARN of the IAM role that Clean Rooms ML can assume to read the data referred to in the dataSource field of each dataset.

      Passing a role across AWS accounts is not allowed. If you pass a role that isn’t in your account, you get an AccessDeniedException error.


    • training_data(Dataset) / set_training_data(Option<Vec::<Dataset>>):
      required: true

      An array of information that lists the Dataset objects, which specifies the dataset type and details on its location and schema. You must provide a role that has read access to these tables.


    • tags(impl Into<String>, impl Into<String>) / set_tags(Option<HashMap::<String, String>>):
      required: false

      The optional metadata that you apply to the resource to help you categorize and organize them. Each tag consists of a key and an optional value, both of which you define.

      The following basic restrictions apply to tags:

      • Maximum number of tags per resource - 50.

      • For each resource, each tag key must be unique, and each tag key can have only one value.

      • Maximum key length - 128 Unicode characters in UTF-8.

      • Maximum value length - 256 Unicode characters in UTF-8.

      • If your tagging schema is used across multiple services and resources, remember that other services may have restrictions on allowed characters. Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following characters: + - = . _ : / @.

      • Tag keys and values are case sensitive.

      • Do not use aws:, AWS:, or any upper or lowercase combination of such as a prefix for keys as it is reserved for AWS use. You cannot edit or delete tag keys with this prefix. Values can have this prefix. If a tag value has aws as its prefix but the key does not, then Clean Rooms ML considers it to be a user tag and will count against the limit of 50 tags. Tags with only the key prefix of aws do not count against your tags per resource limit.


    • description(impl Into<String>) / set_description(Option<String>):
      required: false

      The description of the training dataset.


  • On success, responds with CreateTrainingDatasetOutput with field(s):
  • On failure, responds with SdkError<CreateTrainingDatasetError>
source§

impl Client

source

pub fn delete_audience_generation_job( &self ) -> DeleteAudienceGenerationJobFluentBuilder

Constructs a fluent builder for the DeleteAudienceGenerationJob operation.

source§

impl Client

source

pub fn delete_audience_model(&self) -> DeleteAudienceModelFluentBuilder

Constructs a fluent builder for the DeleteAudienceModel operation.

source§

impl Client

source

pub fn delete_configured_audience_model( &self ) -> DeleteConfiguredAudienceModelFluentBuilder

Constructs a fluent builder for the DeleteConfiguredAudienceModel operation.

source§

impl Client

source

pub fn delete_configured_audience_model_policy( &self ) -> DeleteConfiguredAudienceModelPolicyFluentBuilder

Constructs a fluent builder for the DeleteConfiguredAudienceModelPolicy operation.

source§

impl Client

source

pub fn delete_training_dataset(&self) -> DeleteTrainingDatasetFluentBuilder

Constructs a fluent builder for the DeleteTrainingDataset operation.

source§

impl Client

source

pub fn get_audience_generation_job( &self ) -> GetAudienceGenerationJobFluentBuilder

Constructs a fluent builder for the GetAudienceGenerationJob operation.

source§

impl Client

source

pub fn get_audience_model(&self) -> GetAudienceModelFluentBuilder

Constructs a fluent builder for the GetAudienceModel operation.

source§

impl Client

source

pub fn get_configured_audience_model( &self ) -> GetConfiguredAudienceModelFluentBuilder

Constructs a fluent builder for the GetConfiguredAudienceModel operation.

source§

impl Client

source

pub fn get_configured_audience_model_policy( &self ) -> GetConfiguredAudienceModelPolicyFluentBuilder

Constructs a fluent builder for the GetConfiguredAudienceModelPolicy operation.

source§

impl Client

source

pub fn get_training_dataset(&self) -> GetTrainingDatasetFluentBuilder

Constructs a fluent builder for the GetTrainingDataset operation.

source§

impl Client

source

pub fn list_audience_export_jobs(&self) -> ListAudienceExportJobsFluentBuilder

Constructs a fluent builder for the ListAudienceExportJobs operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_audience_generation_jobs( &self ) -> ListAudienceGenerationJobsFluentBuilder

Constructs a fluent builder for the ListAudienceGenerationJobs operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_audience_models(&self) -> ListAudienceModelsFluentBuilder

Constructs a fluent builder for the ListAudienceModels operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_configured_audience_models( &self ) -> ListConfiguredAudienceModelsFluentBuilder

Constructs a fluent builder for the ListConfiguredAudienceModels operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_tags_for_resource(&self) -> ListTagsForResourceFluentBuilder

Constructs a fluent builder for the ListTagsForResource operation.

source§

impl Client

source

pub fn list_training_datasets(&self) -> ListTrainingDatasetsFluentBuilder

Constructs a fluent builder for the ListTrainingDatasets operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn put_configured_audience_model_policy( &self ) -> PutConfiguredAudienceModelPolicyFluentBuilder

Constructs a fluent builder for the PutConfiguredAudienceModelPolicy operation.

source§

impl Client

source

pub fn start_audience_export_job(&self) -> StartAudienceExportJobFluentBuilder

Constructs a fluent builder for the StartAudienceExportJob operation.

source§

impl Client

source

pub fn start_audience_generation_job( &self ) -> StartAudienceGenerationJobFluentBuilder

Constructs a fluent builder for the StartAudienceGenerationJob operation.

source§

impl Client

source

pub fn tag_resource(&self) -> TagResourceFluentBuilder

Constructs a fluent builder for the TagResource operation.

  • The fluent builder is configurable:
    • resource_arn(impl Into<String>) / set_resource_arn(Option<String>):
      required: true

      The Amazon Resource Name (ARN) of the resource that you want to assign tags.


    • tags(impl Into<String>, impl Into<String>) / set_tags(Option<HashMap::<String, String>>):
      required: true

      The optional metadata that you apply to the resource to help you categorize and organize them. Each tag consists of a key and an optional value, both of which you define.

      The following basic restrictions apply to tags:

      • Maximum number of tags per resource - 50.

      • For each resource, each tag key must be unique, and each tag key can have only one value.

      • Maximum key length - 128 Unicode characters in UTF-8.

      • Maximum value length - 256 Unicode characters in UTF-8.

      • If your tagging schema is used across multiple services and resources, remember that other services may have restrictions on allowed characters. Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following characters: + - = . _ : / @.

      • Tag keys and values are case sensitive.

      • Do not use aws:, AWS:, or any upper or lowercase combination of such as a prefix for keys as it is reserved for AWS use. You cannot edit or delete tag keys with this prefix. Values can have this prefix. If a tag value has aws as its prefix but the key does not, then Clean Rooms considers it to be a user tag and will count against the limit of 50 tags. Tags with only the key prefix of aws do not count against your tags per resource limit.


  • On success, responds with TagResourceOutput
  • On failure, responds with SdkError<TagResourceError>
source§

impl Client

source

pub fn untag_resource(&self) -> UntagResourceFluentBuilder

Constructs a fluent builder for the UntagResource operation.

source§

impl Client

source

pub fn update_configured_audience_model( &self ) -> UpdateConfiguredAudienceModelFluentBuilder

Constructs a fluent builder for the UpdateConfiguredAudienceModel operation.

source§

impl Client

source

pub fn from_conf(conf: Config) -> Self

Creates a new client from the service Config.

§Panics

This method will panic in the following cases:

  • Retries or timeouts are enabled without a sleep_impl configured.
  • Identity caching is enabled without a sleep_impl and time_source configured.
  • No behavior_version is provided.

The panic message for each of these will have instructions on how to resolve them.

source

pub fn config(&self) -> &Config

Returns the client’s configuration.

source§

impl Client

source

pub fn new(sdk_config: &SdkConfig) -> Self

Creates a new client from an SDK Config.

§Panics
  • This method will panic if the sdk_config is missing an async sleep implementation. If you experience this panic, set the sleep_impl on the Config passed into this function to fix it.
  • This method will panic if the sdk_config is missing an HTTP connector. If you experience this panic, set the http_connector on the Config passed into this function to fix it.
  • This method will panic if no BehaviorVersion is provided. If you experience this panic, set behavior_version on the Config or enable the behavior-version-latest Cargo feature.

Trait Implementations§

source§

impl Clone for Client

source§

fn clone(&self) -> Client

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Client

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Client

§

impl !RefUnwindSafe for Client

§

impl Send for Client

§

impl Sync for Client

§

impl Unpin for Client

§

impl !UnwindSafe for Client

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more