98 releases (54 stable)

new 1.55.0 Jan 15, 2025
1.53.0 Dec 28, 2024
1.50.0 Nov 6, 2024
1.37.0 Jul 22, 2024
0.0.0 May 7, 2021

#2699 in Network programming

Download history 222/week @ 2024-09-25 173/week @ 2024-10-02 181/week @ 2024-10-09 26/week @ 2024-10-16 109/week @ 2024-10-23 167/week @ 2024-10-30 186/week @ 2024-11-06 12/week @ 2024-11-13 15/week @ 2024-11-20 8/week @ 2024-11-27 145/week @ 2024-12-04 40/week @ 2024-12-11 158/week @ 2024-12-18 114/week @ 2024-12-25 133/week @ 2025-01-01 13/week @ 2025-01-08

419 downloads per month
Used in aws-greengrass-nucleus

Apache-2.0

2.5MB
38K SLoC

aws-sdk-greengrassv2

IoT Greengrass brings local compute, messaging, data management, sync, and ML inference capabilities to edge devices. This enables devices to collect and analyze data closer to the source of information, react autonomously to local events, and communicate securely with each other on local networks. Local devices can also communicate securely with Amazon Web Services IoT Core and export IoT data to the Amazon Web Services Cloud. IoT Greengrass developers can use Lambda functions and components to create and deploy applications to fleets of edge devices for local operation.

IoT Greengrass Version 2 provides a new major version of the IoT Greengrass Core software, new APIs, and a new console. Use this API reference to learn how to use the IoT Greengrass V2 API operations to manage components, manage deployments, and core devices.

For more information, see What is IoT Greengrass? in the IoT Greengrass V2 Developer Guide.

Getting Started

Examples are available for many services and operations, check out the examples folder in GitHub.

The SDK provides one crate per AWS service. You must add Tokio as a dependency within your Rust project to execute asynchronous code. To add aws-sdk-greengrassv2 to your project, add the following to your Cargo.toml file:

[dependencies]
aws-config = { version = "1.1.7", features = ["behavior-version-latest"] }
aws-sdk-greengrassv2 = "1.54.0"
tokio = { version = "1", features = ["full"] }

Then in code, a client can be created with the following:

use aws_sdk_greengrassv2 as greengrassv2;

#[::tokio::main]
async fn main() -> Result<(), greengrassv2::Error> {
    let config = aws_config::load_from_env().await;
    let client = aws_sdk_greengrassv2::Client::new(&config);

    // ... make some calls with the client

    Ok(())
}

See the client documentation for information on what calls can be made, and the inputs and outputs for each of those calls.

Using the SDK

Until the SDK is released, we will be adding information about using the SDK to the Developer Guide. Feel free to suggest additional sections for the guide by opening an issue and describing what you are trying to do.

Getting Help

License

This project is licensed under the Apache-2.0 License.

Dependencies

~8–20MB
~287K SLoC