aws_sdk_globalaccelerator/
lib.rs

1#![allow(deprecated)]
2#![allow(unknown_lints)]
3#![allow(clippy::module_inception)]
4#![allow(clippy::upper_case_acronyms)]
5#![allow(clippy::large_enum_variant)]
6#![allow(clippy::wrong_self_convention)]
7#![allow(clippy::should_implement_trait)]
8#![allow(clippy::disallowed_names)]
9#![allow(clippy::vec_init_then_push)]
10#![allow(clippy::type_complexity)]
11#![allow(clippy::needless_return)]
12#![allow(clippy::derive_partial_eq_without_eq)]
13#![allow(clippy::result_large_err)]
14#![allow(clippy::unnecessary_map_on_constructor)]
15#![allow(rustdoc::bare_urls)]
16#![allow(rustdoc::redundant_explicit_links)]
17#![allow(rustdoc::invalid_html_tags)]
18#![forbid(unsafe_code)]
19#![warn(missing_docs)]
20#![cfg_attr(docsrs, feature(doc_auto_cfg))]
21//! This is the _Global Accelerator API Reference_. This guide is for developers who need detailed information about Global Accelerator API actions, data types, and errors. For more information about Global Accelerator features, see the [Global Accelerator Developer Guide](https://docs.aws.amazon.com/global-accelerator/latest/dg/what-is-global-accelerator.html).
22//!
23//! Global Accelerator is a service in which you create _accelerators_ to improve the performance of your applications for local and global users. Depending on the type of accelerator you choose, you can gain additional benefits.
24//!   - By using a standard accelerator, you can improve availability of your internet applications that are used by a global audience. With a standard accelerator, Global Accelerator directs traffic to optimal endpoints over the Amazon Web Services global network.
25//!   - For other scenarios, you might choose a custom routing accelerator. With a custom routing accelerator, you can use application logic to directly map one or more users to a specific endpoint among many endpoints.
26//!
27//! Global Accelerator is a global service that supports endpoints in multiple Amazon Web Services Regions but you must specify the US West (Oregon) Region to create, update, or otherwise work with accelerators. That is, for example, specify --region us-west-2 on Amazon Web Services CLI commands.
28//!
29//! By default, Global Accelerator provides you with static IP addresses that you associate with your accelerator. The static IP addresses are anycast from the Amazon Web Services edge network. For IPv4, Global Accelerator provides two static IPv4 addresses. For dual-stack, Global Accelerator provides a total of four addresses: two static IPv4 addresses and two static IPv6 addresses. With a standard accelerator for IPv4, instead of using the addresses that Global Accelerator provides, you can configure these entry points to be IPv4 addresses from your own IP address ranges that you bring to Global Accelerator (BYOIP).
30//!
31//! For a standard accelerator, they distribute incoming application traffic across multiple endpoint resources in multiple Amazon Web Services Regions , which increases the availability of your applications. Endpoints for standard accelerators can be Network Load Balancers, Application Load Balancers, Amazon EC2 instances, or Elastic IP addresses that are located in one Amazon Web Services Region or multiple Amazon Web Services Regions. For custom routing accelerators, you map traffic that arrives to the static IP addresses to specific Amazon EC2 servers in endpoints that are virtual private cloud (VPC) subnets.
32//!
33//! The static IP addresses remain assigned to your accelerator for as long as it exists, even if you disable the accelerator and it no longer accepts or routes traffic. However, when you _delete_ an accelerator, you lose the static IP addresses that are assigned to it, so you can no longer route traffic by using them. You can use IAM policies like tag-based permissions with Global Accelerator to limit the users who have permissions to delete an accelerator. For more information, see [Tag-based policies](https://docs.aws.amazon.com/global-accelerator/latest/dg/access-control-manage-access-tag-policies.html).
34//!
35//! For standard accelerators, Global Accelerator uses the Amazon Web Services global network to route traffic to the optimal regional endpoint based on health, client location, and policies that you configure. The service reacts instantly to changes in health or configuration to ensure that internet traffic from clients is always directed to healthy endpoints.
36//!
37//! For more information about understanding and using Global Accelerator, see the [Global Accelerator Developer Guide](https://docs.aws.amazon.com/global-accelerator/latest/dg/what-is-global-accelerator.html).
38//!
39//! ## Getting Started
40//!
41//! > Examples are available for many services and operations, check out the
42//! > [examples folder in GitHub](https://github.com/awslabs/aws-sdk-rust/tree/main/examples).
43//!
44//! The SDK provides one crate per AWS service. You must add [Tokio](https://crates.io/crates/tokio)
45//! as a dependency within your Rust project to execute asynchronous code. To add `aws-sdk-globalaccelerator` to
46//! your project, add the following to your **Cargo.toml** file:
47//!
48//! ```toml
49//! [dependencies]
50//! aws-config = { version = "1.1.7", features = ["behavior-version-latest"] }
51//! aws-sdk-globalaccelerator = "1.73.0"
52//! tokio = { version = "1", features = ["full"] }
53//! ```
54//!
55//! Then in code, a client can be created with the following:
56//!
57//! ```rust,no_run
58//! use aws_sdk_globalaccelerator as globalaccelerator;
59//!
60//! #[::tokio::main]
61//! async fn main() -> Result<(), globalaccelerator::Error> {
62//!     let config = aws_config::load_from_env().await;
63//!     let client = aws_sdk_globalaccelerator::Client::new(&config);
64//!
65//!     // ... make some calls with the client
66//!
67//!     Ok(())
68//! }
69//! ```
70//!
71//! See the [client documentation](https://docs.rs/aws-sdk-globalaccelerator/latest/aws_sdk_globalaccelerator/client/struct.Client.html)
72//! for information on what calls can be made, and the inputs and outputs for each of those calls.
73//!
74//! ## Using the SDK
75//!
76//! Until the SDK is released, we will be adding information about using the SDK to the
77//! [Developer Guide](https://docs.aws.amazon.com/sdk-for-rust/latest/dg/welcome.html). Feel free to suggest
78//! additional sections for the guide by opening an issue and describing what you are trying to do.
79//!
80//! ## Getting Help
81//!
82//! * [GitHub discussions](https://github.com/awslabs/aws-sdk-rust/discussions) - For ideas, RFCs & general questions
83//! * [GitHub issues](https://github.com/awslabs/aws-sdk-rust/issues/new/choose) - For bug reports & feature requests
84//! * [Generated Docs (latest version)](https://awslabs.github.io/aws-sdk-rust/)
85//! * [Usage examples](https://github.com/awslabs/aws-sdk-rust/tree/main/examples)
86//!
87//!
88//! # Crate Organization
89//!
90//! The entry point for most customers will be [`Client`], which exposes one method for each API
91//! offered by AWS Global Accelerator. The return value of each of these methods is a "fluent builder",
92//! where the different inputs for that API are added by builder-style function call chaining,
93//! followed by calling `send()` to get a [`Future`](std::future::Future) that will result in
94//! either a successful output or a [`SdkError`](crate::error::SdkError).
95//!
96//! Some of these API inputs may be structs or enums to provide more complex structured information.
97//! These structs and enums live in [`types`](crate::types). There are some simpler types for
98//! representing data such as date times or binary blobs that live in [`primitives`](crate::primitives).
99//!
100//! All types required to configure a client via the [`Config`](crate::Config) struct live
101//! in [`config`](crate::config).
102//!
103//! The [`operation`](crate::operation) module has a submodule for every API, and in each submodule
104//! is the input, output, and error type for that API, as well as builders to construct each of those.
105//!
106//! There is a top-level [`Error`](crate::Error) type that encompasses all the errors that the
107//! client can return. Any other error type can be converted to this `Error` type via the
108//! [`From`](std::convert::From) trait.
109//!
110//! The other modules within this crate are not required for normal usage.
111
112// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
113pub use error_meta::Error;
114
115#[doc(inline)]
116pub use config::Config;
117
118/// Client for calling AWS Global Accelerator.
119/// ## Constructing a `Client`
120///
121/// A [`Config`] is required to construct a client. For most use cases, the [`aws-config`]
122/// crate should be used to automatically resolve this config using
123/// [`aws_config::load_from_env()`], since this will resolve an [`SdkConfig`] which can be shared
124/// across multiple different AWS SDK clients. This config resolution process can be customized
125/// by calling [`aws_config::from_env()`] instead, which returns a [`ConfigLoader`] that uses
126/// the [builder pattern] to customize the default config.
127///
128/// In the simplest case, creating a client looks as follows:
129/// ```rust,no_run
130/// # async fn wrapper() {
131/// let config = aws_config::load_from_env().await;
132/// let client = aws_sdk_globalaccelerator::Client::new(&config);
133/// # }
134/// ```
135///
136/// Occasionally, SDKs may have additional service-specific values that can be set on the [`Config`] that
137/// is absent from [`SdkConfig`], or slightly different settings for a specific client may be desired.
138/// The [`Builder`](crate::config::Builder) struct implements `From<&SdkConfig>`, so setting these specific settings can be
139/// done as follows:
140///
141/// ```rust,no_run
142/// # async fn wrapper() {
143/// let sdk_config = ::aws_config::load_from_env().await;
144/// let config = aws_sdk_globalaccelerator::config::Builder::from(&sdk_config)
145/// # /*
146///     .some_service_specific_setting("value")
147/// # */
148///     .build();
149/// # }
150/// ```
151///
152/// See the [`aws-config` docs] and [`Config`] for more information on customizing configuration.
153///
154/// _Note:_ Client construction is expensive due to connection thread pool initialization, and should
155/// be done once at application start-up.
156///
157/// [`Config`]: crate::Config
158/// [`ConfigLoader`]: https://docs.rs/aws-config/*/aws_config/struct.ConfigLoader.html
159/// [`SdkConfig`]: https://docs.rs/aws-config/*/aws_config/struct.SdkConfig.html
160/// [`aws-config` docs]: https://docs.rs/aws-config/*
161/// [`aws-config`]: https://crates.io/crates/aws-config
162/// [`aws_config::from_env()`]: https://docs.rs/aws-config/*/aws_config/fn.from_env.html
163/// [`aws_config::load_from_env()`]: https://docs.rs/aws-config/*/aws_config/fn.load_from_env.html
164/// [builder pattern]: https://rust-lang.github.io/api-guidelines/type-safety.html#builders-enable-construction-of-complex-values-c-builder
165/// # Using the `Client`
166///
167/// A client has a function for every operation that can be performed by the service.
168/// For example, the [`AddCustomRoutingEndpoints`](crate::operation::add_custom_routing_endpoints) operation has
169/// a [`Client::add_custom_routing_endpoints`], function which returns a builder for that operation.
170/// The fluent builder ultimately has a `send()` function that returns an async future that
171/// returns a result, as illustrated below:
172///
173/// ```rust,ignore
174/// let result = client.add_custom_routing_endpoints()
175///     .endpoint_group_arn("example")
176///     .send()
177///     .await;
178/// ```
179///
180/// The underlying HTTP requests that get made by this can be modified with the `customize_operation`
181/// function on the fluent builder. See the [`customize`](crate::client::customize) module for more
182/// information.
183pub mod client;
184
185/// Configuration for AWS Global Accelerator.
186pub mod config;
187
188/// Common errors and error handling utilities.
189pub mod error;
190
191mod error_meta;
192
193/// Information about this crate.
194pub mod meta;
195
196/// All operations that this crate can perform.
197pub mod operation;
198
199/// Primitives such as `Blob` or `DateTime` used by other types.
200pub mod primitives;
201
202/// Data structures used by operation inputs/outputs.
203pub mod types;
204
205mod auth_plugin;
206
207pub(crate) mod client_idempotency_token;
208
209mod idempotency_token;
210
211pub(crate) mod protocol_serde;
212
213mod sdk_feature_tracker;
214
215mod serialization_settings;
216
217mod endpoint_lib;
218
219mod lens;
220
221mod json_errors;
222
223mod serde_util;
224
225#[doc(inline)]
226pub use client::Client;