惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

www.infosecurity-magazine.com
www.infosecurity-magazine.com
Security Archives - TechRepublic
Security Archives - TechRepublic
TaoSecurity Blog
TaoSecurity Blog
Cloudbric
Cloudbric
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
N
News and Events Feed by Topic
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
S
Securelist
The Cloudflare Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
D
DataBreaches.Net
S
Schneier on Security
L
LangChain Blog
Jina AI
Jina AI
M
MIT News - Artificial intelligence
Recent Announcements
Recent Announcements
T
Tenable Blog
B
Blog RSS Feed
V
Visual Studio Blog
Simon Willison's Weblog
Simon Willison's Weblog
G
Google Developers Blog
T
The Exploit Database - CXSecurity.com
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
WordPress大学
WordPress大学
W
WeLiveSecurity
I
InfoQ
The Hacker News
The Hacker News
雷峰网
雷峰网
月光博客
月光博客
P
Privacy & Cybersecurity Law Blog
O
OpenAI News
Hacker News: Ask HN
Hacker News: Ask HN
T
Threat Research - Cisco Blogs
GbyAI
GbyAI
The Last Watchdog
The Last Watchdog
P
Privacy International News Feed
Cyberwarzone
Cyberwarzone
S
SegmentFault 最新的问题
L
Lohrmann on Cybersecurity
人人都是产品经理
人人都是产品经理
V
V2EX
V
Vulnerabilities – Threatpost
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
C
Cybersecurity and Infrastructure Security Agency CISA
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
T
Troy Hunt's Blog
Application and Cybersecurity Blog
Application and Cybersecurity Blog
阮一峰的网络日志
阮一峰的网络日志
SecWiki News
SecWiki News
Microsoft Azure Blog
Microsoft Azure Blog

Show HN

