Skip to content

Skraelinger/AzureIoT_LoRaWan_StarterKit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

91 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Azure IoT Edge LoRaWAN Starter Kit

Experimental sample implementation of LoRaWAN components to connect LoRaWAN antenna gateway running IoT Edge directly with Azure IoT.

The goal of the project is to provide guidance and a reference for Azure IoT Edge users to experiment with LoRaWAN technology.

Background

LoRaWAN is a type of wireless wide-area networking that is designed to allow long-range communication at a low bit rate among low-power connected objects, such as sensors operated on a battery.

Network topology is of star-of-stars type, with the leaf sensors sending data to gateways for forwarding telemetry to and receiving commands from backing Internet services. Nowadays, even for simple scenarios like having 10 devices connected to a single LoRaWan gateway (hardware with antenna), you need to connect your gateway to a Network Server and then work through connectors provided by the server vendor to integrate your LoRa gateways and devices with the back end. These setups can be connected to Azure IoT Hub quite easily. As a matter of fact such scenarios exist. Customers looking for an operated network with national or international reach (e.g. fleet operators, logistics) will tend to choose this setup accepting the potentially higher complexity and dependency on the network operator.

However, customers looking for any of the following are expected to prefer a setup where the LoRaWAN network servers runs directly on the gateway/Azure IoT Edge:

  • Primarily coverage on their own ground (e.g. manufacturing plants, smart buildings, facilities, ports).
  • Capabilities that Azure IoT edge brings to the table:
    • Local processing on the gateway.
    • Offline capabilities of the gateway.
    • Gateway management.
  • Homogenous management of devices and gateways independent of connectivity technology.

Functionality

  • Support of Class A devices
  • Activation through ABP and OTAA
  • Confirmed and unconfirmed upstream messages
  • Confirmed downstream messages
  • Device and Gateway management done completely in Azure IoT Hub

Current limitations

  • Multigateway works but is not fully tested and you need to implement message deduplication after IoT Hub, if multiples gateways are used in the same range of the device we recommend setting the gateway tag "GatewayID" on the device twins with the IoT Edge ID of the preferred gateway for that device.

  • No Class B and C

  • No ADR

  • No Mac commands

  • Tested only for EU frequency

  • Max 51 bytes downstream payload, longer will be cut. It supports multiple messages with the fpending flag

  • IoT Edge must have internet connectivity, it can work for limited time offline if the device has previously transmitted an upstream message.

  • The network server Azure IoT Edge module and the Facade function have an API dependency on each other. its generally recommended for the deployments on the same source level.

  • In addition we generally recommend as read the Azure IoT Edge trouble shooting guide

Tested Gateway HW

Architecture

Architecture

Directory Structure

The code is organized into three sections:

  • LoRaEngine - a .NET Standard 2.0 solution with the following folders:
    • modules - Azure IoT Edge modules.
    • LoraKeysManagerFacade - An Azure function handling device provisioning (e.g. LoRa network join, OTAA) with Azure IoT Hub as persistence layer.
    • LoRaDevTools - library for dev tools (git submodule)
  • Arduino - Examples and references for LoRa Arduino based devices.
  • Template - Contain code useful for the "deploy to Azure button"

Reporting Security Issues

Security issues and bugs should be reported privately, via email, to the Microsoft Security Response Center (MSRC) at [email protected]. You should receive a response within 24 hours. If for some reason you do not, please follow up via email to ensure we received your original message. Further information, including the MSRC PGP key, can be found in the Security TechCenter.

Quick start

An Azure deployment template is available to deploy all the required Azure infrastructure and get you started quickly. If you'd rather deploy it manually please jump directly into the do it yourself section.

Prequisites

Currently, the template work only with ARM based gateways, like a Raspberry Pi, support for x86 will be added in a future release. (you could actually already deploy it for intel by following the instructions in the do it yourself section) The template was tested to work on the following gateway types:

The LoRa device demo code for Arduino is built only for Seeduino LoRaWan board and was not test with other Arduino LoRa boards.

Deployed Azure Infrastructure

The template will deploy in your Azure subscription the Following ressources:

