Skip to content

Commit

Permalink
format
Browse files Browse the repository at this point in the history
  • Loading branch information
fatedier committed Jun 8, 2017
1 parent 6742fa2 commit 70e2aee
Show file tree
Hide file tree
Showing 6 changed files with 105 additions and 83 deletions.
2 changes: 1 addition & 1 deletion models/plugin/http_proxy.go
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ func (hp *HttpProxy) ConnectHandler(rw http.ResponseWriter, req *http.Request) {
client.Close()
return
}
client.Write([]byte("HTTP/1.0 200 OK\r\n\r\n"))
client.Write([]byte("HTTP/1.1 200 OK\r\n\r\n"))

go frpIo.Join(remote, client)
}
Expand Down
90 changes: 55 additions & 35 deletions utils/net/conn.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,12 @@
package net

import (
"bytes"
"errors"
"fmt"
"io"
"net"
"sync"
"time"

"github.com/fatedier/frp/utils/log"
Expand Down Expand Up @@ -48,6 +51,13 @@ type WrapReadWriteCloserConn struct {
log.Logger
}

func WrapReadWriteCloserToConn(rwc io.ReadWriteCloser) Conn {
return &WrapReadWriteCloserConn{
ReadWriteCloser: rwc,
Logger: log.NewPrefixLogger(""),
}
}

func (conn *WrapReadWriteCloserConn) LocalAddr() net.Addr {
return (*net.TCPAddr)(nil)
}
Expand All @@ -57,47 +67,15 @@ func (conn *WrapReadWriteCloserConn) RemoteAddr() net.Addr {
}

func (conn *WrapReadWriteCloserConn) SetDeadline(t time.Time) error {
return nil
return &net.OpError{Op: "set", Net: "wrap", Source: nil, Addr: nil, Err: errors.New("deadline not supported")}
}

func (conn *WrapReadWriteCloserConn) SetReadDeadline(t time.Time) error {
return nil
return &net.OpError{Op: "set", Net: "wrap", Source: nil, Addr: nil, Err: errors.New("deadline not supported")}
}

func (conn *WrapReadWriteCloserConn) SetWriteDeadline(t time.Time) error {
return nil
}

func WrapReadWriteCloserToConn(rwc io.ReadWriteCloser) Conn {
return &WrapReadWriteCloserConn{
ReadWriteCloser: rwc,
Logger: log.NewPrefixLogger(""),
}
}

type Listener interface {
Accept() (Conn, error)
Close() error
log.Logger
}

type LogListener struct {
l net.Listener
net.Listener
log.Logger
}

func WrapLogListener(l net.Listener) Listener {
return &LogListener{
l: l,
Listener: l,
Logger: log.NewPrefixLogger(""),
}
}

func (logL *LogListener) Accept() (Conn, error) {
c, err := logL.l.Accept()
return WrapConn(c), err
return &net.OpError{Op: "set", Net: "wrap", Source: nil, Addr: nil, Err: errors.New("deadline not supported")}
}

func ConnectServer(protocol string, addr string) (c Conn, err error) {
Expand Down Expand Up @@ -136,3 +114,45 @@ func ConnectServerByHttpProxy(httpProxy string, protocol string, addr string) (c
return nil, fmt.Errorf("unsupport protocol: %s", protocol)
}
}

type SharedConn struct {
Conn
sync.Mutex
buf *bytes.Buffer
}

// the bytes you read in io.Reader, will be reserved in SharedConn
func NewShareConn(conn Conn) (*SharedConn, io.Reader) {
sc := &SharedConn{
Conn: conn,
buf: bytes.NewBuffer(make([]byte, 0, 1024)),
}
return sc, io.TeeReader(conn, sc.buf)
}

func (sc *SharedConn) Read(p []byte) (n int, err error) {
sc.Lock()
if sc.buf == nil {
sc.Unlock()
return sc.Conn.Read(p)
}
sc.Unlock()
n, err = sc.buf.Read(p)

if err == io.EOF {
sc.Lock()
sc.buf = nil
sc.Unlock()
var n2 int
n2, err = sc.Conn.Read(p[n:])

n += n2
}
return
}

func (sc *SharedConn) WriteBuff(buffer []byte) (err error) {
sc.buf.Reset()
_, err = sc.buf.Write(buffer)
return err
}
46 changes: 46 additions & 0 deletions utils/net/listener.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
// Copyright 2017 fatedier, [email protected]
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package net

import (
"net"

"github.com/fatedier/frp/utils/log"
)

type Listener interface {
Accept() (Conn, error)
Close() error
log.Logger
}

type LogListener struct {
l net.Listener
net.Listener
log.Logger
}

func WrapLogListener(l net.Listener) Listener {
return &LogListener{
l: l,
Listener: l,
Logger: log.NewPrefixLogger(""),
}
}

func (logL *LogListener) Accept() (Conn, error) {
c, err := logL.l.Accept()
return WrapConn(c), err
}
4 changes: 2 additions & 2 deletions utils/vhost/http.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ type HttpMuxer struct {

func GetHttpRequestInfo(c frpNet.Conn) (_ frpNet.Conn, _ map[string]string, err error) {
reqInfoMap := make(map[string]string, 0)
sc, rd := newShareConn(c)
sc, rd := frpNet.NewShareConn(c)

request, err := http.ReadRequest(bufio.NewReader(rd))
if err != nil {
Expand All @@ -62,7 +62,7 @@ func NewHttpMuxer(listener frpNet.Listener, timeout time.Duration) (*HttpMuxer,
}

func HttpHostNameRewrite(c frpNet.Conn, rewriteHost string) (_ frpNet.Conn, err error) {
sc, rd := newShareConn(c)
sc, rd := frpNet.NewShareConn(c)
var buff []byte
if buff, err = hostNameRewrite(rd, rewriteHost); err != nil {
return sc, err
Expand Down
2 changes: 1 addition & 1 deletion utils/vhost/https.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ func readHandshake(rd io.Reader) (host string, err error) {

func GetHttpsHostname(c frpNet.Conn) (sc frpNet.Conn, _ map[string]string, err error) {
reqInfoMap := make(map[string]string, 0)
sc, rd := newShareConn(c)
sc, rd := frpNet.NewShareConn(c)
host, err := readHandshake(rd)
if err != nil {
return sc, reqInfoMap, err
Expand Down
44 changes: 0 additions & 44 deletions utils/vhost/vhost.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,7 @@
package vhost

import (
"bytes"
"fmt"
"io"
"strings"
"sync"
"time"
Expand Down Expand Up @@ -209,45 +207,3 @@ func (l *Listener) Close() error {
func (l *Listener) Name() string {
return l.name
}

type sharedConn struct {
frpNet.Conn
sync.Mutex
buff *bytes.Buffer
}

// the bytes you read in io.Reader, will be reserved in sharedConn
func newShareConn(conn frpNet.Conn) (*sharedConn, io.Reader) {
sc := &sharedConn{
Conn: conn,
buff: bytes.NewBuffer(make([]byte, 0, 1024)),
}
return sc, io.TeeReader(conn, sc.buff)
}

func (sc *sharedConn) Read(p []byte) (n int, err error) {
sc.Lock()
if sc.buff == nil {
sc.Unlock()
return sc.Conn.Read(p)
}
sc.Unlock()
n, err = sc.buff.Read(p)

if err == io.EOF {
sc.Lock()
sc.buff = nil
sc.Unlock()
var n2 int
n2, err = sc.Conn.Read(p[n:])

n += n2
}
return
}

func (sc *sharedConn) WriteBuff(buffer []byte) (err error) {
sc.buff.Reset()
_, err = sc.buff.Write(buffer)
return err
}

0 comments on commit 70e2aee

Please sign in to comment.