#[non_exhaustive]pub struct CreateJobInputBuilder { /* private fields */ }Expand description
A builder for CreateJobInput.
Implementations§
source§impl CreateJobInputBuilder
 
impl CreateJobInputBuilder
sourcepub fn job_id(self, input: impl Into<String>) -> Self
 
pub fn job_id(self, input: impl Into<String>) -> Self
A job identifier which must be unique for your Amazon Web Services account. We recommend using a UUID. Alpha-numeric characters, "-" and "_" are valid for use here.
This field is required.sourcepub fn set_job_id(self, input: Option<String>) -> Self
 
pub fn set_job_id(self, input: Option<String>) -> Self
A job identifier which must be unique for your Amazon Web Services account. We recommend using a UUID. Alpha-numeric characters, "-" and "_" are valid for use here.
sourcepub fn get_job_id(&self) -> &Option<String>
 
pub fn get_job_id(&self) -> &Option<String>
A job identifier which must be unique for your Amazon Web Services account. We recommend using a UUID. Alpha-numeric characters, "-" and "_" are valid for use here.
sourcepub fn targets(self, input: impl Into<String>) -> Self
 
pub fn targets(self, input: impl Into<String>) -> Self
Appends an item to targets.
To override the contents of this collection use set_targets.
A list of things and thing groups to which the job should be sent.
sourcepub fn set_targets(self, input: Option<Vec<String>>) -> Self
 
pub fn set_targets(self, input: Option<Vec<String>>) -> Self
A list of things and thing groups to which the job should be sent.
sourcepub fn get_targets(&self) -> &Option<Vec<String>>
 
pub fn get_targets(&self) -> &Option<Vec<String>>
A list of things and thing groups to which the job should be sent.
sourcepub fn document_source(self, input: impl Into<String>) -> Self
 
pub fn document_source(self, input: impl Into<String>) -> Self
An S3 link, or S3 object URL, to the job document. The link is an Amazon S3 object URL and is required if you don't specify a value for document.
For example, --document-source https://s3.region-code.amazonaws.com/example-firmware/device-firmware.1.0
For more information, see Methods for accessing a bucket.
sourcepub fn set_document_source(self, input: Option<String>) -> Self
 
pub fn set_document_source(self, input: Option<String>) -> Self
An S3 link, or S3 object URL, to the job document. The link is an Amazon S3 object URL and is required if you don't specify a value for document.
For example, --document-source https://s3.region-code.amazonaws.com/example-firmware/device-firmware.1.0
For more information, see Methods for accessing a bucket.
sourcepub fn get_document_source(&self) -> &Option<String>
 
pub fn get_document_source(&self) -> &Option<String>
An S3 link, or S3 object URL, to the job document. The link is an Amazon S3 object URL and is required if you don't specify a value for document.
For example, --document-source https://s3.region-code.amazonaws.com/example-firmware/device-firmware.1.0
For more information, see Methods for accessing a bucket.
sourcepub fn document(self, input: impl Into<String>) -> Self
 
pub fn document(self, input: impl Into<String>) -> Self
The job document. Required if you don't specify a value for documentSource.
sourcepub fn set_document(self, input: Option<String>) -> Self
 
pub fn set_document(self, input: Option<String>) -> Self
The job document. Required if you don't specify a value for documentSource.
sourcepub fn get_document(&self) -> &Option<String>
 
pub fn get_document(&self) -> &Option<String>
The job document. Required if you don't specify a value for documentSource.
sourcepub fn description(self, input: impl Into<String>) -> Self
 
pub fn description(self, input: impl Into<String>) -> Self
A short text description of the job.
sourcepub fn set_description(self, input: Option<String>) -> Self
 
pub fn set_description(self, input: Option<String>) -> Self
A short text description of the job.
sourcepub fn get_description(&self) -> &Option<String>
 
pub fn get_description(&self) -> &Option<String>
A short text description of the job.
sourcepub fn presigned_url_config(self, input: PresignedUrlConfig) -> Self
 
