/tischkickermonitor

Tischkickermonitor @Jambit :)

Primary LanguageHTML

Tischkicker Monitor @Jambit

Motivation

This project aims for monitoring our Tischkicker in our office. We frequently have the problem that the table is already occupied during peak times around lunch or in the late afternoon. Our office is distributed on multiple floors, hence it takes some time to walk for a short match. Usually you need to wait in an already long queue in front of it or you will come back later. If you are lucky, you'll find a free table, if not it's already in use again by your beloved colleagues. To avoid situations like this, I equipped the table with several sensors which are exposed by a RESTful API. It can be used to develop custom frontends like tray icon applications, Android apps or web applications. Feel free to develop whatever you like and offer it to your colleagues so that everybody can use it as well. As you know, sharing is caring. ;)

Available Sensors

The following sensors are currently available:

Planned Sensors (testing phase)

If you are missing a sensor, check out this lists of supported sensors and feel free to contribute to this project. :)

Architecture

Each sensor service is designed as a single microservice which is implemented using NodeJS running on a RaspberryPi 3 offering RESTful webservices via HTTP. The sensors are connected via a pretty neat technology called GrovePi and is very easy to extend. GrovePi is created by Dexter Industries as a Kickstarter project which aims for simplifying IoT application development. The GrovePi is an add-on board for the Raspberry Pi that connects modular sensors to the RPi GPIO connectors. GrovePi was developed and launched in partnership with Seeed Studio, an electronics manufacturer. The result is a rich selection of sensors, actuators and more components which can be used with multiple programming languages by almost as easy as "plug&play".

For this services an api first approach is used with NodeJS and Swagger-Express-MW. Based on the defined API (see swagger's OAI) the skeleton is created and then modified for the specific sensors. The sensors are connected via node-grovepi module. The services itself are managed by the process manager PM2. To offer a standardized interface and preserve flexibility nginx is used as reverse proxy.

Hardware Assembly

The ultra sonic sensors are mounted on two wooden boards which are fixed with two screws on a mounting threat. For transportation of the table just remove those two screws for each board and you can remove the wooden boards. The RPi, the sound sensor and the vibration sensor are mounted on a wooden board as well which is fixed by a screw and a mounting thread as well.

In the following you'll find some images of the implementation and the final result.

Contribute

If you're interested in this project or you just want more sensors or more information offered by the existing sensors please contact me in person in my office, via email or just simply create an issue on github for this project or go directly the corresponding repository.

The related repositories for each sensor can be found here

Cheers,
Cherry