React Native Component wrapper for connecting to AWS IoT from a device using SDK JavaScript bundle
Allows developers to use the AWS IOT shadow support from a React Native component.
- Overview
- Installation
- Examples
- API Documentation
- Connection Types
- AWS bundle
- Debugging mode
- Unit Tests
- License
- Support
This document provides instructions on how to install and configure the AWS IoT device/Shadow in React Native.
This package is built on top of the AWS SDK aws-sdk.js which provides two classes: 'device' and 'thingShadow'.
The 'thingShadow' class implements additional functionality for accessing Thing Shadows via the AWS IoT API; the thingShadow class allows devices to update, be notified of changes to, get the current state of, or delete Thing Shadows from AWS IoT. Thing Shadows allow applications and devices to synchronize their state on the AWS IoT platform.
The 'device' class wraps mqtt.js to provide a secure connection to the AWS IoT platform and expose the mqtt.js interfaces upward. It provides features to simplify handling of intermittent connections, including progressive backoff retries, automatic re-subscription upon connection, and queued offline publishing with configurable drain rate.
Installing with npm:
npm install react-native-aws-iot-device-shadows
<AWSIoTMQTT
ref={(ref) => { this.AWSIoTMQTT = ref; }}
type="shadow"
region="us-west-2"
host="asdasd.iot.aws.com"
onReconnect={() => this.onConnect()}
onConnect={() => this.onConnect()}
onDelta={(thingId, stateObject) => this.onDelta(thingId, stateObject)}
onStatus={(thingId, statusType, clientToken, stateObject) =>
this.onStatus(thingId, statusType, clientToken, stateObject)}
onThingConnected={(thingId) => { this.onThingConnected(thingId); }}
/>
<AWSIoTMQTT
ref={(ref) => { this.AWSIoTMQTT = ref; }}
type="device"
region="us-west-2"
host="asdasd.iot.aws.com"
onReconnect={() => this.onConnect()}
onConnect={() => this.onConnect()}
/>
Returns a React Native component whichs wraps xxxxxxxx
type
: use 'device' for device type and 'shadows' for ShadowThinghost
: the AWS IoT endpoint you will use to connectregion
: the AWS IoT region you will use to connectconfig
: extra configuration for the thingShadowonConnect
: callback for when the websockets connectsonReconnect
: callback for when the websockets reconnectsonDelta
: callback for delta msgonStatus
: callback for status msgonThingConnected
: callback for each registered thing
This react native component only supports one type of connections to the AWS IoT platform:
- MQTT over WebSocket/TLS with SigV4 authentication using port 443
The enable debug mode for display logging information just pass a object with debug:true
<AWSIoTMQTT
config={debug:true}
...
/>
This IOT JS SDK is packaged withwebpack, because currently there is not official support for AWS IOT react native. This is already bundle it for you using the last version.
npm run build
This package includes unit tests which can be run as follows:
npm test
Running the unit tests will also generate code coverage data in the 'reports' directory.
This react native component is distributed under the Apache License, Version 2.0, see LICENSE.txt and NOTICE.txt for more information.
feel free to open any ticket in github issues