4 releases
new 0.1.3 | Jan 2, 2025 |
---|---|
0.1.2 | Dec 30, 2024 |
0.1.1 | Dec 29, 2024 |
0.1.0 | Dec 29, 2024 |
#340 in Network programming
404 downloads per month
Used in 4 crates
(3 directly)
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
Group Monitor
Downloadable binary releases for Linux (and maybe Windows) will be provided in the future.
Related crates
- knxkit_dpt - DPT definitions
- knxkit_dptgen - DPT definitions generator
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
~14–26MB
~362K SLoC