forked from TuyaAPI/cli
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcli.js
executable file
·133 lines (119 loc) · 4.81 KB
/
cli.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
#! /usr/bin/env node
// Imports
const updateNotifier = require('update-notifier');
const program = require('commander');
const Configstore = require('configstore');
// Import local files
const cloud = require('./lib/cloud');
const link = require('./lib/link');
const listApp = require('./lib/list-app');
const mock = require('./lib/mock');
const control = require('./lib/control');
const wizard = require('./lib/wizard');
const pkg = require('./package.json');
// Set up config store
const conf = new Configstore(pkg.name);
updateNotifier({pkg}).notify();
// Cloud methods
program
.command('cloud list')
.option('--api-key [apiKey]', 'your tuya.com API key')
.option('--api-secret [apiSecret]', 'your tuya.com API secret')
.option('--schema <schema>', 'your tuya.com app identifier')
.option('-r, --region [region]', 'the region closest to you from the following list: us=Americas, eu=Europe, cn=Asia', 'us')
.option('-s, --stringify', 'stringify JSON before printing', false)
.action(cloud.list);
// Link a device (old method)
program
.command('link')
.description('link a new device')
.option('--ssid <ssid>', 'name of WiFi to connect to')
.option('--password <password>', 'password of WiFi')
.option('--api-key [apiKey]', 'your tuya.com API key')
.option('--api-secret [apiSecret]', 'your tuya.com API secret')
.option('--schema <schema>', 'your tuya.com app identifier')
.option('-t, --timezone [timezone]', 'your local timezone in tz format', 'America/Chicago')
.option('-r, --region [region]', 'the region closest to you from the following list: us=Americas, eu=Europe, cn=Asia', 'us')
.option('--saveAPI', 'save your API pair so you can omit it for subsequent commands')
.option('-s, --save', 'save device parameters for subsequent commands')
.option('-n, --num [num]', 'number of devices to link', 1)
.action(options => {
link(conf, options);
});
// Get a property
program
.command('get')
.description('get a property on a device')
.option('-s, --save', 'save key so you can omit it for subsequent commands')
.option('--ip <ip_addr>', 'ip address of device')
.option('--id <id>', 'id of device')
.option('--key [key]', 'key of device')
.option('--cid [cid_zigbee_device]', 'if specified, use device id of zigbee gateway and cid of subdevice to get its status')
.option('--dps [dps]', 'property index to get')
.option('--full', 'get full response payload', false)
.option('--protocol-version [version]', 'tuya protocol version', parseFloat, 3.1)
.action(options => {
control.get(conf, options);
});
// Set a property
program
.command('set')
.description('set a property on a device')
.option('-s, --save', 'save key so you can omit it for subsequent commands')
.option('--ip <ip_addr>', 'ip address of device')
.option('--id <id>', 'id of device')
.option('--key [key]', 'key of device')
.option('--cid [cid_zigbee_device]', 'if specified, use device id of zigbee gateway and cid of subdevice to set its property')
.option('--set <set>', 'value to set')
.option('--raw-value', 'pass the raw set value without attempting to parse it from a string')
.option('--dps [dps]', 'DPS index to set', 1)
.option('--protocol-version [version]', 'tuya protocol version', parseFloat, 3.1)
.action(options => {
control.set(conf, options);
});
// List all locally saved devices
program
.command('list')
.description('list all locally saved devices')
.action(() => {
console.log(conf.all);
});
// MITM Tuya App and list devices
program
.command('list-app')
.description('list devices from Tuya Smart app (deprecated)')
.option('--ip <ip_addr>', 'IP address to bind the proxy and certificate server to')
.option('-p, --port [port]', 'port to use for proxy', 8001)
.option('--cert-port [port]', 'port to use for certificate download', 8002)
.option('-q, --omitQR', 'don\'t show the QR code for certificate setup', false)
.option('-o, --out [file]', 'export devices to a JSON file instead of printing them', '')
.action(options => {
listApp(conf, options);
});
program
.command('mock')
.description('mock a Tuya device for local testing')
.option('-i, --id [id]', 'ID to use for mock device')
.option('-k, --key [key]', 'key to use for mock device')
.option('-a, --ip <host>', 'IP/host name to use for mock device', 'localhost')
.option('-s, --state [state]', 'inital state to use for device', JSON.stringify({1: true, 2: false}))
.option('-u, --disableUDP', 'disable the UDP broadcast')
.action(options => {
mock(conf, options);
});
program
.command('wizard')
.description('list devices from an offical app')
.option('-s, --stringify', 'stringify JSON before printing', false)
.action(options => wizard(conf, options));
// Get help
program
.command('help')
.description('output usage information')
.action(() => {
program.outputHelp();
});
// Get version
program.version(pkg.version);
// Parse arguments
program.parse(process.argv);