2018-07-15 18:27:59 +00:00
|
|
|
# IGMP Packet Generator
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
The IGMP Packet Generator is a specialized tool designed for generating various
|
|
|
|
types of Internet Group Management Protocol (IGMP) p ackets. This tool is
|
|
|
|
particularly useful for network administrators, developers, and researchers
|
|
|
|
involved in testing and analyzing ne twork protocols, multicast networks, and
|
|
|
|
network security systems.
|
2018-07-15 18:27:59 +00:00
|
|
|
|
|
|
|
## Features
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
* **Support for Multiple IGMP Versions**: Compatible with IGMPv1, IGMPv2, and IGMPv3.
|
|
|
|
* **Variety of IGMP Packets**: Capable of generating Query, Report, Leave, and other IGMP packet types.
|
|
|
|
* **Customizable Packet Parameters**: Allows setting of source/destination IPs, ports, and multicast groups.
|
|
|
|
* **Router Alert Option**: Implements the Router Alert IP option (IPOPT_RA).
|
2018-07-15 18:27:59 +00:00
|
|
|
|
|
|
|
## Requirements
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
* Unix-like operating system.
|
|
|
|
* `libnet` library
|
|
|
|
* CMake for building the project.
|
2018-07-15 18:27:59 +00:00
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
For debian/ubuntu, simply type:
|
2018-07-15 18:27:59 +00:00
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
```shell-session
|
|
|
|
sudo apt-get install cmake libnet1-dev
|
|
|
|
```
|
|
|
|
|
|
|
|
## Install
|
|
|
|
|
|
|
|
### Clone the Repository (if applicable):
|
2018-07-15 18:27:59 +00:00
|
|
|
|
|
|
|
```bash
|
2023-12-24 19:27:59 +00:00
|
|
|
git clone [repository-url]
|
|
|
|
cd igmpgen
|
2018-07-15 18:27:59 +00:00
|
|
|
```
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
### Build with CMake:
|
2018-07-15 18:27:59 +00:00
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
Create a build directory:
|
2018-07-15 18:27:59 +00:00
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
```shell-session
|
|
|
|
mkdir _build && cd _build
|
|
|
|
```
|
2018-07-15 18:27:59 +00:00
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
Run CMake and build the project:
|
|
|
|
|
|
|
|
```shell-session
|
|
|
|
cmake ..
|
|
|
|
cmake --build .
|
|
|
|
```
|
|
|
|
|
|
|
|
### Install binaries
|
|
|
|
|
|
|
|
```shell-session
|
|
|
|
cmake ..
|
|
|
|
cmake --install .
|
2018-07-15 18:27:59 +00:00
|
|
|
```
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
After building, you can run `igmpgen` with the necessary command-line arguments:
|
|
|
|
|
2018-07-15 18:27:59 +00:00
|
|
|
### Command-Line Arguments
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
```bash
|
|
|
|
IGMP packet generator
|
|
|
|
|
|
|
|
Usage: ./igmpgen [options]
|
|
|
|
|
|
|
|
Options:
|
|
|
|
-i <interface> Specify the network interface (e.g., eth0)
|
|
|
|
-t <type> Specify the IGMP packet type and version (e.g., 1.query)
|
|
|
|
-g <group> Specify the IGMP group (e.g., 224.0.0.1)
|
|
|
|
-s <source> Specify the source IP and port (e.g., 192.168.1.1:1234)
|
|
|
|
-d <destination> Specify the destination IP and port (e.g., 224.0.0.2:5678)
|
|
|
|
-n <number> Specify delay between packets in seconds (optional)
|
|
|
|
|
|
|
|
Available IGMP packet types:
|
|
|
|
- 1.query
|
|
|
|
- 1.report
|
|
|
|
- 1.dvmrp
|
|
|
|
- 2.query
|
|
|
|
- 2.report
|
|
|
|
- 2.leave
|
|
|
|
- 3.report
|
|
|
|
```
|
2018-07-15 18:27:59 +00:00
|
|
|
|
|
|
|
### Example
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
Generate an IGMPv2 Membership Report for group `224.0.0.1` on `eth0`:
|
2018-07-15 18:27:59 +00:00
|
|
|
|
|
|
|
```bash
|
2023-12-24 19:27:59 +00:00
|
|
|
./igmpgen -i eth0 -g 224.0.0.1 -t 2.report
|
2018-07-15 18:27:59 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## Contributing
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
Contributions to `igmpgen` are welcome. Please feel free to report issues,
|
|
|
|
suggest features, or submit pull requests.
|
2018-07-15 18:27:59 +00:00
|
|
|
|
|
|
|
## License
|
|
|
|
|
2023-12-24 19:27:59 +00:00
|
|
|
This project is licensed under the LGPL 3.0-or-later.
|
|
|
|
|