From 84b9ddcc2905f5d8667cfef1359b724c23d27365 Mon Sep 17 00:00:00 2001 From: xengineering Date: Thu, 29 Oct 2020 12:11:32 +0100 Subject: Setup basic Systemd Units --- iot_barcode_device_handler | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100755 iot_barcode_device_handler (limited to 'iot_barcode_device_handler') diff --git a/iot_barcode_device_handler b/iot_barcode_device_handler new file mode 100755 index 0000000..5c05aab --- /dev/null +++ b/iot_barcode_device_handler @@ -0,0 +1,43 @@ +#!/usr/bin/python3 + + +"""Executable to read the Key Events from the Barcode Scanner (root Priviledges necessary)""" + + +import evdev +import os + +import iot_barcode.config as config + + +def main(): + + try: + # read config + cfg = config.get_config() + fifo_path = cfg["scanner"]["fifo_path"] + event_device_path = cfg["scanner"]["evdev_path"] + + # prepare fifo + os.makedirs(os.path.dirname(fifo_path), exist_ok=True) + os.mkfifo(fifo_path) + + barcode_scanner = evdev.InputDevice(event_device_path) + with barcode_scanner.grab_context(): + for event in barcode_scanner.read_loop(): + if event.type == evdev.ecodes.EV_KEY: + eventdata = evdev.categorize(event) + if eventdata.keystate: + with open(fifo_path, "w") as fifo: + fifo.write(eventdata.keycode) + fifo.flush() + + except KeyboardInterrupt: + pass + + finally: + os.remove(fifo_path) + + +if __name__ == "__main__": + main() -- cgit v1.2.3-70-g09d2