This script was made to read out the new Smart Meter "Kaifa MA309" used by Austrian power grid operators, here tested with TINETZ and EVN.
Specification of the interface: https://www.tinetz.at/fileadmin/user_upload/Kundenservice/pdf/Beschreibung_Kundenschnittstelle_Smart_Meter_TINETZ.pdf
Discussion about this script: https://www.photovoltaikforum.com/thread/157476-stromz%C3%A4hler-kaifa-ma309-welches-mbus-usb-kabel/?pageNo=2#post2350873
Useful description of TiNetz frames: https://www.gurux.fi/node/18232
This script was only tested with the above meter and the mentioned suppliers.
-
RJ12 6P6C Plug
e.g. https://www.amazon.de/6P6C-Stecker-6-polige-Schraubklemmen-Adapterstecker-CCTV-Adapterstecker/dp/B07KFGS3BF
Note: you have to cut off the plastic shell of the RJ12 plug to fit it into the socket of the MA309. -
MBUS Slave module like this:
Create a file meter.json
to configure your serial connection
parameters and your AES key.
A template file meter_template.json
can be recycled for this.
{
"loglevel": "logging.INFO",
"logfile": "/var/log/kaifareader/kaifa.log",
"port": "/dev/ttyUSB0",
"baudrate": 2400,
"parity": "serial.PARITY_NONE",
"stopbits": "serial.STOPBITS_ONE",
"bytesize": "serial.EIGHTBITS",
"key_hex_string": "",
"interval": 1,
"supplier": "TINETZ",
"export_format": "SOLARVIEW",
"export_file_abspath": "/var/run/kaifareader/kaifa.txt",
"export_mqtt_server": "mymqtt.examplebroker.com",
"export_mqtt_port": 1883,
"export_mqtt_user": "mymqttuser",
"export_mqtt_password": "supersecretmqttpass",
"export_mqtt_basetopic": "kaifareader",
"wanted_values": [
"VoltageL1",
"VoltageL2",
"VoltageL3",
"CurrentL1",
"CurrentL2",
"CurrentL3",
"RealPowerIn",
"RealPowerOut",
"RealEnergyIn",
"RealEnergyOut",
"ReactiveEnergyIn",
"ReactiveEnergyOut",
"Factor"
]
}
The AES key format is "hex string", e.g. a4f2d...
Please provide your electricity supplier by the field "supplier". Because each supplier uses its own security standard, the telegrams differ. This script was tested with suppliers:
- TINETZ
- EVN
Make sure to only select the values you need from the list in wanted_values
by deleting the elements you don't want.
The logfile will show the related OBIS-Values when run in logging.INFO
.
interval
must be <5
seconds, 1
second is recommended tho.
Solarview
Currently, the export to a file readable by Solarview (http://solarview.info/) is supported.
- The config key
export_format
has to be set toSOLARVIEW
- The config key
export_file_abspath
has to be set to the absolute file path
MQTT
- The config key
export_format
has to be set toMQTT
- The config keys
export_mqtt_server
,export_mqtt_port
,export_mqtt_user
,export_mqtt_password
andexport_mqtt_basetopic
have to be set.
This installs and automatically starts a systemd service.
Install the debian package
sudo dpkg -i kaifareader_...deb
If there are problems on missing packages, execute afterwards:
sudo apt -f install
Startup done, automatically.
Status of the service:
sudo systemctl status kaifareader
Start manually (e.g. after manually stopped)
sudo systemctl start kaifareader
python3 kaifa.py
nohup python3 kaifa.py &
sudo systemctl stop kaifareader
Press CTRL+C
Possible by killing the process