Files
esp32-web/TASKS.md
user 2456194332 docs: Clean up stale docs, add CHANGELOG
- Remove completed items from TODO.md (OSINT, fleet, collector done)
- Move TASKS.md sprint to v0.1.4, archive v0.1.3 as complete
- Create CHANGELOG.md covering v0.1.0 through v0.1.3
2026-02-05 23:54:52 +01:00

1.9 KiB

ESP32-Web Tasks

Last Updated: 2026-02-05

Current Sprint: v0.1.4 — Zones & Presence

P1 - High

  • Zone model (name, description, location)
  • POST /api/v1/zones — create zone
  • GET /api/v1/zones — list zones
  • PUT /api/v1/zones/<id> — update zone
  • Assign sensors to zones

P2 - Normal

  • Device zone tracking (which zone a device is in)
  • Dwell time analysis
  • Presence history endpoint

P3 - Low (carried from v0.1.3)

  • Add pagination to all list endpoints
  • Add request logging middleware

Completed: v0.1.3 — Fleet Management

  • GET /api/v1/sensors/<id>/config — read sensor config
  • PUT /api/v1/sensors/<id>/config — update sensor config
  • POST /api/v1/sensors/<id>/ota — trigger OTA update
  • POST /api/v1/sensors/<id>/calibrate — trigger calibration
  • Sensor heartbeat timeout detection
  • Sensor metrics history endpoint
  • OpenAPI 3.0 spec with Swagger UI

Completed: v0.1.2 — OSINT Features

  • IEEE OUI database download (make oui)
  • MAC vendor lookup utility
  • BLE company_id mapping (30+ vendors)
  • Device profile enrichment in API
  • Export endpoints (devices.csv, devices.json, alerts.csv, probes.csv)
  • Auto-populate vendor on device creation

Completed: v0.1.1 — Server Management

  • Makefile start/stop/restart/status commands
  • Health endpoint with uptime tracking
  • CLI module (esp32-web command)
  • Initial database migration
  • Listen on all interfaces (0.0.0.0:5500)

Completed: v0.1.0 — Project Scaffold

  • Flask app factory pattern
  • SQLAlchemy 2.x models
  • API blueprint with endpoints
  • UDP collector with parsers
  • pytest fixtures and tests
  • Containerfile for podman
  • Makefile for common tasks

Notes

  • Sensors send data to UDP 5500
  • API listens on TCP 5500
  • Commands sent to sensors on UDP 5501
  • SQLite for dev, PostgreSQL for prod