We invite you on March 12, 2019 to join the first IoT-Leb Hackathon along with Lebanon's most talented hackers, programmers, makers, and entrepreneurs. IoT-Leb Hackathon is part of IoT-Leb 19 conference that will take place at ESIB-USJ, CST Campus, Mar Roukos.
In the evolution towards the Internet of Things, an increasing number of devices equipped with sensors and communication interfaces will interact and collect data, communicate over the internet, and provide valuable monitoring and automation services. IoT-Leb Hackathon is a unique opportunity to get acquainted with the technologies that are set to play an essential role in the IoT landscape. During the Hackathon, you will get exclusive access to the latest IoT technologies.
During this lab, you will benefit from the first experimental platform implementing an end-to-end LoRaWAN solution in Lebanon. The platform consists of the following elements:
In a LoRaWAN network, the devices communicate with a Network Server through the gateway. The backend installed in the platform is based on an open-source LoRaWAN network-server https://www.loraserver.io. A web interface is available for configuring the applications and devices on the platform (https://212.98.ZZ.ZZ:8080).
Start by choosing the application named hackathon
to create a new device.
You should provide the following information for creating your device:
IoTXX
(where XX
is your group number)
Make sure to choose lora-profile
as a Device-profile
in order to enable OTAA join method.
Devices in the LoRaWAN platform are implemented on TTGO boards with ESP32 system on a chip microcontrollers with integrated Wi-Fi and dual-mode Bluetooth, and an additional LoRa transceiver.
Start by verifying the installation on your PC of the latest Arduino IDE and the presence of the LoRaWAN LMIC library. Then, download the example sketch from https://github.com/samerlahoud/iotleb-hacktools and open with Arduino IDE.
Now you should configure your device with the same identifiers DEVEUI
and APPKEY
as in the backend:
// This EUI must be in little-endian format, so least-significant-byte // first. When copying an EUI from loraserver, this means to reverse // the bytes. static const u1_t PROGMEM DEVEUI[8]={ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; // LSB mode void os_getDevEui (u1_t* buf) { memcpy_P(buf, DEVEUI, 8);} // This key should be in big endian format (or, since it is not really a // number but a block of memory, endianness does not really apply). In // practice, a key taken from loraserver can be copied as-is. static const u1_t PROGMEM APPKEY[16] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; // MSB mode void os_getDevKey (u1_t* buf) { memcpy_P(buf, APPKEY, 16);}
Note that the device EUI should be in little endian format. Hence, the key, 0badde1cafe2deca
should be written as 0xCA, 0xDE, 0xE2, 0xAF, 0x1C, 0xDE, 0xAD, 0x0B
in the Arduino sketch.
The LMIC library (see documentation) defines a set of events corresponding to the protocol machine state. These events appear in the onEvent()
function. For instance, the EV_TXCOMPLETE
event is called after the completion of a LoRa transmission.
The do_send
function enables to transmit data over LoRaWAN. After each transmission (EV_TXCOMPLETE
event) the next one is scheduled in a way to obtain periodic messaging. This period is defined by TX_INTERVAL
and is subject to duty cycle limitations.
Now you are ready to compile the sketch and upload it to the LoRaWAN device. Connect the device to a USB port on your PC, choose the board type (TTGO LoRa32
or T-Beam
from the ESP32 Arduino
category) and select the corresponding port. Compile and upload!
Open the serial monitor in the Arduino IDE at 115200 baud and analyse the debug messages.
Getting back to the backend, you can monitor some important information related to your device such as the activation status, frame counters, and live data.
mqtt.fx is a utility intended to help you with monitoring activity on MQTT topics. It has been designed to deal with high volumes of messages, as well as occasional publications.
You can use mqtt.fx to debug the messages received from the LoRaWAN devices. After starting the application, configure a new connection to the MQTT broker by simply adding the IP address of the broker and the user credentials. Now you can subscribe to any MQTT topic. If you want to receive all messages arriving at the backend, you can use the generic topic #
. You can also limit to the topic including the messages of any specific device: application/16/device/DEV_EUI/rx
.
The payload received by the MQTT client is decrypted but encoded in Base64. On the loraserver, we have activated a script that decodes the message before delivery.
If you need to send data to your device, you should publish an encoded message in the corresponding topic application/16/device/DEV_EUI/tx
as follows:
{"confirmed": false,"fPort": 10,"data": "aGVsbG8gSW9U"}
Note that the payload data sent by the MQTT client must be encoded in Base64. For this purpose, you can use the online tool at https://www.base64encode.org): for example, aGVsbG8gSW9U
is the Base64 encoding of Hello IoT
.