CSP Radar GitHub - awebai/aweb-team-coord-worktrees: An aweb team template for a minimum team with a permanent coordinator and worktrees with local developers. GitHub - fujibee/agmsg GitHub - lucastononro/notify: 100% local, free, offline attention skill for Claude Code: plays a sound and speaks a short status update when a long task finishes, blocks, or needs a decision. GitHub - sebastianwessel/skills: AI Skills tivatdoar / workout-to-work · GitLab GitHub - enumura1/py-sql-cleaner: Find, format, and safely extract embedded SQL from Python files. GitHub - intent-bench/intent-bench: Intent fulfillment benchmark for agentic AI engineering GitHub - steveking-gh/firmion: Firmion is DSL and engine for firmware image generation. GitHub - villagesql/villagesql-skills: Agent skills for VillageSQL - gemini-cli-extension; claude-code-plugin GitHub - 0gsd/enough: a personal language system for planning, writing, and translation. GitHub - Kaelio/ktx: ktx is an executable context layer for data and analytics agents 🐙 Allow Claude Code, Codex, and any AI agent to query data accurately through MCP with skills, memory and a semantic layer GitHub - ThatXliner/xtras: Xliner's Claude Code Skills GitHub - flightdeckhq/flightdeck: Observability and control plane for AI agents. GitHub - search-router/simple-search: Open-source reference app on top of the Search Router API: FastAPI + Jinja metasearch service with pluggable backends, deterministic mocks (no API key needed), RTL UI, Redis cache, and a demo ads cabinet. CSP Radar GitHub - Light-Heart-Labs/DreamServer: Turn your PC, Mac, or Linux box into an AI server. LLM inference, chat UI, voice, agents, workflows, RAG, and image generation. GitHub - Diplomat-ai/diplomat-agent-ts: What can your TypeScript AI agent do to the real world? Scan your code. See which tool calls have zero checks Code Block Selector - Visual Studio Marketplace Prometheus dependency graph — interactive showcase | Riftmap Show HN: I made a vi-like modal keyboard plugin for Figma GitHub - run-llama/liteparse: A fast, helpful, and open-source document parser GitHub - dalemyers/Roar: A macOS CLI tool for notifications GitHub - district-solutions/open-agent-tools-coder: Enables small-to-large self-hosted ai models to use local source code when running tool-calling agentic workloads. We actively data mine 20,900+ (2+ TB) popular github repos using large and small ai models to create reuseable: json, markdown and parquet files for local-first tool-calling models. GitHub - progapandist/stripeek: A local TUI proxy for real-time Stripe API debugging, built for navigating complex payloads fast. GitHub - sir1st/hermes-desktop: All-in-one cross-platform desktop app for Hermes Agent — bundles Python + hermes-agent + hermes-web-ui GitHub - astefanutti/shaderbang: Shebang for Shaders Show HN: Generate Claude Code Workflows using Spec Driven Development approach GitHub - nixys/nxs-universal-chart: The Helm chart you can use to install any of your applications into Kubernetes/OpenShift Show HN: AI agents for UK GDAD PCF roles and their skills The Two Pillars: Mixer Mode and Meta-Software in the Reorganization of Software Work After AI GitHub - JaiCode08/teleport-env What 1,000+ Harness Experiments Taught Me About Self-Improving Agents Show HN: Liiists, a Markdown-first, iOS and CLI list app SwiperTab – Get this Extension for 🦊 Firefox (en-US) GitHub - kouhxp/fftext: Summarize, explain, fact-check, or translate any text, URL, or file. No GPU. No cloud. One command GitHub - sweetpad-dev/sweetpad: Develop Swift/iOS projects using VSCode GitHub - dogmaticdev/IRON: IRON a.k.a. Intermediate Representation Object Notation is a Interpreter/Database that is used to create Programming Languages. GitHub - sjhalani7/vaen: Package your AI coding harness into a portable .agent file, and share it across repos, teams, & the community without ever having to copy-paste instructions, skills, MCP config, or secrets. Show HN: Gandalf the Grader Show HN: Citadeld – replay any CI failure locally from a single file GitHub - tdortman/cuSBF: High-Performance GPU Super Bloom Filter coral-ai/claude-code-token-xray at main · Coral-Bricks-AI/coral-ai GitHub - ulyssestenn/funes: Funes is a Git-based framework for LLM-managed knowledge work: an AI Librarian ingests raw sources, builds an interlinked Markdown knowledge base, and uses it to produce cited reports, analyses, and other outputs. GitHub - ThatXliner/gah: Git Add Hunk, built for agents to use GitHub - harmont-dev/harmont-cli: Command-line client for the Harmont CI platform GitHub - brooksmcmillin/mcp-authflow: OAuth 2.0 Authorization Server framework for MCP servers GitHub - javaid-codes/audit-supply-chain-agents GitHub - amorey/gochan: A small library of common channel architectures for Go, inspired by Rust GitHub - arifozgun/OpenGem: Free, Open-Source AI API Gateway with Gemini, OpenAI & Anthropic Compatibility in 1 file GitHub - Pranesh950/BioPetals: 🌸 Run BIOxAI models at home, BitTorrent-style. Fine-tuning and inference up to 10x faster than offloading GitHub - cnguyen14/bounty-doctor: Diagnose a GitHub bounty issue before you waste hours: detects honeypot scam repos, AI-bot attempt swarms, and stale contests. Show HN: CoreMCP – MCP Server for On-Prem DBs Show HN: KittyHTML – Render HTML/CSS as an inline image in your terminal GitHub - bingud/filemat: Web-based file manager Show HN: TruthLens – Free multi-signal deepfake image detector GitHub - apexlocal-jz/claude-usage-tray: Windows system-tray app showing your Claude Code rate-limit usage at a glance. Zero deps, ~300 lines of PowerShell. Cross-IDE (works regardless of VS Code, Cursor, plain terminal). Release v0.1.2.1 · kouhxp/yapsnap GitHub - noopolis/moltnet: Self-hostable chat network for AI agents. Pre-built bridges for Claude Code, Codex, and the Claws. Rooms, DMs, history. No Slack bots, no Matrix, no glue code. GitHub - tamerh/enju: Coordinating Humans, AI Agents, and Compute as Peers on a Shared Workflow Graph Show HN: Continuity-auth – Respect-weighted rate limits for the open web GitHub - luml-ai/luml: AI lifecycle platform where engineers and agents track experiments, train models, and ship to production. GitHub - mrdanielcasper/CoreTex: A UNIX-inspired, biomimetic, flat-file AI harness and knowledge engine. GitHub - clemg/pierre-github: Pierre's diffs.com and trees.software for Github GitHub - lyriks-io/unspaghettit: Behavior-driven AI development without prompt spaghetti. GitHub - sofumel/claude-handoff-revive: Resume Claude Code work after rate/usage/context limits without replaying the prior transcript. Auto-saves at 90%/95% usage. Plugin-installable, 10 languages. GitHub - dotexorg/saferpc: Typed, end-to-end encrypted RPC over any bidirectional channel. GitHub - BeeZeeAgent/beezee: Agent harness orchestration Legato Next.js Boilerplate for Internal Tools · CoreUI GitHub - clark-labs-inc/clark-hash: Clark Hash, 32x smaller searchable sketches for embeddings GitHub - ZeroPointRepo/youtube-mcp: The fastest YouTube transcript + YouTube search MCP for AI agents. Try for free. Typing Mastery — climb toward 100+ WPM, deliberately GitHub - Andebugulin/Awareen GitHub - fayzan123/claude-workflow-composer: Visual desktop app for composing multi-agent coding workflows. Drag agents, attach skills and MCPs, wire handoffs, export to .claude/ GitHub - StackOneHQ/stack-nudge We hardened an LLM agent. Each defense we added made it more exploitable. GitHub - alkait/WhatsKept: Agent-queryable WhatsApp history from an iOS backup — a single Go binary. GitHub - octelium/cordium: Open-source, general-purpose sandbox platform for devs and AI agents that provides identity-based secure access to infrastructure without credentials. GitHub - scosman/videowright: Build animated explainer videos with your coding agent GitHub - dipankar/dscode: The code editor you can take apart. GitHub - zoharbabin/web-researcher-mcp: MCP server (Go) for AI assistants: web search, content extraction, academic/patent/news research. Multi-provider routing, 4-tier scraping, search lenses. Works with Claude, Cursor, and any MCP client. GitHub - scanaislop/aislop: Catch the slop AI coding agents leave in your code: narrative comments, swallowed exceptions, as-any casts, dead code, oversized functions. 50+ rules across 7 languages (TypeScript, JavaScript, Python, Go, Rust, Ruby, PHP). Sub-second, deterministic, no LLM at runtime. MIT-licensed. GitHub - kouhxp/cheap-im: CPU-only voice agent approximating Thinking Machines' Interaction Models demo GitHub - unprovable/OrchidMantis: Orchid Mantis — standalone framework for Zero-Knowledge Proofs of eXploit (ZKPoX). GitHub - TangibleResearch/Halgorithem: A Algo designed to detect AI Hallucitions GitHub - CarpseDeam/Aura-IDE: An AI coding harness that shaped itself - Planner/Worker agents, repo awareness, surgical edits, validation, recovery, and safe diff approvals. GitHub - chojs23/concord: A feature-rich TUI client for Discord GitHub - aerf-spec/aerf: Agent Evidence Receipt Format (AERF) — an open specification for tamper-evident, independently verifiable records of AI agent actions. GitHub - Jwrede/tokentoll: Catch LLM cost changes in code review. Infracost for LLM spend. GitHub - samchon/ttsc: A `typescript-go` toolchain for compiler-powered plugins and type-safe execution + 500x faster lint integrated into compiler GitHub - Higangssh/homebutler: 🏠 Manage your homelab from chat. Single binary, zero dependencies. GitHub - olalie/tapmap: See where your computer connects and what stands out on a live world map. GitHub - Diplomat-ai/diplomat-agent: What can your AI agent do to the real world? Scan your code. See which tool calls have zero checks GitHub - Bajusz15/beacon: Open-source agent for secure remote access, monitoring, and deploys across home-lab and self-hosted machines like Raspberry Pi, N100, or any Linux server. Open web based TTY or tunnel Home Assistant and other local services securely without opening ports. BigTech AI News - Chrome 应用商店 GitHub - vinhnx/VTCode: VT Code is an open-source coding agent with LLM-native code understanding and robust shell safety. Supports multiple LLM providers with automatic failover and efficient context management. GitHub - Lumen-Labs/brainapi2: BrainAPI is a knowledge graph–powered AI memory layer that transforms unstructured data into structured knowledge, enabling intelligent search, recommendations, and contextual memory for AI agents and applications. GitHub - familiar-software/familiar: Let AI watch you work. Familiar lets your AI update its memory, skills, and knowledge by watching your screen. make sidebar/address bar rounded corner toggleable
GitHub - ossianericson/netsentinel: Network Security Scanner & Connectivity Monitor — rogue device detection, STP/BPDU, storm analysis, WiFi scanner, DNS logger, port scanner, MTR
ossianericso · 2026-06-19 · via Show HN

