1.6.3 • Published 6 months ago

elyeu-shelly-node5 v1.6.3

Weekly downloads
-
License
GPL-3.0
Repository
github
Last release
6 months ago

node-shellies-ng

npm-version

Handles communication with the next generation of Shelly devices.

This branch adds support for the I4 DC version device.

For the first generation of Shelly devices, see node-shellies. For the source of this branch, see the great work of Alexander Rydén at node-shellies-ng.

Supported devices

1 Support for outbound websockets is a work in progress.

2 Works currently the same way as the original I4.

Basic usage example

import {
  Device,
  DeviceId,
  MdnsDeviceDiscoverer,
  Shellies,
  ShellyPlus1,
} from 'shellies-ng';

const shellies = new Shellies();

// handle discovered devices
shellies.on('add', async (device: Device) => {
  console.log(`${device.modelName} discovered`);
  console.log(`ID: ${device.id}`);

  // use instanceof to determine the device model
  if (device instanceof ShellyPlus1) {
    const plus1 = device as ShellyPlus1;

    // toggle the switch
    await plus1.switch0.toggle();
  }
});

// handle asynchronous errors
shellies.on('error', (deviceId: DeviceId, error: Error) => {
  console.error('An error occured:', error.message);
});

// create an mDNS device discoverer
const discoverer = new MdnsDeviceDiscoverer();
// register it
shellies.registerDiscoverer(discoverer);
// start discovering devices
discoverer.start();

See homebridge-shelly-ng for a real-world example.