Skip to main content

Pushing data of ISKRA MT175 smart meter to openhab

Project description

smart-meter-to-openhab

Pushing data of ISKRA MT175 smart meter to openhab. For a connection to the Smart meter you need a USB infrared adapter. There are several adapters on the market (e.g. https://weidmann-elektronik.de/Produkt_IR-Kopf.html) that just need to be pluged in. They are usually detected as a casual serial port (/dev/ttyUSB0)

Installation

The python package can be installed from PyPi (https://pypi.org/project/smart-meter-to-openhab/) It as advisable to use the same python version as specfied in the pyproject.toml. Follow the process in install-poetry.sh

  1. Navigate to the folder where the virtual environment shall be created (e.g. your home dir):
cd ~
  1. Create virtual environment (this will create a new folder smart_meter_py_env):
python3 -m venv smart_meter_py_env
  1. Activate the virtual environment
source smart_meter_py_env/bin/activate
  1. Upgrade pip and setuptools
python3 -m pip install --upgrade pip setuptools
  1. Install smart-meter-to-openhab
pip install smart-meter-to-openhab
  1. Provide environment variables. You can e.g. pass a .env file to smart-meter-to-openhab via the option --dotenv_path. Or provide them by any other means (e.g. in your ~/.profile).
# Hostname incl. http(s) (required)
OH_HOST='<http://your_ip:your_port'
#openhab user (or token) for login (optional)
OH_USER=''
#openhab password for login (optional)
OH_PASSWD=''
#current consumption openhab item (required)
OVERALL_CONSUMPTION_WATT_OH_ITEM='smart_meter_overall_consumption'
#other openhab item names (optional)
PHASE_1_CONSUMPTION_WATT_OH_ITEM='smart_meter_phase_1_consumption'
PHASE_2_CONSUMPTION_WATT_OH_ITEM='smart_meter_phase_2_consumption'
PHASE_3_CONSUMPTION_WATT_OH_ITEM='smart_meter_phase_3_consumption'
ELECTRICITY_METER_KWH_OH_ITEM='smart_meter_electricity_meter'

NOTE: certificate verification is turned off, in case OH_HOST refers to an https address (since most openHAB instances do probably use self-signed certificates)

  1. Run smart-meter-to-openhab with e.g.
nohup smart_meter_to_openhab --logfile ~/smart_meter.log --verbose &

Autostart after reboot and on failure

Create a systemd service by opening the file /etc/systemd/system/smart_meter_to_openhab.service and copy paste the following contents. Replace User/Group/ExecStart accordingly.

[Unit]
Description=smart_meter_to_openhab
Documentation=https://github.com/die-bauerei/smart-meter-to-openhab
After=network-online.target

[Service]
Type=simple
User=openhab
Group=openhab
UMask=002
Restart=always
RestartSec=5s
ExecStart=/usr/bin/bash -lc "/home/openhab/smart_meter_py_env/bin/smart_meter_to_openhab --logfile /home/openhab/smart_meter.log --verbose"

[Install]
WantedBy=multi-user.target

Now execute the following commands to enable autostart:

sudo systemctl --system daemon-reload
sudo systemctl enable smart_meter_to_openhab.service

It is now possible to start, stop, restart and check the status of smart-meter-to-openhab with:

sudo systemctl start smart_meter_to_openhab.service
sudo systemctl stop smart_meter_to_openhab.service
sudo systemctl restart smart_meter_to_openhab.service
sudo systemctl status smart_meter_to_openhab.service

Development

Development is done in wsl2 on ubuntu 22.04. Setting up the development environment on Windows is not supported. But in principal it could be setup as well since no OS specific functionalities are used.

Setup

The project is using poetry for managing packaging and resolve dependencies. To install poetry call install-poetry.sh. This will install poetry itself as well as python and the required packages as a virtual environment in .venv. Example settings for development in VS Code are provided in vscode-settings. (Copy them to .vscode folder) Follow these instructions to enable proper linting and type checking.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

smart_meter_to_openhab-0.5.3.tar.gz (12.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

smart_meter_to_openhab-0.5.3-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file smart_meter_to_openhab-0.5.3.tar.gz.

File metadata

  • Download URL: smart_meter_to_openhab-0.5.3.tar.gz
  • Upload date:
  • Size: 12.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for smart_meter_to_openhab-0.5.3.tar.gz
Algorithm Hash digest
SHA256 5ebee6b0dec431c826a7a10a6fa1e086226012875a5ed356702a581cf459f600
MD5 892273af32f69077d68715558a3e8f0c
BLAKE2b-256 d423ff58dae63ab0a6e9f12f2b1968c95e72cf1184a6f7feedd9d9effe3649d3

See more details on using hashes here.

File details

Details for the file smart_meter_to_openhab-0.5.3-py3-none-any.whl.

File metadata

File hashes

Hashes for smart_meter_to_openhab-0.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4e12dc2ec5ae89da0cd496d6c13436b3b23ea59b0cc1567c515a49bd5db2d861
MD5 510f99076894364e34a76399bc84e3c8
BLAKE2b-256 0a5612cd24b78649ece548d1a660eba27cc2d75fb81eb7107d0578cb2dc65044

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page