Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/tobozo/ESP32-BLECollector

ᛡᛒ BLE Scanner + Data persistence on SD Card for M5Stack, M5Core2, Odroid-Go, ESP32-Wrover-Kit and other models
https://github.com/tobozo/ESP32-BLECollector

arduino ble ble-scanner blescan blescanner bluetooth esp-wrover-kit esp32 esp32-chimera-core esp32-wrover ili9341 low-energy m5stack m5stack-sd-updater odroid-go scanner sd-card sqlite3 sqlite3-database st7789

Last synced: 2 months ago
JSON representation

ᛡᛒ BLE Scanner + Data persistence on SD Card for M5Stack, M5Core2, Odroid-Go, ESP32-Wrover-Kit and other models

Lists

README

        

# ESP32-BLECollector

[![Join the chat at https://gitter.im/ESP32-BLECollector/ESP32-BLECollector](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/ESP32-BLECollector/ESP32-BLECollector)
[![Build Status](https://travis-ci.com/tobozo/ESP32-BLECollector.svg?branch=master)](https://travis-ci.com/github/tobozo/ESP32-BLECollector)

A BLE Scanner with persistence.

![ESP32 BLECollector running on Wrover-Kit](https://user-images.githubusercontent.com/1893754/81865372-1b965680-956e-11ea-9f2d-448c2330f3d3.png) ![ESP32 BLECollector running on M5Stack](https://raw.githubusercontent.com/tobozo/ESP32-BLECollector/unstable/screenshots/BLECollector-M5Stack.jpeg)

🎬 [Demo video](https://youtu.be/w5V80PobVWs)
------------

BLECollector is just a passive BLE scanner with a fancy UI.
All BLE data found by the BLE Scanner is collected into a [sqlite3](https://github.com/siara-cc/esp32_arduino_sqlite3_lib) format on the SD Card.

Public Mac addresses are compared against [OUI list](https://code.wireshark.org/review/gitweb?p=wireshark.git;a=blob_plain;f=manuf), while Vendor names are compared against [BLE Device list](https://www.bluetooth.com/specifications/assigned-numbers/company-identifiers).

Those two database files are provided in a db format ([mac-oui-light.db](https://github.com/tobozo/ESP32-BLECollector/blob/master/SD/mac-oui-light.db) and [ble-oui.db](https://github.com/tobozo/ESP32-BLECollector/blob/master/SD/ble-oui.db)).

On first run, a default `blemacs.db` file is created, this is where BLE data will be stored.
When a BLE device is found by the scanner, it is populated with the matching oui/vendor name (if any) and eventually inserted in the `blemasc.db` file.

⚠️ This sketch is big! Use the "No OTA (Large Apps)" or "Minimal SPIFFS (Large APPS with OTA)" partition scheme to compile it.
The memory cost of using sqlite and BLE libraries is quite high.

⚠️ Builds using ESP32-Wrover can eventually choose the 3.6MB SPIFFS partition scheme, and have the BLECollector working without the SD Card. Experimental support only since SPIFFS tends to get slower and buggy when the partition becomes full.

Hardware requirements
---------------------
- [mandatory] ESP32-Wroom or ESP32-Wrover (Wrover is recommended)
- [mandatory] SD Card (breakout or bundled in Wrover-Kit, M5Stack, Odroid-Go, LoLinD32 Pro)
- [mandatory] Micro SD (FAT32 formatted, **max 4GB**)
- [mandatory] [mac-oui-light.db](https://github.com/tobozo/ESP32-BLECollector/blob/master/SD/mac-oui-light.db) and [ble-oui.db](https://github.com/tobozo/ESP32-BLECollector/blob/master/SD/ble-oui.db) files copied on the Micro SD Card root
- [mandatory] ST7789/ILI9341 320x240 TFT (or bundled in Wrover-Kit, M5Stack, Odroid-Go, LoLinD32 Pro, D-Duino32-XS)
- [optional] (but recommended) I2C RTC Module (see `#define HAS_EXTERNAL_RTC` in Settings.h)
- [optional] Serial GPS Module (see `#define HAS_GPS` in Settings.h)
- [⚠ NEW][optional] [XPad Buttons Shield](https://www.tindie.com/products/deshipu/x-pad-buttons-shield-for-d1-mini-version-60/) from [Radomir Dopieralski](https://github.com/deshipu)

Software requirements (updated)
---------------------
- [mandatory] Arduino IDE
- [mandatory] [ESP32-Chimera-Core](https://github.com/tobozo/ESP32-Chimera-Core/) (get it from the Arduino Library Manager)
- [mandatory] [LovyanGFX](https://github.com/Lovyan03/LovyanGFX/) (get it from the Arduino Library Manager)
- [mandatory] [M5Stack-SD-Updater](https://github.com/tobozo/M5Stack-SD-Updater) (get it from the Arduino Library Manager)
- [mandatory] [NimBLE Library](https://github.com/h2zero/NimBLE-Arduino/archive/master.zip) supersedes the BLE (legacy or custom) library versions, install it manually in the Arduino/Libraries folder.
- [mandatory] [PaulStoffregen's Time library](https://github.com/PaulStoffregen/Time) (get it from the Arduino Library Manager)
- [mandatory] [esp32_arduino_sqlite3_lib](https://github.com/siara-cc/esp32_arduino_sqlite3_lib) (get it from the Arduino Library Manager)
- [optional] [TinyGPSPlus](https://github.com/mikalhart/TinyGPSPlus)

Behaviours (auto-selected except for WiFi):
---------------------------
- **Hobo**: when no TinyRTC module exists in your build, only uptime will be displayed
- **Rogue**: TinyRTC module adjusted after flashing (build DateTime), shares time over BLE
- **Chronomaniac**: TinyRTC module adjusts itself via GPS, shares time over BLE
- **With WiFi**: Temporary dual BLE/WiFi mode to allow downloading or serving .db files, see `#define WITH_WIFI` in `Settings.h`

Optional I2C RTC Module requirements
------------------------------------
- Wire your TinyRTC to RTC_SDA/RTC_SCL (see `Settings.h` or `Display.h` to override)
- Insert the SD Card
- Set `#define HAS_EXTERNAL_RTC true` in [Settings.h](https://github.com/tobozo/ESP32-BLECollector/blob/master/Settings.h)
- Flash the ESP with partition scheme `Minimal SPIFFS (Large APPS with OTA)`

Optional Serial GPS Module requirements
---------------------------------------
- Wire your GPS module to TX1/RX1 (edit `GPS_RX` and `GPS_TX` in GPS.h
- Set `#define HAS_GPS true` in [Settings.h](https://github.com/tobozo/ESP32-BLECollector/blob/master/Settings.h)
- Flash the ESP with partition scheme `Minimal SPIFFS (Large APPS with OTA)`
- Wait for the GPS to find a fix
- issue the command `gpstime` in the serial console

Optional XPad Buttons Shield requirements
-----------------------------------------
- Wire your XPad Buttons Shield to XPAD_SDA/XPAD_SCL (see `HID_XPad.h` to override)
- Enable the module in `Display.h` : `#define hasXPaxShield() (bool) true`
- Controls are:
- Down / Up : brightness
- Right / Left : unassigned (yet)
- A : start/stop scan
- B / C : toggle mac filter
- D : unassigned (yet)

Time Sharing
------------
- Once the time is set using RTC, GPS or NTP, the BLECollector may start the TimeSharing service and advertise a DateTime characteristic for other BLECollectors to sync with.
- Builds with no RTC/GPS will try to identify this service during their scan duty cycle and subscribe for notifications.

File Downloading (still experimental)
------------

Sending the `DownloadDB` command will:

- Stop BLE
- Start WiFi
- Synchronize time to a nearby NTP server
- Download the latest oui/vendors database from github

Serial command interface
------------

Available Commands:

01) help : Print this list
02) halp : Same as help except it doesn't print anything
03) start : Start/resume scan
04) stop : Stop scan
05) toggleFilter : Toggle vendor filter on the TFT (persistent)
06) toggleEcho : Toggle BLECards in the Serial Console (persistent)
07) setTimeZone : Set the timezone for next NTP Sync (persistent)
08) setSummerTime : Toggle CEST / CET for next NTP Sync (persistent)
09) dump : Dump returning BLE devices to the display and updates DB
10) setBrightness : Set brightness to [value] (0-255) (persistent)
11) ls : Show [dir] Content on the SD
12) rm : Delete [file] from the SD
13) restart : Restart BLECollector ('restart now' to skip replication)
14) screenshot : Make a screenshot and save it on the SD
15) screenshow : Show screenshot
16) toggle : toggle a bool value
17) resetDB : Hard Reset DB + forced restart
18) pruneDB : Soft Reset DB without restarting (hopefully)
19) bleclock : Broadcast time to another BLE Device (implicit)
20) bletime : Get time from another BLE Device (explicit)
21) gpstime : Sync time from GPS
22) latlng : Print the GPS lat/lng
23) stopBLE : Stop BLE (use 'restart' command to re-enable)
24) startWiFi : Start WiFi (will stop BLE)
25) setPoolZone : Set NTP Pool Zone for next NTP Sync (persistent)
26) NTPSync : Update time from NTP (will start WiFi)
27) DownloadDB : Download or update db files (will start WiFi and update NTP first)
28) setWiFiSSID : Set WiFi SSID
29) setWiFiPASS : Set WiFi Password

