#keyboard #hid #cli #qmk

bin+lib qmk-hid

A simple CLI for bidirectional communication with QMK keyboards using raw HID

1 unstable release

Uses new Rust 2024

new 0.1.0 Mar 8, 2025

#1219 in Command line utilities

Download history 115/week @ 2025-03-05

115 downloads per month

MIT license

9KB
142 lines

qmk-hid

A simple CLI for bidirectional communication with QMK keyboards using raw HID, written in Rust with a small memory footprint.

Installation

You can install qmk-hid using Cargo or by building it from source.

cargo install qmk-hid

Usage

To use qmk-hid you must find you keyboard's vendor ID and product ID. They can be usually found in your keyboard's info.json or using tools like lsusb.

On Linux, you have to setup udev rules to allow access to the HID device.

qmk-hid --help ## prints help
qmk-hid --vendor-id 18003 --product-id 4 ## example using a corve v4 keyboard

Once qmk-hid is running:

  • Incoming HID messages from the keyboard will be printed to standard output.
  • Messages can be sent to the keyboard by writing to standard input.
  • Errors and connection issues are reported to standard error output.
  • If the keyboard is not connected, qmk-hid will continuously poll for a connection until the device is available (the default interval is 3000ms).

[!IMPORTANT] In both directions the message length should be 32 bytes or less, you have to implement a custom protocol overwise

Since qmk-hid uses standard input and output for communication, it can be easily integrated into scripts or other programs. You can checkout the NodeJS demo for a simple example.

Build

To build qmk-hid you will need the Rust toolchain and libhidapi system libraries. Then you can just clone the repository and use the following command:

cargo build --release

Dependencies

~1–13MB
~90K SLoC