The Berlin IoT Hub consists of two components, namely: an RESTful API and a frontend. All of these components are administrated within their very own Repository stored in
- github.com/technologiestiftung/berlin-datahub-api
- github.com/technologiestiftung/berlin-iot-hub-frontend
The API is written in Typescript and uses Express.js + and Prisma.
You can find an example .env
file under ./prisma/env.example. Make sure to obtain an LogDNA Key to connect to your account. (You can get this by going to the addon section on render.com).
- Node.js >= 12
- Docker >= 19
docker-compose up
npm ci
# Assumes you habe a posstgres DB running
npm run dev
Uses Jest. Prisma creates for each test run a sqlite DB. Currently this is fine. We might need to switch to a Postgres setup later on.
npm t
The API is deployed to render.com. You can find all definition in render.yaml. Deploy via Infrastructure as Code. Don't forget to add your environment variables.
This api provides some endpoints for posting data over HTTP. You need an user account to do that. You can find many examples in the file http-requests/api.http. This file can be used with the VSCode Rest Client Extension. Make sure to create your .env
file there from the provided example under ./http-requests/env.example.
Docs are generated using typedoc and deployed to github pages.
If you want to connect you very own TTN application and their devices with the IoT Data Hub you'll need:
- a sensor which measures something
- a proper payload aka. decoder function
- to activate the official TTN HTTP Integration and configurate it
This is the most obvious step and propably comes by default if you already found your way to our repo. To show the data which was measured by your sensors in the IoT Data Hub, of course, you'll need a sensor which already measures some data e.g. temperature, CO2, dezibel, pressure etc.., first.
So far, our API only can handle one record per device. In order to handle the incoming payloads in a way our API is aware of what is happening, you simply have to update the payload aka. decoder function in your very own TTN application. You measrued data, e.g. CO2 value, needs to be returned as "value" otherwise our API wont recognize it. Please see the following example for a simple CO2-sensor below:
function Decoder(bytes) {
var myCO2;
//if no value was measured return 0
if (!bytes[0]) {
myCO2 = 0;
} else {
//cuz co2 sensors usually delivery records higher than 255 we look at 2 bytes of the uplink
myCO2 = (bytes[1] << 8) | bytes[0];
}
return {
now: new Date().toISOString(),
value: myCO2,
};
}
You can simply test your decoder function by simulating an uplink. In our case we simply used a payload with the hexadecimal values of 01 05. Our decoder function now returns us a decimal value of 1281. Time to open the window and let some fresh air in!
The IoT Data Hub uses a RESTful API and therefore can be used by any device which is communicating over HTTP. Luckily, the TTN Community already provides a very powerful built-in integration to wire the incoming payload messages (MQTT) with the HTTP protocol. To use this HTTP integration for the API, simply follow these steps:
- navigate to the overview of your TTN application
- in the menu to the top right click on Integrtions
- choose HTTP Integration to activate it
- enter a process ID e.g. berlin-datahub-co2
- enter the URL: https://berlin-datahub-api.onrender.com/api/ttn
- enter Method: POST
- enter "Bearer" + your very own Authorization token (you''ll get this from the admin of the IoT Data Hub by request --> just send us a ping)
By finally setting up the HTTP integration, your part is done and everything should work as expected. Yeah. However, if you're going to test the API be simulating some uplinks, you'll will notice that no record and even no application will appear in the IoT Data Hub Frontend.
Don't worry! This is because we have to add your application and your sending device manually first. So: please don't hesitate to get in contact and tell us your AppID & the ID of your device(s) which is/are sending. We will send you your very own Authorization token and configure our DB so you can finally see your sensor data our Frontend