-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.go
90 lines (85 loc) · 2.28 KB
/
main.go
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
package main
import (
"flag"
"fmt"
"io"
"log"
"os"
"github.com/skywind3000/tcpdup/forward"
)
func getlogger() *log.Logger {
logFile, err := os.OpenFile("tcpdup.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
if err != nil {
log.Printf("Failed to open log file: %s", err)
return log.Default()
}
multiWriter := io.MultiWriter(logFile, os.Stdout)
logger := log.New(multiWriter, "INFO: ", log.Ldate|log.Ltime|log.Lshortfile)
return logger
}
func start(listen string, target string, input string, output string) int {
if listen == "" || target == "" {
return -1
}
logger := getlogger()
logger.Printf("Service starting:\n")
logger.Printf("config: listen %s\n", listen)
logger.Printf("config: target %s\n", target)
logger.Printf("config: input %s\n", input)
logger.Printf("config: output %s\n", output)
service := forward.NewTcpForward()
service.SetLogger(logger)
service.SetInput(input)
service.SetOutput(output)
listenAddr := forward.AddressResolve(listen)
if listenAddr == nil {
logger.Printf("invalid listen address: %s\n", listen)
return -1
}
targetAddr := forward.AddressResolve(target)
if targetAddr == nil {
logger.Printf("invalid target address: %s\n", target)
return -1
}
service.Open(listenAddr, targetAddr)
service.Wait()
return 0
}
func main() {
listen := flag.String("listen", "", "local address (required), eg: 0.0.0.0:8080")
target := flag.String("target", "", "destination address (required), eg: 8.8.8.8:8080")
input := flag.String("input", "", "input duplication address (optional), eg: 127.0.0.1:8081")
output := flag.String("output", "", "output duplication address (optional), eg: 127.0.0.1:8082")
flag.Usage = func() {
flagSet := flag.CommandLine
fmt.Printf("Usage of %s:\n", os.Args[0])
order := []string{"listen", "target", "input", "output"}
for _, name := range order {
flag := flagSet.Lookup(name)
fmt.Printf("-%s\n", flag.Name)
fmt.Printf(" %s\n", flag.Usage)
}
}
if false {
start("0.0.0.0:8080", "127.0.0.1:8000", "127.0.0.1:8081", "127.0.0.1:8082")
return
}
flag.Parse()
if listen == nil || target == nil {
flag.Usage()
return
}
if *listen == "" || *target == "" {
flag.Usage()
return
}
i := ""
o := ""
if input != nil {
i = *input
}
if output != nil {
o = *output
}
start(*listen, *target, i, o)
}