Skip to content

Commit 792150d

Browse files
committed
Initial proxy that parses SNI and Host headers
1 parent ca40968 commit 792150d

File tree

1 file changed

+71
-0
lines changed
  • server/common/oursrc/scripts-proxy

1 file changed

+71
-0
lines changed
Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
package main
2+
3+
import (
4+
"context"
5+
"flag"
6+
"fmt"
7+
"log"
8+
"net"
9+
"strings"
10+
11+
"inet.af/tcpproxy"
12+
)
13+
14+
var (
15+
httpAddrs = flag.String("http_addrs", ":80", "comma-separated addresses to listen for HTTP traffic on")
16+
sniAddrs = flag.String("sni_addrs", ":443,:444", "comma-separated addresses to listen for SNI traffic on")
17+
defaultHost = flag.String("default_host", "scripts.mit.edu", "default host to route traffic to if SNI/Host header cannot be parsed or cannot be found in LDAP")
18+
)
19+
20+
func always(context.Context, string) bool {
21+
return true
22+
}
23+
24+
type ldapTarget struct {
25+
}
26+
27+
func (l *ldapTarget) HandleConn(netConn net.Conn) {
28+
var pool string
29+
var err error
30+
if conn, ok := netConn.(*tcpproxy.Conn); ok {
31+
pool, err = l.resolvePool(conn.HostName)
32+
if err != nil {
33+
log.Printf("resolving %q: %v", conn.HostName, err)
34+
}
35+
}
36+
if pool == "" {
37+
pool, err = l.resolvePool(*defaultHost)
38+
if err != nil {
39+
log.Printf("resolving default pool: %v", err)
40+
}
41+
}
42+
if pool == "" {
43+
netConn.Close()
44+
return
45+
}
46+
laddr := netConn.LocalAddr().(*net.TCPAddr)
47+
dp := &tcpproxy.DialProxy{
48+
Addr: fmt.Sprintf("%s:%d", pool, laddr.Port),
49+
// TODO: Set DialContext to override the source address
50+
}
51+
dp.HandleConn(netConn)
52+
}
53+
54+
func (l *ldapTarget) resolvePool(hostname string) (string, error) {
55+
return "18.4.86.22", nil
56+
}
57+
58+
func main() {
59+
flag.Parse()
60+
61+
var p tcpproxy.Proxy
62+
t := &ldapTarget{}
63+
for _, addr := range strings.Split(*httpAddrs, ",") {
64+
p.AddHTTPHostMatchRoute(addr, always, t)
65+
}
66+
for _, addr := range strings.Split(*sniAddrs, ",") {
67+
p.AddStopACMESearch(addr)
68+
p.AddSNIMatchRoute(addr, always, t)
69+
}
70+
log.Fatal(p.Run())
71+
}

0 commit comments

Comments
 (0)