pub fn presigned_url_config(self, input: PresignedUrlConfig) -> Self
Configuration information for pre-signed S3 URLs.
sourcepub fn set_presigned_url_config(self, input: Option<PresignedUrlConfig>) -> Self
 
pub fn set_presigned_url_config(self, input: Option<PresignedUrlConfig>) -> Self
Configuration information for pre-signed S3 URLs.
sourcepub fn get_presigned_url_config(&self) -> &Option<PresignedUrlConfig>
 
pub fn get_presigned_url_config(&self) -> &Option<PresignedUrlConfig>
Configuration information for pre-signed S3 URLs.
sourcepub fn target_selection(self, input: TargetSelection) -> Self
 
pub fn target_selection(self, input: TargetSelection) -> Self
Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a thing when the thing is added to a target group, even after the job was completed by all things originally in the group.
We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.
sourcepub fn set_target_selection(self, input: Option<TargetSelection>) -> Self
 
pub fn set_target_selection(self, input: Option<TargetSelection>) -> Self
Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a thing when the thing is added to a target group, even after the job was completed by all things originally in the group.
We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.
sourcepub fn get_target_selection(&self) -> &Option<TargetSelection>
 
pub fn get_target_selection(&self) -> &Option<TargetSelection>
Specifies whether the job will continue to run (CONTINUOUS), or will be complete after all those things specified as targets have completed the job (SNAPSHOT). If continuous, the job may also be run on a thing when a change is detected in a target. For example, a job will run on a thing when the thing is added to a target group, even after the job was completed by all things originally in the group.
We recommend that you use continuous jobs instead of snapshot jobs for dynamic thing group targets. By using continuous jobs, devices that join the group receive the job execution even after the job has been created.
sourcepub fn job_executions_rollout_config(
    self,
    input: JobExecutionsRolloutConfig,
) -> Self
 
pub fn job_executions_rollout_config( self, input: JobExecutionsRolloutConfig, ) -> Self
Allows you to create a staged rollout of the job.
sourcepub fn set_job_executions_rollout_config(
    self,
    input: Option<JobExecutionsRolloutConfig>,
) -> Self
 
pub fn set_job_executions_rollout_config( self, input: Option<JobExecutionsRolloutConfig>, ) -> Self
Allows you to create a staged rollout of the job.
sourcepub fn get_job_executions_rollout_config(
    &self,
) -> &Option<JobExecutionsRolloutConfig>
 
pub fn get_job_executions_rollout_config( &self, ) -> &Option<JobExecutionsRolloutConfig>
Allows you to create a staged rollout of the job.
sourcepub fn abort_config(self, input: AbortConfig) -> Self
 
pub fn abort_config(self, input: AbortConfig) -> Self
Allows you to create the criteria to abort a job.
sourcepub fn set_abort_config(self, input: Option<AbortConfig>) -> Self
 
pub fn set_abort_config(self, input: Option<AbortConfig>) -> Self
Allows you to create the criteria to abort a job.
sourcepub fn get_abort_config(&self) -> &Option<AbortConfig>
 
pub fn get_abort_config(&self) -> &Option<AbortConfig>
Allows you to create the criteria to abort a job.
sourcepub fn timeout_config(self, input: TimeoutConfig) -> Self
 
pub fn timeout_config(self, input: TimeoutConfig) -> Self
Specifies the amount of time each device has to finish its execution of the job. The timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the time expires, it will be automatically set to TIMED_OUT.
sourcepub fn set_timeout_config(self, input: Option<TimeoutConfig>) -> Self
 
pub fn set_timeout_config(self, input: Option<TimeoutConfig>) -> Self
Specifies the amount of time each device has to finish its execution of the job. The timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the time expires, it will be automatically set to TIMED_OUT.
sourcepub fn get_timeout_config(&self) -> &Option<TimeoutConfig>
 
