Core Component, handles delivery, acknowledgements and more
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
cheetah.cat f6f376f268 added tetracontrol support 9 months ago
boskrypt added BOSKrypt support 4 years ago
examples/bash changed some examle 2 years ago
html fixed typo in cfg interface 2 years ago
html_config added tetracontrol support 9 months ago
html_main optimized paths 2 years ago
types added tetracontrol support 9 months ago
.gitignore gitignore 4 years ago
README.md updated readme 2 years ago
config.json added tetracontrol support 9 months ago
index.js added tetracontrol support 9 months ago
package.json fixed some vulns in the packages 2 years ago
ttnv3.uplink.birdyslim.js added birdy slim payloadformatter 2 years ago

README.md

dispatcher-daemon

Workflow

Features Working rn:

  • Duplex and Simplex Processing
  • DAPNET integration
  • Cityruf and 2wayS integration
  • Configuration WebInterface (:3001)
  • API Test WebInterface (:3000) image

Features in W.I.P:

  • LoRaWAN progress 70%
  • POCSAG only TX , no RX path
  • Still missing a RX path and processing (Message gets passed along every Device Class, which then tries to parse it, if successfull it breaks the processing loop and the Device Class handles decoding+status handling for delivery)

Planned:

  • WebSocket Live Routing Status
  • more DeviceStats (when LoRaWAN, store Distance to nearest/latest LoRaWAN Gateway of TTN)

API Server running on Port 3000

API Calls:

| GET /api/message/ack/recv/<id> - marks a Message as Delivered

| GET /api/message/status/<id> - fetches the current Message Data(DeliveryLog, Payload, etc.)

| GET /api/device/: - Lists all Device IDs

| GET /api/device/<DeviceType>:<ID> - Returns the Device State.

Example:

/api/device/birdyslim:test333

{
  "lastSeen": "2021-03-30T10:01:24.988Z",
  "rssi": 34,
  "lastLoRaPacket": {
    "end_device_ids": {
      "device_id": "test333",
      "application_ids": {
        "application_id": "birdy-slim-iot"
      }
    },
    "correlation_ids": [ ... ],
    "received_at": "2021-03-30T10:01:24.988088037Z",
    "uplink_message": {
      "f_port": 5,
      "frm_payload": "AB4z1wBKLDEQ",
      "decoded_payload": {
        "lastGPSAcquisition": 16,
        "latitude": 19.79351,
        "longitude": 48.60977,
        "type": "gps"
      },
      "settings": {
        "data_rate": {}
      },
      "received_at": "0001-01-01T00:00:00Z"
    },
    "simulated": true
  },
  "gps": {
    "gps": {
      "lastGPSAcquisition": 16,
      "latitude": 19.79351,
      "longitude": 48.60977
    }
  }
}

| POST /api/message/advanced - Creates a new Message and starts delivering it, returns the Message ID. HTTP Body is a JSON Object. for example:

{
    "type": "duplex",
    "routing": {
        "device": "birdyslim",
        "connectors": [
            [ "dummy", "fail" ],
            [ "pocsag", "133701D" ],
            [ "dummy", "works" ]
        ]
    },
    "payload": "Testbericht"
}