mirror of
				https://github.com/therootcompany/telebit.git
				synced 2025-10-25 02:12:49 +00:00 
			
		
		
		
	Testing for AJ
This commit is contained in:
		
							parent
							
								
									fc89682b9e
								
							
						
					
					
						commit
						d7ef074ea2
					
				| @ -2,9 +2,9 @@ package admin | ||||
| 
 | ||||
| //DomainAPI -- Structure to hold the domain tracking for JSON | ||||
| type DomainAPI struct { | ||||
| 	Domain   string | ||||
| 	BytesIn  int64 | ||||
| 	BytesOut int64 | ||||
| 	Domain   string `json:"domain"` | ||||
| 	BytesIn  int64  `json:"bytes_in"` | ||||
| 	BytesOut int64  `json:"bytes_out"` | ||||
| } | ||||
| 
 | ||||
| //NewDomainAPI - Constructor | ||||
|  | ||||
| @ -9,11 +9,11 @@ import ( | ||||
| 
 | ||||
| //ServerAPI -- Structure to support the server API | ||||
| type ServerAPI struct { | ||||
| 	ServerName string | ||||
| 	Domains    []*DomainAPI | ||||
| 	Duration   float64 | ||||
| 	BytesIn    int64 | ||||
| 	BytesOut   int64 | ||||
| 	ServerName string       `json:"server_name"` | ||||
| 	Domains    []*DomainAPI `json:"domains"` | ||||
| 	Duration   float64      `json:"duration"` | ||||
| 	BytesIn    int64        `json:"bytes_in"` | ||||
| 	BytesOut   int64        `json:"bytes_out"` | ||||
| } | ||||
| 
 | ||||
| //NewServerAPI - Constructor | ||||
| @ -35,7 +35,7 @@ func NewServerAPI(c *connection.Connection) (s *ServerAPI) { | ||||
| 
 | ||||
| //ServerAPIContainer -- Holder for all the Servers | ||||
| type ServerAPIContainer struct { | ||||
| 	Servers []*ServerAPI | ||||
| 	Servers []*ServerAPI `json:"servers"` | ||||
| } | ||||
| 
 | ||||
| //NewServerAPIContainer -- Constructor | ||||
|  | ||||
							
								
								
									
										3
									
								
								rvpn/external/listener_webrequest.go
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								rvpn/external/listener_webrequest.go
									
									
									
									
										vendored
									
									
								
							| @ -47,10 +47,13 @@ func LaunchWebRequestExternalListener(serverBinding *string, connectionTable *co | ||||
| 				http.Error(w, "Domain not supported", http.StatusBadRequest) | ||||
| 
 | ||||
| 			} else { | ||||
| 				loginfo.Println("Domain Accepted") | ||||
| 				loginfo.Println(conn, rAddr, rPort) | ||||
| 				p := packer.NewPacker() | ||||
| 				p.Header.SetAddress(rAddr) | ||||
| 				p.Header.Port, err = strconv.Atoi(rPort) | ||||
| 				p.Header.Port = 8080 | ||||
| 				p.Header.Service = "http" | ||||
| 				p.Data.AppendBytes(dump) | ||||
| 				buf := p.PackV1() | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										175
									
								
								rvpn/external/server.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								rvpn/external/server.go
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,175 @@ | ||||
| package external | ||||
| 
 | ||||
| import ( | ||||
| 	"encoding/hex" | ||||
| 	"net" | ||||
| 	"net/http" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"bytes" | ||||
| 
 | ||||
| 	"bufio" | ||||
| 
 | ||||
| 	"git.daplie.com/Daplie/go-rvpn-server/rvpn/connection" | ||||
| 	"git.daplie.com/Daplie/go-rvpn-server/rvpn/packer" | ||||
| ) | ||||
| 
 | ||||
| //LaunchExternalServer -- used to listen for external connections destin for WSS | ||||
| func LaunchExternalServer(serverBinding string, connectionTable *connection.Table) { | ||||
| 	addr, err := net.ResolveTCPAddr("tcp4", serverBinding) | ||||
| 	if err != nil { | ||||
| 		loginfo.Println("Unabled to resolve ", serverBinding, " in launchExternalServer") | ||||
| 		loginfo.Println(err) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	loginfo.Println("passed ResolveTCPAddr") | ||||
| 
 | ||||
| 	listener, err := net.ListenTCP("tcp", addr) | ||||
| 	if err != nil { | ||||
| 		loginfo.Println("unable to bind ", serverBinding) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	loginfo.Println("listening") | ||||
| 
 | ||||
| 	for { | ||||
| 		conn, err := listener.AcceptTCP() | ||||
| 		if err != nil { | ||||
| 			loginfo.Println("Bad accept ", err) | ||||
| 			continue | ||||
| 		} | ||||
| 
 | ||||
| 		go handleConnection(conn, connectionTable) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| type protocol int | ||||
| 
 | ||||
| //Family -- ENUM for Address Family | ||||
| const ( | ||||
| 	protoHTTP protocol = iota + 1 | ||||
| 	protoHTTPS | ||||
| 	protoSSLV3 | ||||
| 	protoTLSV1 | ||||
| 	protoTLSV11 | ||||
| 	protoTLSV2 | ||||
| ) | ||||
| 
 | ||||
| //State -- state of connection | ||||
| type State struct { | ||||
| 	Protocol protocol | ||||
| } | ||||
| 
 | ||||
| //NewState -- Constructor | ||||
| func NewState() (p *State) { | ||||
| 	p = new(State) | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| func handleConnection(conn net.Conn, connectionTable *connection.Table) { | ||||
| 	defer conn.Close() | ||||
| 
 | ||||
| 	state := NewState() | ||||
| 
 | ||||
| 	var buffer [512]byte | ||||
| 
 | ||||
| 	for { | ||||
| 		cnt, err := conn.Read(buffer[0:]) | ||||
| 		if err != nil { | ||||
| 			return | ||||
| 		} | ||||
| 		loginfo.Println("state ", state, " ", state.Protocol) | ||||
| 		loginfo.Println("conn ", conn) | ||||
| 		loginfo.Println("byte read", cnt) | ||||
| 		loginfo.Println("buffer") | ||||
| 		loginfo.Println(hex.Dump(buffer[0:cnt])) | ||||
| 
 | ||||
| 		if state.Protocol == 0 { | ||||
| 			//attempt to discover protocol | ||||
| 
 | ||||
| 			// HTTP Identifcation | ||||
| 			if bytes.Contains(buffer[:], []byte{0x0d, 0x0a}) { | ||||
| 				//string protocol | ||||
| 				if bytes.ContainsAny(buffer[:], "HTTP/") { | ||||
| 					loginfo.Println("identifed HTTP") | ||||
| 					state.Protocol = protoHTTP | ||||
| 				} | ||||
| 
 | ||||
| 			} else if bytes.Contains(buffer[:], []byte{0x16, 0x03, 0x00}) { | ||||
| 				loginfo.Println("identifed SSLV3") | ||||
| 				state.Protocol = protoSSLV3 | ||||
| 
 | ||||
| 			} else if bytes.Contains(buffer[:], []byte{0x16, 0x03, 0x01}) { | ||||
| 				loginfo.Println("identifed TLSV1") | ||||
| 				state.Protocol = protoTLSV1 | ||||
| 
 | ||||
| 			} else if bytes.Contains(buffer[:], []byte{0x16, 0x03, 0x02}) { | ||||
| 				loginfo.Println("identifed TLSV1.1") | ||||
| 				state.Protocol = protoTLSV11 | ||||
| 
 | ||||
| 			} else if bytes.Contains(buffer[:], []byte{0x16, 0x03, 0x03}) { | ||||
| 				loginfo.Println("identifed TLSV2") | ||||
| 				state.Protocol = protoTLSV2 | ||||
| 
 | ||||
| 			} else { | ||||
| 				loginfo.Println("Protocol not identified", conn) | ||||
| 				return | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if state.Protocol == 0 { | ||||
| 			loginfo.Println("Making sure protocol is set") | ||||
| 			loginfo.Println(state) | ||||
| 			return | ||||
| 		} else if state.Protocol == protoHTTP { | ||||
| 			readBuffer := bytes.NewBuffer(buffer[0:cnt]) | ||||
| 			reader := bufio.NewReader(readBuffer) | ||||
| 			r, err := http.ReadRequest(reader) | ||||
| 
 | ||||
| 			loginfo.Println(r) | ||||
| 
 | ||||
| 			if err != nil { | ||||
| 				loginfo.Println("error parsing request") | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			hostname := r.Host | ||||
| 			loginfo.Println("Host: ", hostname) | ||||
| 
 | ||||
| 			if strings.Contains(hostname, ":") { | ||||
| 				arr := strings.Split(hostname, ":") | ||||
| 				hostname = arr[0] | ||||
| 			} | ||||
| 
 | ||||
| 			loginfo.Println("Remote: ", conn.RemoteAddr().String()) | ||||
| 
 | ||||
| 			remoteSplit := strings.Split(conn.RemoteAddr().String(), ":") | ||||
| 			rAddr := remoteSplit[0] | ||||
| 			rPort := remoteSplit[1] | ||||
| 
 | ||||
| 			if conn, ok := connectionTable.ConnByDomain(hostname); !ok { | ||||
| 				//matching connection can not be found based on ConnByDomain | ||||
| 				loginfo.Println("unable to match ", hostname, " to an existing connection") | ||||
| 				//http.Error(, "Domain not supported", http.StatusBadRequest) | ||||
| 
 | ||||
| 			} else { | ||||
| 
 | ||||
| 				loginfo.Println("Domain Accepted") | ||||
| 				loginfo.Println(conn, rAddr, rPort) | ||||
| 				p := packer.NewPacker() | ||||
| 				p.Header.SetAddress(rAddr) | ||||
| 				p.Header.Port, err = strconv.Atoi(rPort) | ||||
| 				p.Header.Port = 8080 | ||||
| 				p.Header.Service = "http" | ||||
| 				p.Data.AppendBytes(buffer[0:cnt]) | ||||
| 				buf := p.PackV1() | ||||
| 
 | ||||
| 				sendTrack := connection.NewSendTrack(buf.Bytes(), hostname) | ||||
| 				conn.SendCh() <- sendTrack | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										62
									
								
								rvpn/matching/protocol.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								rvpn/matching/protocol.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,62 @@ | ||||
| package matching | ||||
| 
 | ||||
| type headerTerm int | ||||
| type matchType int | ||||
| type protocolType int | ||||
| 
 | ||||
| //headerTerm -- ENUM for header terminator | ||||
| const ( | ||||
| 	CRLF2 headerTerm = iota | ||||
| 	ZER0 | ||||
| ) | ||||
| 
 | ||||
| //Family -- ENUM for Address Family | ||||
| const ( | ||||
| 	BYTES matchType = iota | ||||
| 	REGEX | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	pHTTP = iota + 1 | ||||
| 	pTLS | ||||
| 	pSSH | ||||
| ) | ||||
| 
 | ||||
| //Protocol -- | ||||
| type Protocol struct { | ||||
| 	HeaderTerm  headerTerm | ||||
| 	MatchType   matchType | ||||
| 	Type        protocolType | ||||
| 	SearchRegex string | ||||
| 	SearchBytes []byte | ||||
| } | ||||
| 
 | ||||
| //NewProtocol -- Constructor | ||||
| func NewProtocol() (p *Protocol) { | ||||
| 	p = new(Protocol) | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| //Protocols -- | ||||
| type Protocols struct { | ||||
| 	protocols []*Protocol | ||||
| } | ||||
| 
 | ||||
| func (p *Protocols) add(protocol *Protocol) []*Protocol { | ||||
| 	p.protocols = append(p.protocols, protocol) | ||||
| 	return p.protocols | ||||
| } | ||||
| 
 | ||||
| //NewProtocols -- | ||||
| func NewProtocols() (p *Protocols) { | ||||
| 	p = new(Protocols) | ||||
| 	p.protocols = make([]*Protocol, 0) | ||||
| 
 | ||||
| 	newp := NewProtocol() | ||||
| 	newp.MatchType = REGEX | ||||
| 	newp.HeaderTerm = CRLF2 | ||||
| 	newp.MatchType = pHTTP | ||||
| 	p.add(newp) | ||||
| 
 | ||||
| 	return | ||||
| } | ||||
							
								
								
									
										13
									
								
								rvpn/matching/setup.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								rvpn/matching/setup.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | ||||
| package matching | ||||
| 
 | ||||
| import "log" | ||||
| import "os" | ||||
| 
 | ||||
| func init() { | ||||
| 	logFlags := log.Ldate | log.Lmicroseconds | log.Lshortfile | ||||
| 	loginfo := log.New(os.Stdout, "INFO: matching: ", logFlags) | ||||
| 	logdebug := log.New(os.Stdout, "DEBUG: matching:", logFlags) | ||||
| 
 | ||||
| 	loginfo.Println("") | ||||
| 	logdebug.Println("") | ||||
| } | ||||
| @ -2,6 +2,7 @@ package packer | ||||
| 
 | ||||
| import ( | ||||
| 	"bytes" | ||||
| 	"encoding/hex" | ||||
| 	"fmt" | ||||
| ) | ||||
| 
 | ||||
| @ -47,6 +48,7 @@ func (p *Packer) PackV1() (b bytes.Buffer) { | ||||
| 	fmt.Println("meta: ", metaBuf) | ||||
| 	fmt.Println("Data: ", p.Data.buffer) | ||||
| 	fmt.Println("Buffer: ", buf.Bytes()) | ||||
| 	fmt.Println("Buffer: ", hex.Dump(buf.Bytes())) | ||||
| 	fmt.Printf("Buffer %s", buf.Bytes()) | ||||
| 
 | ||||
| 	b = buf | ||||
|  | ||||
| @ -20,8 +20,8 @@ const ( | ||||
| ) | ||||
| 
 | ||||
| var addressFamilyText = [...]string{ | ||||
| 	"ipv4", | ||||
| 	"ipv6", | ||||
| 	"IPv4", | ||||
| 	"IPv6", | ||||
| } | ||||
| 
 | ||||
| func newPackerHeader() (p *packerHeader) { | ||||
|  | ||||
| @ -56,8 +56,8 @@ func Run() { | ||||
| 	connectionTable = connection.NewTable() | ||||
| 	go connectionTable.Run() | ||||
| 	go client.LaunchClientListener(connectionTable, &secretKey, &argServerBinding) | ||||
| 	go external.LaunchWebRequestExternalListener(&argServerExternalBinding, connectionTable) | ||||
| 
 | ||||
| 	//go external.LaunchWebRequestExternalListener(&argServerExternalBinding, connectionTable) | ||||
| 	go external.LaunchExternalServer(argServerExternalBinding, connectionTable) | ||||
| 	err := admin.LaunchAdminListener(&argServerAdminBinding, connectionTable) | ||||
| 	if err != nil { | ||||
| 		loginfo.Println("LauchAdminListener failed: ", err) | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user