GithubHelp home page GithubHelp logo

jvandenaardweg / homewizard-energy-api Goto Github PK

View Code? Open in Web Editor NEW
22.0 6.0 5.0 2.3 MB

Full type-safe implementation of the HomeWizard Energy API in Node. Use the Local API of your HomeWizard devices with ease.

License: MIT License

Shell 0.04% TypeScript 99.96%
homewizard homewizard-energy homewizard-energy-socket homewizard-p1-meter homewizard-api homewizard-watermeter api-client iot node nodejs

homewizard-energy-api's Introduction

HomeWizard Energy API

npm   github   github sponsor   mit license

Full type-safe implementation of the HomeWizard Energy API in Node. Use the Local API of your HomeWizard devices with ease.

Features

  • Complete type-safety on all API methods, responses, and errors
  • Supports all HomeWizard Wi-Fi devices that have a Local API
  • Exposes a discovery method to discover devices on your local network using Multicast DNS
  • Provides a simple polling interface to request near real-time data from your devices
  • Transforms the P1 telegram text from the P1 meter into a readable detailed object
  • Includes inline documentation on each method, type and property
  • Follows the guidelines provided in the official HomeWizard Energy API documentation

Installation

This library requires Node 14 or higher. Typescript is only required for type-safety, the library will also work without Typescript.

npm install homewizard-energy-api

or

yarn add homewizard-energy-api

Supported devices

This library supports all devices from HomeWizard that expose an API. This includes:

Make sure to enable the Local API setting for each device you want to use with this library. You can do this in the Energy app.

P1 Meter

Get the power consumption or gas usage in your home from the Wi-Fi P1 Meter:

import { P1MeterApi } from 'homewizard-energy-api';

const p1Meter = new P1MeterApi('http://192.168.1.11');

// Get the active power and gas usage
const data = await p1Meter.getData();
Method API Function Description
GET /api getBasic() Get basic information from the device. More info in the official docs.
GET /api/v1/data getData() Returns the most recent measurement from the device. More info in the official docs.
GET /api/v1/telegram getTelegram() Returns the most recent, valid telegram in text format that was given by the P1 meter, therefore this endpoint is only available for the HWE-P1. More info in the official docs.
GET /api/v1/telegram getParsedTelegram() Returns the telegram as a detailed JSON response. This is a feature of this library, and not of the API itself. See telegram docs for more info about the telegram endpoint
PUT /api/v1/identify identify() Identify the device. The status light will blink for a few seconds after calling this endpoint. More info in the official docs.
GET /api/v1/system getSystem() Returns the actual system settings. More info in the official docs.
PUT /api/v1/system updateSystem() Configure system settings. Currently the only available option it to turn on and off all cloud communication. More info in the official docs.

Data polling

A simple polling interface for the P1 Meter (and all other devices) is exposed via api.polling.getData, api.polling.getTelegram and api.polling.getParsedTelegram. See the examples for more information.

import { P1MeterApi } from 'homewizard-energy-api';

const p1Meter = new P1MeterApi('http://192.168.1.35', {
  polling: {
    interval: 1000, // Poll the endpoints each second. Defaults to 1000
    stopOnError: true, // Will stop polling when an error occurs. Defaults to false
  },
});

p1Meter.polling.getData.start();

p1Meter.polling.getData.on('response', response => {
  // Receive the latest data of this P1 Meter from the /api/v1/data endpoint each second:
  // {
  //   smr_version: 50,
  //   meter_model: 'ISKRA 2M550T-1012',
  //   wifi_ssid: 'SOME_WIFI_SSID',
  //   wifi_strength: 100,
  //   total_power_import_t1_kwh: 19055.287,
  //   total_power_import_t2_kwh: 19505.815,
  //   total_power_export_t1_kwh: 0.002,
  //   total_power_export_t2_kwh: 0.007,
  //   active_power_w: 997,
  //   active_power_l1_w: 66,
  //   active_power_l2_w: 88,
  //   active_power_l3_w: 852,
  //   total_gas_m3: 6789.488,
  //   gas_timestamp: 221217223003
  // }
});

