Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/massoudasadi/packiffer
lightweight cross-platform networking toolkit
https://github.com/massoudasadi/packiffer
bpf ebpf firewall gopacket inject libpcap packet pcap xdp
Last synced: 2 months ago
JSON representation
lightweight cross-platform networking toolkit
- Host: GitHub
- URL: https://github.com/massoudasadi/packiffer
- Owner: massoudasadi
- License: bsd-3-clause
- Created: 2020-09-16T13:45:50.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-03-31T19:41:20.000Z (almost 2 years ago)
- Last Synced: 2024-08-02T06:02:04.133Z (6 months ago)
- Topics: bpf, ebpf, firewall, gopacket, inject, libpcap, packet, pcap, xdp
- Language: Go
- Homepage:
- Size: 11 MB
- Stars: 80
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome_go_article - 跨平台的包嗅探工具
README
[![Go Report Card](https://goreportcard.com/badge/github.com/massoudasadi/packiffer)](https://goreportcard.com/report/github.com/massoudasadi/packiffer)
# Packiffer
Packiffer is a lightweight cross-platform networking toolkit that let you sniff/analyze/inject/filter packets.
Features:
-display list of network interfaces
-sniff packets live from interface
-set promiscuous mode on interface
-apply filters to packets
-transform selected packets from pcap file to another
-inspect packets in terminal
-inject packets into network
-filter packets with specified destination ip
Modes:
Sniff:
sniff packets live from interfaceTransform:
transform packets from offline pcapInspect:
inspect & analysis packets from offline pcap filesInject:
Inject Raw & Constructed PacketsFilter:
Drop or Accept Packets# Prerequisites For Binary
Libpcap v1.9.1
Clang/LLVM (Only on Linux for eBPF XDP packet filtering)
Iptables (Only on Linux for Iptables packet filtering)
# Prerequisites For Source
Golang v1.16
GoPacket v1.1.19
Go eBPF v0.0.0-20210223
Libpcap v1.9.1
Fiber v2.8.0
Clang/LLVM (Only on Linux for eBPF XDP packet filtering)
Iptables (Only on Linux for Iptables packet filtering)
# How to get Packiffer
Checkout packiffer git repo using git clone
```
git clone https://github.com/massoudasadi/packiffer.git
cd packiffer
```# Run Packiffer
Sniff mode:
```
make build_go./packiffer sniff
("i", "Specify interface name. Default is eth0")
("p", "Specify promiscuous mode. Default is false")
("f", "Specify filter query. Default is all")
("od", "Specify output directory. Defaultis packiffer directory")
("of", "Specify output file name. Defaultis interface name")
("sl", "Specify Snapshot Lenght. Default is 2014")
("t", "limit sniffing timeout. Default is 30 seconds")
("c", "Limit count of packets to sniff. Default is 1000")
```transform mode:
```
make build_go./packiffer transform
("f", "Specify filter query. Default is all")
("in", "Specify input pcap file")
("od", "Specify output directory.Default is packiffer directory")
("of", "Specify output file name.Default is interface name")
("c", "Limit count of packets to sniff. Default is1000")
```inspect mode:
```
make build_go./packiffer inspect
("in", "Specify input pcap file")
("f", "Specify filter query. Default is all")
("c", "Limit count of packets to sniff. Default is 1000")
```inject mode:
```
make build_go./packiffer inject
("i", "Specify interface name. Default is eth0")
("ir", "Specify Raw Packet Inject. Default is false")
("ic", "Specify Constructed Packet Inject. Default is False")
("f", "Specify Path to packet file. Default is inject.txt")
```firewall mode:
```
make build_bpf
make build_go./packiffer firewall
("i", "Specify interface name. Default is eth0")
("f", "Specify Path to firewall file. Default is firewall.txt")
```default mode:
```
./packiffer("h", "Specify help display. Default is false")
("d", "Specify devices display. Default is false")
```# Examples
Display list of network interfaces
```
./packiffer -d
```Sniff packets on 'eth0' and save packets in 'eth0.pcap' (promiscuous mode) until Ctrl+C pressed
```
./packiffer sniff -i eth0 -p
```transformonly udp packets from 'eth0.pcap' to 'eth0_udp.pcap' until Ctrl+C pressed
```
./packiffer transform -in /path/to/eth0.pcap -of eth0_udp
```inspect only tcp packets from pcap file
```
./packiffer inspect -in /path/to/file.pcap -f tcp
```inject constructed tcp packets from InjectConstructed.json
```
./packiffer inject -i eth0 -ic -f /path/to/file.json
```filter packets from ips inside firewall.txt
```
./packiffer firewall -i eth0 -f /path/to/file.txt
```