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
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`DescribeClassificationJob`](crate::operation::describe_classification_job::builders::DescribeClassificationJobFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`job_id(impl Into<String>)`](crate::operation::describe_classification_job::builders::DescribeClassificationJobFluentBuilder::job_id) / [`set_job_id(Option<String>)`](crate::operation::describe_classification_job::builders::DescribeClassificationJobFluentBuilder::set_job_id): <p>The unique identifier for the classification job.</p>
    /// - On success, responds with [`DescribeClassificationJobOutput`](crate::operation::describe_classification_job::DescribeClassificationJobOutput) with field(s):
    ///   - [`allow_list_ids(Option<Vec<String>>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::allow_list_ids): <p>An array of unique identifiers, one for each allow list that the job uses when it analyzes data.</p>
    ///   - [`client_token(Option<String>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::client_token): <p>The token that was provided to ensure the idempotency of the request to create the job.</p>
    ///   - [`created_at(Option<DateTime>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::created_at): <p>The date and time, in UTC and extended ISO 8601 format, when the job was created.</p>
    ///   - [`custom_data_identifier_ids(Option<Vec<String>>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::custom_data_identifier_ids): <p>An array of unique identifiers, one for each custom data identifier that the job uses when it analyzes data. This value is null if the job uses only managed data identifiers to analyze data.</p>
    ///   - [`description(Option<String>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::description): <p>The custom description of the job.</p>
    ///   - [`initial_run(Option<bool>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::initial_run): <p>For a recurring job, specifies whether you configured the job to analyze all existing, eligible objects immediately after the job was created (true). If you configured the job to analyze only those objects that were created or changed after the job was created and before the job's first scheduled run, this value is false. This value is also false for a one-time job.</p>
    ///   - [`job_arn(Option<String>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::job_arn): <p>The Amazon Resource Name (ARN) of the job.</p>
    ///   - [`job_id(Option<String>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::job_id): <p>The unique identifier for the job.</p>
    ///   - [`job_status(Option<JobStatus>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::job_status): <p>The current status of the job. Possible values are:</p>  <ul>  <li><p>CANCELLED - You cancelled the job or, if it's a one-time job, you paused the job and didn't resume it within 30 days.</p></li>   <li><p>COMPLETE - For a one-time job, Amazon Macie finished processing the data specified for the job. This value doesn't apply to recurring jobs.</p></li>   <li><p>IDLE - For a recurring job, the previous scheduled run is complete and the next scheduled run is pending. This value doesn't apply to one-time jobs.</p></li>   <li><p>PAUSED - Macie started running the job but additional processing would exceed the monthly sensitive data discovery quota for your account or one or more member accounts that the job analyzes data for.</p></li>   <li><p>RUNNING - For a one-time job, the job is in progress. For a recurring job, a scheduled run is in progress.</p></li>   <li><p>USER_PAUSED - You paused the job. If you paused the job while it had a status of RUNNING and you don't resume it within 30 days of pausing it, the job or job run will expire and be cancelled, depending on the job's type. To check the expiration date, refer to the UserPausedDetails.jobExpiresAt property.</p></li> </ul>
    ///   - [`job_type(Option<JobType>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::job_type): <p>The schedule for running the job. Possible values are:</p>  <ul>  <li><p>ONE_TIME - The job runs only once.</p></li>   <li><p>SCHEDULED - The job runs on a daily, weekly, or monthly basis. The scheduleFrequency property indicates the recurrence pattern for the job.</p></li> </ul>
    ///   - [`last_run_error_status(Option<LastRunErrorStatus>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::last_run_error_status): <p>Specifies whether any account- or bucket-level access errors occurred when the job ran. For a recurring job, this value indicates the error status of the job's most recent run.</p>
    ///   - [`last_run_time(Option<DateTime>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::last_run_time): <p>The date and time, in UTC and extended ISO 8601 format, when the job started. If the job is a recurring job, this value indicates when the most recent run started or, if the job hasn't run yet, when the job was created.</p>
    ///   - [`managed_data_identifier_ids(Option<Vec<String>>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::managed_data_identifier_ids): <p>An array of unique identifiers, one for each managed data identifier that the job is explicitly configured to include (use) or exclude (not use) when it analyzes data. Inclusion or exclusion depends on the managed data identifier selection type specified for the job (managedDataIdentifierSelector).</p> <p>This value is null if the job's managed data identifier selection type is ALL, NONE, or RECOMMENDED.</p>
    ///   - [`managed_data_identifier_selector(Option<ManagedDataIdentifierSelector>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::managed_data_identifier_selector): <p>The selection type that determines which managed data identifiers the job uses when it analyzes data. Possible values are:</p>  <ul>  <li><p>ALL - Use all managed data identifiers.</p></li>   <li><p>EXCLUDE - Use all managed data identifiers except the ones specified by the managedDataIdentifierIds property.</p></li>   <li><p>INCLUDE - Use only the managed data identifiers specified by the managedDataIdentifierIds property.</p></li>   <li><p>NONE - Don't use any managed data identifiers. Use only custom data identifiers (customDataIdentifierIds).</p></li>   <li><p>RECOMMENDED (default) - Use the recommended set of managed data identifiers.</p></li> </ul>  <p>If this value is null, the job uses the recommended set of managed data identifiers.</p>  <p>If the job is a recurring job and this value is ALL or EXCLUDE, each job run automatically uses new managed data identifiers that are released. If this value is null or RECOMMENDED for a recurring job, each job run uses all the managed data identifiers that are in the recommended set when the run starts.</p>  <p>For information about individual managed data identifiers or to determine which ones are in the recommended set, see <a href="https://docs.aws.amazon.com/macie/latest/user/managed-data-identifiers.html">Using managed data identifiers</a> and <a href="https://docs.aws.amazon.com/macie/latest/user/discovery-jobs-mdis-recommended.html">Recommended managed data identifiers</a> in the <i>Amazon Macie User Guide</i>.</p>
    ///   - [`name(Option<String>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::name): <p>The custom name of the job.</p>
    ///   - [`s3_job_definition(Option<S3JobDefinition>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::s3_job_definition): <p>The S3 buckets that contain the objects to analyze, and the scope of that analysis.</p>
    ///   - [`sampling_percentage(Option<i32>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::sampling_percentage): <p>The sampling depth, as a percentage, that determines the percentage of eligible objects that the job analyzes.</p>
    ///   - [`schedule_frequency(Option<JobScheduleFrequency>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::schedule_frequency): <p>The recurrence pattern for running the job. This value is null if the job is configured to run only once.</p>
    ///   - [`statistics(Option<Statistics>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::statistics): <p>The number of times that the job has run and processing statistics for the job's current run.</p>
    ///   - [`tags(Option<HashMap<String, String>>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::tags): <p>A map of key-value pairs that specifies which tags (keys and values) are associated with the classification job.</p>
    ///   - [`user_paused_details(Option<UserPausedDetails>)`](crate::operation::describe_classification_job::DescribeClassificationJobOutput::user_paused_details): <p>If the current status of the job is USER_PAUSED, specifies when the job was paused and when the job or job run will expire and be cancelled if it isn't resumed. This value is present only if the value for jobStatus is USER_PAUSED.</p>
    /// - On failure, responds with [`SdkError<DescribeClassificationJobError>`](crate::operation::describe_classification_job::DescribeClassificationJobError)
    pub fn describe_classification_job(&self) -> crate::operation::describe_classification_job::builders::DescribeClassificationJobFluentBuilder {
        crate::operation::describe_classification_job::builders::DescribeClassificationJobFluentBuilder::new(self.handle.clone())
    }
}