p1Meter.polling.getData.on('error', error => {
  // handle an error
});

Energy Socket

Control your Wi-Fi Energy Socket:

import { EnergySocketApi } from 'homewizard-energy-api';

const energySocket = new EnergySocketApi('http://192.168.1.10');

// Turn the Energy Socket ON
const updatedState = await energySocket.updateState({ power_on: true });
Method API Function Description
GET /api getBasic() Get basic information from the device. More info in the official docs.
GET /api/v1/state getState() Returns the actual state of the Energy Socket. More info in the official docs.
PUT /api/v1/state updateState() Control the state of the Energy Socket. More info in the official docs.
GET /api/v1/data getData() Returns the most recent measurement from the device. More info in the official docs.
PUT /api/v1/identify identify() Identify the device. The status light will blink for a few seconds after calling this endpoint. More info in the official docs.
GET /api/v1/system getSystem() Returns the actual system settings. More info in the official docs.
PUT /api/v1/system updateSystem() Configure system settings. Currently the only available option it to turn on and off all cloud communication. More info in the official docs.

Data polling

A simple polling interface for the Energy Sockets is exposed via api.polling.getData and api.polling.getState. See the examples for more information.

Watermeter

Get the water consumption in your home from the Wi-Fi Watermeter:

import { WaterMeterApi } from 'homewizard-energy-api';

const waterMeter = new WaterMeterApi('http://192.168.1.12');

// Get the active water usage
const data = await waterMeter.getData();
Method API Function Description
GET /api getBasic() Get basic information from the device. More info in the official docs.
GET /api/v1/data getData() Returns the most recent measurement from the device. More info in the official docs.

Data polling

A simple polling interface for the Watermeter is exposed via api.polling.getData. See the examples for more information.

kWh Meter 1-phase

Get the power consumption from the Wi-Fi kWh meter 1-phase MID:

import { KwhMeter1PhaseApi } from 'homewizard-energy-api';

const kwhMeter1Phase = new KwhMeter1PhaseApi('http://192.168.1.13');

// Get the power usage from your Wi-Fi kWh meter 1-phase MID
const data = await kwhMeter1Phase.getData();
Method API Function Description
GET /api getBasic() Get basic information from the device. More info in the official docs.
GET /api/v1/data getData() Returns the most recent measurement from the device. More info in the official docs.
GET /api/v1/system getSystem() Returns the actual system settings. More info in the official docs.
PUT /api/v1/system updateSystem() Configure system settings. Currently the only available option it to turn on and off all cloud communication. More info in the official docs.

Data polling

A simple polling interface for the kWh Meter 1-phase is exposed via api.polling.getData. See the examples for more information.

kWh Meter 3-phase

Get the power consumption from the Wi-Fi kWh meter 3-phase MID:

import { KwhMeter3PhaseApi } from 'homewizard-energy-api';

const kwhMeter3Phase = new KwhMeter3PhaseApi('http://192.168.1.14');

// Get the power usage from your Wi-Fi kWh meter 3-phase MID
const data = await kwhMeter3Phase.getData();
Method API Function Description
GET /api getBasic() Get basic information from the device. More info in the official docs.
GET /api/v1/data getData() Returns the most recent measurement from the device. More info in the official docs.
GET /api/v1/system getSystem() Returns the actual system settings. More info in the official docs.
PUT /api/v1/system updateSystem() Configure system settings. Currently the only available option it to turn on and off all cloud communication. More info in the official docs.

Data polling

A simple polling interface for the kWh Meter 3-phase is exposed via api.polling.getData. See the examples for more information.

Discover HomeWizard devices in your network

This library exposes a discovery method to discover HomeWizard Energy devices in your local network. Each HomeWizard device broadcasts itself on your local network using Multicast DNS. This allows you to use all the devices in your network without knowing the actual IP address of the device. You can find more details about this in the official docs.

Discovery example

import { HomeWizardEnergyDiscovery } from 'homewizard-energy-api';

