Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
This is a fork of TuyaInc/tuyasmart-home-sdk-react-native, fixing a lot of issues we came across and a better install guide. It also uses TypeScript. We use it currently in multiple projects for clients and it is stable.
Some features are not implemented, feel free to send a PR for those missing features. Unfortunately there is no demo yet
Tuya Smart APP SDK provides the interface package for the communication with hardware and Tuya Cloud to accelerate the application development process, including the following features:
Hardware functions (network configuration, control, status reporting, regular tasks, groups, firmware upgrades, sharing) Account system (phone number, email registration, login, password reset and other general account functions) Tuya Cloud HTTP API interface package
yarn add thiagobueno/rn-tuya
This library contains native code which is automatically linked in React Native >= 0.59. For iOS, run cd ios && pod install
.
In the Tuya development environment create a new app and make sure you have an "App key", "App secret" and "Secure image". Read how to do this.
Put the secure image into the root path of your project as explained here.
In ios/AppDelegate.m
, add the following import;
#import <TuyaSmartHomeKit/TuyaSmartKit.h>
Then, under the roootView.backgroundColor
line in the same file, add this:
#ifdef DEBUG
[[TuyaSmartSDK sharedInstance] setDebugMode:YES];
#endif
[[TuyaSmartSDK sharedInstance] startWithAppKey:@"xxx" secretKey:@"xxx"];
Now replace the xxx
with your app key and secret key.
Assuming you already have created an app in the Tuya development environment (otherwise follow the iOS steps before this), follow these steps. You should now have an app key, app secret and security image for Android. Make sure the security image is put in android/src/main/assets/t_s.bmp
.
Open your AndroidManifest.xml
and put the following in the <application>
tag:
<meta-data
android:name="TUYA_SMART_APPKEY"
android:value="xxx" />
<meta-data
android:name="TUYA_SMART_SECRET"
android:value="xxx" />
Replace the xxx
with your app key and secret key.
Now open MainApplication.java
and add the following import to the top:
import com.tuya.smart.rnsdk.core.TuyaCoreModule;
Change the onCreate
function to look like this:
@Override
public void onCreate() {
super.onCreate();
SoLoader.init(this, /* native exopackage */ false);
initializeFlipper(this); // Remove this line if you don't want Flipper enabled
TuyaCoreModule.Companion.initTuyaSDKWithoutOptions(this);
}
Now you can try to build, but you'll probably run into an error saying that it can't choose between libc++_shared
or something. One fix for this (don't know if it's the best fix) is to open android/app/build.gradle
and add this;
android {
...
packagingOptions {
pickFirst '**/armeabi-v7a/libc++_shared.so'
pickFirst '**/x86/libc++_shared.so'
pickFirst '**/arm64-v8a/libc++_shared.so'
pickFirst '**/x86_64/libc++_shared.so'
pickFirst '**/x86/libjsc.so'
pickFirst '**/armeabi-v7a/libjsc.so'
}
}
Now you can actually use the methods in this package. Unfortunately I don't have time to document them all, so it is advised to read the source code, but here's a start.
To login with an existing account:
import { loginWithEmail } from 'thiagobueno/rn-tuya';
await loginWithEmail({
countryCode: '+1',
email: 'you@example.com',
password: 'testtest'
});
To register a new account you first need to validate the email address. And then actually register using the code in the email.
import { getRegisterEmailValidateCode, registerAccountWithEmail } from 'thiagobueno/rn-tuya';
await getRegisterEmailValidateCode({
countryCode: '+1',
email: 'you@example.com'
});
...
await registerAccountWithEmail({
countryCode: '+1',
email: 'you@example.com',
password: 'testtest',
validateCode: 'xxxxxx'
})
To get the currently logged in user:
import { getCurrentUser } from 'thiagobueno/rn-tuya';
const user = await getCurrentUser();
FAQs
React Native bindings for the Tuya SDK
We found that rn-tuya demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.