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.10a0.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.10a0.tar.gz.
File metadata
- Download URL: py-pcapplusplus-1.0.10a0.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 |
2c33be997605cd5d127575ed6aea379eea8464a5b98e7274f5c25df31c6b0412
|
|
| MD5 |
5ee647c81dc07f0ad9eec56ae6a4ed12
|
|
| BLAKE2b-256 |
6b9930b719aa5177c1a57372ba45109d034b75776c93009bec28f8d1607dc136
|
File details
Details for the file py_pcapplusplus-1.0.10a0-cp310-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.whl.
File metadata
- Download URL: py_pcapplusplus-1.0.10a0-cp310-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.whl
- Upload date:
- Size: 791.4 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 |
919f0eac9f38d0c43b3d06fa535758589fa62910badf8162106fd0834db76dfc
|
|
| MD5 |
23e4c95cd98c04cf1a64e660452de330
|
|
| BLAKE2b-256 |
789d2e1dbeb59d591b94b7e97f15e93ff7de4d224385dc361e8a50f478ac199e
|