goknockr/knockr.go

83 lines
1.3 KiB
Go
Raw Normal View History

2017-09-27 13:44:02 +00:00
package main
import (
"fmt"
"io"
"net"
)
var whitelist []string
func main() {
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 {
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 {
go listen_func(conn)
2017-09-27 13:44:02 +00:00
}
}
}
}
func whitelist_handler(c net.Conn) {
2017-09-27 13:44:02 +00:00
host, _, _ := net.SplitHostPort(c.RemoteAddr().String())
io.WriteString(c, "Knock Knock, ")
io.WriteString(c, host)
io.WriteString(c, ". ")
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) {
fmt.Println("OK: ", host)
2017-09-27 14:40:29 +00:00
proxy(c)
2017-09-27 13:44:02 +00:00
} else {
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)
}
}