Version License Platform Microsoft Store winget Python Tests

The free, open-source network monitor that works with any router, modem, or access point — not just the brands it was built for. Runs 100% locally.

NetSentinel dashboard overview


Install

Windows — three options:

Get it from Microsoft

Or via winget (keeps the app updated automatically):

winget install NetSentinel.NetSentinel

macOS / Linux / manual Windows — download the binary for your platform from the latest release.

Windows notes

Layer 2 features (STP, broadcast storm, ARP monitor) require Npcap — free, one-click installer maintained by the Nmap project. Standard features work without it.

If Windows blocks the installer on first run, right-click the downloaded file → Properties → check UnblockOK, then run it. This does not apply to winget installs.

macOS notes

Note: Most features work on macOS. Gatekeeper bypass is required on first launch — right-click the app → Open.

Layer 2 features (STP, storm detection, ARP monitor) require libpcap:

Run with sudo to enable packet capture features. On Apple Silicon, ensure you are using a native arm64 Python build — x86_64 Python via Rosetta may have issues with Scapy and libpcap.

To run from source instead of the pre-built binary:

git clone https://github.com/ossianericson/netsentinel
cd netsentinel
pip install -r requirements.txt
sudo python app.py

Linux notes

Note: Tested on Ubuntu 22.04+ and Debian 12+.

