about summary refs log blame commit diff
path: root/main.go
blob: 3bb4ac9fd8d64da02ea1d78163a0b79bf1387608 (plain) (tree)














































































































                                                                                  
package main

import (
	"encoding/hex"
	"flag"
	"fmt"
	"io/ioutil"
	"log"
	"net"
	"os"
)

func main() {
	log.SetPrefix("gProxy: ")
	fmt.Println("Starting gProxy...")

	var localAddr string
	var remoteAddr string

	getArgs(&localAddr, &remoteAddr)

	addr, err := net.ResolveTCPAddr("tcp", localAddr)
	if err != nil {
		panic(err)
	}

	listener, err := net.ListenTCP("tcp", addr)
	if err != nil {
		panic(err)
	}

	fmt.Println("Listening for connections...")

	for {
		conn, err := listener.AcceptTCP()
		if err != nil {
			panic(err)
		}
		go proxyConn(conn, remoteAddr)
	}
}

func proxyConn(conn *net.TCPConn, remoteAddr string) {
	fmt.Println("New connection from", conn.RemoteAddr())

	defer conn.Close()

	rAddr, err := net.ResolveTCPAddr("tcp", remoteAddr)
	if err != nil {
		panic(err)
	}

	rConn, err := net.DialTCP("tcp", nil, rAddr)
	if err != nil {
		panic(err)
	}

	defer rConn.Close()

	go func() {
		log.Println("waiting for data from client")
		data := make([]byte, 1024)
		for {
			n, err := conn.Read(data)
			if err != nil {
				break
			}
			_, err = rConn.Write(data[:n])
			if err != nil {
				break
			}
			log.Printf("sent:\n%v\nend of send\n", hex.Dump(data[:n]))
		}
	}()

	data := make([]byte, 1024)
	for {
		n, err := rConn.Read(data)
		if err != nil {
			break
		}
		_, err = conn.Write(data[:n])
		if err != nil {
			break
		}
		log.Printf("recv:\n%v\nend of recv\n", hex.Dump(data[:n]))
	}

	fmt.Println("Closed connection from", conn.RemoteAddr())
}

func getArgs(localAddr *string, remoteAddr *string) {
	flag.StringVar(localAddr, "l", "0.0.0.0:9999", "local address")
	flag.StringVar(remoteAddr, "r", "", "remote address")
	var dbg = flag.Bool("d", false, "debug info")

	flag.Parse()

	if *remoteAddr == "" {
		usage()
		os.Exit(1)
	}

	if *dbg == false {
		log.SetOutput(ioutil.Discard)
	}
}

func usage() {
	fmt.Println("./proxy -r [remote addr] (-d)")
}