A simple JavaScript API to control eufy's smart light bulbs, switches and power plugs. Ported from python-lakeside.
This project is not developed, supported or endorsed by eufy.
This package does not work reliable for all devices due to a firmware bug, which means the device will, when receiving a message via your local network, simply close the connection.
There is no known workaround for this problem.
Device Code | Device Name | Comment |
---|---|---|
T1201 | Smart Plug | |
T1202 | Smart Plug Mini | |
T1203 | Smart WiFi Plug (UK) | |
T1211 | Smart Light Switch | Untested |
T1011 | Lumos Smart Bulb - White | |
T1012 | Lumos Smart Bulb - Tunable White | Untested |
T1013 | Lumos Smart Bulb - White & Color |
All devices listed above should work, since they are supported in python-lakeside. Because an error might have occurred during the porting process, some are marked as untested.
If you own one of these untested, or any new devices that aren't listed, please consider running the command-line interface and open an issue to confirm whether or not they work.
Device Code | Device Name |
---|---|
T1015 | Lumos Smart Bulb - Tunable White |
T1018 | Lumos Smart Bulb 2.0 Lite - White & Color |
The homebridge-eufy
plugin lets you add HomeKit support for your Eufy (and other) devices. Find out further details on the plugin page.
Add the node-eufy-api package to your project:
npm install node-eufy-api --save
The package exposes the functions loadDevices
and createDevice
, as well as several TypeScript interfaces. The API Reference section below contains details about the API.
To run the Eufy command-line interface, run the following commands:
# Clone repository to your computer
git clone [email protected]:sebmos/node-eufy-api.git
cd node-eufy-api/
# Install dependencies
npm install
# Build code
npm run build
# Run CLI (usual way)
npm run cli
# Alternative: Run CLI (with verbose logging)
npm run cli:verbose
After authenticating, this command lists all available eufy devices, models, codes & IP addresses and lets you control them.
It is necessary to connect and authenticate with eufy's API to identify the device model, code and IP address. With this information, devices can be controlled directly, without connecting to eufy's API.
Since the devices are controlled through a local socket connection, node-eufy-api needs to run on the same WiFi network as the devices.
To identify the devices you have, as well as their models, codes and IP addresses, use the command-line interface or run the loadDevices(email: string, password: string): Promise<Device[]>
function.
- Try restarting (unplugging & replugging) the device.
- Try pinging the device's IP address from the computer this code is running from.
- To verify what WiFi network the device is on, look in the device settings in the EufyHome app.
Loads devices connected to the provided eufy account.
import { loadDevices } from 'node-eufy-api';
loadDevices("[email protected]", "s3cr3t").then(devices => {
console.log('Devices loaded:', devices);
});
To create a Device
object without authenticating via loadDevices
, call the createDevice
function.
The device name is optional, but may be useful for users of your app. (loadDevices
will use the name set in the eufy app.) If no name is available, it will be auto-generated.
import { createDevice, Model } from 'node-eufy-api';
const powerPlug = createDevice(Model.T1203, 'DEVICE-CODE-FROM-API', '192.168.0.123', 'My Power Plug');
const lightBulb = createDevice('T1013', 'DIFFERENT-DEVICE-CODE', '192.168.0.124');
Returns the device type from a device model.
import { getTypeForModel, DeviceType } from 'node-eufy-api';
getTypeForModel('T1203') === DeviceType.POWER_PLUG;
getTypeForModel('T1211') === DeviceType.SWITCH;
getTypeForModel('T1013') === DeviceType.LIGHT_BULB;
eufy's model number for the device, the device-specific code required to establish a connection to the device, and the IP address, are required to create a Device
object without running loadDevices
first.
console.log('Model:', powerPlug.model);
console.log('Code:', powerPlug.code);
console.log('IP Address:', powerPlug.ipAddress);
The deviceType field is either LIGHT_BULB
, POWER_PLUG
or SWITCH
.
if (powerPlugOrSwitch.deviceType === DeviceType.SWITCH) {
console.log('This is a switch');
} else {
console.log('This is a power plug');
}
Handler is called each time the connection stops or starts again. It is not necessary call Device.connect()
to reconnect, since this will be attempted automatically. Calling Device.disconnect()
removes the event handler.
import { DeviceEvent } from 'node-eufy-api';
lightBulb.on(DeviceEvent.CONNECTION_STATE_CHANGED, connected => {
console.log('Device is ' + (connected ? 'connected' : 'disconnected'));
});
Returns whether or not there is an open socket connection to the device.
console.log('The device is currently ' + (lightBulb.isConnected() ? 'connected' : 'disconnected'));
Establishes a connection to the device and calls loadCurrentState()
.
lightBulb.connect().then(() => {
console.log('Device connected');
});
Disconnects the socket connection to the device and removes any CONNECTION_STATE_CHANGED event handlers. The socket connection disconnects automatically when the node process stops running.
lightBulb.disconnect().then(() => {
console.log('The device is now disconnected');
});
Refreshes the current state of the device. (Power on/off, light brightness, etc.) It returns a Promise that resolves when the status is updated.
This method is called when the device is connected, and when its state is changed.
lightBulb.loadCurrentState().then(() => {
console.log('Device state refreshed');
});
Returns whether or not the light bulb, power plug or switch are on.
console.log('The light is currently ' + (lightBulb.isPowerOn() ? 'on' : 'off'));
Changes the light bulb/power plug/switch power status. Returns a Promise with the new power state of the device when the change has been confirmed.
switch.setPowerOn(false).then(powerState => {
console.log('Power is now off');
});
To determine whether the device supports setting brightness. Always returns false for power plugs/switches, and always returns true for the currently available light bulbs.
if (lightBulb.supportsBrightness()) {
console.log('We can change the brightness for this device');
}
Returns the brightness setting of the light bulb, as a percentage. This method throws an exception if it is not supported.
if (lightBulb.supportsBrightness()) {
console.log('The current brightness is: ' + lightBulb.getBrightness());
}
Changes the brightness of the light. The parameter is a percentage value. This method returns a Promise that rejects if changing the brightness isn't supported, and resolves with the new brightness value once the change is confirmed.
if (lightBulb.supportsBrightness()) {
lightBulb.setBrightness(80).then(newBrightness => {
console.log('The brightness is now set to:', newBrightness);
});
}
To determine whether the device supports changing the color temperature. Always returns false for power plugs/switches.
if (lightBulb.supportsTemperature()) {
console.log('We can change the color temperature for this device');
}
Returns the color temperature setting of the light bulb, as a percentage. This method throws an exception if it is not supported.
if (lightBulb.supportsTemperature()) {
console.log('The current color temperature is: ' + lightBulb.getTemperature());
}
Changes the color temperature of the light. The parameter is a percentage value, with 0 being the warmest color and 100 the coldest. This method returns a Promise that rejects if changing the temperature is not supported, and resolves with the new color temperature value once the change is confirmed.
if (lightBulb.supportsTemperature()) {
lightBulb.setTemperature(80).then(newTemperature => {
console.log('The color temperature is now set to:', newTemperature);
});
}
To determine whether the device supports changing its color. Always returns false for power plugs/switches.
if (lightBulb.supportsColors()) {
console.log('We can change the color for this device');
}
Returns the colors of the light bulb, in three numbers (red, green, blue) between 0 and 255. This method throws an exception if changing the colors are not supported.
if (lightBulb.supportsColors()) {
console.log('The current red value is: ' + lightBulb.getRgbColors().red);
}
Device.setRgbColors(red: number, green: number, blue: number): Promise<{ red: number, green: number, blue: number }>
Changes the color of the light. The parameters are numbers between 0 and 255. This method returns a Promise that rejects if changing the color is not supported, and resolves with the new color values once the change is confirmed.
if (lightBulb.supportsColors()) {
lightBulb.setRgbColors(255, 0, 0).then(newColors => {
console.log('The color is now red:', newColors);
});
}
Returns the colors of the light bulb, in hue, saturation and lightness - numbers between 0 and 1. This method throws an exception if colors are not supported.
if (lightBulb.supportsColors()) {
console.log('The saturation of the color is:', lightBulb.getHslColors().saturation.toLocaleString(undefined, { style: 'percent' }));
}
Device.setHslColors(hue: number, saturation: number, lightness: number): Promise<{ hue: number, saturation: number, lightness: number }>
Changes the color of the light. The parameters are numbers between 0 and 1. The method returns a Promise that rejects if changing the color is not supported, and resolves with the new color values once the change is confirmed.
if (lightBulb.supportsColors()) {
lightBulb.setHslColors(0, 1, 0.5).then(newColors => {
console.log('The color is now red:', newColors);
});
}
Loads devices connected to the provided eufy account.
import { setLogVerbosity, Verbosity } from 'node-eufy-api';
setLogVerbosity(Verbosity.ALL);
setLogVerbosity(Verbosity.INFO); // used for CLI
setLogVerbosity(Verbosity.WARNING);
setLogVerbosity(Verbosity.ERROR); // used when running homebridge-eufy
setLogVerbosity(Verbosity.SUCCESS);
setLogVerbosity(Verbosity.NONE);
- Energy Reporting
- Controlling devices remotely/not from within the same WiFi connection