Skip to content

yo1t/widemap

Widemap

Home / SOHO Network Security Monitor — Real-time visibility into every LAN device's outbound connections

Is your smart TV phoning home to unexpected servers? Are your IP cameras, IoT appliances, or NAS boxes making connections you never authorised? Widemap answers these questions by passively monitoring every outbound connection from every device on your LAN, then turning that data into an investigation workflow: Graph Map and Statistics for the big picture, Connection Log and Devices for drill-down analysis — with automatic threat detection.

No new hardware. No inline traffic interception. Works via your existing Yamaha RTX router's NAT session table.

License Node

🇯🇵 日本語版 README はこちら | 🌐 Project Page


For Home / SOHO Security

Modern home and SOHO networks run 20–40 devices: smart TVs, IP cameras, NAS drives, Wi-Fi speakers, printers, network switches, PCs, and smartphones. Many of these — especially IoT equipment — update infrequently and have unknown outbound behaviors. Any of them can be silently compromised and begin exfiltrating data or relaying traffic for a botnet.

Widemap answers the question most home users can't ask: what is each device on my network actually connecting to?

  • Passive, zero-impact monitoring — reads the router's NAT session table over SSH; no inline tap, no throughput penalty, no latency added
  • Per-device visibility — every connection tagged to the source device (vendor, model, hostname) via OUI, mDNS, SSDP, and NetBIOS
  • Automatic threat detection — every connection checked in real time against Feodo Tracker, ThreatFox, URLhaus, and Spamhaus DROP
  • Instant Slack alerts — DM the moment any device connects to a known C2 server or malware distribution host
  • No hardware changes — runs on any Mac, PC, or Raspberry Pi alongside your existing Yamaha RTX router

What it does

  • Connects to a Yamaha RTX router via SSH and reads the NAT session table every 60 seconds
  • [INSPECT] syslog supplement — tails the Yamaha syslog in real time to capture short-lived TCP sessions that complete within the 60-second polling gap
  • dnsmasq DNS query log — tails the EC2/server-side dnsmasq log to resolve destination IPs to meaningful domain names (e.g. example.com) per client device; forward DNS names take priority over PTR reverse lookups
  • [DHCPD] syslog tracking — tails Yamaha DHCP events (Allocates/Extends) for real-time IP→MAC mapping
  • Threat intelligence: matches all connections against Feodo Tracker, ThreatFox, URLhaus, and Spamhaus DROP feeds (auto-refreshed hourly)
  • Slack notifications: sends a DM when a threat is detected (configurable cooldown, language-aware)
  • Identifies local devices using OUI vendor lookup, mDNS/Bonjour, SSDP, NetBIOS, and an Apple model dictionary (resolves down to "iPhone 15 Pro")
  • Enriches each destination IP with reverse DNS, RDAP (organization name), and GeoIP (latitude/longitude/city)
  • Uses Graph Map and Statistics for whole-network overview, then Connection Log and Devices for per-session and per-device drill-down
  • Optionally connects to an ASUS WiFi access point (used as AP/mesh, not as a router) to get WiFi client details (band, signal strength, traffic rates, AiMesh topology)
  • Keeps a connection history in SQLite (WAL mode, crash-safe; configurable retention up to 2 years)
  • Connection log: sortable/searchable table of all sessions with threat status badges
  • 📡 Data Sources tab — configure each data source (dnsmasq / [INSPECT] / [DHCPD]) independently from the settings UI
  • Single-page dark-themed UI focused on Graph Map, Statistics, Connection Log, Devices, and Settings

Demo

widemap-redacted.mp4

UI language: English / Japanese selectable

Graph Map and Statistics give you the network-wide overview: device/destination patterns, session trends, and noisy endpoints — all updating in real time.

Connection Log and Devices let you drill down into suspicious destinations, noisy devices, beacon candidates, notes, and device history: see the pattern, filter the time range, inspect sessions, then pivot to the device.

Screenshots

Graph Map overview Statistics view Connection Log drill-down Devices drill-down

Architecture

┌─────────────────┐  SSH (NAT)  ┌──────────────────────┐
│  Yamaha RTX     │◄───────────►│                      │
│  [INSPECT] log  │  syslog/UDP │   Widemap Server     │  WebSocket
│  [DHCPD] log    │────────────►│   (Node.js)          │◄──────────► Browser
└─────────────────┘             │                      │
┌─────────────────┐  HTTP       │  Pollers:            │
│  ASUS WiFi AP   │◄───────────►│  • yamaha (SSH)      │
│  (Client list)  │             │  • asus (HTTP)       │
└─────────────────┘             │  • inspect-syslog    │
┌─────────────────┐  tail -F    │  • dhcpd-syslog      │
│  dnsmasq        │────────────►│  • dnsmasq-log       │
│  query log      │             └──────────┬───────────┘
└─────────────────┘                        │
                       ┌───────────────────┼───────────────┐
                       │                   │               │
                 ┌─────┴─────┐  ┌─────────┴───┐  ┌───────┴───┐
                 │ Enrichment│  │  Threat Intel│  │  SQLite   │
                 │ • dnsmasq │  │  • Feodo     │  │  History  │
                 │ • Rev DNS │  │  • ThreatFox │  │  (WAL)    │
                 │ • RDAP    │  │  • URLhaus   │  └───────────┘
                 │ • GeoIP   │  │  • DROP      │
                 │ • OUI     │  └─────────────┘
                 │ • mDNS    │
                 └───────────┘

