smilep1

Node package to interface directly with Plugwise Smile P1 energy monitor devices (no Stretch or bridge required)

Usage no npm install needed!

<script type="module">
  import smilep1 from 'https://cdn.skypack.dev/smilep1';
</script>

README

Node package to interface directly with Plugwise Smile P1 energy monitor devices (no Stretch or bridge required).

It allows you to:

get:

  • device information
  • network and wifi information
  • live energy and gas readings
  • historic logs of energy and gas readings

set:

  • nothing (yet)

do:

  • discover the device in a local network (internet connection to plugwise required)
  • login with device ID
  • reboot the device (V3 firmware only)

Note:

This package has been developed and tested with firmware V2 and V3.

Install:

If you don't have Node installed yet, get it from: Nodejs.org.

To install the Smile P1 package:

> npm i smilep1

Test:

From the folder in which you installed the SmileP1 package, just run below command. The port only needs to be set if you are not using the default port 80. TLS/SSL will be used when setting port to 443. When no host is entered, autodiscovery will be attempted. For Belgian P1 meters you need to add reversed=true

> npm test id=yourDeviceID [host=yourDeviceIP] [port=yourHostPort]

Quickstart:

// create a Smile P1 session, login to device, fetch meter readings
    const Smile = require('smilep1');

    const smile = new Smile();

    async function getMeterReadings() {
        try {
            // fill in the id of the device, e.g. 'hcfrasde'
            // fill in the ip address of the device, e.g. '192.168.1.50'
            const options = { id='yourDeviceID', host='yourDeviceIP'}
            await smile.login(options);
            const powerInfo = await smile.getMeterReadings();
            console.log(powerInfo);
        } catch (error) {
            console.log(error);
        }
    }

    getMeterReadings();

Detailed documentation:

Detailed documentation