/l2pivot

A layer 2 pivot tool for linux

Primary LanguageC

Layer 2 Pivot

A pivot tool operating on layer 2 of the OSI model, that allows one linux machine (the client) to pivot into a remote network via another dual homed linux machine (the server).

Concept

Layer 2 pivoting concept

Compilation and Usage

Compile with

gcc -o l2pivot l2pivot.c

Usage:

Both the client and server require root.

└─# ./l2pivot -h                    
Usage: ./l2pivot [-c] [-p] [-h] SERVER_IP CIDR_NEW|CIDR_PIVOT

          -h:  view this help message
          -c:  run as client (requires CIDR_NEW)
               (if not specified run as server (requires CIDR_PIVOT))
          -p:  fake promiscuous mode (think of NAT but for MAC)
               (only applies on server, see `Notes` for more details)
   SERVER_IP:  the ip address of the interface on the server that will be used for the tunnel
    CIDR_NEW:  the new ip address on the client (including the subnet mask in CIDR notation)
               (the netmask must match the target network and you should choose an available IP address)
  CIDR_PIVOT:  the ip address of the interface to pivot to (including the subnet mask in CIDR notation)

Example:
 (Client: 10.0.0.1)      (Server: 10.0.0.2 & 172.16.0.2)      (Target: 172.16.0.1)

         Server# ./l2pivot [-p] 10.0.0.2 172.16.0.2/24
         Client# ./l2pivot -c 10.0.0.2 172.16.0.3/24

 ==> (Client: 10.0.0.1 & 172.16.0.3)

Notes:
  If the server is unable to capture traffic that's meant for the client (i.e. no promiscuous
  mode available), you can use `-p` to masquerade/forward all traffic.
  
  Careful, everything coming from the target network will be forwarded to the client.
  This will render the server unreachable from the target network.

Example

In this example the promiscuous mode for the target interface of the virtual server was disabled to mirror a real switched network.

Example

Acknowledges

This tool was built with the help of countless stack overflow posts and based on the following great articles/projects:

Improvements

There's a lot that could be said about this project - but i feel like i've commented the code good enough to at least convey the ideas.

Unfortunately, i don't have time to keep working on this tool but a library independent port to windows would be awesome. Oh and the "encryption" of the tunnel could obviously be improved (currently just XOR).

Disclaimer

This has only been tested in a local virtual environment with Kali <-> Ubuntu <-> AD so far. Use this tool at your own risk. If you encounter any problems, however, feel free to open an issue.