42 lines
1.3 KiB
Text
42 lines
1.3 KiB
Text
|
== NAT Hole Punching Example ==
|
||
|
|
||
|
This code should never be used, ever. But, it's a nice demonstration of how
|
||
|
to punch holes and have two NAT'd peers talk to each other.
|
||
|
|
||
|
Compile with:
|
||
|
$ gcc nat-punch-client.c -o client -lresolv
|
||
|
$ gcc nat-punch-server.c -o server
|
||
|
|
||
|
|
||
|
Server is 1.2.3.4 and is on the public internet accepting UDP:49918.
|
||
|
Client A is NAT'd and doesnt't know its IP address.
|
||
|
Client B is NAT'd and doesnt't know its IP address.
|
||
|
|
||
|
|
||
|
Server runs:
|
||
|
$ ./server
|
||
|
|
||
|
Client A runs:
|
||
|
# ip link add wg0 type wireguard
|
||
|
# ip addr add 10.200.200.1 peer 10.200.200.2 dev wg0
|
||
|
# wg set wg0 private-key ... peer ... allowed-ips 10.200.200.2/32
|
||
|
# ./client 1.2.3.4 wg0
|
||
|
# ping 10.200.200.2
|
||
|
|
||
|
Client B runs:
|
||
|
# ip link add wg0 type wireguard
|
||
|
# ip addr add 10.200.200.2 peer 10.200.200.1 dev wg0
|
||
|
# wg set wg0 private-key ... peer ... allowed-ips 10.200.200.1/32
|
||
|
# ./client 1.2.3.4 wg0
|
||
|
# ping 10.200.200.1
|
||
|
|
||
|
And voila! Client A and Client B can speak from behind NAT.
|
||
|
|
||
|
|
||
|
|
||
|
-----
|
||
|
Keep in mind that this is proof-of-concept example code. It is not code that
|
||
|
should be used in production, ever. It is woefully insecure, and is unsuitable
|
||
|
for any real usage. With that said, this is useful as a learning example of
|
||
|
how NAT hole punching might work within a more developed solution.
|