Requirements

  • Node.js 18+
  • Yamaha RTX router with SSH access enabled (RTX1200, RTX1210, RTX1220, RTX1300, etc.)
  • (Optional) ASUS WiFi access point with web admin enabled (used as AP/mesh mode, not as a router)

Quick Start

Choose the shortest setup path

Start with the smallest path that matches your network, then add sources later from Settings.

Pattern Use this when What to configure first
Minimal: Yamaha RTX only You want the fastest first run with no extra hardware Yamaha IP, SSH username, SSH password, then Connect & Auto-detect
Recommended: Yamaha RTX + ASUS AP You also want WiFi client names, vendors, and MAC visibility Minimal setup, then ASUS AP IP and admin login
Detailed: + dnsmasq / INSPECT / DHCPD You want richer hostnames, short-lived TCP sessions, and live IP-to-MAC mapping Recommended setup, then enable Data Sources
Notifications: + Slack You want threat detections delivered by DM Any setup above, then Slack notifications

Step 1 — Prerequisites checklist

Requirement Setup guide
Node.js 18+ installed on your Mac/PC/Raspberry Pi nodejs.org
Yamaha RTX router with SSH enabled Setup guide →
(Optional) ASUS WiFi AP with web admin enabled Setup guide →

Step 2 — Install and launch

git clone https://github.com/yo1t/widemap.git
cd widemap
npm install
npm start

Step 3 — Open the browser and log in

On first startup, an initial login password is printed to the console:

══════════════════════════════════════════════════════════════
  Widemap login password (initial):
  KFpDqntYRfcr...
  → Log in with this password on first access
══════════════════════════════════════════════════════════════

Open http://localhost:3000 and enter the password. Each browser/device gets its own login session (30-day sliding expiry); you can review and revoke them — and change the password — in Settings → General.

Step 4 — Configure your router

Open the Settings panel (⚙) and enter your router details:

Field Where to find it
Yamaha RTX IP Your router's LAN IP (e.g. 192.168.1.1)
SSH username / password The login you set up in Yamaha setup guide
ASUS AP IP / password The AP's LAN IP and admin password (ASUS setup guide)

For the Yamaha RTX, click Connect & Auto-detect after entering the IP, username, and password. Widemap checks SSH access, detects the NAT descriptor (usually 100), finds the LAN IP when available, verifies that NAT sessions can be read, and fills the recommended setting before you save.

Within a few seconds, devices, sessions, and statistics will start appearing in the UI.

Note: Credentials are generated once on first startup and saved (hashed) in .widemap.json. If you lose the password, remove the auth section from .widemap.json and restart — a new initial password will be printed.

Authentication

All API endpoints and the WebSocket connection are protected. Two credentials exist:

Credential Purpose Where
Login password Browser login. Each device gets its own revocable session (30-day sliding expiry) Printed on first startup; change it in Settings → General
API token Scripts / automation (X-Admin-Token header) .widemap.json (adminToken); regenerate in Settings → General

Session management

  • Settings → General lists every logged-in device with last-activity time
  • Revoke a single device, or log out all other devices at once
  • Changing the password can optionally revoke all other sessions

If you lose the password

# Remove the auth section and restart — a new initial password is printed
node -e "const f='.widemap.json',c=require('./'+f);delete c.auth;require('fs').writeFileSync(f,JSON.stringify(c,null,2))"
npm start

How it works

  • Passwords are hashed with scrypt; sessions are stored as SHA-256 hashes in SQLite
  • Failed logins are delayed 500 ms; comparisons use crypto.timingSafeEqual
  • Session tokens ride the same X-Admin-Token header / Socket.IO handshake as the API token

HTTPS (optional)

By default Widemap serves plain HTTP. To enable HTTPS, add to .widemap.json and restart:

"https": { "enabled": true }

A self-signed certificate (.widemap-cert.pem / .widemap-key.pem, 10-year validity) is generated automatically via the openssl CLI — your browser will show a one-time warning to accept it. To use your own certificate instead:

"https": { "enabled": true, "certPath": "/path/to/cert.pem", "keyPath": "/path/to/key.pem" }

HTTPS is recommended if you use the login password from multiple devices, since it protects credentials and interface data from eavesdropping inside the LAN.

Configuration

All settings are stored in .widemap.json (auto-generated, gitignored). You can also use environment variables:

Variable Default Description
PORT 3000 HTTP server port
POLL_INTERVAL_MS 60000 ASUS polling interval (ms)
ROUTER_IP 192.168.1.1 Default ASUS router IP
YAMAHA_IP Yamaha RTX IP address
YAMAHA_USER Yamaha SSH username
YAMAHA_PASS Yamaha SSH password
YAMAHA_NAT 100 NAT descriptor number
SUBPATH Reverse proxy sub-path (e.g. /widemap)
WIDEMAP_DB .widemap.db Path to the SQLite database file
LOG_LEVEL info Log verbosity: error / warn / info / debug

Features

L3/L4: Yamaha RTX (NAT Session Monitoring)

  • Parses show nat descriptor address <N> detail output
  • Tracks TCP/UDP/ICMP/GRE sessions with source, destination, port, TTL
  • Auto-reconnects on SSH timeout or connection loss
  • TOFU (Trust On First Use) host key verification

L2: ASUS WiFi Access Point (Mesh-capable, Client Monitoring)

The ASUS device is used as a WiFi access point (AP mode or AiMesh), not as a router. Yamaha RTX handles all L3 routing and NAT. The ASUS AP provides L2 client visibility:

  • SHA256 challenge-response authentication
  • Client list with connection type (wired/2.4G/5G/6G), RSSI, traffic rates
  • AiMesh node discovery (multi-AP topology)
  • Auto token refresh

Device Identification

  • OUI database (Wireshark manuf, auto-downloaded weekly)
  • mDNS/Bonjour service discovery (100+ service types)
  • SSDP/UPnP device detection
  • NetBIOS name resolution
  • Apple model dictionary (200+ models: iPhone, iPad, Mac, Apple TV, HomePod, Apple Watch)
  • Auto-investigation mode: scans unknown devices in the background

Investigation Views

  • Graph Map: Whole-network topology overview for spotting unusual device/destination clusters
  • Statistics: Time-series charts and destination summaries for traffic trends
  • Connection Log: Full session table with threat indicators, sortable columns, and per-column search filters (text match, regex, date range)
  • Devices: Inventory view for drilling into device identity, notes, status, and history
  • Connection panel: Per-device list of active internet connections with org/country info
  • IPv4/IPv6 badges: Protocol detection per device via NDP cache polling

Threat Intelligence (C2/Botnet Detection)

  • Feodo Tracker: Emotet/Dridex/TrickBot C2 server IPs
  • ThreatFox: Malware IOC (IP:port)
  • URLhaus: Malware distribution URLs (with low-confidence handling for CDN domains like GitHub)
  • Spamhaus DROP: Hijacked IP ranges (CIDR)
  • Three confidence levels: 🚨 Detected (high) / ⚠️ Review (low — legitimate service) / ✅ Clear
  • Detailed threat popup with actionable guidance per confidence level
  • Auto-refresh feeds every hour (configurable)

Slack Notifications

  • Sends a Slack DM when a threat is detected
  • Configurable per-destination cooldown (default 1 hour) to prevent notification spam
  • Message language follows the UI language setting (English / Japanese)
  • Test-send button in settings to verify configuration
  • Requires a Slack Bot Token and your User ID (U01XXXXXXX) — set up via Settings → Threat Detection

Security

  • Admin token authentication (timing-safe comparison)
  • SSRF protection (private IP ranges only)
  • Socket.IO same-origin enforcement
  • SSH host key fingerprint verification (TOFU)
  • Config files stored with 0600 permissions
  • No passwords sent to browser (only boolean flags)

Supported Routers

Yamaha RTX (L3/L4)

Any model with SSH access and NAT descriptor support:

  • RTX1200, RTX1210, RTX1220, RTX1300
  • RTX810, RTX830
  • NVR500, NVR510, NVR700W

ASUS WiFi AP (L2, Mesh-capable)

Any model with the standard web admin interface, used in AP mode or AiMesh:

  • RT-AX series (AX86U, AX88U, AX92U, etc.)
  • RT-AC series
  • ZenWiFi (AiMesh)

License

Widemap is dual-licensed:

You may use, modify, and distribute Widemap under the AGPL-3.0. If you include Widemap or derivative works in a proprietary product, distribute it without source code, or provide a modified version as a network service, you must comply with the AGPL-3.0 source code obligations.

If you want to use Widemap in a proprietary or closed-source commercial product without releasing the corresponding source code under the AGPL-3.0, you must obtain a commercial license from the copyright holder.

Widemap — Real-time network connection visualizer
Copyright (C) 2025 Yoichi Takizawa

Source code: https://github.com/yo1t/widemap

Contributing

Issues and pull requests are welcome. Please open an issue first for major changes. See CONTRIBUTING.md for development setup and guidelines, ROADMAP.md for what's planned, and SECURITY.md for how to report vulnerabilities privately.

About

Real-time network connection visualizer for Yamaha RTX routers + ASUS WiFi APs

Resources

License

Contributing

Security policy

Stars

Watchers

Forks

Packages

 
 
 

Contributors