pub fn get_timeout_config(&self) -> &Option<TimeoutConfig>
Specifies the amount of time each device has to finish its execution of the job. The timer is started when the job execution status is set to IN_PROGRESS. If the job execution status is not set to another terminal state before the time expires, it will be automatically set to TIMED_OUT.
Appends an item to tags.
To override the contents of this collection use set_tags.
Metadata which can be used to manage the job.
Metadata which can be used to manage the job.
Metadata which can be used to manage the job.
sourcepub fn namespace_id(self, input: impl Into<String>) -> Self
 
pub fn namespace_id(self, input: impl Into<String>) -> Self
The namespace used to indicate that a job is a customer-managed job.
When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.
$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/
The namespaceId feature is only supported by IoT Greengrass at this time. For more information, see Setting up IoT Greengrass core devices.
sourcepub fn set_namespace_id(self, input: Option<String>) -> Self
 
pub fn set_namespace_id(self, input: Option<String>) -> Self
The namespace used to indicate that a job is a customer-managed job.
When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.
$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/
The namespaceId feature is only supported by IoT Greengrass at this time. For more information, see Setting up IoT Greengrass core devices.
sourcepub fn get_namespace_id(&self) -> &Option<String>
 
pub fn get_namespace_id(&self) -> &Option<String>
The namespace used to indicate that a job is a customer-managed job.
When you specify a value for this parameter, Amazon Web Services IoT Core sends jobs notifications to MQTT topics that contain the value in the following format.
$aws/things/THING_NAME/jobs/JOB_ID/notify-namespace-NAMESPACE_ID/
The namespaceId feature is only supported by IoT Greengrass at this time. For more information, see Setting up IoT Greengrass core devices.
sourcepub fn job_template_arn(self, input: impl Into<String>) -> Self
 
pub fn job_template_arn(self, input: impl Into<String>) -> Self
The ARN of the job template used to create the job.
sourcepub fn set_job_template_arn(self, input: Option<String>) -> Self
 
pub fn set_job_template_arn(self, input: Option<String>) -> Self
The ARN of the job template used to create the job.
sourcepub fn get_job_template_arn(&self) -> &Option<String>
 
pub fn get_job_template_arn(&self) -> &Option<String>
The ARN of the job template used to create the job.
sourcepub fn job_executions_retry_config(
    self,
    input: JobExecutionsRetryConfig,
) -> Self
 
pub fn job_executions_retry_config( self, input: JobExecutionsRetryConfig, ) -> Self
Allows you to create the criteria to retry a job.
sourcepub fn set_job_executions_retry_config(
    self,
    input: Option<JobExecutionsRetryConfig>,
) -> Self
 
pub fn set_job_executions_retry_config( self, input: Option<JobExecutionsRetryConfig>, ) -> Self
Allows you to create the criteria to retry a job.
sourcepub fn get_job_executions_retry_config(
    &self,
) -> &Option<JobExecutionsRetryConfig>
 
pub fn get_job_executions_retry_config( &self, ) -> &Option<JobExecutionsRetryConfig>
Allows you to create the criteria to retry a job.
sourcepub fn document_parameters(
    self,
    k: impl Into<String>,
    v: impl Into<String>,
) -> Self
 
pub fn document_parameters( self, k: impl Into<String>, v: impl Into<String>, ) -> Self
Adds a key-value pair to document_parameters.
To override the contents of this collection use set_document_parameters.
Parameters of an Amazon Web Services managed template that you can specify to create the job document.
documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.
sourcepub fn set_document_parameters(
    self,
    input: Option<HashMap<String, String>>,
) -> Self
 
pub fn set_document_parameters( self, input: Option<HashMap<String, String>>, ) -> Self
Parameters of an Amazon Web Services managed template that you can specify to create the job document.
documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.
sourcepub fn get_document_parameters(&self) -> &Option<HashMap<String, String>>
 
