Experimental userspace IPv8 toolkit implementing draft-thain-ipv8-00 — address parsing, packet building, routing simulation, ICMPv8, 8to4 tunnelling, and more.
Project description
Open-IPv8-Lab
Open-IPv8-Lab is an experimental userspace toolkit implementing draft-thain-ipv8-00 — the Internet Protocol Version 8 specification. It covers ASN-based 64-bit addressing, packet encoding/decoding, two-tier routing, ICMPv8, 8to4 tunnelling, security filtering, VRF, PVRST, Cost Factor, WHOIS8, DHCP8, Zone Server (OAuth8/ACL8), NetLog8 telemetry, all companion spec modules, end-to-end integration scenarios, multi-zone simulation, BGP8 path selection with CF metric, XLATE8 north-south traffic flow, PCAP export for Wireshark integration, IPv8 packet fragmentation and reassembly, NAT8, NetFlow8, QoS, Docker testbed, TUI dashboard, packet fuzzer, mTLS encryption layer, and interactive Zone Server CLI.
Created and maintained by Aleksei Aleinikov (@LF3551).
Status
This project is experimental and educational. It is not an official IPv8 implementation, not production networking software.
Spec coverage (draft-thain-ipv8-00)
| Section | Topic | Module |
|---|---|---|
| 1.3 | DHCP8 lease (single-response provisioning) | dhcp8.py |
| 1.3 | Zone Server (OAuth8 cache, ACL8 engine) | zoneserver.py |
| 1.4 | East-west / north-south security | zoneserver.py |
| 1.6 | Cost Factor (CF) metric simulation | cost_factor.py |
| 3 | Address format (64-bit, ASN prefix + host) | address.py |
| 4 | Address classes (unicast, multicast, broadcast, RINE, internal zone) | address.py |
| 5.1 | Packet header (28-byte, version 8) | packet.py |
| 6 | ASN dot notation | address.py |
| 7 | DNS A8 record (even/odd pair, RFC 1918 validation) | dns_a8.py |
| 8.7 | Two-tier routing table | route.py |
| 8.8 | VRF (management VLAN 4090, OOB VLAN 4091) | vrf.py |
| 9 | ICMPv8 (Echo, Unreachable, Redirect, Time Exceeded) | icmpv8.py |
| 10–12 | Multicast, anycast, broadcast | multicast.py |
| 13.3 | 8to4 tunnelling | tunnel.py |
| 17.1–17.3 | Device compliance tiers | compliance.py |
| 17.4 | PVRST (Zone Server root election) | pvrst.py |
| 17.5 | NIC rate limits | ratelimit.py |
| 18 | Security — ingress filtering, prefix protection | security.py, validation.py |
| 18 | NetLog8 telemetry (SEC-ALERT, E3 traps) | netlog8.py |
| — | WHOIS8 mock resolver (ASN/route validation) | whois8.py |
| — | Companion specs (BGP8, OSPF8, IS-IS8, RINE, ARP8, XLATE8, Update8, WiFi8, SNMPv8) | companions.py |
| — | End-to-end integration (DHCP8 → OAuth8 → ACL8 → routing) | integration.py |
| — | Multi-zone simulation (Zone Server pairs, IBGP8 inter-zone routing) | multizone.py |
| 8.4 | BGP8 path selection with CF metric (anomaly detection, failover) | bgp8_selection.py |
| 1.4 | XLATE8 north-south traffic flow (DNS8 → XLATE8 → translation) | xlate8_flow.py |
| — | PCAP export for Wireshark integration (PcapWriter, PcapReader, Lua dissector) | pcap_export.py |
| 5.1 | IPv8 packet fragmentation and reassembly (DF/MF flags, offset, Reassembler) | fragmentation.py |
| — | Interactive Zone Server CLI | cli/zone_cli.py |
| — | NAT8 address translation gateway | nat8.py |
| — | NetFlow8 flow monitoring and telemetry export | netflow8.py |
| — | QoS / traffic shaping based on TOS field | qos.py |
| — | Docker-based multi-node testbed | docker_testbed.py |
| — | TUI dashboard (Rich Live / Textual) | tui_dashboard.py |
| — | Packet fuzzer for protocol security testing | fuzzer.py |
| — | mTLS / encryption layer for Zone Server auth | mtls.py |
Goals
- Parse and validate IPv8 64-bit addresses (Section 3)
- Classify address types: unicast, multicast, broadcast, RINE, internal zone (Section 4)
- Build and parse spec-compliant IPv8 packets (Section 5.1)
- Two-tier routing simulation with VRF support (Sections 8.7, 8.8)
- ICMPv8 messages: Echo, Destination Unreachable, Redirect (Section 9)
- 8to4 tunnelling for IPv8-over-IPv4 transit (Section 13.3)
- DNS A8 record parsing with even/odd pair convention (Section 7)
- Device compliance tier validation (Sections 17.1–17.3)
- PVRST Zone Server root election (Section 17.4)
- NIC firmware rate limiting simulation (Section 17.5)
- Border router ingress filtering and security checks (Section 18)
- Cost Factor (CF) metric: 7-component path quality with physics floor (Section 1.6)
- WHOIS8 route/destination validation
- DHCP8 single-response lease provisioning (Section 1.3)
- Zone Server OAuth8 JWT cache and ACL8 access control (Sections 1.3, 1.4)
- NetLog8 telemetry with SEC-ALERT and E3 traps (Section 18)
- Companion spec modules: BGP8, OSPF8, IS-IS8, RINE, ARP8, XLATE8, Update8, WiFi8, SNMPv8
- End-to-end integration scenario: DHCP8 → OAuth8 → ACL8 → routing lifecycle
- Multi-zone simulation with Zone Server pairs and IBGP8-style inter-zone routing
- BGP8 path selection with CF metric: per-prefix RIB, anomaly detection, failover
- XLATE8 north-south traffic flow: DNS8 → XLATE8 → address translation (Section 1.4)
- PCAP export for Wireshark integration: PcapWriter, PcapReader, Lua dissector
- IPv8 packet fragmentation and reassembly: DF/MF flags, fragment offset, stateful Reassembler
- Interactive Zone Server CLI:
ipv8lab zone(init, status, services, ACL8, OAuth8, VLAN) - Traceroute8 diagnostic:
ipv8lab traceroute(multi-hop trace simulation) - NAT8 address translation gateway simulation:
ipv8lab nat8 - NetFlow8 flow monitoring and telemetry export:
ipv8lab netflow8 - QoS / traffic shaping based on TOS field:
ipv8lab qos - Docker-based multi-node testbed:
ipv8lab docker - TUI dashboard — Rich Live / Textual:
ipv8lab tui - Packet fuzzer for protocol security testing:
ipv8lab fuzz - mTLS / encryption layer for Zone Server authentication:
ipv8lab mtls - Mesh network simulation, packet capture, web dashboard, benchmarks, plugins
Non-goals
- No Linux kernel modifications
- No production networking
- No real BGP integration
- No claim of official IETF endorsement
Installation
python -m venv .venv
source .venv/bin/activate
pip install -e ".[dev]"
Quick start
# Parse an IPv8 address
ipv8lab addr parse 64496.192.0.2.1
# Convert ASN to routing prefix
ipv8lab addr encode-asn 64496
# Decode prefix back to ASN
ipv8lab addr decode-prefix 0.0.251.240
# Build a packet
ipv8lab packet build --src 64496.192.0.2.1 --dst 64497.198.51.100.7 --payload "hello"
# Parse a packet from file
ipv8lab packet parse packet.bin
# Run routing simulation
ipv8lab route simulate --config examples/two_asn_demo.yaml
# Zone Server management
ipv8lab zone init --prefix 127.1.0.0
ipv8lab zone status
ipv8lab zone acl-add "*" gateway --action permit
ipv8lab zone oauth-issue device-42
ipv8lab zone vlan-check 100
# PCAP export for Wireshark
ipv8lab pcap demo -o demo.pcap
ipv8lab pcap inspect demo.pcap
ipv8lab pcap dissector -o ipv8_dissector.lua
ipv8lab pcap export trace.iv8cap trace.pcap
# mTLS encryption layer
ipv8lab mtls init
ipv8lab mtls issue my-device
ipv8lab mtls handshake my-device
ipv8lab mtls encrypt my-device "secret message"
# Packet fuzzer
ipv8lab fuzz run --iterations 1000
ipv8lab fuzz run --strategy all --json
Example output
ipv8lab addr parse 64496.192.0.2.1
Input 64496.192.0.2.1
Format ASN dot notation
ASN 64496
Routing prefix 0.0.251.240
Host part 192.0.2.1
Full notation 0.0.251.240.192.0.2.1
Testing
pytest -v
1406 tests covering all implemented spec sections.
Project structure
src/ipv8lab/
├── address.py # IPv8 64-bit addressing (Section 3, 4, 6)
├── packet.py # Packet header (Section 5.1)
├── checksum.py # CRC32 checksum
├── route.py # Two-tier routing (Section 8.7)
├── vrf.py # Virtual Routing & Forwarding (Section 8.8)
├── icmpv8.py # ICMPv8 protocol (Section 9)
├── multicast.py # Multicast/broadcast (Sections 10–12)
├── tunnel.py # 8to4 tunnelling (Section 13.3)
├── dns_a8.py # DNS A8 records (Section 7)
├── compliance.py # Device compliance tiers (Sections 17.1–17.3)
├── pvrst.py # PVRST spanning tree (Section 17.4)
├── ratelimit.py # NIC rate limits (Section 17.5)
├── security.py # Ingress filtering (Section 18)
├── validation.py # Prefix validation (Sections 3.5, 3.9, 3.10)
├── cost_factor.py # Cost Factor (CF) metric (Section 1.6)
├── whois8.py # WHOIS8 mock resolver
├── dhcp8.py # DHCP8 lease simulation (Section 1.3)
├── zoneserver.py # Zone Server: OAuth8 cache, ACL8 (Sections 1.3, 1.4)
├── netlog8.py # NetLog8 telemetry client (Section 18)
├── companions.py # Companion spec modules (7 companion drafts)
├── integration.py # End-to-end integration scenario
├── multizone.py # Multi-zone simulation with Zone Server pairs
├── bgp8_selection.py # BGP8 path selection with CF metric
├── xlate8_flow.py # XLATE8 north-south traffic flow
├── pcap_export.py # PCAP export for Wireshark (.pcap, Lua dissector)
├── fragmentation.py # Packet fragmentation and reassembly
├── cf_dashboard.py # CF performance dashboard (HTML, JSON API)
├── errors.py # Error hierarchy
├── node.py # Node abstraction
├── simulator.py # Mesh network simulator
├── transport.py # UDP transport
├── udp_runner.py # Async UDP node orchestration
├── capture.py # Packet capture (.iv8cap)
├── dashboard.py # Web dashboard
├── benchmark.py # Performance benchmarks
├── plugin.py # Plugin system
├── dump.py # Hex dump & JSON output
├── nat8.py # NAT8 address translation gateway
├── netflow8.py # NetFlow8 telemetry export
├── qos.py # QoS / traffic shaping (TOS field)
├── docker_testbed.py # Docker-based multi-node testbed
├── tui_dashboard.py # TUI dashboard (Textual)
├── fuzzer.py # Packet fuzzer for security testing
├── mtls.py # mTLS encryption layer for Zone Server
├── traceroute8.py # Traceroute8 diagnostic utility
└── cli/ # Typer CLI commands
Documentation
License
This project is licensed under the Apache License 2.0.
SPDX-License-Identifier: Apache-2.0
Attribution
Use, modification, and distribution are permitted under the Apache License 2.0, provided that the following conditions are met:
- The original copyright notice and license text must be preserved in all copies or substantial portions of the software.
- The NOTICE file must be included in any redistribution.
- Attribution to the original author — Aleksei Aleinikov (@LF3551) — must remain intact.
If you use this project in your own work, please credit:
IPv8 Lab — Copyright 2026 Aleksei Aleinikov
https://github.com/LF3551/Open-IPv8-Lab
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
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 open_ipv8_lab-0.11.1.tar.gz.
File metadata
- Download URL: open_ipv8_lab-0.11.1.tar.gz
- Upload date:
- Size: 203.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5af06a103548d56c8572500ec488a380bd9e1e45649069d1a6cd3c0ad07ebe1d
|
|
| MD5 |
f4aae1e7be4c156fc297a9d01bd16795
|
|
| BLAKE2b-256 |
2037462a2b8267f056318354637a1d8ea56a77b82afa333cd5261857b5b2eb92
|
File details
Details for the file open_ipv8_lab-0.11.1-py3-none-any.whl.
File metadata
- Download URL: open_ipv8_lab-0.11.1-py3-none-any.whl
- Upload date:
- Size: 172.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2e6c1ccf81abdae649e2a72272570db50491fe9ee58092d7060991206b6345e6
|
|
| MD5 |
6c3536120c7427aebf4ed9c53b637122
|
|
| BLAKE2b-256 |
aab345a5b1ea45fd81643a22e1e87b5b446cebae29dfa5b610fe936d47ccfcb8
|