2017-09-27 13:44:02 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"net"
|
|
|
|
)
|
|
|
|
|
|
|
|
var whitelist []string
|
|
|
|
|
|
|
|
func main() {
|
2017-09-27 14:24:38 +00:00
|
|
|
go listener(9090, whitelist_handler)
|
|
|
|
listener(8080, gateway_handler)
|
|
|
|
}
|
|
|
|
|
|
|
|
func listener(port int, listen_func func(c net.Conn)) {
|
|
|
|
ln, err := net.Listen("tcp", fmt.Sprintf(":%d", port))
|
2017-09-27 13:44:02 +00:00
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println("Errur on Listening")
|
|
|
|
} else {
|
2017-09-27 14:24:38 +00:00
|
|
|
fmt.Println("Opened :", port)
|
2017-09-27 13:44:02 +00:00
|
|
|
for {
|
|
|
|
conn, err := ln.Accept()
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println("Errur on Accepting")
|
|
|
|
} else {
|
2017-09-27 14:24:38 +00:00
|
|
|
go listen_func(conn)
|
2017-09-27 13:44:02 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-27 14:24:38 +00:00
|
|
|
func whitelist_handler(c net.Conn) {
|
2017-09-27 13:44:02 +00:00
|
|
|
host, _, _ := net.SplitHostPort(c.RemoteAddr().String())
|
|
|
|
|
2017-09-27 14:44:52 +00:00
|
|
|
io.WriteString(c, fmt.Sprintf("Knock Knock, %s.", host))
|
2017-09-27 14:24:38 +00:00
|
|
|
add_to_whitelist(host)
|
|
|
|
c.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func gateway_handler(c net.Conn) {
|
|
|
|
host, _, _ := net.SplitHostPort(c.RemoteAddr().String())
|
|
|
|
|
2017-09-27 13:44:02 +00:00
|
|
|
if is_whitelisted(host) {
|
2017-09-27 14:24:38 +00:00
|
|
|
fmt.Println("OK: ", host)
|
2017-09-27 14:40:29 +00:00
|
|
|
proxy(c)
|
2017-09-27 13:44:02 +00:00
|
|
|
} else {
|
2017-09-27 14:24:38 +00:00
|
|
|
fmt.Println("BLOCK: ", host)
|
2017-09-27 13:44:02 +00:00
|
|
|
}
|
|
|
|
c.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func add_to_whitelist(addr string) {
|
|
|
|
if ! is_whitelisted(addr) {
|
|
|
|
whitelist = append(whitelist, addr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func is_whitelisted(addr string) bool {
|
|
|
|
for i:=0; i < len(whitelist); i++ {
|
|
|
|
if whitelist[i] == addr {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
2017-09-27 14:40:29 +00:00
|
|
|
|
|
|
|
func proxy(c net.Conn) {
|
|
|
|
ln, err := net.Dial("tcp", "ip.darknebu.la:443")
|
|
|
|
if err != nil {
|
|
|
|
fmt.Println("ERR proxy")
|
|
|
|
} else {
|
|
|
|
go io.Copy(c, ln)
|
|
|
|
io.Copy(ln, c)
|
|
|
|
}
|
|
|
|
}
|