react-native-aws-freertos
v0.1.23
Published
React native aws freertos bridge
Downloads
70
Maintainers
Readme
react-native-aws-freertos
React native aws freertos bridge
Installation
npm install react-native-aws-freertos
cd ios && pod install
Open the ios project with xcode and run from there to a physical device, since npx react-native-run ios will open in the simulator and it wont connect to any bt device.
- Android Add this to your manifest file under android/app/src/main/AndroidManifest.xml
<uses-permission android:name="android.permission.BLUETOOTH"/>
<!-- initiate device discovery and manipulate bluetooth settings -->
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/>
<!-- allow scan BLE -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
- IOS Add this to your Podfile
use_frameworks! :linkage => :static
pod 'AmazonFreeRTOS'
pod 'AWSAuthUI'
pod 'AWSMobileClient','~> 2.17.0'
pod 'AWSUserPoolsSignIn'
pod 'react-native-aws-freertos', :path => '../node_modules/react-native-aws-freertos'
Make sure you add bt permissions keys to your Info.plist
<key>NSBluetoothPeripheralUsageDescription</key>
<string>The app needs access to Bluetooth</string>
<key>NSBluetoothAlwaysUsageDescription</key>
<string>We need to acces BLE to update the device</string>
Usage
import AwsFreertos from "react-native-aws-freertos";
// ...
AwsFreertos.getConnectedDeviceAvailableNetworks(deviceMacAddress);
const eventEmitter = new NativeEventEmitter(NativeModules.AwsFreertos);
const wifiListEvent = eventEmitter.addListener(
eventKeys.DID_LIST_NETWORK,
(network: WifiInfo) => {
console.log(network)
}
);
Available methods
type AwsFreertosType = {
startScanBtDevices(): void;
stopScanBtDevices(): void;
setAdvertisingServiceUUIDs(uuids: string[]): void;
requestBtPermissions(): Promise<any>;
connectDevice(macAddress: string): Promise<any>;
disconnectDevice(macAddress: string): Promise<any>;
disconnectNetworkOnConnectedDevice(macAddress: string, index: number): Promise<any>;
saveNetworkOnConnectedDevice(
macAddress: string,
bssid: string,
pw: string
): Promise<any>;
getConnectedDeviceAvailableNetworks(macAddress: string): Promise<WifiInfo[]>;
getConnectedDeviceSavedNetworks(macAddress: string): Promise<WifiInfo[]>;
getGattCharacteristicsFromServer(
macAddress: string,
serviceUuidString: string
): void;
};
Events
export const events = {
// Bluetooth events
DID_UPDATE_BLE_POWER_STATE: 'DID_UPDATE_BLE_POWER_STATE',
DID_DISCONNECT_DEVICE: 'DID_DISCONNECT_DEVICE',
DID_DISCOVERED_DEVICE: 'DID_DISCOVERED_DEVICE',
DID_CONNECT_DEVICE: 'DID_CONNECT_DEVICE',
DID_FAIL_TO_CONNECT_DEVICE: 'DID_FAIL_TO_CONNECT_DEVICE',
DID_READ_CHARACTERISTIC_FROM_SERVICE: 'DID_READ_CHARACTERISTIC_FROM_SERVICE',
// Wifi events of paired up device
DID_LIST_NETWORK: 'DID_LIST_NETWORK',
DID_SAVE_NETWORK: 'DID_SAVE_NETWORK',
ERROR_SAVE_NETWORK: 'ERROR_SAVE_NETWORK',
DID_EDIT_NETWORK: 'DID_EDIT_NETWORK',
DID_DELETE_NETWORK: 'DID_DELETE_NETWORK',
};
Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
License
MIT