81 releases (37 stable)

new 1.38.0 Jul 12, 2024
1.36.0 Jun 20, 2024
1.19.0 Mar 29, 2024
1.9.0 Dec 21, 2023
0.0.0 May 7, 2021

#1 in #wireless

Download history 105/week @ 2024-03-15 89/week @ 2024-03-22 175/week @ 2024-03-29 102/week @ 2024-04-05 234/week @ 2024-04-12 105/week @ 2024-04-19 97/week @ 2024-04-26 176/week @ 2024-05-03 119/week @ 2024-05-10 153/week @ 2024-05-17 152/week @ 2024-05-24 214/week @ 2024-05-31 229/week @ 2024-06-07 205/week @ 2024-06-14 74/week @ 2024-06-21 2/week @ 2024-06-28

621 downloads per month


120K SLoC


AWS IoT Wireless provides bi-directional communication between internet-connected wireless devices and the AWS Cloud. To onboard both LoRaWAN and Sidewalk devices to AWS IoT, use the IoT Wireless API. These wireless devices use the Low Power Wide Area Networking (LPWAN) communication protocol to communicate with AWS IoT.

Using the API, you can perform create, read, update, and delete operations for your wireless devices, gateways, destinations, and profiles. After onboarding your devices, you can use the API operations to set log levels and monitor your devices with CloudWatch.

You can also use the API operations to create multicast groups and schedule a multicast session for sending a downlink message to devices in the group. By using Firmware Updates Over-The-Air (FUOTA) API operations, you can create a FUOTA task and schedule a session to update the firmware of individual devices or an entire group of devices in a multicast group.

To connect to the AWS IoT Wireless Service, use the Service endpoints as described in IoT Wireless Service endpoints in the AWS General Reference.

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-iotwireless to your project, add the following to your Cargo.toml file:

aws-config = { version = "1.1.7", features = ["behavior-version-latest"] }
aws-sdk-iotwireless = "1.38.0"
tokio = { version = "1", features = ["full"] }

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

use aws_sdk_iotwireless as iotwireless;

async fn main() -> Result<(), iotwireless::Error> {
    let config = aws_config::load_from_env().await;
    let client = aws_sdk_iotwireless::Client::new(&config);

    // ... make some calls with the client


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


This project is licensed under the Apache-2.0 License.


~267K SLoC