Contributions are welcome :-)

Known issues / Roadmap
----------------------

Implementing both [LovyanGFX](https://github.com/lovyan03/LovyanGFX) and [Nimble-Arduino](https://github.com/h2zero/NimBLE-Arduino) was such a huge optimization that none of the previous blockers exist any more!

Some ideas I'll try to implement in the upcoming changes:

- Add GPS Coords to entries for better pruning [as suggested by /u/playaspect](https://www.reddit.com/r/esp8266/comments/9s594c/esp32blecollector_ble_scanner_data_persistence_on/e8nipr6/?context=3)
- Better Analysis of ServiceData (see @reelyactive's [advlib](https://github.com/reelyactive/advlib))
- Extended logging (SDCard-less meshed builds)

Other ESP32 security related tools:
-----------------------------------

- https://github.com/cyberman54/ESP32-Paxcounter
- https://github.com/G4lile0/ESP32-WiFi-Hash-Monster
- https://github.com/justcallmekoko/ESP32Marauder

Credits/requirements:
---------------------

- @Lovyan03 for integrating his [LovyanGFX](https://github.com/lovyan03/LovyanGFX) into the [ESP32-Chimera-Core](https://github.com/tobozo/ESP32-Chimera-Core/tree/lgfx_test) thus saving an enormous amount of sram and flash space
- @h2zero for sharing [NimBLE Library](https://github.com/h2zero/NimBLE-Arduino/) and brillantly proving that BLE can work with WiFi on Arduino without eating all sram/flash space
- https://github.com/siara-cc/esp32_arduino_sqlite3_lib
- huge thanks to https://github.com/chegewara for maintaining the initial [BLE library](https://github.com/tobozo/ESP32-BLECollector/releases/download/1.2/BLE.zip) that made this project possible