Step-by-step instructions

  1. Press on the button here below to start your Azure Deployment.
  1. You will get to a page asking you to fill the following fields :
  • Resource Group - A logical "folder" where all the template resource would be put into, just choose a meaningful name.

  • Location - In which Datacenter the resources should be deployed.

  • Unique Solution Prefix - A string that would be used as prefix for all the resources name to ensure their uniqueness. Hence, avoid any standard prefix such as "lora" as it might already be in use and might make your deployment fail.

  • Edge gateway name - the name of your LoRa Gateway node in the IoT Hub.

  • Deploy Device - Do you want a demo end device to be already provisioned. If yes the code located in the Arduino folder would be ready to use immediately.

    The deployment would take c.a. 10 minutes to complete.

  1. During this time, you can proceed to install IoT Edge to your gateway.

  2. Once the Azure deployment is finished, connect your IoT Edge with the cloud as described in point 3. You can get the connection string by clicking on the deployed IoT Hub -> IoT Edge Devices -> Connection string, as shown in the picture below.

  3. If your gateway is a Raspberry Pi, don't forget to enable SPI , (You need to restart your pi).

By using the docker ps command, you should see the Edge containers being deployed on your local gateway. You can now try one of the samples in the Arduino folder to see LoRa messages being sent to the cloud.

What does the template do?

The template provision an IoT Hub with a packet forwarder and a network server module already preconfigured to work out of the box. As soon as you connect your IoT Edge device in point 4 above, those will be pushed on your device. You can find template definition and Edge deployment specification here.

LoRa Device provisioning

A LoRa device is a normal IoT Hub device with some specific device twin tags. You manage it like you would with any other IoT Hub device. To avoid caching issues you should not allow the device to join or send data before it is provisioned in IoT Hub. In case that you did plese follow the ClearCache proecedure that you find below.

ABP and OTAA provisioning

  • Login in to the Azure portal go to IoT Hub -> IoT devices -> Add

  • Use the DeviceEUI as DeviceID -> Save

  • Click on the newly created device

  • Click on Device Twin menu

  • Add the followings tags for OTAA:

"tags": {
    "AppEUI": "App EUI",
    "AppKey": "App Key",
    "GatewayID": "",
    "SensorDecoder": ""    
  },

The SensorDecoder tag is used to define which method will be use to decode the LoRa payload. If you leave it out or empty it will send the raw payload to IoT Hub. If you want to decode it on the Edge you need to specify a method that implements the right logic in the LoraDecoders class in the LoraDecoders.cs file of the LoRaWan.NetworkServer.

Or the followings tags for ABP:

DevAddr must be unique for every device! It is like an ip address for lora.

"tags": {
    "AppSKey": "Device AppSKey",
    "NwkSKey": "Device NwkSKey",
    "DevAddr": "Device Addr",
    "SensorDecoder": "",
    "GatewayID": ""
  },

It should look something like this for ABP:

{
  "deviceId": "BE7A00000000888F",
  "etag": "AAAAAAAAAAs=",
  "deviceEtag": "NzMzMTE3MTAz",
  "status": "enabled",
  "statusUpdateTime": "0001-01-01T00:00:00",
  "connectionState": "Disconnected",
  "lastActivityTime": "2018-08-06T15:16:32.0658492",
  "cloudToDeviceMessageCount": 0,
  "authenticationType": "sas",
  "x509Thumbprint": {
    "primaryThumbprint": null,
    "secondaryThumbprint": null
  },
  "version": 324,
  "tags": {
    "AppSKey": "2B7E151628AED2A6ABF7158809CF4F3C",
    "NwkSKey": "1B6E151628AED2A6ABF7158809CF4F2C",
    "DevAddr": "0028B9B9",
    "SensorDecoder": "",
    "GatewayID": ""
  },
  "properties": {
    "desired": {
      "$metadata": {
        "$lastUpdated": "2018-03-28T06:12:46.1007943Z"
      },
      "$version": 1
    },
    "reported": {
       "$metadata": {
        "$lastUpdated": "2018-08-06T15:16:32.2689851Z",
        "FCntUp": {
          "$lastUpdated": "2018-08-06T15:16:32.2689851Z"
        }
      },
      "$version": 313
    }
  }
}
  • Click Save
  • Turn on the device and you are ready to go

Cache Clearing

Due to the gateway caching the device information (tags) for 1 day, if the device tries to connect before you have provisioned it, it will not be able to connect because it will be considered a device for another LoRa network. To clear the cache and allow the device to connect follow these steps:

  • IoT Hub -> IoT Edge -> click on the device ID of your gateway
  • Click on LoRaWanNetworkSrvModule
  • Click Direct Method
  • Type "ClearCache" on Method Name
  • Click Invoke Method

Alternatively you can restart the Gateway or the LoRaWanNetworkSrvModule container.

Customize the solution & Deep dive

Have a look at the LoRaEngine folder for more in details explanation.

License

This repository is licensed with the MIT license.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published