An ioBroker adapter for reading data from one or up to eight climate controllers by Technische Alternative using BL-NET. Or an infinite number of climate controllers connected to CMI.
After installation, you need to create an instance and configure custom values i.e. for the IP address, port number, and update interval that the instance should use.
Please ensure that you own the BL-NET device or the newer CMI product.
BL-NET device looks like this: You can find the manual of BL-NET here: https://www.ta.co.at/fileadmin/Downloads/Betriebsanleitungen/00_Auslauftypen/BL-NET/Manual_BL-Net_V2.19-2_EN.pdf
CMI device looks like this: You can find the manual of CMI here: https://www.ta.co.at/download/datei/805
The adapter regularly reads the current data from your heating control system. It establishes contact over Ethernet with:
- the BL-NET Bootloader or
- the CMI Control and Monitoring Interface.
The BL-NET and CMI are products of the company 'Technische Alternative' and allow the data of various heating controls to be read out and buffered via CAN bus or data line bus.
The installation can be done via:
- ioBroker GUI: Go to Expert mode > Adapter > Install from URL and enter
https://github.com/weberk/ioBroker.ta-blnet
- CLI: Run the following command:
iobroker url iobroker.ta-blnet@latest
- [W034] @iobroker/adapter-core 3.2.2 specified. 3.2.3 is recommended. Dependency updated
- merge dependabot pull requests on several libs
- added CMI support to adapters summary description
- port number is taken from config for communication with CMI
- improved retry logic for requests to CMI
- improved error handling for calls to CMI JSON API
- introduced increasing wait time between successive CMI request attempts
- removed port number constraint to allow port 80 for CMI
- added eslint9 config, removed eslint8 config
- added translation and documentation to data object config
- improved JSON Status Code logging
- added data_objects per can_node to config for CMI requests
- added additional sections processing to CMI mode
- used uvr_type_code as capital letter string
- node name for channel is now 4 digid
- improved error handling on CMI return codes
- improved node names
- fixed lint errors
- added initial CMI support
- fixed negative current_heat_power
- added 2DL reading
- renamed main class to TaBlnet and port to 'TA port'
- fixed negative current_heat_power
- renamed adapter and git repo from ioBroker.uvr16xx-blnet to ioBroker.ta-blnet
- published new package to npm
- removed onStateChange;
- streamlined object node names;
- improved node typing;
- explicitely created every node;
- improved outputs value filter;
- ensured calls to setObjectNotExistsAsync happen only once;
- removed data_frame_number parameter
- introduced limit for poll intervall
- removed obsolete react admin GUI settings and artefacts
- use this.setTimeout instead of this.setInterval
- finalized changes because of review findings
- introduced multiple data_frame_reading and population of multiple devices in adapter object tree
- added number of CAN frames to uvr_mode_str
- improved recognition of retry necessity on 'keep patient' messages from BL-NET
- improved reading of flow rate
- code refactoring
- refactorings and improved code documentation
- added frame index to options
- improved CAN bus mode reading
- lint fixes
- improved CAN bus mode reading
- improved reading device info
- fixed handling of negative temperatures
- improved logging and introduced a new socket for each command
- improving logging in order to analyse system using CAN bus
- added retry for reading UVR HEADER in order to identify uvr_mode
- testing deployment via "npm run release"
- testing deployment via "npm run release"
- improve build and deploy using github workflow (workflow>test-and-release.yml, ioBroker Check and Service Bot)
- added compliance with ioBrokers adapter repository (https://github.com/ioBroker/ioBroker.repositories?tab=readme-ov-file#how-to-publish-on-npm)
- improve build and deploy
- (Klaus Weber) initial release
- initial working version
MIT License
Copyright (c) 2025 Klaus Weber klausatweberesprit@gmail.com
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.