4 releases

0.1.3 Jan 2, 2025
0.1.2 Dec 30, 2024
0.1.1 Dec 29, 2024
0.1.0 Dec 29, 2024

#338 in Network programming

Download history 258/week @ 2024-12-25 167/week @ 2025-01-01

425 downloads per month
Used in 4 crates (3 directly)

EPL-2.0 OR GPL-3.0

170KB
3K SLoC

Rust API for KNX devices and networks

knxkit is a library for interfacing with KNX devices and networks. It provides a high-level API for interacting with KNX devices and networks, and is designed to be easy to use and flexible.

  • Data structures — individual and group addresses, CEMI, APDU, DPT, DataPoint, KNXnet/IP frames

  • KNXnet/IP services — search, describe, tunneling are implemented.

  • Project files — read .knxproj files, which are used by ETS to store KNX project information. Devices and group definitions can be extracted.

  • Data point structures generated from knx_master.xml contents. Typed and generic representations are supported

  • Command line utilities for data structures generation and knx network interaction.

Code Example

[dependencies]
tokio = { version = "1.42.0", features = ["full"] }
knxkit = "0.1.1"
knxkit_dpt = "0.1"
use std::{net::Ipv4Addr, str::FromStr, time::Duration};

use knxkit::{
    connection::{self, ops::GroupOps, KnxBusConnection, RemoteSpec},
    core::address::GroupAddress,
};

use knxkit_dpt::{
    specific::{SpecificDataPoint, DPT_9_1},
    typeinfo,
};

#[tokio::main]
async fn main() {
    let remote = RemoteSpec::KnxIpTunnel("192.168.8.2:3671".parse().unwrap());
    let local = Ipv4Addr::from_str("192.168.7.51").unwrap();

    let mut tunnel = connection::connect(local, &remote).await.unwrap();

    let group = GroupAddress::from_str("2/0/0").unwrap();
    let timeout = Duration::from_secs(1);

    let data_point = tunnel.group_read(group, timeout).await.unwrap();

    let temp = DPT_9_1::from_data_point(&data_point).unwrap();
    let info = typeinfo::lookup(DPT_9_1::DPT).unwrap();

    println!("{}: {}{}", info.text.unwrap(), temp.0, info.unit.unwrap());
    // -> temperature (°C): 19.5°C

    tunnel.terminate().await
}

Command line utility example

cargo install knxkit_cli
export KNX_REMOTE=udp://192.168.8.2
export KNX_PROJECT=~/knxkit/_hidden/etc/TestProject.knxproj

Search search

Group Monitor group monitor

Downloadable binary releases for Linux (and maybe Windows) will be provided in the future.

Status

Currently the library is in development. It may be used for testing and experimentation, but is not yet ready for production use. The API is subject to change. The library is being developed in the open, and contributions are welcome.

Plan

In addition to general improvements and bug fixes, the following features are planned for the library:

  • KNXnet/IP routing
  • KNXnet/IP secure
  • USB tunneling
  • multiplexing of single tunnel connection over unix domain socket

Tools and applications

  • knx2mqtt
  • knx2ws (WebSocket)
  • knx2prometheus
  • scriptable logic engine

knxkit is licensed under either of Eclipse Public License - v2.0 or GNU General Public License v3 at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~15–26MB
~368K SLoC