aws_sdk_connect/operation/update_contact_routing_data/builders.rs
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 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub use crate::operation::update_contact_routing_data::_update_contact_routing_data_output::UpdateContactRoutingDataOutputBuilder;
pub use crate::operation::update_contact_routing_data::_update_contact_routing_data_input::UpdateContactRoutingDataInputBuilder;
impl crate::operation::update_contact_routing_data::builders::UpdateContactRoutingDataInputBuilder {
/// Sends a request with this input using the given client.
pub async fn send_with(
self,
client: &crate::Client,
) -> ::std::result::Result<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataOutput,
::aws_smithy_runtime_api::client::result::SdkError<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataError,
::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
>,
> {
let mut fluent_builder = client.update_contact_routing_data();
fluent_builder.inner = self;
fluent_builder.send().await
}
}
/// Fluent builder constructing a request to `UpdateContactRoutingData`.
///
/// <p>Updates routing priority and age on the contact (<b>QueuePriority</b> and <b>QueueTimeAdjustmentInSeconds</b>). These properties can be used to change a customer's position in the queue. For example, you can move a contact to the back of the queue by setting a lower routing priority relative to other contacts in queue; or you can move a contact to the front of the queue by increasing the routing age which will make the contact look artificially older and therefore higher up in the first-in-first-out routing order. Note that adjusting the routing age of a contact affects only its position in queue, and not its actual queue wait time as reported through metrics. These properties can also be updated by using <a href="https://docs.aws.amazon.com/connect/latest/adminguide/change-routing-priority.html">the Set routing priority / age flow block</a>.</p><note>
/// <p>Either <b>QueuePriority</b> or <b>QueueTimeAdjustmentInSeconds</b> should be provided within the request body, but not both.</p>
/// </note>
#[derive(::std::clone::Clone, ::std::fmt::Debug)]
pub struct UpdateContactRoutingDataFluentBuilder {
handle: ::std::sync::Arc<crate::client::Handle>,
inner: crate::operation::update_contact_routing_data::builders::UpdateContactRoutingDataInputBuilder,
config_override: ::std::option::Option<crate::config::Builder>,
}
impl
crate::client::customize::internal::CustomizableSend<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataOutput,
crate::operation::update_contact_routing_data::UpdateContactRoutingDataError,
> for UpdateContactRoutingDataFluentBuilder
{
fn send(
self,
config_override: crate::config::Builder,
) -> crate::client::customize::internal::BoxFuture<
crate::client::customize::internal::SendResult<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataOutput,
crate::operation::update_contact_routing_data::UpdateContactRoutingDataError,
>,
> {
::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
}
}
impl UpdateContactRoutingDataFluentBuilder {
/// Creates a new `UpdateContactRoutingDataFluentBuilder`.
pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
Self {
handle,
inner: ::std::default::Default::default(),
config_override: ::std::option::Option::None,
}
}
/// Access the UpdateContactRoutingData as a reference.
pub fn as_input(&self) -> &crate::operation::update_contact_routing_data::builders::UpdateContactRoutingDataInputBuilder {
&self.inner
}
/// Sends the request and returns the response.
///
/// If an error occurs, an `SdkError` will be returned with additional details that
/// can be matched against.
///
/// By default, any retryable failures will be retried twice. Retry behavior
/// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
/// set when configuring the client.
pub async fn send(
self,
) -> ::std::result::Result<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataOutput,
::aws_smithy_runtime_api::client::result::SdkError<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataError,
::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
>,
> {
let input = self
.inner
.build()
.map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
let runtime_plugins = crate::operation::update_contact_routing_data::UpdateContactRoutingData::operation_runtime_plugins(
self.handle.runtime_plugins.clone(),
&self.handle.conf,
self.config_override,
);
crate::operation::update_contact_routing_data::UpdateContactRoutingData::orchestrate(&runtime_plugins, input).await
}
/// Consumes this builder, creating a customizable operation that can be modified before being sent.
pub fn customize(
self,
) -> crate::client::customize::CustomizableOperation<
crate::operation::update_contact_routing_data::UpdateContactRoutingDataOutput,
crate::operation::update_contact_routing_data::UpdateContactRoutingDataError,
Self,
> {
crate::client::customize::CustomizableOperation::new(self)
}
pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
self.set_config_override(::std::option::Option::Some(config_override.into()));
self
}
pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
self.config_override = config_override;
self
}
/// <p>The identifier of the Amazon Connect instance. You can <a href="https://docs.aws.amazon.com/connect/latest/adminguide/find-instance-arn.html">find the instance ID</a> in the Amazon Resource Name (ARN) of the instance.</p>
pub fn instance_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.inner = self.inner.instance_id(input.into());
self
}
/// <p>The identifier of the Amazon Connect instance. You can <a href="https://docs.aws.amazon.com/connect/latest/adminguide/find-instance-arn.html">find the instance ID</a> in the Amazon Resource Name (ARN) of the instance.</p>
pub fn set_instance_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.inner = self.inner.set_instance_id(input);
self
}
/// <p>The identifier of the Amazon Connect instance. You can <a href="https://docs.aws.amazon.com/connect/latest/adminguide/find-instance-arn.html">find the instance ID</a> in the Amazon Resource Name (ARN) of the instance.</p>
pub fn get_instance_id(&self) -> &::std::option::Option<::std::string::String> {
self.inner.get_instance_id()
}
/// <p>The identifier of the contact in this instance of Amazon Connect.</p>
pub fn contact_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.inner = self.inner.contact_id(input.into());
self
}
/// <p>The identifier of the contact in this instance of Amazon Connect.</p>
pub fn set_contact_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.inner = self.inner.set_contact_id(input);
self
}
/// <p>The identifier of the contact in this instance of Amazon Connect.</p>
pub fn get_contact_id(&self) -> &::std::option::Option<::std::string::String> {
self.inner.get_contact_id()
}
/// <p>The number of seconds to add or subtract from the contact's routing age. Contacts are routed to agents on a first-come, first-serve basis. This means that changing their amount of time in queue compared to others also changes their position in queue.</p>
pub fn queue_time_adjustment_seconds(mut self, input: i32) -> Self {
self.inner = self.inner.queue_time_adjustment_seconds(input);
self
}
/// <p>The number of seconds to add or subtract from the contact's routing age. Contacts are routed to agents on a first-come, first-serve basis. This means that changing their amount of time in queue compared to others also changes their position in queue.</p>
pub fn set_queue_time_adjustment_seconds(mut self, input: ::std::option::Option<i32>) -> Self {
self.inner = self.inner.set_queue_time_adjustment_seconds(input);
self
}
/// <p>The number of seconds to add or subtract from the contact's routing age. Contacts are routed to agents on a first-come, first-serve basis. This means that changing their amount of time in queue compared to others also changes their position in queue.</p>
pub fn get_queue_time_adjustment_seconds(&self) -> &::std::option::Option<i32> {
self.inner.get_queue_time_adjustment_seconds()
}
/// <p>Priority of the contact in the queue. The default priority for new contacts is 5. You can raise the priority of a contact compared to other contacts in the queue by assigning them a higher priority, such as 1 or 2.</p>
pub fn queue_priority(mut self, input: i64) -> Self {
self.inner = self.inner.queue_priority(input);
self
}
/// <p>Priority of the contact in the queue. The default priority for new contacts is 5. You can raise the priority of a contact compared to other contacts in the queue by assigning them a higher priority, such as 1 or 2.</p>
pub fn set_queue_priority(mut self, input: ::std::option::Option<i64>) -> Self {
self.inner = self.inner.set_queue_priority(input);
self
}
/// <p>Priority of the contact in the queue. The default priority for new contacts is 5. You can raise the priority of a contact compared to other contacts in the queue by assigning them a higher priority, such as 1 or 2.</p>
pub fn get_queue_priority(&self) -> &::std::option::Option<i64> {
self.inner.get_queue_priority()
}
/// <p>Updates the routing criteria on the contact. These properties can be used to change how a
contact is routed within the queue.</p>
pub fn routing_criteria(mut self, input: crate::types::RoutingCriteriaInput) -> Self {
self.inner = self.inner.routing_criteria(input);
self
}
/// <p>Updates the routing criteria on the contact. These properties can be used to change how a
contact is routed within the queue.</p>
pub fn set_routing_criteria(mut self, input: ::std::option::Option<crate::types::RoutingCriteriaInput>) -> Self {
self.inner = self.inner.set_routing_criteria(input);
self
}
/// <p>Updates the routing criteria on the contact. These properties can be used to change how a
contact is routed within the queue.</p>
pub fn get_routing_criteria(&self) -> &::std::option::Option<crate::types::RoutingCriteriaInput> {
self.inner.get_routing_criteria()
}
}