Layer 2 features require libpcap:

sudo apt-get install libpcap-dev   # Debian/Ubuntu
sudo dnf install libpcap-devel     # Fedora/RHEL

If the app fails on launch with a Qt platform plugin error:

sudo apt-get install libxcb-cursor0
QT_QPA_PLATFORM=xcb sudo ./NetSentinel

To run from source instead of the pre-built binary:

git clone https://github.com/ossianericson/netsentinel
cd netsentinel
pip install -r requirements.txt
sudo python app.py

Why NetSentinel exists

Most home network problems require a different tool for each symptom — a CLI ping tool, a separate ARP scanner, a Wi-Fi analyzer, a traceroute utility, and whatever your ISP recommends this week. None of them produce evidence you can hand to a support technician. None of them talk to each other.

The specific incident that started this project: a Google Nest speaker connected via Ethernet was winning the STP root bridge election on the local network. Every 30–45 seconds it forced the actual router to block its own uplink port and reconverge — producing exactly the intermittent drops and DNS failures that ISP helpdesks dismiss as "Wi-Fi interference." Tracking it down required jumping between five separate tools and produced no shareable evidence.

NetSentinel handles discovery, Layer 2 detection, long-term logging, and report generation in one place. No account, no cloud, no telemetry. Free forever.

Replaces:

  • Nmap — device discovery, port scanning, OS fingerprinting
  • Wireshark — broadcast storm detection and ARP monitoring (simplified, read-only)
  • PingPlotter / MTR — hop-by-hop trace, stability logging, outage evidence
  • Wi-Fi analyzer apps — hidden SSIDs, rogue APs, co-channel interference, signal heatmap
  • Manual ISP support documentation — the ISP Accountability Report replaces the copy-paste grind

All analysis runs 100% locally. Nothing leaves your machine unless you explicitly trigger an external check.


Works with any hardware — open plugin protocol

Most network monitoring tools are locked to their own ecosystem. Ubiquiti works with UniFi. Synology works with Synology. If your hardware is not on the supported list, you are out of luck.

NetSentinel takes a different approach: an open plugin protocol that any Python script can implement.

The minimal interface is two constants and two required functions:

