-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathmain.go
64 lines (54 loc) · 1.43 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
package main
// socksie is a SOCKS4/5 compatible proxy that forwards connections via
// SSH to a remote host
import (
"flag"
"fmt"
"log"
"net"
"os"
"golang.org/x/crypto/ssh"
)
var (
USER = flag.String("user", os.Getenv("USER"), "ssh username")
HOST = flag.String("host", "127.0.0.1", "ssh server hostname")
PORT = flag.Int("port", 1080, "socksie listening port")
PASS = flag.String("pass", os.Getenv("SOCKSIE_SSH_PASSWORD"), "ssh password")
)
func init() { flag.Parse() }
type Dialer interface {
DialTCP(net string, laddr, raddr *net.TCPAddr) (net.Conn, error)
}
func main() {
var auths []ssh.AuthMethod
if *PASS != "" {
auths = append(auths, ssh.Password(*PASS))
}
config := &ssh.ClientConfig{
User: *USER,
Auth: auths,
}
addr := fmt.Sprintf("%s:%d", *HOST, 22)
conn, err := ssh.Dial("tcp", addr, config)
if err != nil {
log.Fatalf("unable to connect to [%s]: %v", addr, err)
}
defer conn.Close()
addr = fmt.Sprintf("%s:%d", "0", *PORT)
l, err := net.Listen("tcp", addr)
if err != nil {
log.Fatalf("unable to listen on SOCKS port [%s]: %v", addr, err)
}
defer l.Close()
log.Printf("listening for incoming SOCKS connections on [%s]\n", addr)
for {
c, err := l.Accept()
if err != nil {
log.Fatalf("failed to accept incoming SOCKS connection: %v", err)
}
go handleConn(c.(*net.TCPConn), conn)
}
log.Println("waiting for all existing connections to finish")
connections.Wait()
log.Println("shutting down")
}