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(clippy::deprecated_semver)]
16#![allow(rustdoc::bare_urls)]
17#![allow(rustdoc::redundant_explicit_links)]
18#![allow(rustdoc::invalid_html_tags)]
19#![forbid(unsafe_code)]
20#![warn(missing_docs)]
21#![cfg_attr(docsrs, feature(doc_cfg))]
22//! 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).
23//!
24//! 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.
25//! - 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.
26//! - 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.
27//!
28//! 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.
29//!
30//! 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).
31//!
32//! 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.
33//!
34//! 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).
35//!
36//! 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.
37//!
38//! 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).
39//!
40//! ## Getting Started
41//!
42//! > Examples are available for many services and operations, check out the
43//! > [usage examples](https://github.com/awsdocs/aws-doc-sdk-examples/tree/main/rustv1).
44//!
45//! The SDK provides one crate per AWS service. You must add [Tokio](https://crates.io/crates/tokio)
46//! as a dependency within your Rust project to execute asynchronous code. To add `aws-sdk-globalaccelerator` to
47//! your project, add the following to your **Cargo.toml** file:
48//!
49//! ```toml
50//! [dependencies]
51//! aws-config = { version = "1.1.7", features = ["behavior-version-latest"] }
52//! aws-sdk-globalaccelerator = "1.92.0"
53//! tokio = { version = "1", features = ["full"] }
54//! ```
55//!
56//! Then in code, a client can be created with the following:
57//!
58//! ```rust,no_run
59//! use aws_sdk_globalaccelerator as globalaccelerator;
60//!
61//! #[::tokio::main]
62//! async fn main() -> Result<(), globalaccelerator::Error> {
63//! let config = aws_config::load_from_env().await;
64//! let client = aws_sdk_globalaccelerator::Client::new(&config);
65//!
66//! // ... make some calls with the client
67//!
68//! Ok(())
69//! }
70//! ```
71//!
72//! See the [client documentation](https://docs.rs/aws-sdk-globalaccelerator/latest/aws_sdk_globalaccelerator/client/struct.Client.html)
73//! for information on what calls can be made, and the inputs and outputs for each of those calls.
74//!
75//! ## Using the SDK
76//!
77//! Until the SDK is released, we will be adding information about using the SDK to the
78//! [Developer Guide](https://docs.aws.amazon.com/sdk-for-rust/latest/dg/welcome.html). Feel free to suggest
79//! additional sections for the guide by opening an issue and describing what you are trying to do.
80//!
81//! ## Getting Help
82//!
83//! * [GitHub discussions](https://github.com/awslabs/aws-sdk-rust/discussions) - For ideas, RFCs & general questions
84//! * [GitHub issues](https://github.com/awslabs/aws-sdk-rust/issues/new/choose) - For bug reports & feature requests
85//! * [Generated Docs (latest version)](https://awslabs.github.io/aws-sdk-rust/)
86//! * [Usage examples](https://github.com/awsdocs/aws-doc-sdk-examples/tree/main/rustv1)
87//!
88//!
89//! # Crate Organization
90//!
91//! The entry point for most customers will be [`Client`], which exposes one method for each API
92//! offered by AWS Global Accelerator. The return value of each of these methods is a "fluent builder",
93//! where the different inputs for that API are added by builder-style function call chaining,
94//! followed by calling `send()` to get a [`Future`](std::future::Future) that will result in
95//! either a successful output or a [`SdkError`](crate::error::SdkError).
96//!
97//! Some of these API inputs may be structs or enums to provide more complex structured information.
98//! These structs and enums live in [`types`](crate::types). There are some simpler types for
99//! representing data such as date times or binary blobs that live in [`primitives`](crate::primitives).
100//!
101//! All types required to configure a client via the [`Config`](crate::Config) struct live
102//! in [`config`](crate::config).
103//!
104//! The [`operation`](crate::operation) module has a submodule for every API, and in each submodule
105//! is the input, output, and error type for that API, as well as builders to construct each of those.
106//!
107//! There is a top-level [`Error`](crate::Error) type that encompasses all the errors that the
108//! client can return. Any other error type can be converted to this `Error` type via the
109//! [`From`](std::convert::From) trait.
110//!
111//! The other modules within this crate are not required for normal usage.
112
113// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
114pub use error_meta::Error;
115
116#[doc(inline)]
117pub use config::Config;
118
119/// Client for calling AWS Global Accelerator.
120/// ## Constructing a `Client`
121///
122/// A [`Config`] is required to construct a client. For most use cases, the [`aws-config`]
123/// crate should be used to automatically resolve this config using
124/// [`aws_config::load_from_env()`], since this will resolve an [`SdkConfig`] which can be shared
125/// across multiple different AWS SDK clients. This config resolution process can be customized
126/// by calling [`aws_config::from_env()`] instead, which returns a [`ConfigLoader`] that uses
127/// the [builder pattern] to customize the default config.
128///
129/// In the simplest case, creating a client looks as follows:
130/// ```rust,no_run
131/// # async fn wrapper() {
132/// let config = aws_config::load_from_env().await;
133/// let client = aws_sdk_globalaccelerator::Client::new(&config);
134/// # }
135/// ```
136///
137/// Occasionally, SDKs may have additional service-specific values that can be set on the [`Config`] that
138/// is absent from [`SdkConfig`], or slightly different settings for a specific client may be desired.
139/// The [`Builder`](crate::config::Builder) struct implements `From<&SdkConfig>`, so setting these specific settings can be
140/// done as follows:
141///
142/// ```rust,no_run
143/// # async fn wrapper() {
144/// let sdk_config = ::aws_config::load_from_env().await;
145/// let config = aws_sdk_globalaccelerator::config::Builder::from(&sdk_config)
146/// # /*
147/// .some_service_specific_setting("value")
148/// # */
149/// .build();
150/// # }
151/// ```
152///
153/// See the [`aws-config` docs] and [`Config`] for more information on customizing configuration.
154///
155/// _Note:_ Client construction is expensive due to connection thread pool initialization, and should
156/// be done once at application start-up.
157///
158/// [`Config`]: crate::Config
159/// [`ConfigLoader`]: https://docs.rs/aws-config/*/aws_config/struct.ConfigLoader.html
160/// [`SdkConfig`]: https://docs.rs/aws-config/*/aws_config/struct.SdkConfig.html
161/// [`aws-config` docs]: https://docs.rs/aws-config/*
162/// [`aws-config`]: https://crates.io/crates/aws-config
163/// [`aws_config::from_env()`]: https://docs.rs/aws-config/*/aws_config/fn.from_env.html
164/// [`aws_config::load_from_env()`]: https://docs.rs/aws-config/*/aws_config/fn.load_from_env.html
165/// [builder pattern]: https://rust-lang.github.io/api-guidelines/type-safety.html#builders-enable-construction-of-complex-values-c-builder
166/// # Using the `Client`
167///
168/// A client has a function for every operation that can be performed by the service.
169/// For example, the [`AddCustomRoutingEndpoints`](crate::operation::add_custom_routing_endpoints) operation has
170/// a [`Client::add_custom_routing_endpoints`], function which returns a builder for that operation.
171/// The fluent builder ultimately has a `send()` function that returns an async future that
172/// returns a result, as illustrated below:
173///
174/// ```rust,ignore
175/// let result = client.add_custom_routing_endpoints()
176/// .endpoint_group_arn("example")
177/// .send()
178/// .await;
179/// ```
180///
181/// The underlying HTTP requests that get made by this can be modified with the `customize_operation`
182/// function on the fluent builder. See the [`customize`](crate::client::customize) module for more
183/// information.
184pub mod client;
185
186/// Configuration for AWS Global Accelerator.
187pub mod config;
188
189/// Common errors and error handling utilities.
190pub mod error;
191
192mod error_meta;
193
194/// Information about this crate.
195pub mod meta;
196
197/// All operations that this crate can perform.
198pub mod operation;
199
200/// Primitives such as `Blob` or `DateTime` used by other types.
201pub mod primitives;
202
203/// Data structures used by operation inputs/outputs.
204pub mod types;
205
206pub(crate) mod client_idempotency_token;
207
208mod idempotency_token;
209
210pub(crate) mod protocol_serde;
211
212mod sdk_feature_tracker;
213
214mod serialization_settings;
215
216mod endpoint_lib;
217
218mod lens;
219
220mod json_errors;
221
222mod serde_util;
223
224#[doc(inline)]
225pub use client::Client;