openhab-addons/bundles/org.openhab.binding.linuxinput
Thomas Weißschuh e510244cb6
[linuxinput] fixes to thing properties (#10634)
* Do not discover on ENTRY_MODIFY

ENTRY_MODIFY is triggered on each keypress multiple times, so we should
not trigger on it.

The usecase for ENTRY_MODIFY triggers where detecting permission changes
of the event nodes.
Inotify does have a dedicate event ("ATTRIB") for that but Java
WatchService normalizes this to a ENTRY_MODIFY event
(See LinuxWatchService.java)

After permission changes users now have to trigger a scan manually.

* Use proper representation property

* Show event node in label

This makes it easier to figure out which thing is which device in the
presence of symlinks or multiple identical devices.

Signed-off-by: Thomas Weißschuh <thomas@t-8ch.de>
2021-05-05 22:22:18 +02:00
..
src/main [linuxinput] fixes to thing properties (#10634) 2021-05-05 22:22:18 +02:00
NOTICE added migrated 2.x add-ons 2020-09-21 03:37:19 +02:00
README.md added migrated 2.x add-ons 2020-09-21 03:37:19 +02:00
noEmbedDependencies.profile added migrated 2.x add-ons 2020-09-21 03:37:19 +02:00
pom.xml Apply Spotless, update skeleton project version, resolve itest runbundles (#9459) 2020-12-22 10:37:44 +01:00

README.md

Linux Input Binding

This binding allows to you use a keyboard to control your openHAB instance. It works by exposing all keys on the keyboard as channels.

As indicated by the name of the binding this only works on Linux. (It uses the libevdev library the receive events from the kernel) As all the low-level protocols are handled by the Linux kernel it works for any kind of keyboard; USB, Bluetooth, etc.

Supported Things

All keyboards supported by the Linux kernel.

Discovery

The discovery feature finds all cold- or hotplugged keyboards by watching the /dev/input/ directory. The discovery uses the numeric ids for the devices. (/dev/input/event0, etc...). This can lead to issues when the kernel autodiscovery enumerates devices in a nondeterministic order. This problem can be circumvented by using predictable device names in /dev/input/by-id/ or /dev/input/by-path/ or by using Udev facilities (out of scope for this document).

Binding Configuration

openHAB will need rights on the /dev/input/ files it is supposed to access. This can be implemented by group-memberships, (custom) initscripts or Udev rules. The exact configurations possible depend on your system (out of scope for this document).

The libevdev library has to be installed for this plugin to work. (It should be available via your package manager)

Thing Configuration

Each thing has has to be explicitly enabled after it is configured. While it is enabled all of the generated events will be consumed by openHAB. The device will not be available for normal input processing!

Static configuration

Thing

Thing linuxinput:input-device:some-keyboard [ enable=true, path="/dev/input/eventXX" ]

Item

Contact SomeButton "Some Button" { channel="linuxinput:input-device:event17:keypresses#KEY_0" }

Channels

Each Thing provides multiple channels

  • A key channel that aggregates all events.
  • Per physical key channels.

Events

The following happens when pressing and releasing a key:

Press

  1. State of global key channel updated to new key.
  2. State of per-key channel updated to "CLOSED".
  3. Global key channel triggered with the current key name.
  4. Per-key channel triggered with "PRESSED"".
  5. State of global key channel updated to "" (Empty string)

Release

  1. State of per-key channel updated to "OPEN"
  2. Per-key channel triggered with "RELEASED"

Rationale

Channel states are updated first to allow rules triggered by channel triggers to access the new state.