proxy arp

proxy ARP golang

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package main

import (
"flag"
"log"
"net"

"github.com/mdlayher/arp"
)

type cliFlag struct {
Ifname string
Debug bool
}

func main() {

var cli cliFlag
flag.StringVar(&cli.Ifname, "i", "vlan1000", "Proxy Arp interface name")
flag.BoolVar(&cli.Debug, "v", false, "show verbose informations")
flag.Parse()

ifname, err := net.InterfaceByName(cli.Ifname)

if err != nil {
log.Fatalln("get interface by name: ", err)
}
client, _ := arp.Dial(ifname)
for {
arp_recv, _, err := client.Read()

if err != nil {
log.Fatalln("read packets error: ", err)

}
if cli.Debug {
log.Println("recv arp: ", arp_recv)
}
arp_replay, err := arp.NewPacket(arp.OperationReply, ifname.HardwareAddr, arp_recv.TargetIP, arp_recv.SenderHardwareAddr, arp_recv.SenderIP)
if err != nil {
log.Fatalln("create packets error: ", err)
}
destinationMAC := arp_recv.SenderHardwareAddr
err = client.WriteTo(arp_replay, destinationMAC)
if err != nil {

log.Fatalln("sent packet error: ", err)
}
if cli.Debug {
log.Println("sent arp: ", arp_replay)
}

}

}


go.mod

1
2
3
4
5
6
7
8
9
10
11
12
13
14
module proxy_arp

go 1.17

require github.com/google/gopacket v1.1.19

require (
github.com/mdlayher/arp v0.0.0-20191213142603-f72070a231fc // indirect
github.com/mdlayher/ethernet v0.0.0-20190606142754-0394541c37b7 // indirect
github.com/mdlayher/raw v0.0.0-20211126142749-4eae47f3d54b // indirect
golang.org/x/net v0.0.0-20211216030914-fe4d6282115f // indirect
golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e // indirect
)

makefile

1
2
3
4
5
linux-arm64:	
CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -o ./bin/proxy_arp.arm64 src/main.go
linux:
CGO_ENABLED=1 GOOS=linux GOARCH=amd64 go build -o ./bin/proxy_arp src/main.go