pub fn get_document_parameters(&self) -> &Option<HashMap<String, String>>
Parameters of an Amazon Web Services managed template that you can specify to create the job document.
documentParameters can only be used when creating jobs from Amazon Web Services managed templates. This parameter can't be used with custom job templates or to create jobs from them.
sourcepub fn scheduling_config(self, input: SchedulingConfig) -> Self
 
pub fn scheduling_config(self, input: SchedulingConfig) -> Self
The configuration that allows you to schedule a job for a future date and time in addition to specifying the end behavior for each job execution.
sourcepub fn set_scheduling_config(self, input: Option<SchedulingConfig>) -> Self
 
pub fn set_scheduling_config(self, input: Option<SchedulingConfig>) -> Self
The configuration that allows you to schedule a job for a future date and time in addition to specifying the end behavior for each job execution.
sourcepub fn get_scheduling_config(&self) -> &Option<SchedulingConfig>
 
pub fn get_scheduling_config(&self) -> &Option<SchedulingConfig>
The configuration that allows you to schedule a job for a future date and time in addition to specifying the end behavior for each job execution.
sourcepub fn destination_package_versions(self, input: impl Into<String>) -> Self
 
pub fn destination_package_versions(self, input: impl Into<String>) -> Self
Appends an item to destination_package_versions.
To override the contents of this collection use set_destination_package_versions.
The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes. The package version must be in either the Published or Deprecated state when the job deploys. For more information, see Package version lifecycle.
Note:The following Length Constraints relates to a single ARN. Up to 25 package version ARNs are allowed.
sourcepub fn set_destination_package_versions(
    self,
    input: Option<Vec<String>>,
) -> Self
 
pub fn set_destination_package_versions( self, input: Option<Vec<String>>, ) -> Self
The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes. The package version must be in either the Published or Deprecated state when the job deploys. For more information, see Package version lifecycle.
Note:The following Length Constraints relates to a single ARN. Up to 25 package version ARNs are allowed.
sourcepub fn get_destination_package_versions(&self) -> &Option<Vec<String>>
 
pub fn get_destination_package_versions(&self) -> &Option<Vec<String>>
The package version Amazon Resource Names (ARNs) that are installed on the device when the job successfully completes. The package version must be in either the Published or Deprecated state when the job deploys. For more information, see Package version lifecycle.
Note:The following Length Constraints relates to a single ARN. Up to 25 package version ARNs are allowed.
sourcepub fn build(self) -> Result<CreateJobInput, BuildError>
 
pub fn build(self) -> Result<CreateJobInput, BuildError>
Consumes the builder and constructs a CreateJobInput.
source§impl CreateJobInputBuilder
 
impl CreateJobInputBuilder
sourcepub async fn send_with(
    self,
    client: &Client,
) -> Result<CreateJobOutput, SdkError<CreateJobError, HttpResponse>>
 
pub async fn send_with( self, client: &Client, ) -> Result<CreateJobOutput, SdkError<CreateJobError, HttpResponse>>
Sends a request with this input using the given client.
Trait Implementations§
source§impl Clone for CreateJobInputBuilder
 
impl Clone for CreateJobInputBuilder
source§fn clone(&self) -> CreateJobInputBuilder
 
fn clone(&self) -> CreateJobInputBuilder
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for CreateJobInputBuilder
 
impl Debug for CreateJobInputBuilder
source§impl Default for CreateJobInputBuilder
 
impl Default for CreateJobInputBuilder
source§fn default() -> CreateJobInputBuilder
 
fn default() -> CreateJobInputBuilder
source§impl PartialEq for CreateJobInputBuilder
 
impl PartialEq for CreateJobInputBuilder
impl StructuralPartialEq for CreateJobInputBuilder
Auto Trait Implementations§
impl Freeze for CreateJobInputBuilder
impl RefUnwindSafe for CreateJobInputBuilder
impl Send for CreateJobInputBuilder
impl Sync for CreateJobInputBuilder
impl Unpin for CreateJobInputBuilder
impl UnwindSafe for CreateJobInputBuilder
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
 
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit)source§impl<T> Instrument for T
 
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moresource§impl<T> Paint for Twhere
    T: ?Sized,
 
