Skip to main content

MiTM over TCP to intercept and manipulate flow

Project description

p4lantir

PyPI version License Python versions


p4lantir is a simple tool to perform Man-in-the-Middle over TCP using ARP spoofing, allowing to intercept, drop, forward and see TCP flows.

This project is intended to be relatively simple, making simple future contributions for new features/bug fix.

[!CAUTION] This ethical hacking project is intended for educational purposes and awareness training sessions only. I decline all responsability about the usage of this project.


Installation

  • Install the system dependencies (arpspoof, iptables)
  • Create python virtual environnement
  • Install the package

Setup instructions :

Debian-based systems

sudo apt install dsniff iptables

python3 -m venv venv
source venv/bin/activate

pip install p4lantir

Archlinux

pacman -S dsniff iptables

python3 -m venv venv
source venv/bin/activate

pip install p4lantir

Usage

[!WARNING] You need to run the script as root due to arpspoof and iptables. You should open a shell as root, activate the venv and then use p4lantir.

usage: p4lantir [-h] --host-1 HOST_1 --host-2 HOST_2 [--gateway GATEWAY] -i INTERFACE -l LPORT [--pport PPORT] [--debug]

Man-in-the-Middle over TCP terminal app.

options:
  -h, --help            show this help message and exit
  --host-1 HOST_1       First host to spoof, must be the host instanciating the connection
  --host-2 HOST_2       Second host to spoof
  --gateway GATEWAY     Gateway IP
  -i, --interface INTERFACE
                        Interface to perform arp spoofing
  -l, --lport LPORT     Port to listen for MITM attack
  --pport PPORT         Internal port used for proxy.
  --debug               Enable debug mode.

Examples

Client/server in the same localhost

Let say that a client at IP C connect to a remote server at IP R, both in the same LAN. You need to know the name of the interface that connects you this LAN (let call this iface. Then your command should look like :

p4lantir --host-1 [replace with C] \
         --host-2 [replace with R] \
         -i [replace with iface] \
         -lport [server's listening port]

About the listening port, if you intend to intercept SMTP you may choose 25, 80 for HTTP, and so on ...

Client/server on a different LAN

If the client is in the same LAN as you and the server is not in your LAN, then you have to add another parameter : the gateway IP. p4lantir will then spoof the gateway IP and open a connection to the server.

p4lantir --host-1 [replace with C] \
         --host-2 [replace with R] \
         --gateway [replace with gw's IP]
         -i [replace with iface] \
         -lport [server's listening port]

Contributing

All contributions are welcome !

Please see CONTRIBUTING.md for more details.

License

This project is under the GPL-v3 license, please see LICENSE.TXT

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

p4lantir-1.0.0.tar.gz (140.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

p4lantir-1.0.0-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file p4lantir-1.0.0.tar.gz.

File metadata

  • Download URL: p4lantir-1.0.0.tar.gz
  • Upload date:
  • Size: 140.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for p4lantir-1.0.0.tar.gz
Algorithm Hash digest
SHA256 79fe2018c1e877a90f710b2e5db60cc0f57a6ab618b2c98d537eb0ff1d53fe56
MD5 8b8a311bcbf6a4aade3d742c6831a1ac
BLAKE2b-256 084c23be67b05a6349083eafb2416bf8f4c9194071a4ede2a057f8efc2e469af

See more details on using hashes here.

Provenance

The following attestation bundles were made for p4lantir-1.0.0.tar.gz:

Publisher: upload-to-pypi.yml on acmo0/p4lantir

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file p4lantir-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: p4lantir-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 26.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for p4lantir-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e2754f8804ba18d3efbf959ef1d06f0fe47c37512ae78dd875c8085ea937e62f
MD5 b5b4d5d4dcaa570c558ff380b2e83e89
BLAKE2b-256 c9332114cb2bfb611af4773a986f347ec7e04e0b348d94ba7348c9747953169d

See more details on using hashes here.

Provenance

The following attestation bundles were made for p4lantir-1.0.0-py3-none-any.whl:

Publisher: upload-to-pypi.yml on acmo0/p4lantir

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page