HARDWARE_NAME = "My Router XYZ"   # displayed in the app
HARDWARE_TYPE = "router"           # router | modem | ap | switch | other

def get_info()    -> dict   # static metadata: model, firmware, IP
def get_status()  -> dict   # live data: WAN IP, uptime, signal, speed

# Optional — if present, clients appear on the plugin's device page
def get_clients() -> list   # connected devices: ip, mac, hostname

Optional constants: HARDWARE_IP (target address), PYPI_PACKAGE (pip dependency name), CONFIG_SCHEMA (typed settings the Hub card auto-generates a config form for), ICON_PATH (24×24 icon shown on the Hub card).

Any .py file that satisfies the required interface becomes a first-class NetSentinel integration.

Bundled integrations

12 plugins ship with the app, all signed and hash-verified:

Plugin Hardware
zte_plugin.py ZTE MC889 5G modem (SINR, RSRP, band, cell ID)
deco_plugin.py TP-Link Deco XE75 mesh router (nodes, clients, topology)
asus_plugin.py ASUS routers and ZenWiFi mesh (via asusrouter library)
fritzbox_plugin.py AVM FRITZ!Box (DSL/cable, WAN IP, uptime, clients)
unifi_plugin.py Ubiquiti UniFi (via UniFi API; requires local controller)
netgear_plugin.py Netgear routers (Nighthawk, Orbi via SOAP API)
mikrotik_plugin.py MikroTik RouterOS (REST API; v7.1+)
openwrt_plugin.py OpenWrt (ubus JSON-RPC API)
synology_plugin.py Synology NAS (DSM API; connection stats, uptime)
ha_plugin.py Home Assistant (REST API; entity state and attributes)
template_plugin.py Starter template for writing a new plugin

How users create integrations

The Hardware Hub (Extend section in the nav) has a dedicated Write a Plugin tab that walks through the process:

  1. Find your hardware's API — GitHub search strings, Home Assistant integration library, and a five-step browser dev-tools workflow (F12 → Network tab → Copy as cURL) to capture the exact API calls your router admin panel makes
  2. Write the script — click "⬡ New Plugin" to open the template wizard; fill in hardware name, type, IP, and any pip dependencies; a complete .py file is generated and opened in your system editor
  3. Test and import — NetSentinel validates the plugin via AST (no code executed during validation), runs a live credential test in a background thread before registering, and executes subsequent polls in a sandboxed subprocess so a buggy script cannot crash the app
  4. Share — submit a working script as a GitHub Issue; reviewed scripts are merged as built-in integrations

The AI angle

An AI assistant (Claude, ChatGPT, Gemini) can write a working plugin for most hardware in about 10 minutes if you give it the right input. The Write a Plugin tab includes three copy-ready AI prompts:

  • Prompt A — general: "write a script for my Brand Model at 192.168.1.1, I need WAN IP, uptime, clients, and speed"
  • Prompt B — from cURL: paste the captured request from your browser dev tools and ask the AI to convert it to a full plugin (this produces the best results)
  • Prompt C — debug: paste a broken script and error message and ask the AI to fix it

Plugin ecosystem features

Every registered plugin gets a Hub card and a dedicated page under the Extend section. The full feature set:

Capability Notes
AST validation before import No code executed during validation; checks required constants and function signatures
Live credential test before registration Runs get_info() + get_status() in a background thread; only saves on success
Sandboxed subprocess execution Buggy polls cannot crash the app; each poll runs in an isolated namespace
Multi-instance support Same plugin type, multiple device IPs — each gets its own Hub card and nav entry
Per-instance OS keychain credentials Password stored under a unique instance ID; zero cross-instance key collisions
CONFIG_SCHEMA typed config panel Plugin declares poll_interval, verify_ssl, etc.; Hub card auto-generates the form
Health tracking + circuit breaker Success/error counters visible on each card; auto-disables after 10 consecutive errors; amber "degraded" state after 24 h without a successful poll
Structured error classification AUTH: / DEPS: / NET: / TIMEOUT: prefixes route to specific remediation text ("Re-enter Password", "pip install …", "Check IP")
Re-enter Password button Appears on AUTH errors; reopens the credential dialog and restarts the worker on success
Plugin log console "≡ Logs" toggle on each Hub card shows the last 100 structured poll log lines
Plugin validator CLI python -m modules.plugin_tools validate <plugin.py> — static checks for required interface, PYPI_PACKAGE, top-level network calls, and unsafe imports
Bundled plugin signing data/plugin_hashes.json SHA-256 list; tampered bundled files are blocked at load time
Unsigned plugin consent One-time SHA-256-keyed warning dialog for non-bundled scripts; consent persisted in QSettings
Restricted import advisory Warns when imports fall outside the safe-list; plugin can declare SAFE_IMPORTS to acknowledge custom dependencies
Plugin icon support icon.png alongside the script or ICON_PATH constant; displayed as 24×24 on Hub cards and community catalog entries
Plugin rename "✎" button renames the instance; change propagates atomically to nav flyout, breadcrumb, and command palette
Community Browse tab Fetches a GitHub-hosted JSON index; per-entry SHA-256 verified before download; Install button copies to AppData and runs the normal registration flow
.nspkg bundle format ZIP containing plugin.py + manifest.json + optional icon.png; "⬡ Import .nspkg" button in the Hub handles the full install flow
Startup dependency smoke-check Missing PYPI_PACKAGE dependencies surface as card errors immediately on startup

Quick start

  1. Install NetSentinel — see Install above
  2. On Windows, install Npcap if you want STP, broadcast storm, or ARP monitor features
  3. Run as Administrator — right-click the app → Run as Administrator on Windows; sudo python app.py on macOS/Linux
  4. Click Scan in the top bar to discover all devices on your network
  5. Open the Network Grade tab for an A–F assessment across 8 health dimensions

Features

Works without admin rights

Feature What it tells you
Device discovery Every device's IP, MAC, hostname, vendor, and model (e.g. "Google Nest Audio", "TP-Link Deco M5") with device type and risk level
Network grade A–F Benchmark across uptime, latency, jitter, DNS speed, download speed, device safety, STP health, and storm level vs. a "perfect home network" baseline
ISP Accountability Report MTR hop table, packet-loss %, DNS latency, and timestamped outage log formatted as a standalone HTML file for support escalation
Stability logger Runs unattended for hours or days — timestamped CSV log of every ping, DNS latency, and ARP change; evidence-grade output for ISP disputes
Availability history Persistent RTT and UP/DEGRADED/DOWN state charts per device with 1 h / 12 h / 24 h / 7 d zoom
DNS benchmarking Compares your system resolver against Cloudflare, Google, and Quad9 side-by-side; includes DNS leak test
Speed test 3-tier engine: Ookla CLI → speedtest-cli → pure-Python fallback with no extra dependencies
TLS certificate monitor Hourly expiry checks per host; alerts 30 days before expiry; OK / EXPIRING / EXPIRED badges
Active connections Process-to-socket map with one-click firewall block/unblock per process
Live bandwidth chart 60-second rolling upload/download chart per interface
CVE lookup Cross-references discovered OS and service versions against the NVD database on demand
Wi-Fi network scan Hidden SSIDs, rogue APs, WPS-enabled networks, co-channel interference, connected client list
IoT behaviour baseline Learns normal traffic per IoT device; alerts on port scans, new destinations, and traffic rate spikes
DHCP lease inventory Lists all active DHCP leases; flags any rogue DHCP server on the segment
Geolocation map Plots internet-facing IPs on an offline world map using MaxMind GeoLite2-City — no API key, no external calls
Topology diagram Visual topology diagram: flat star by default; upgrades to a three-tier mesh tree (Gateway → Satellites → Clients grouped by satellite) when Deco credentials are configured — devices invisible to the mesh attach directly to the gateway so nothing is dropped
Mesh router integration Pulls live data from your mesh gateway — Deco-assigned device names replace rDNS guesses in the Devices on Network table; Node and Band columns appear automatically; per-device upload/download rates from the router's own counters. Runs silently after each scan when credentials are saved. TP-Link Deco fully supported; architecture supports Eero, Google Nest, Asus ZenWiFi, Netgear Orbi
Hardware plugin protocol 12 bundled plugins included (TP-Link Deco, UniFi, FRITZ!Box, OpenWrt, MikroTik, Netgear, ASUS, Synology, Home Assistant, ZTE 5G modem). Import any router, modem, or AP via a Python script. Per-instance credentials, health tracking, circuit breaker, plugin log console, CONFIG_SCHEMA typed config, community Browse tab, and .nspkg bundle format all live. See Works with any hardware.
Automation hooks Webhook and script triggers on network events — device down, high RTT, new device discovered
REST API Read-only local HTTP API at http://127.0.0.1:8765 — query devices, alerts, and uptime from Home Assistant or scripts
"What's Wrong?" diagnosis One-click root-cause analysis across slow / dropping / can't-connect symptoms — sequences network, storm, rogue device, and STP checks then surfaces a prioritised plain-English finding
Shareable diagnostic card "Share Card" button on the Overview page — exports a 520×300 summary card (grade, ISP, top 3 findings) as PNG, clipboard image, or standalone HTML; zero external dependencies
Lab / Scenario Mode Four guided exercises — Find the Rogue Device, Diagnose Slow DNS, Identify the Broadcast Storm Source, Map Your Subnet — with progressive hints, solution reveal, and exportable HTML result report