impl<T> Paint for Twhere
    T: ?Sized,
source§fn fg(&self, value: Color) -> Painted<&T>
 
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();source§fn bright_black(&self) -> Painted<&T>
 
fn bright_black(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightBlack.
§Example
println!("{}", value.bright_black());source§fn bright_red(&self) -> Painted<&T>
 
fn bright_red(&self) -> Painted<&T>
source§fn bright_green(&self) -> Painted<&T>
 
fn bright_green(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightGreen.
§Example
println!("{}", value.bright_green());source§fn bright_yellow(&self) -> Painted<&T>
 
fn bright_yellow(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightYellow.
§Example
println!("{}", value.bright_yellow());source§fn bright_blue(&self) -> Painted<&T>
 
fn bright_blue(&self) -> Painted<&T>
source§fn bright_magenta(&self) -> Painted<&T>
 
fn bright_magenta(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightMagenta.
§Example
println!("{}", value.bright_magenta());source§fn bright_cyan(&self) -> Painted<&T>
 
fn bright_cyan(&self) -> Painted<&T>
source§fn bright_white(&self) -> Painted<&T>
 
fn bright_white(&self) -> Painted<&T>
Returns self with the
fg()
set to
Color::BrightWhite.
§Example
println!("{}", value.bright_white());source§fn bg(&self, value: Color) -> Painted<&T>
 
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();source§fn on_primary(&self) -> Painted<&T>
 
fn on_primary(&self) -> Painted<&T>
source§fn on_magenta(&self) -> Painted<&T>
 
fn on_magenta(&self) -> Painted<&T>
source§fn on_bright_black(&self) -> Painted<&T>
 
fn on_bright_black(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightBlack.
§Example
println!("{}", value.on_bright_black());source§fn on_bright_red(&self) -> Painted<&T>
 
fn on_bright_red(&self) -> Painted<&T>
source§fn on_bright_green(&self) -> Painted<&T>
 
fn on_bright_green(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightGreen.
§Example
println!("{}", value.on_bright_green());source§fn on_bright_yellow(&self) -> Painted<&T>
 
fn on_bright_yellow(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightYellow.
§Example
println!("{}", value.on_bright_yellow());source§fn on_bright_blue(&self) -> Painted<&T>
 
fn on_bright_blue(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightBlue.
§Example
println!("{}", value.on_bright_blue());source§fn on_bright_magenta(&self) -> Painted<&T>
 
fn on_bright_magenta(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightMagenta.
§Example
println!("{}", value.on_bright_magenta());source§fn on_bright_cyan(&self) -> Painted<&T>
 
fn on_bright_cyan(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightCyan.
§Example
println!("{}", value.on_bright_cyan());source§fn on_bright_white(&self) -> Painted<&T>
 
fn on_bright_white(&self) -> Painted<&T>
Returns self with the
bg()
set to
Color::BrightWhite.
§Example
println!("{}", value.on_bright_white());source§fn attr(&self, value: Attribute) -> Painted<&T>
 
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();source§fn underline(&self) -> Painted<&T>
 
fn underline(&self) -> Painted<&T>
Returns self with the
attr()
set to
Attribute::Underline.
§Example
println!("{}", value.underline());source§fn rapid_blink(&self) -> Painted<&T>
 
fn rapid_blink(&self) -> Painted<&T>
Returns self with the
attr()
set to
Attribute::RapidBlink.
§Example
println!("{}", value.rapid_blink());source§fn quirk(&self, value: Quirk) -> Painted<&T>
 
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();source§fn clear(&self) -> Painted<&T>
 👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.source§fn whenever(&self, value: Condition) -> Painted<&T>
 
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);