kasa-smart-hub
Virtual Smart Hub for TP-Link Kasa Smart Home
Designed to be run on a LAN server, e.g. on a Raspberry Pi.
How to
Install as global npm packages. Then create configuration file and start with
kasa-smart-hub /path/to/config.json
Config
Configuration can be in multiple formats. Most likely you want to use config.js
or config.json
.
logFile
Where events logs are stored
links
Object that contains "linked" switches that are always executed together.
timer
Used to automatically switch off devices
__default
Default fallback timer. Can be set to zero to disable.
Config Example
import path from 'path';
import fs from 'smart-fs';
export default {
logFile: path.join(fs.dirname(import.meta.url), 'kasa-logs.txt'),
links: {
'kitchen-lights': [
// when either of these is switched on / off the other one will also switch on / off
'Kitchen Counter Lights',
'Kitchen Ceiling Light'
]
},
timer: {
__default: 8 * 60 * 60, // switch off everything after eight hours
'Bathroom Fan': 60 * 60 // switch off after one hour
},
on: {
'Plant Light': ['We 21:00'] // switch on every Wednesday at 9pm
},
off: {
TV: ['02:00'] // switch off every day at 2am
},
timezone: 'America/Vancouver'
};
Configure Raspberry Pi Auto Start
Ensure you are running a recent node version. Install with
npm install -g kasa-smart-hub
Place
[Service]
WorkingDirectory=/home/pi/kasa-smart-hub
ExecStart=kasa-smart-hub start /home/pi/kasa-smart-hub/config.js
Restart=always
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=
User=pi
Group=pi
[Install]
WantedBy=multi-user.target
in /etc/systemd/system/kasa-smart-hub.service
.
Ensure it is readable/writeable/executable by the appropriate user.
Now enable service with sudo systemctl enable kasa-smart-hub
To start the service right away run sudo systemctl start kasa-smart-hub
Acknowledgements
This project relies on tplink-smarthome-api. Documentation for that project can be found here.