Requires admin + Npcap (Windows) / libpcap (macOS, Linux)

Feature What it tells you
STP root bridge detection Identifies which device is claiming the root bridge via BPDU capture — the hidden cause of periodic 30–45 s reconnection drops
Broadcast storm detection Measures broadcast and multicast flood levels that silently choke bandwidth; pinpoints the source device
ARP spoofing detection Watches for MAC address conflicts that indicate a MITM attack in progress on the local segment
Per-device bandwidth monitor Exact rx/tx bps per device via live packet capture
SYN stealth port scanner Half-open TCP scan — faster and quieter than a connect scan; requires Scapy + admin
Full device discovery Parallel ARP + ICMP + TCP SYN + mDNS sweep for maximum device census accuracy

For educators and students

NetSentinel runs real scans against a live network, which means every result maps directly to a protocol or concept covered in CompTIA Network+ and CCNA curricula.

Concepts visible in real time:

  • ARP — the ARP Spoof Watch tab shows every ARP request and reply on the segment; the device table shows the current MAC-to-IP mapping your system holds
  • DNS — the DNS & Outages tab graphs resolver latency live; the DNS benchmarking tool compares four resolvers simultaneously; the DNS leak test shows exactly which resolver handles your queries
  • STP — the Rogue Bridge tab captures BPDUs and identifies the current root bridge, port roles, and reconvergence timing
  • TCP — the port scanner and Active Connections tab show three-way handshake outcomes (open/filtered/closed) and live socket states per process
  • DHCP — the DHCP Lease Inventory tab parses the OS lease table and flags any unauthorized DHCP server on the segment
  • ICMP — the Stability Logger and Availability History tabs plot round-trip times and packet loss across days or weeks
  • Layer 2 vs. Layer 3 — STP, ARP, and broadcast storm features operate at Layer 2 (MAC/frame); device discovery, DNS, and traceroute operate at Layer 3 (IP); each tab makes the distinction explicit

Built-in reference material:

  • Protocol Visualizer — animated step-by-step diagrams of ARP resolution, DNS lookup, TCP handshake, DHCP lease, and STP election using real scan data from your own network (not placeholder addresses)

Protocol Visualizer — animated packet trace

  • Lab / Scenario Mode — four guided exercises (Find the Rogue Device, Diagnose Slow DNS, Identify the Broadcast Storm Source, Map Your Subnet) with progressive hints, solution reveal, and exportable HTML result reports
  • IP and subnet calculator with reference panels explaining CIDR notation, subnetting rules, and address classes
  • 24-term networking glossary (ARP, BPDU, CGNAT, CVE, mDNS, STP, TLS, and more) — accessible via the help button from any page without leaving current context
  • In-app "Common Scenarios" lookup table mapping 17 user goals to the correct feature

If you use NetSentinel in a course or lab and need curriculum-specific features, open an issue — feedback from educators shapes the roadmap directly.


