Python wrapper module for the Pcap++ library using nanobind
Project description
py-pcapplusplus
A Python wrapper for the Pcap++ library using nanobind, providing a high-level interface for network packet manipulation, capture, and analysis.
Features
- Read and parse PCAP files
- Create and modify network packets
- Support for multiple protocol layers:
- Ethernet
- IPv4/IPv6
- TCP/UDP
- ARP
- VLAN
- DHCP
- SOME/IP and SOME/IP-SD
- Raw socket operations for packet capture and injection
- High-performance packet processing
Installation
pip install py-pcapplusplus
Quick Start
Reading PCAP Files
from py_pcapplusplus import Reader, Packet
# Open a PCAP file
reader = Reader("capture.pcap")
# Iterate through packets
for packet in reader:
# Access different layers
eth_layer = packet[LayerType.EthLayer]
ip_layer = packet[LayerType.IPv4Layer]
# Print packet information
print(packet)
Creating Packets
from py_pcapplusplus import Packet, EthLayer, IPv4Layer, TcpLayer
# Create a new packet
packet = Packet()
# Add layers
eth = EthLayer(src_mac_addr="00:11:22:33:44:55", dst_mac_addr="66:77:88:99:aa:bb")
ip = IPv4Layer(src_addr="192.168.1.1", dst_addr="192.168.1.2")
tcp = TcpLayer(src_port=12345, dst_port=80)
# Add layers to packet
packet / eth / ip / tcp
Packet Capture
from py_pcapplusplus import RawSocket
# Create a raw socket on a specific interface
socket = RawSocket("eth0")
# Capture packets
packets = socket.sniff(timeout=5.0) # Capture for 5 seconds
# Process captured packets
for packet in packets:
print(packet)
API Reference
Core Classes
Packet
get_layer(layer_type): Get a specific layer from the packetadd_layer(layer): Add a new layer to the packetinsert_layer(prev_layer, new_layer): Insert a layer after an existing one
Layer Types
EthLayer: Ethernet layerIPv4Layer: IPv4 layerIPv6Layer: IPv6 layerTcpLayer: TCP layerUdpLayer: UDP layerArpLayer: ARP layerVlanLayer: VLAN layerDhcpLayer: DHCP layerSomeIpLayer: SOME/IP layerSomeIpSdLayer: SOME/IP-SD layerPayloadLayer: Raw payload layer
Protocol-Specific Features
Ethernet Layer
eth = EthLayer(src_mac_addr="00:11:22:33:44:55", dst_mac_addr="66:77:88:99:aa:bb")
eth.src_mac_addr = "00:11:22:33:44:55" # Set source MAC
eth.dst_mac_addr = "66:77:88:99:aa:bb" # Set destination MAC
eth.ether_type = True # Set to IPv4 (False for IPv6)
IPv4 Layer
ip = IPv4Layer(src_addr="192.168.1.1", dst_addr="192.168.1.2")
ip.src_ip = "192.168.1.1" # Set source IP
ip.dst_ip = "192.168.1.2" # Set destination IP
ip.ttl = 64 # Set TTL
ip.clear_chksum() # Clear checksum for recalculation
TCP Layer
tcp = TcpLayer(src_port=12345, dst_port=80)
tcp.syn_flag = True # Set SYN flag
tcp.ack_flag = True # Set ACK flag
tcp.rst_flag = False # Set RST flag
Raw Socket Operations
socket = RawSocket("eth0")
# Send a single packet
socket.send_packet(packet)
# Send multiple packets
socket.send_packets([packet1, packet2, packet3])
# Receive a packet
packet = socket.receive_packet(blocking=True, timeout=1.0)
# Sniff packets
packets = socket.sniff(timeout=5.0)
Dependencies
- Pcap++ library
- nanobind
- Python 3.10
Acknowledgments
- Pcap++ library for the underlying packet processing capabilities
- nanobind for the Python binding framework
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
py-pcapplusplus-1.0.9a0.tar.gz
(17.1 kB
view details)
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 py-pcapplusplus-1.0.9a0.tar.gz.
File metadata
- Download URL: py-pcapplusplus-1.0.9a0.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8472684fc0a731c51ffeb4a01de87f6e117e6ee53fd9941ada48a48d9196f95f
|
|
| MD5 |
6fe1ccc70b44589d686ff36e0837df46
|
|
| BLAKE2b-256 |
9adb880f2e901e1edbb0223637775218b66649a26759d2f91f7b89b47008a7a0
|
File details
Details for the file py_pcapplusplus-1.0.9a0-cp310-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.whl.
File metadata
- Download URL: py_pcapplusplus-1.0.9a0-cp310-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.whl
- Upload date:
- Size: 790.1 kB
- Tags: CPython 3.10+, manylinux: glibc 2.17+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
095a0fc7f101ed59cae80bb60119b5a1cbf673a52c2e1ec7f331b28a265af208
|
|
| MD5 |
2b69dc3f517dc1172bfe3e5c6c69e702
|
|
| BLAKE2b-256 |
4c4de01f57a04fce8604aaa3463a2e53b7c4562c997c4bafe7c2b321e2f55085
|