Skip to main content

Jumper GATT proxy for logging BLE traffic

Project description

# Jumper BLE Logger ## Introduction The BLE Logger is part of Jumper Insights- a full visibility platform for IoT systems. The BLE Logger is a process that runs on Linux gateways and logs data from BLE devices that are connected to the gateway via BLE and are using the [Jumper uLogger](https://github.com/Jumperr-labs/jumper-ulogger).

## Prerequisites Gateway:

  • Linux based device as a central BLE device

  • Python2.7 and Pip installed

  • LE connection to the BLE peripheral

Peripherals

  • Jumper’s uLogger should be installed

  • BLE - Currently, only GATT protocol is supported.

## Installation
  • Install prerequisits: - gatttool (Ubuntu: sudo apt-get install bluez) - pip (Ubuntu: sudo apt install python-pip python-dev) - libffi-dev and libssl-dev (Ubuntu: sudo apt-get install libffi-dev libssl-dev)

  • Install the logger: sudo -H pip install jumper-ble-logger

## Getting Started Check out our [sample project for the Nordic nRF52 development kit](https://github.com/Jumperr-labs/jumper-ulogger/tree/master/samples/nrf52-ble-sample-project).

## Usage - Make sure Jumper’s Logging Agent is running sudo service jumper-agent start - Modify _”/etc/jumper_ble_logger/events_config.json”_ to create new types of events if needed - Run hciconfig and check your current available HCI devices - Start the BLE Logger: sudo service jumper-ble start - Run hciconfig again to see your newly created HCI device - Start your gateway program as usual. Make sure to connect to the newly created HCI device. The BLE Logger will start logging as soon as you connect to a peripheral and discover its characteristics.

## How it Works If you just want to get started, feel free to skip this step

When the BLE Logger is started, it will connect to your current HCI device (usually “hci0”) and will create a new proxied HCI device (usually “hci1”) which you will set your gateway program to connect to.

The new “hci1” device can be used just like the original “hci0”, as all commands and events will transparently pass on to it. When logging notifications are received from the peripheral, the BLE Logger will send them to Jumper’s Logging Agent and will not pass them on to “hci1” (gateway program).

This is the process of how it works (GATT only):

  1. The BLE Logger recognizes established LE connections.

  2. When the gateway program is discovering characteristics, the BLE Logger recognizes Jumper’s GATT service.

  3. The BLE Logger reads the current timestamp from the device and synchronizes it with the real world time.

  4. The BLE Logger writes to the notifications handle to enable logging notifications.

  5. When a logging notification is being received, the BLE Logger will write it to the Logging Agent.

The user/gateway program is not being affected by steps 3-4 and they are being filtered out from ‘hci1’

## Troubleshooting Check out the following files for logs: - /var/log/jumper-ble.err - /var/log/jumper-ble.log - /var/log/jumper-agent.err - /var/log/jumper-agent.log

## Contact Us We are happy to help! Feel free to contact us about any issue and give us your feedback at [info@jumper.io](mailto:info@jumper.io)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jumper-ble-logger-0.1.3.tar.gz (22.0 kB view details)

Uploaded Source

File details

Details for the file jumper-ble-logger-0.1.3.tar.gz.

File metadata

File hashes

Hashes for jumper-ble-logger-0.1.3.tar.gz
Algorithm Hash digest
SHA256 2500c39fa03d1d771cbd41926bb4d049dd101a6da90d5d7c9ad3f4e2a7b81136
MD5 44c44b5e009c2e272b441ecdab897876
BLAKE2b-256 0e891ca091c716d16fb069d7a8c4ecc9fe3ba7f9c580a202a87a73168a4419e4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page