const discovery = new HomeWizardEnergyDiscovery();

discovery.start();

discovery.on('response', response => {
  // You'll get a response for each device that is found
  // Example response:
  // {
  //   ip: '192.168.1.34',
  //   hostname: 'energysocket-25FF1A.local',
  //   fqdn: 'energysocket-25FF1A._hwenergy._tcp.local',
  //   txt: {
  //     api_enabled: '1',
  //     path: '/api/v1',
  //     serial: '3c39e725ff1a',
  //     product_name: 'Energy Socket',
  //     product_type: 'HWE-SKT'
  //   }
  // }
});

About this library

Hi there! I created this library to provide type-safety when using the HomeWizard Energy API's in my own projects. I made it open source so that you can easily control your HomeWizard devices and have the same level of type-safety while developing your projects.

I'm not affiliated with HomeWizard. I create open source projects in my free time. If you find this project helpful, please consider supporting me on my GitHub Sponsor page. Your support will help me continue to create high-quality, open source projects and cover the costs of maintaining them.

Thank you for your support!

Note that logos, products, and trademarks are the property of HomeWizard.

About HomeWizard Energy

With the HomeWizard Energy platform, you can get insights in your energy usage. Use the HomeWizard Wi-Fi P1 meter to access real-time data directly from your smart meter, the HomeWizard Wi-Fi Energy Socket to get energy insights from all your devices, the HomeWizard Wi-Fi kWh meter to measure devices such as solar panels and the HomeWizard Wi-Fi Watermeter to get insight in your water usage. With the open API you can integrate the data directly into your system of choice.

API Introduction

The HomeWizard Wi-Fi P1 meter, Wi-Fi Energy Socket, Wi-Fi kWh meter and Wi-Fi Watermeter (‘device’) have a local API to retrieve the most recent measurements or control the device. You can access this API as long as you are connected to the same (Wi-Fi) network as the device and the API is enabled in the HomeWizard Energy app. This API is intended to connect your device to your own automation, home automation or graphing system. It is not possible to retrieve data history with the local API, as this is not stored on the device itself.

homewizard-energy-api's People

Contributors

dependabot[bot] avatar jvandenaardweg avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar

homewizard-energy-api's Issues

Unable to parse line in parsed telegram

Hi,

I have some unparsed replies in my telegram data :

Unable to parse line: 1-0:1.4.0(00.255*kW)
Unable to parse line: 1-0:1.6.0(230903114500S)(02.762*kW)
Unable to parse line: 0-0:98.1.0(8)(1-0:1.6.0)(1-0:1.6.0)(230201000000W)(230110174500W)(04.769*kW)(230301000000W)(230207221500W)(05.092*kW)(230401000000S)(230312144500W)(04.575*kW)(230501000000S)(230428174500S)(04.886*kW)(230601000000S)(230523220000S)(04.639*kW)(230701000000S)(230604140000S)(02.791*kW)(230801000000S)(230723164500S)(03.525*kW)(230901000000S)(230812111500S)(02.727*kW)

here is the parsed result :

