High-performance network discovery and subnet analysis suite with native Rust speed.
Project description
⚡ NetPulse
NetPulse is a high-performance, modern network discovery and analysis suite. It marries the speed and safety of low-level Rust raw-socket packet crafting with the developer ergonomics of Python, FastAPI, and Typer.
Designed as a modern monorepo, NetPulse is optimized for rapid Layer 2 (ARP) and Layer 3 (ICMP) network sweeps.
📐 System Architecture
NetPulse is structured as a modular monorepo that separates high-speed systems execution (Rust) from orchestration, validation, and delivery interfaces (CLI, REST API).
graph TD
A[Client Interfaces] --> B[CLI: apps/cli]
A --> C[REST API: apps/api]
B --> D[Core Service: packages/core]
C --> D
D --> E[Engine Interface: packages/engine]
E --> F[Rust Core Extension: rust/src/lib.rs]
F -->|Raw L2 ARP Frames| G[Network Interface Card]
F -->|Raw L3 ICMP Sweeps| G
📂 Monorepo Layout
| Component Path | Language | Description |
|---|---|---|
rust/ |
Rust | High-speed native core utilizing raw sockets (pnet, socket2) for ARP framing and ICMP sweeps. |
packages/core/ |
Python | Central orchestration layer (netpulse_core). Defines domain Pydantic V2 models, handles service coordination, and powers the Subnetting & VLSM calculation engine. |
packages/engine/ |
Python | Loader package (netpulse_engine) exposing compiled Rust bindings to Python, featuring a zero-privilege mock fallback. |
apps/cli/ |
Python | Premium CLI tool (netpulse_cli) powered by Typer and Rich for beautiful terminal data representation. |
apps/api/ |
Python | Production-ready FastAPI service (netpulse_api) featuring custom rate-limiters, security headers, and CORS restrictions. |
tests/ |
Python | Complete automated test suite verifying models, mock engine interfaces, CLI, and API layers. |
🔒 Security & Elevated Privileges
Because L2 ARP (ethernet frames) and L3 ICMP (ping) sweeps open and read from raw network sockets, they require systems-level privileges under Linux.
🛡️ Local Testing (Mock Mode)
To build and test NetPulse locally without needing root privileges, you can activate Forced Mock Mode by exporting the environment variable:
export NETPULSE_MOCK=1
In mock mode, the Python engine will bypass the Rust raw socket layer and return simulated subnets instantly, preserving full layout, validation, and API testing capabilities.
⚡ Running in Native Production Mode
When executing real scans on a network interface card, you must provide the python interpreter with standard Linux network capabilities or run with superuser rights:
- Option A (Recommended): Grant capabilities to the virtualenv Python binary
sudo setcap cap_net_raw,cap_net_admin+eip $(readlink -f .venv/bin/python)
- Option B: Execute via superuser (
sudo)sudo .venv/bin/python apps/cli/netpulse_cli/main.py discover 192.168.1.0/24
🚀 Installation & Build
NetPulse uses uv to manage its dependencies, and compiles its Rust engine inline using maturin.
Prerequisites
Ensure you have Rust, cargo, and python installed on your system.
Steps
- Clone the workspace and navigate to the project directory:
cd netpulse
- Sync workspace dependencies using
uv:uv sync - Compile and register the Rust engine inside the virtual environment:
cd rust ../.venv/bin/maturin develop --release cd ..
🖥️ Command Line Interface (CLI)
The CLI offers stunning console aesthetics with dynamic loading states, table outputs, and detailed error instructions.
Subcommands
version: Shows package and CLI version details.discover [target]: Sweeps the target CIDR network and automatically stores the result in history.discover-history [network]: Queries all past discovery scan summaries from local SQLite storage.discover-drift [target]: Sweeps the network target and instantly computes status drift against baseline history.discover-compare [old_scan_uuid] [new_scan_uuid]: Compares two specific past sweeps in database history.subnet info [ip_or_cidr]: Calculates network boundaries and displays bitwise binary alignments.subnet split [parent_network]: Partitions a parent CIDR into equal-sized subnets (FLSM) by count (--subnets) or host capacity (--hosts).subnet vlsm [parent_network]: Calculates optimal subnets using Variable-Length Subnet Masking (VLSM) for varying host size requirements.subnet discover [ip]: Finds which containing CIDR subnet block from a candidate list contains the given IP address.
Execution Examples
# Standard interactive table sweep (requires root or setcap permissions)
sudo .venv/bin/python apps/cli/netpulse_cli/main.py discover 172.19.57.0/24
# Output results directly in formatted JSON
NETPULSE_MOCK=1 .venv/bin/python apps/cli/netpulse_cli/main.py discover 172.19.57.0/24 --format json
# Subnet bitwise alignment calculator
.venv/bin/python apps/cli/netpulse_cli/main.py subnet info 192.168.1.50/24
# Perform VLSM allocation for varying departmental size requirements
.venv/bin/python apps/cli/netpulse_cli/main.py subnet vlsm 192.168.1.0/24 --req "HR=120,Dev=50,Sales=20,Links=2"
🌐 REST API Service
The REST API is a secure, production-grade FastAPI web service.
API Security Features
- Strict Bind Address: Exclusively listens on localhost (
127.0.0.1:8000) for development, avoiding open exposures (0.0.0.0). - Sliding Window Rate Limiter: Limits clients to 5 scans per minute per IP, returning structured
429 Too Many Requestsresponses withretry_after_secondsretry bounds. - Security Headers: Emits strict headers on every response:
X-Content-Type-Options: nosniffX-Frame-Options: DENYContent-Security-Policy: default-src 'self';
- CORS Restrictions: Rejects wildcards (
*) and explicitly boundaries access tolocalhost:3000developers. - Structured Error Translation: Safe handling of raw socket
PermissionErrorcodes, translating them into helpful instructions.
Start the REST Server
# Run in Mock Mode (Unprivileged)
PYTHONPATH=apps/api NETPULSE_MOCK=1 .venv/bin/python -m uvicorn netpulse_api.main:app --host 127.0.0.1 --port 8000
# Run in Production Mode (Requires raw socket capabilities)
sudo PYTHONPATH=apps/api .venv/bin/python -m uvicorn netpulse_api.main:app --host 127.0.0.1 --port 8000
Endpoint Reference
GET /health
Validates server reachability and responds with compliancy metadata.
- Response (200):
{ "status": "healthy", "service": "netpulse-api", "timestamp": 1779482308.33 }
POST /api/v1/discover
Orchestrates a discovery scan.
- Request Payload:
{ "target_network": "172.19.57.0/24", "methods": ["icmp"], "timeout_ms": 1000 }
- Response (200):
{ "id": "7b86da45-ad65-4b55-b200-92a41a71a998", "network": "172.19.57.0/24", "methods": ["icmp"], "status": "completed", "errors": [], "devices": [ { "id": "e38d70be-71fa-4677-962a-62bbb3685394", "ip": "172.19.57.1", "mac": null, "hostname": null, "vendor": null, "status": "up", "rtt_ms": 0.35 } ], "started_at": "2026-05-22T20:47:32.256Z", "finished_at": "2026-05-22T20:47:32.257Z", "stats": { "scanned": 256, "responsive": 1 }, "metadata": {} }
POST /api/v1/subnet/info
Acts as a subnet calculator. Computes detailed boundary configurations.
- Request Payload:
{ "ip": "192.168.1.50", "mask_or_prefix": "24" }
POST /api/v1/subnet/split
Partitions a parent CIDR into equal-sized subnets (FLSM).
- Request Payload:
{ "parent_network": "192.168.1.0/24", "subnets_count": 4 }
POST /api/v1/subnet/vlsm
Calculates optimal Variable-Length Subnet Masking (VLSM) allocations.
- Request Payload:
{ "parent_network": "192.168.1.0/24", "requirements": [ {"name": "HR", "hosts": 120}, {"name": "Dev", "hosts": 50} ] }
POST /api/v1/subnet/discover
Matches a target IP against candidate subnets to locate its container.
- Request Payload:
{ "ip": "192.168.1.45", "subnets": ["192.168.1.0/26", "192.168.1.64/26"] }
🧪 Running Automated Tests
NetPulse comes with 69 automated unit and integration tests built on top of pytest and httpx.
Tests run securely inside the local sandbox using mock overrides without needing root/sudo permissions:
PYTHONPATH=apps/api:apps/cli:packages/core:packages/engine NETPULSE_MOCK=1 .venv/bin/pytest tests/ -v
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file netpulse-0.1.0.1.tar.gz.
File metadata
- Download URL: netpulse-0.1.0.1.tar.gz
- Upload date:
- Size: 13.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3166bf9eb90a5cdd3772383279b7bb5e539673224bad61961aa982261e27e1db
|
|
| MD5 |
f0ebddb7d54046d9b3a98e52c481f7c6
|
|
| BLAKE2b-256 |
c446896c9924f16fced42cf3aa731520b5379518babb471892a2d19446fa8a40
|
Provenance
The following attestation bundles were made for netpulse-0.1.0.1.tar.gz:
Publisher:
release.yml on bonheurNE07/netpulse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
netpulse-0.1.0.1.tar.gz -
Subject digest:
3166bf9eb90a5cdd3772383279b7bb5e539673224bad61961aa982261e27e1db - Sigstore transparency entry: 1625018910
- Sigstore integration time:
-
Permalink:
bonheurNE07/netpulse@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Branch / Tag:
refs/tags/v0.1.0.1 - Owner: https://github.com/bonheurNE07
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Trigger Event:
push
-
Statement type:
File details
Details for the file netpulse-0.1.0.1-cp38-abi3-win_amd64.whl.
File metadata
- Download URL: netpulse-0.1.0.1-cp38-abi3-win_amd64.whl
- Upload date:
- Size: 156.2 kB
- Tags: CPython 3.8+, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e72f66ddc99853668eb71094a371883de09ef178c5a4fd14eaa79e6ca2041150
|
|
| MD5 |
b5604dc1e940b03f293199bfae9874fe
|
|
| BLAKE2b-256 |
65d5f5428ee42b7095904ac85f797c44dba69e3074abe049b1633618fa441073
|
Provenance
The following attestation bundles were made for netpulse-0.1.0.1-cp38-abi3-win_amd64.whl:
Publisher:
release.yml on bonheurNE07/netpulse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
netpulse-0.1.0.1-cp38-abi3-win_amd64.whl -
Subject digest:
e72f66ddc99853668eb71094a371883de09ef178c5a4fd14eaa79e6ca2041150 - Sigstore transparency entry: 1625018913
- Sigstore integration time:
-
Permalink:
bonheurNE07/netpulse@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Branch / Tag:
refs/tags/v0.1.0.1 - Owner: https://github.com/bonheurNE07
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Trigger Event:
push
-
Statement type:
File details
Details for the file netpulse-0.1.0.1-cp38-abi3-manylinux_2_34_x86_64.whl.
File metadata
- Download URL: netpulse-0.1.0.1-cp38-abi3-manylinux_2_34_x86_64.whl
- Upload date:
- Size: 299.0 kB
- Tags: CPython 3.8+, manylinux: glibc 2.34+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fe3f65de5c3a61daf99bdd3d84f5a84ef2d56845df63be4d7a73065cd5066504
|
|
| MD5 |
8a32ac7437ae7fd212ca34e217cb9de6
|
|
| BLAKE2b-256 |
d4e5eb9f822326950b791ce4b8e30a2ea378e9e0515c2b52ccad3755d8f0d011
|
Provenance
The following attestation bundles were made for netpulse-0.1.0.1-cp38-abi3-manylinux_2_34_x86_64.whl:
Publisher:
release.yml on bonheurNE07/netpulse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
netpulse-0.1.0.1-cp38-abi3-manylinux_2_34_x86_64.whl -
Subject digest:
fe3f65de5c3a61daf99bdd3d84f5a84ef2d56845df63be4d7a73065cd5066504 - Sigstore transparency entry: 1625018931
- Sigstore integration time:
-
Permalink:
bonheurNE07/netpulse@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Branch / Tag:
refs/tags/v0.1.0.1 - Owner: https://github.com/bonheurNE07
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Trigger Event:
push
-
Statement type:
File details
Details for the file netpulse-0.1.0.1-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.
File metadata
- Download URL: netpulse-0.1.0.1-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
- Upload date:
- Size: 295.1 kB
- Tags: CPython 3.8+, manylinux: glibc 2.17+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f43679433701900307b328997ffed6aa3e04b8a98ce001c28f3c48f99954eff
|
|
| MD5 |
edb9143a8e64cf02cd834f1171e938e7
|
|
| BLAKE2b-256 |
0580b7377f6ff9abee98dbeed8c0eeafd36fbd6c1a6fe63b067c272058dec9e1
|
Provenance
The following attestation bundles were made for netpulse-0.1.0.1-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl:
Publisher:
release.yml on bonheurNE07/netpulse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
netpulse-0.1.0.1-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl -
Subject digest:
1f43679433701900307b328997ffed6aa3e04b8a98ce001c28f3c48f99954eff - Sigstore transparency entry: 1625018918
- Sigstore integration time:
-
Permalink:
bonheurNE07/netpulse@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Branch / Tag:
refs/tags/v0.1.0.1 - Owner: https://github.com/bonheurNE07
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Trigger Event:
push
-
Statement type:
File details
Details for the file netpulse-0.1.0.1-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl.
File metadata
- Download URL: netpulse-0.1.0.1-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl
- Upload date:
- Size: 510.7 kB
- Tags: CPython 3.8+, macOS 10.12+ universal2 (ARM64, x86-64), macOS 10.12+ x86-64, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
697fe2d93f52538fda5e96985108a90e9af5e9e20698528a7f1739309a96d0dc
|
|
| MD5 |
0afb4cfaeedf491e719704f5bd36d251
|
|
| BLAKE2b-256 |
46a740c7fa3a99c1ee353f156de8b9b242d6baa7242b270b825fafecff527b23
|
Provenance
The following attestation bundles were made for netpulse-0.1.0.1-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl:
Publisher:
release.yml on bonheurNE07/netpulse
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
netpulse-0.1.0.1-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl -
Subject digest:
697fe2d93f52538fda5e96985108a90e9af5e9e20698528a7f1739309a96d0dc - Sigstore transparency entry: 1625018923
- Sigstore integration time:
-
Permalink:
bonheurNE07/netpulse@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Branch / Tag:
refs/tags/v0.1.0.1 - Owner: https://github.com/bonheurNE07
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@18a1ff9147e5355200ca8f563a13d5f73a5e0b60 -
Trigger Event:
push
-
Statement type: