Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tuya/tuya-connector-fe

Tuya SaaS Connector for Javascript
https://github.com/tuya/tuya-connector-fe

tuya

Last synced: 2 months ago
JSON representation

Tuya SaaS Connector for Javascript

Awesome Lists containing this project

README

        

=======





Tuya Connector FE SDK
===

[English](README.md) | [中文版](README_zh.md)

Contents
---

- [Overview](#Overview)
- [Compatible browsers](#Compatible-browsers)
- [Installation](#Installation)
- [Examples](#Examples)
- [Features](#Features)
- [Methods](#Methods)
- [Error handling](#Error-handling)
- [Configure requests](#Configure-requests)
- [Test cases](#Test-cases)

## Overview

Tuya Connector FE SDK encapsulates APIs in JavaScript that allow the Tuya SaaS Admin to manage data.
Currently, it provides APIs related to `account login and logout`, `password change`, `asset management`, and `device management`.

For more information about the image of the demo project,visit [https://hub.docker.com/r/iotportal/iot-suite](https://hub.docker.com/r/iotportal/iot-suite).

## Compatible browsers

| ![Google Chrome](https://raw.github.com/alrra/browser-logos/master/src/chrome/chrome_48x48.png) | ![Firefox](https://raw.github.com/alrra/browser-logos/master/src/firefox/firefox_48x48.png) | ![Safari](https://raw.github.com/alrra/browser-logos/master/src/safari/safari_48x48.png) | ![Opera](https://raw.github.com/alrra/browser-logos/master/src/opera/opera_48x48.png) | ![Microsoft Edge](https://raw.github.com/alrra/browser-logos/master/src/edge/edge_48x48.png) | ![Internet Explorer](https://raw.github.com/alrra/browser-logos/master/src/archive/internet-explorer_9-11/internet-explorer_9-11_48x48.png) |
--- | --- | --- | --- | --- | --- |
| Latest ✔ | Latest ✔ | Latest ✔ | Latest ✔ | Latest ✔ | 11 ✔ |

## Installation

```shell
npm install @tuya/connector

or

yarn add @tuya/connector
```

## Examples

```js
import {version, apiService} from '@tuya/connector'

// Current SDK version number.
console.log(version);

const {multiLogin} = apiService;

multiLogin({
userName: 'test',
pwd: '123123a',
}).then((res) => {
if (res) {
// Login is successful.
console.log('logged in');
} else {
console.error('fail to login');
}
}).catch((err) => {
// Failed to log in.
console.error('login fail', err);
})
```

If a specific domain or port is required, you can initialize the relevant configuration before use.

```js
import {configMethod} from '@tuya/connector'

const {initGlobalConfig, getGlobalConfig, setGlobalConfig} = configMethod;

// Called when the project is initialized. Global initialization is required only once.
// For specific configurations, see Request Config.
initGlobalConfig({
baseURL: '',
method: 'GET',
onError: () => {}, // Global error callback.
})

// Returns the currently changed configuration. The default configuration of Request Config will not be carried.
getGlobalConfig()

// The specific configuration is the same as initGlobalConfig, and the underlying layer of initGlobalConfig is implemented using setGlobalConfig.
setGlobalConfig({})
```

## Features

- [login(userName, password[, config])](#login) Log in
- [multiLogin(loginParams[, config])](#multiLogin) Log in with an email or phone number
- [logout()](#logout) Log out
- [resetPassword(userName, currentPwd, newPwd[, config])](#resetPassword) Change the password
- [forgetPassword(params[, config])](#forgetPassword) Reset the password
- [getVerifyCode(params[, config])](#getVerifyCode) Get a verification code

- [addAsset(assetName[, parentAssetId)[, config]]](#addAsset) Add an asset
- [editAsset(assetId, assetName[, config])](#editAsset) Edit a specified asset
- [removeAsset(assetId[, config])](#removeAsset) Remove a specified asset
- [getChildrenAssetsByAssetId(assetId[, config])](#getChildrenAssetsByAssetId) Get the list of assets by asset ID
- [searchAssetByName(assetName[, config])](#searchAssetByName) Perform a fuzzy search for assets
- [getEntireTree([config])](#getEntireTree) Get a specified asset tree (with device information)
- [getSubTree(assetId[, config])](#getSubTree) Get the subtree of the specified asset

- [getDevicesInfoByAssetId(assetId, pageNum, pageSize[, config])](#getDevicesInfoByAssetId) Get device information under the specified asset
- [getDeviceInfoByDeviceId(deviceId[, config])](#getDeviceInfoByDeviceId) Get device information
- [removeDeviceById(deviceId[, config])](#removeDeviceById) Remove a device
- [modifyDeviceInfo(deviceId, name[,config])](#modifyDeviceInfo) Modify a device
- [modifyDeviceDP(deviceId, deviceStatuses[, config])](#modifyDeviceDP) Control a device
- [getDeviceDP(deviceId[,config])](#getDeviceDP) Get a device control command
- [getDeviceInfoWithDP(deviceId[, config])](#getDeviceInfoWithDP) Get device information and data point (DP)
- [getProjectInfo([config])](#getProjectInfo) Get the QR code to bind a device

- [getAccountList(params[, config])](#getAccountList) Get the list of users
- [getPermissionListByAccount(uid[, config])](#getPermissionListByAccount) Get the list of user permissions
- [addAccount(params[, config])](#addAccount) Add a user
- [batchRemoveAccount(userIds[, config])](#batchRemoveAccount) Delete multiple users
- [removeAccount(userId[, config])](#removeAccount) Delete a user
- [editAccountPwd(userName, newPwd[, config])](#editAccountPwd) Modify the password
- [batchModifyUserRole(userIds, roleCode[, config])](#batchModifyUserRole) Modify multiple passwords
- [modifyUserRole(userId, roleCode[, config])](#modifyUserRole) Modify a single user role
- [getEntireAssetTree([config])](#getEntireAssetTree) Get the entire asset tree (without the information about device quantity)
- [getUserAssetPermissionTree(userId)](#getUserAssetPermissionTree) Get the list of a user's available assets
- [grantUserAssetPermission(userId, assetIds[, config])](#grantUserAssetPermission) Modify a user's asset authorization
- [getRoleList(pageNo, pageSize, opts)](#getRoleList) Get the list of roles on pages
- [getEntireRoles()](#getEntireRoles) Get all roles
- [addRole(params[, config])](#addRole) Add a role
- [removeRole(roleCode[, config])](#removeRole) Remove a role
- [editRoleName(params[, config])](#editRoleName) Edit a role name
- [grantPermissionByRole(params[, config])](#grantPermissionByRole) Modify the permissions of a specified role
- [getRolePermissionDetail(roleCode[, config])](#getRolePermissionDetail) Get the permission list of a specified role
- [getRolePermissionTemplate(roleCode[, config])](#getRolePermissionTemplate) Get the template of role permissions

## Methods
#### login

Log in with an email address.

```ts
type UserToken = {
nick_name: string, // Username.
token: string,
role_type: string[], // Role type.
userId: string;
}
/**
* @param username: string
* @param pwd: string
*/

login('test', 'test').then((res) => {
// Returns UserToken on success.
console.log(res)
})
```

#### multiLogin

Log in with an email address or mobile phone number.

```ts
interface loginParams {
userName?: string,
pwd: string,
countryCode?: string,
phoneNum?: string,
}

// Log in with an email address.
multiLogin({
userName: '[email protected]',
pwd: 'test',
}).then((res) => {
// Returns UserToken on success.
console.log(res)
});

// Log in with a mobile phone number.
multiLogin({
countryCode: '86',
phoneNum: '13000000000',
pwd: 'test',
}).then((res) => {
// Returns UserToken on success.
console.log(res)
})
```

#### logout

Log out of the current account.

```ts
logout().then(() => {
// The login status in the server has been cleaned up, and you must maintain the local status.
console.log('logout success');
});
```

#### resetPassword

Change the password.

```js
/**
* @param username
* @param oldPwd
* @param newPwd
*/
resetPassword('test', '123', '321').then((res) => {
// Boolean type. It indicates whether the operation is successful.
console.log(res);
})

resetPassword('test', '123', '321', {
baseURL: 'http://localhost:8000',
method: 'POST'
}).then((res) => {
// Boolean type. It indicates whether the operation is successful.
console.log(res);
})
```

#### forgetPassword

Reset the password.

```ts
interface forgetPwdParams {
code: string;
newPassword: string;
}

interface emailForgetPwdParams extends forgetPwdParams {
mail: string;
}

interface phoneForgetPwdParams extends forgetPwdParams {
countryCode: string;
phone: string;
}

const params1 = {
countryCode: '86',
phone: '13100001111',
code: '123456',
newPassword: 'abcdefg123',
} : phoneForgetPwdParams;

forgetPassword(params1).then((res) => {
console.log(res);
});

const params1 = {
mail: '[email protected]',
code: '123456',
newPassword: 'abcdefg123',
} : emailForgetPwdParams;
forgetPassword(params1).then((res) => {
console.log(res);
});
```

#### getVerifyCode

Get a verification code.

```ts
interface verifyCodeParamsPhone {
language: string,
countryCode: string,
phone: string,
}

interface verifyCodeParamsEmail {
mail: string,
language: string,
}

const params1 = {
countryCode: '86',
phone: '13100001111',
language: 'zh-CN',
}: verifyCodeParamsPhone;

getVerifyCode(params1).then((res) => {
console.log(res);
});

const params2 = {
mail: '[email protected]',
language: 'en-US',
}: verifyCodeParamsEmail;

getVerifyCode(params2).then((res) => {
console.log(res);
});
```

#### getChildrenAssetsByAssetId

Get the list of first-level sub-assets.

```ts
type Asset = {
asset_id: string;
asset_name: string;
full_asset_name: string;
};

/**
* @param assetId: string
*/
getChildrenAssetsByAssetId('1').then((res) => {
console.log(res);
})
```

#### searchAssetByName

Search for an asset.

```ts
/**
* @param assetName: string
*/
searchAssetByName('test').then((res) => {
console.log(res);
})
```

#### addAsset

Add an asset.

```ts
/**
* @param assetName: string,
* @param parentAssetId: string = "",
*/
addAsset('newAsset', '1').then((res) => {
// The ID of the new asset.
console.log(res)
})
```

#### editAsset

Edit the asset name.

```ts
type errorType = {
apiMethodName: string;
msg: string;
code: number;
httpCode: string;
}

/**
* @param assetId: string,
* @param assetName: string,
*/
editAsset('assetId', 'assetName').then((res) => {
// Edited the asset name successfully.
console.log(res)
}).catch((err) => {
// Failure reason.
console.error(err)
})
```

#### removeAsset

Remove an asset.

```ts
type errorType = {
apiMethodName: string;
msg: string;
code: number;
httpCode: string;
}

/**
* @param assetId: string,
*/
removeAsset('assetId').then((res) => {
// Deleted the asset successfully.
console.log(res)
}).catch((err) => {
// Failure reason.
console.error(err)
})
```

#### getEntireTree

Get the entire asset tree.

```ts
type BaseAsset = {
asset_id: string;
asset_name: string;
full_asset_name: string;
};

type Asset = BaseAsset & {
child_asset_count: number;
child_device_count: number;
};

type AssetDeep = Asset & {
subAssets: AssetDeep[];
};

getEntireTree().then((res) => {
// Got the asset tree successfully.
console.log(res);
})
```

#### getSubTree

Get the asset subtree.

```ts
/**
* @param assetId: string,
*/
getSubTree('1').then((res) => {
// Get the asset subtree of which the asset ID is `1`.
console.log(res);
});
```

#### getDevicesInfoByAssetId

```ts
type DeviceStatus = {
code: string; // Status name
value: Object; // Status value
options?: string; // DP value configuration
editable?: boolean; // Indicates whether it is editable
name?: string; // DP name
type?: string; // DP type
};

type DeviceInfo = {
id: string; // Device number
name: string; // Device name
uid: string; // User ID
local_key: string; // Key
category: string; // Product category
product_id: string; // Product ID
product_name: string; // Product name
sub: boolean; // Indicates whether a sub-device is used
uuid: string; // The universally unique identifier of a device
online: boolean; // The online status of a device
active_time: number; // The timestamp when a device is activated, in seconds
icon: string; // The icon of a device
ip: string; // The IP address of a device
create_time: number; // The timestamp when a device is created, in seconds
update_time: number; // The timestamp when a device is updated, in seconds
time_zone: string; // Time zone, for example, `+08:00`
status: DeviceStatus[];
}

/**
* @param assetId: string,
* @param pageNum: number,
* @param pageSize: number,
*/
getDevicesInfoByAssetId('1', 1, 20).then((res) => {
console.log(res);
})
```

#### getDeviceInfoByDeviceId

```ts
type DeviceInfo = {
id: string; // Device number
name: string; // Device name
uid: string; // User ID
local_key: string; // Key
category: string; // Product category
product_id: string; // Product ID
product_name: string; // Product name
sub: boolean; // Indicates whether a sub-device is used
uuid: string; // The universally unique identifier of a device
online: boolean; // The online status of a device
active_time: number; // The timestamp when a device is activated, in seconds
icon: string; // The icon of a device
ip: string; // The IP address of a device
create_time: number; // The timestamp when a device is created, in seconds
update_time: number; // The timestamp when a device is updated, in seconds
time_zone: string; // Time zone, for example, `+08:00`
status: DeviceStatus[];
}

/**
* @param deviceId: string,
*/
getDeviceInfoByDeviceId('1').then((res) => {
console.log(res)
})
```

#### removeDeviceById

Remove a device.

```ts
/**
* @param deviceId: string,
*/
removeDeviceById('12').then((res) => {
console.log(res);
})
```

#### modifyDeviceInfo

Modify the information about a device.

```ts
/**
* @param deviceId: string,
* @param devicename: string,
*/
modifyDeviceInfo('12', 'devicename').then((res) => {
console.log(res);
})
```

#### modifyDeviceDP
Control a device.

For more information about standard instruction sets, see the [official website](https://developer.tuya.com/en/docs/iot/datatypedescription?id=K9i5ql2jo7j1k).

```ts
type DeviceStatus = {
code: string; // Status name
value: Object; // Status value
options?: string; // DP value configuration
editable?: boolean; // Indicates whether it is editable
name?: string; // DP name
type?: string; // DP type
};
/**
* @param deviceId: string,
* @param deviceStatuses: DeviceStatus[],
*/
modifyDeviceDP('12', [{code: '', value: 2}]).then((res) => {
console.log(res);
})
```

#### getDeviceDP

Get the instructions.

For more information about standard instruction sets, see the [official website](https://developer.tuya.com/en/docs/iot/datatypedescription?id=K9i5ql2jo7j1k).

```ts
/**
* @param deviceId: string,
*/
getDeviceDP('12').then((res) => {
console.log(res)
})
```

#### getDeviceInfoWithDP

Get the device information and DP.

This method is the aggregation result of `getDeviceDP` and `getDeviceInfoByDeviceId`. Specify the DP in the `status` field of `deviceInfo`.


```ts
/**
* @param deviceId: string,
*/
getDeviceInfoWithDP('deviceId1').then((res) => {
console.log(res);
})

// Sample
{
id: 'deviceId1',
name: 'deviceId1',
uid: 'uid1',
local_key: 'local_key',
category: 'category',
product_id: 'product_id',
product_name: 'product_name',
sub: true,
uuid: 'uuid',
online: true,
active_time: 1615175477,
icon: 'icon',
ip: '127.0.0.1',
create_time: 1615175477,
update_time: 1615175477,
time_zone: '+08:00',
status: [
{
code: "va_temperature",
value: 243,
editable: false,
type: "Integer",
options: "{\"unit\":\"℃\",\"min\":-399,\"max\":800,\"scale\":1,\"step\":1}",
name: '',
},
{
code: "va_humidity",
value: 55,
editable: false,
type: "Integer",
options: "{\"unit\":\"%\",\"min\":0,\"max\":100,\"scale\":0,\"step\":1}",
name: '',
},
{
code: "battery_percentage",
value: 40,
name: '',
editable: false,
type: "Integer",
options: "{\"unit\":\"%\",\"min\":0,\"max\":100,\"scale\":0,\"step\":1}",
},
{
code: "charge_state",
value: false,
editable: false,
type: "Boolean",
options: "{}",
name: '',
},
{
code: "temp_unit_convert",
value: "c",
editable: true,
name: "Temperature unit conversion",
type: "Enum",
options: "{\"range\":[\"c\",\"f\"]}",
},
{
code: "maxtemp_set",
value: 535,
editable: true,
name: "Maximum temperature",
type: "Integer",
options: "{\"unit\":\"℃\",\"min\":-399,\"max\":800,\"scale\":1,\"step\":1}",
},
{
code: "minitemp_set",
value: 0,
editable: true,
name: "Minimum temperature",
type: "Integer",
options: "{\"unit\":\"℃\",\"min\":-399,\"max\":800,\"scale\":1,\"step\":1}",
},
{
code: "maxhum_set",
value: 95,
editable: true,
name: "Maximum humidity",
type: "Integer",
options: "{\"unit\":\"%\",\"min\":0,\"max\":100,\"scale\":0,\"step\":1}"
},
{
code: "minihum_set",
value: 10,
name: "Minimum humidity",
editable: true,
type: "Integer",
options: "{\"unit\":\"%\",\"min\":0,\"max\":100,\"scale\":0,\"step\":1}"
},
{
code: "temp_alarm",
value: "upperalarm",
type: "Enum",
editable: false,
options: "{\"range\":[\"loweralarm\",\"upperalarm\",\"cancel\"]}",
name: '',
},
{
code: "hum_alarm",
value: "cancel",
type: "Enum",
editable: false,
options: "{\"range\":[\"loweralarm\",\"upperalarm\",\"cancel\"]}",
name: '',
}
]
}
```

#### getProjectInfo

Get the QR code to bind a device.

```ts
type ProjectInfo = {
project_name: string;
project_code: string;
};

getProjectInfo().then((res) => {
// Got the QR code successfully.
console.log(res);
})
```

#### getAccountList

Get the list of accounts.

```ts
interface user {
userId: string;
nickName: string;
userName: string; // The login account
createTime: string;
roles: role[];
}

interface getAccountListParams {
searchKey: string;
roleCode: string;
pageNo: number;
pageSize: number;
}

interface userListResp {
total: number;
pageNo: number;
pageSize: number;
data: user[];
}
getAccountList({
searchKey: '',
roleCode: '',
pageNo: 1,
pageSize: 20,
}).then((res) => {
return res;
})
```

#### getPermissionListByAccount

Get the list of permissions granted to the account.

```ts
getPermissionListByAccount('uid').then((res) => {
return res;
})
```

#### addAccount

Add an account.

```ts
interface addAccountParams {
password: string;
nickName?: string;
roleCodes: string[];
userName: string,
countryCode?: string,
}
addAccount({
password: '123123A',
roleCodes: ['manager-1000'],
userName: '[email protected]',
}).then((res) => {
return res;
})
```

#### batchRemoveAccount

Delete multiple accounts in a call.

```ts
batchRemoveAccount(['userId1', 'userId2']).then((res) => {
return res;
})
```

#### removeAccount

Delete an account.

```ts
removeAccount('userID').then((res) => {
return res;
})
```

#### editAccountPwd

Change the account password.

```ts
editAccountPwd('userName', '123456A').then((res) => {
return res;
})
```

#### batchModifyUserRole

Modify multiple account roles.

```ts
batchModifyUserRole(['userId1', 'userId2'], 'manager-1000').then((res) => {
return res;
})
```

#### modifyUserRole

Modify an account role.

```ts
modifyUserRole('userId', 'manager-1000').then((res) => {
return res;
});
```

#### getEntireAssetTree

Get the entire asset tree (without the information about device quantity).

```ts
type PermissionAsset = Omit;
type PermissionAssetTree = PermissionAsset & {
subAssets: PermissionAssetTree[];
};
getEntireAssetTree().then((res) => {
return res;
});
```

#### getUserAssetPermissionTree

Get the list of user assets.

```ts
getUserAssetPermissionTree('userId').then((res) => {
return res;
});
```

#### grantUserAssetPermission

Modify the list of user assets.

```ts
grantUserAssetPermission('userId', ['1', '2']).then((res) => {
return res;
});
```

#### getRoleList

Get the list of roles.

```ts
interface role {
roleCode: string;
roleName: string;
}
interface paginationType {
total: number;
pageNo: number;
pageSize: number;
};
interface roleListResp extends paginationType {
data: role[],
}
getRoleList(1, 20).then((res) => {
return res;
})
```

#### getEntireRoles

Get all roles.

```ts
getEntireRoles().then((res) => {
return res;
})
```

#### addRole

Add a role.

```ts
enum RoleType {
manager = 'manager',
normal = 'normal',
}

interface addRoleParams {
roleName: string;
roleType: RoleType;
roleRemark?: string; // Role description
}
addRole({
roleName: 'roleName',
roleType: 'normal',
}).then((res) => {
return res;
})
```

#### removeRole

Delete a role.

```ts
removeRole('roleCode').then((res) => {
return res;
})
```

#### editRoleName

Modify a role name.

```ts
interface editRoleNameParams {
roleCode: string,
roleName: string,
roleRemark?: string,
}
editRoleName({
roleCode: 'normal-xxx',
roleName: '321',
}).then((res) => {
return res;
})
```

#### grantPermissionByRole

Modify the list of permissions granted to a role.

```ts
interface grantPermissionByRoleParams {
roleCode: string;
permissionCodes: string[];
}
grantPermissionByRole({
roleCode: 'normal-xxxxx',
permissionCodes: ['1000', '2000'],
}).then((res) => {
return res;
})
```

#### getRolePermissionDetail

Get the list of permissions granted to a role.

```ts
enum PermissionType {
menu = 'menu',
api = 'api',
button = 'button',
data = 'data',
};

interface permission {
permissionCode: string;
permissionName: string;
permissionType: PermissionType;
parentCode: string;
order: string;
remark: string;
authorizable: boolean;
}

getRolePermissionDetail('manager-1000').then((res) => {
return res;
})
```

#### getRolePermissionTemplate

Get the template of role permissions.

```ts
getRolePermissionTemplate('manager').then((res) => {
return res;
})
```

---------

## Error handling
If an HTTP error occurs, `apiService` will get the error. You can use `promise catch` to get the error message.

```ts
apiService.getDeviceInfoByDeviceId('1').catch(({msg, code}) => {
console.error(msg);
})
```

Alternatively, you can register the global error handling methods in `initConfig`.

```ts
type ApiError = {
httpCode: number, // HTTP code
code: number,
msg: string,
apiMethodName: string, // The API method name
}

initConfig({
onError: (errorObj) => {}
})
```

## Configure requests

For more information about request configuration, see [Axios request config](https://github.com/axios/axios#request-config).

## Test cases

As a preparation, start the mock server.

Listen on port 7001 by default.

```bash
npm run testServer
```

Start the unit test.

```bash
npm run jest
```

## License

For more information about the license, see [MIT License](./LICENSE).