Quality

The project ships with 4,100+ automated tests across 230 test files, covering detection logic, metric storage, version consistency, UI wiring, encoding hygiene, and CodeQL-prevention gates. Run the full suite with:

python -m pytest tests/ -v --tb=short

All tests are offline — no real network traffic, no live devices required.


Architecture

The short version: app.py is the GUI entry point; cli.py is the headless CLI; all detection logic is in modules/; UI pages are in ui/pages/; background threads are in workers/. All colour and style values live in ui/styles.py — no hex values appear elsewhere in the UI code.

ui/dashboard.py is the main window shell (1,967 lines). Its functionality is split across six inherited mixins: ScanResultMixin (scan_wiring.py), AppHeaderMixin (header.py), TabBuilderMixin (tabs.py), _NavBuilderMixin (nav/builder.py), _MonitorStateMixin (monitor_state.py), and _PluginPageMixin (plugin_page_mixin.py).


Contributing

See CONTRIBUTING.md for the development setup, coding conventions, and PR process.

Hardware plugins (no coding required beyond Python)

12 plugins ship with the app (see Bundled integrations above). If your hardware is not on that list, the highest-value contribution is a working plugin script. Use the Write a Plugin tab in the Hardware Hub — the in-app guide, template wizard ("⬡ New Plugin"), and AI prompts get most people to a working script in under 30 minutes.

To submit: open a GitHub Issue titled [Hardware Plugin] Brand Model XYZ, attach the .py file, describe what get_status() returns, and list any pip install dependencies. Reviewed scripts are signed, added to data/plugin_hashes.json, and merged as built-in integrations.

Template for the issue:

Hardware: Brand Model XYZ
Firmware tested: vX.Y.Z
Access method: HTTP REST / HTML scrape / SNMP / SSH
pip dependencies: requests, beautifulsoup4   (or none)
get_status() returns: wan_ip, uptime_sec, connected_clients, download_mbps, upload_mbps

[attach your .py file]

Rogue device signatures (edit a JSON file, no Python needed)

To flag a device that misbehaves on home networks, edit offenders.json and submit a pull request:

{
  "vendor": "Your Device Brand",
  "ouis": ["aa:bb:cc"],
  "known_issues": ["STP BPDU injection — claims Root Bridge via Ethernet"],
  "risk_level": "HIGH",
  "forum_reference": "https://...",
  "remediation": "Disconnect its Ethernet cable and use Wi-Fi backhaul only."
}

Privacy

No telemetry. No cloud. No accounts. All scanning and analysis runs on your machine.

The only external endpoints contacted are ones you explicitly trigger:

Endpoint Purpose
speed.cloudflare.com Download speed test
services.nvd.nist.gov CVE lookup (Security Audit mode, on demand)
bash.ws DNS leak test
api.github.com Update check on startup

All other analysis — device discovery, ARP monitoring, STP detection, bandwidth logging, availability tracking — is local.


Changelog

See CHANGELOG.md for the full release history.

v2.1.12 (current)

Added

  • Status-icon shape constants (STATUS_ICON_OK/WARN/CRIT/UNKNOWN) in ui/styles.py — status no longer conveyed by colour alone in service heartbeat, uptime, and monitor verdict displays
  • In-app feedback dialog (ui/widgets/feedback_dialog.py) — writes timestamped entries to feedback.log locally; no network calls; accessible via Ctrl+K "Give Feedback"
  • Nav timing warnings and cProfile page-init instrumentation (ui/perf_audit.py)
  • Focus rings on activity-rail buttons and flyout items for keyboard navigation

Fixed

  • Stripped UTF-8 BOM from ui/nav/rail.py that caused silent SyntaxError in ast.parse-based test checks
  • test_no_duplicate_methods.py now correctly exempts @pyqtProperty getter/setter pairs

About

NetSentinel — Network Security Scanner & Connectivity Monitor

NetSentinel will always remain free and open source.

If you find this tool valuable, please consider supporting:

Thank you for using NetSentinel.

Disclaimer: For use on networks you own or have explicit authorization to test.

Built by Ossian Ericson · GitHub


License

MIT — see LICENSE.