{
     "meter": {
          "brand": "FLU5",
          "model": "myModel_A"
     },
     "version": "50217",
     "timestamp": "2023-09-06T18:41:03+02:00",
     "equipmentId": "myUniqueID",
     "textMessage": {
          "codes": null,
          "message": ""
     },
     "power": {
          "import": {
               "t1": {
                    "value": 2340.885,
                    "unit": "kWh"
               },
               "t2": {
                    "value": 2608.465,
                    "unit": "kWh"
               },
               "active": {
                    "value": 0.37,
                    "unit": "kW"
               }
          },
          "export": {
               "t1": {
                    "value": 0,
                    "unit": "kWh"
               },
               "t2": {
                    "value": 0.021,
                    "unit": "kWh"
               },
               "active": {
                    "value": 0,
                    "unit": "kW"
               }
          },
          "tariffIndicator": 1,
          "threshold": {
               "value": 999.9,
               "unit": "kW"
          },
          "fuseThreshold": {
               "value": 999,
               "unit": "A"
          },
          "switchPosition": "1",
          "numberOfPowerFailures": null,
          "numberOfLongPowerFailures": null,
          "longPowerFailureLog": {
               "count": null,
               "log": []
          },
          "voltageSags": {
               "l1": null,
               "l2": null,
               "l3": null
          },
          "voltageSwell": {
               "l1": null,
               "l2": null,
               "l3": null
          },
          "instantaneous": {
               "current": {
                    "l1": {
                         "value": 1,
                         "unit": "A"
                    },
                    "l2": {
                         "value": null,
                         "unit": null
                    },
                    "l3": {
                         "value": null,
                         "unit": null
                    }
               },
               "voltage": {
                    "l1": {
                         "value": 229,
                         "unit": "V"
                    },
                    "l2": {
                         "value": null,
                         "unit": null
                    },
                    "l3": {
                         "value": null,
                         "unit": null
                    }
               },
               "power": {
                    "positive": {
                         "l1": {
                              "value": 0.37,
                              "unit": "kW"
                         },
                         "l2": {
                              "value": null,
                              "unit": null
                         },
                         "l3": {
                              "value": null,
                              "unit": null
                         }
                    },
                    "negative": {
                         "l1": {
                              "value": 0,
                              "unit": "kW"
                         },
                         "l2": {
                              "value": null,
                              "unit": null
                         },
                         "l3": {
                              "value": null,
                              "unit": null
                         }
                    }
               }
          }
     },
     "gas": {
          "deviceType": null,
          "equipmentId": null,
          "timestamp": null,
          "value": null,
          "unit": null,
          "valvePosition": null
     }
}

here is the full telegram :

/FLU5\myModel_A

0-0:96.1.4(50217)
0-0:96.1.1(myUniqueID)
0-0:1.0.0(230906164103S)
1-0:1.8.1(002340.885*kWh)
1-0:1.8.2(002608.465*kWh)
1-0:2.8.1(000000.000*kWh)
1-0:2.8.2(000000.021*kWh)
0-0:96.14.0(0001)
1-0:1.4.0(00.255*kW)
1-0:1.6.0(230903114500S)(02.762*kW)
0-0:98.1.0(8)(1-0:1.6.0)(1-0:1.6.0)(230201000000W)(230110174500W)(04.769*kW)(230301000000W)(230207221500W)(05.092*kW)(230401000000S)(230312144500W)(04.575*kW)(230501000000S)(230428174500S)(04.886*kW)(230601000000S)(230523220000S)(04.639*kW)(230701000000S)(230604140000S)(02.791*kW)(230801000000S)(230723164500S)(03.525*kW)(230901000000S)(230812111500S)(02.727*kW)
1-0:1.7.0(00.370*kW)
1-0:2.7.0(00.000*kW)
1-0:21.7.0(00.370*kW)
1-0:22.7.0(00.000*kW)
1-0:32.7.0(229.7*V)
1-0:31.7.0(001.93*A)
0-0:96.3.10(1)
0-0:17.0.0(999.9*kW)
1-0:31.4.0(999*A)
0-0:96.13.0()
!26AD

and the data at the same time :

{
  wifi_ssid: 'mySSID',
  wifi_strength: 100,
  smr_version: 50,
  meter_model: 'Fluvius myModel_A',
  unique_id: 'myUniqueID',
  active_tariff: 1,
  total_power_import_kwh: 4949.35,
  total_power_import_t1_kwh: 2340.885,
  total_power_import_t2_kwh: 2608.465,
  total_power_export_kwh: 0.021,
  total_power_export_t1_kwh: 0,
  total_power_export_t2_kwh: 0.021,
  active_power_w: 370,
  active_power_l1_w: 370,
  active_voltage_l1_v: 229.7,
  active_current_l1_a: 1.93,
  active_power_average_w: 255,
  montly_power_peak_w: 2762,
  montly_power_peak_timestamp: 230903114500,
  external: []
}

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.