mirror of https://github.com/v2ray/v2ray-core
parent
5a30e27f04
commit
5f4acaa9ea
|
@ -87,6 +87,17 @@ func NewReader(reader io.Reader) Reader {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func NewMergingReader(reader io.Reader) Reader {
|
||||||
|
return NewMergingReaderSize(reader, 32*1024)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewMergingReaderSize(reader io.Reader, size uint32) Reader {
|
||||||
|
return &BytesToBufferReader{
|
||||||
|
reader: reader,
|
||||||
|
buffer: make([]byte, size),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ToBytesReader converts a Reaaer to io.Reader.
|
// ToBytesReader converts a Reaaer to io.Reader.
|
||||||
func ToBytesReader(stream Reader) io.Reader {
|
func ToBytesReader(stream Reader) io.Reader {
|
||||||
return &bufferToBytesReader{
|
return &bufferToBytesReader{
|
||||||
|
@ -107,6 +118,17 @@ func NewWriter(writer io.Writer) Writer {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func NewMergingWriter(writer io.Writer) Writer {
|
||||||
|
return NewMergingWriterSize(writer, 4096)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewMergingWriterSize(writer io.Writer, size uint32) Writer {
|
||||||
|
return &mergingWriter{
|
||||||
|
writer: writer,
|
||||||
|
buffer: make([]byte, size),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ToBytesWriter converts a Writer to io.Writer
|
// ToBytesWriter converts a Writer to io.Writer
|
||||||
func ToBytesWriter(writer Writer) io.Writer {
|
func ToBytesWriter(writer Writer) io.Writer {
|
||||||
return &bytesToBufferWriter{
|
return &bytesToBufferWriter{
|
||||||
|
|
|
@ -25,6 +25,23 @@ func (w *writerAdapter) Write(mb MultiBuffer) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type mergingWriter struct {
|
||||||
|
writer io.Writer
|
||||||
|
buffer []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w *mergingWriter) Write(mb MultiBuffer) error {
|
||||||
|
defer mb.Release()
|
||||||
|
|
||||||
|
for !mb.IsEmpty() {
|
||||||
|
nBytes, _ := mb.Read(w.buffer)
|
||||||
|
if _, err := w.writer.Write(w.buffer[:nBytes]); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
type bytesToBufferWriter struct {
|
type bytesToBufferWriter struct {
|
||||||
writer Writer
|
writer Writer
|
||||||
}
|
}
|
||||||
|
|
|
@ -168,6 +168,10 @@ type SystemConnection interface {
|
||||||
Overhead() int
|
Overhead() int
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
_ buf.MultiBufferWriter = (*Connection)(nil)
|
||||||
|
)
|
||||||
|
|
||||||
// Connection is a KCP connection over UDP.
|
// Connection is a KCP connection over UDP.
|
||||||
type Connection struct {
|
type Connection struct {
|
||||||
conn SystemConnection
|
conn SystemConnection
|
||||||
|
@ -194,6 +198,8 @@ type Connection struct {
|
||||||
|
|
||||||
dataUpdater *Updater
|
dataUpdater *Updater
|
||||||
pingUpdater *Updater
|
pingUpdater *Updater
|
||||||
|
|
||||||
|
mergingWriter buf.Writer
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewConnection create a new KCP connection between local and remote.
|
// NewConnection create a new KCP connection between local and remote.
|
||||||
|
@ -332,23 +338,10 @@ func (v *Connection) Write(b []byte) (int, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Connection) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
|
func (c *Connection) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
|
||||||
defer mb.Release()
|
if c.mergingWriter == nil {
|
||||||
|
c.mergingWriter = buf.NewMergingWriterSize(c, c.mss)
|
||||||
buffer := buf.New()
|
|
||||||
defer buffer.Release()
|
|
||||||
|
|
||||||
totalBytes := 0
|
|
||||||
for !mb.IsEmpty() {
|
|
||||||
buffer.Reset(func(b []byte) (int, error) {
|
|
||||||
return mb.Read(b[:c.mss])
|
|
||||||
})
|
|
||||||
nBytes, err := c.Write(buffer.Bytes())
|
|
||||||
totalBytes += nBytes
|
|
||||||
if err != nil {
|
|
||||||
return totalBytes, err
|
|
||||||
}
|
}
|
||||||
}
|
return mb.Len(), c.mergingWriter.Write(mb)
|
||||||
return totalBytes, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *Connection) SetState(state State) {
|
func (v *Connection) SetState(state State) {
|
||||||
|
|
|
@ -2,13 +2,12 @@ package tcp
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"crypto/tls"
|
|
||||||
|
|
||||||
"v2ray.com/core/app/log"
|
"v2ray.com/core/app/log"
|
||||||
"v2ray.com/core/common"
|
"v2ray.com/core/common"
|
||||||
v2net "v2ray.com/core/common/net"
|
v2net "v2ray.com/core/common/net"
|
||||||
"v2ray.com/core/transport/internet"
|
"v2ray.com/core/transport/internet"
|
||||||
v2tls "v2ray.com/core/transport/internet/tls"
|
"v2ray.com/core/transport/internet/tls"
|
||||||
)
|
)
|
||||||
|
|
||||||
func getTCPSettingsFromContext(ctx context.Context) *Config {
|
func getTCPSettingsFromContext(ctx context.Context) *Config {
|
||||||
|
@ -28,7 +27,7 @@ func Dial(ctx context.Context, dest v2net.Destination) (internet.Connection, err
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if securitySettings := internet.SecuritySettingsFromContext(ctx); securitySettings != nil {
|
if securitySettings := internet.SecuritySettingsFromContext(ctx); securitySettings != nil {
|
||||||
tlsConfig, ok := securitySettings.(*v2tls.Config)
|
tlsConfig, ok := securitySettings.(*tls.Config)
|
||||||
if ok {
|
if ok {
|
||||||
config := tlsConfig.GetTLSConfig()
|
config := tlsConfig.GetTLSConfig()
|
||||||
if dest.Address.Family().IsDomain() {
|
if dest.Address.Family().IsDomain() {
|
||||||
|
|
|
@ -2,7 +2,7 @@ package tcp
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"crypto/tls"
|
gotls "crypto/tls"
|
||||||
"net"
|
"net"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ import (
|
||||||
v2net "v2ray.com/core/common/net"
|
v2net "v2ray.com/core/common/net"
|
||||||
"v2ray.com/core/common/retry"
|
"v2ray.com/core/common/retry"
|
||||||
"v2ray.com/core/transport/internet"
|
"v2ray.com/core/transport/internet"
|
||||||
v2tls "v2ray.com/core/transport/internet/tls"
|
"v2ray.com/core/transport/internet/tls"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -21,7 +21,7 @@ var (
|
||||||
type TCPListener struct {
|
type TCPListener struct {
|
||||||
ctx context.Context
|
ctx context.Context
|
||||||
listener *net.TCPListener
|
listener *net.TCPListener
|
||||||
tlsConfig *tls.Config
|
tlsConfig *gotls.Config
|
||||||
authConfig internet.ConnectionAuthenticator
|
authConfig internet.ConnectionAuthenticator
|
||||||
config *Config
|
config *Config
|
||||||
conns chan<- internet.Connection
|
conns chan<- internet.Connection
|
||||||
|
@ -46,7 +46,7 @@ func ListenTCP(ctx context.Context, address v2net.Address, port v2net.Port, conn
|
||||||
conns: conns,
|
conns: conns,
|
||||||
}
|
}
|
||||||
if securitySettings := internet.SecuritySettingsFromContext(ctx); securitySettings != nil {
|
if securitySettings := internet.SecuritySettingsFromContext(ctx); securitySettings != nil {
|
||||||
tlsConfig, ok := securitySettings.(*v2tls.Config)
|
tlsConfig, ok := securitySettings.(*tls.Config)
|
||||||
if ok {
|
if ok {
|
||||||
l.tlsConfig = tlsConfig.GetTLSConfig()
|
l.tlsConfig = tlsConfig.GetTLSConfig()
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,41 @@
|
||||||
package tls
|
package tls
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/tls"
|
||||||
|
"net"
|
||||||
|
|
||||||
|
"v2ray.com/core/common/buf"
|
||||||
|
)
|
||||||
|
|
||||||
//go:generate go run $GOPATH/src/v2ray.com/core/tools/generrorgen/main.go -pkg tls -path Transport,Internet,TLS
|
//go:generate go run $GOPATH/src/v2ray.com/core/tools/generrorgen/main.go -pkg tls -path Transport,Internet,TLS
|
||||||
|
|
||||||
|
type conn struct {
|
||||||
|
net.Conn
|
||||||
|
|
||||||
|
mergingReader buf.Reader
|
||||||
|
mergingWriter buf.Writer
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *conn) ReadMultiBuffer() (buf.MultiBuffer, error) {
|
||||||
|
if c.mergingReader == nil {
|
||||||
|
c.mergingReader = buf.NewMergingReaderSize(c.Conn, 16*1024)
|
||||||
|
}
|
||||||
|
return c.mergingReader.Read()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *conn) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
|
||||||
|
if c.mergingWriter == nil {
|
||||||
|
c.mergingWriter = buf.NewMergingWriter(c.Conn)
|
||||||
|
}
|
||||||
|
return mb.Len(), c.mergingWriter.Write(mb)
|
||||||
|
}
|
||||||
|
|
||||||
|
func Client(c net.Conn, config *tls.Config) net.Conn {
|
||||||
|
tlsConn := tls.Client(c, config)
|
||||||
|
return &conn{Conn: tlsConn}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Server(c net.Conn, config *tls.Config) net.Conn {
|
||||||
|
tlsConn := tls.Server(c, config)
|
||||||
|
return &conn{Conn: tlsConn}
|
||||||
|
}
|
||||||
|
|
|
@ -10,11 +10,18 @@ import (
|
||||||
"v2ray.com/core/common/errors"
|
"v2ray.com/core/common/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
_ buf.MultiBufferReader = (*connection)(nil)
|
||||||
|
_ buf.MultiBufferWriter = (*connection)(nil)
|
||||||
|
)
|
||||||
|
|
||||||
// connection is a wrapper for net.Conn over WebSocket connection.
|
// connection is a wrapper for net.Conn over WebSocket connection.
|
||||||
type connection struct {
|
type connection struct {
|
||||||
wsc *websocket.Conn
|
wsc *websocket.Conn
|
||||||
reader io.Reader
|
reader io.Reader
|
||||||
writeBuffer []byte
|
|
||||||
|
mergingReader buf.Reader
|
||||||
|
mergingWriter buf.Writer
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read implements net.Conn.Read()
|
// Read implements net.Conn.Read()
|
||||||
|
@ -34,6 +41,13 @@ func (c *connection) Read(b []byte) (int, error) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *connection) ReadMultiBuffer() (buf.MultiBuffer, error) {
|
||||||
|
if c.mergingReader == nil {
|
||||||
|
c.mergingReader = buf.NewMergingReader(c)
|
||||||
|
}
|
||||||
|
return c.mergingReader.Read()
|
||||||
|
}
|
||||||
|
|
||||||
func (c *connection) getReader() (io.Reader, error) {
|
func (c *connection) getReader() (io.Reader, error) {
|
||||||
if c.reader != nil {
|
if c.reader != nil {
|
||||||
return c.reader, nil
|
return c.reader, nil
|
||||||
|
@ -55,20 +69,10 @@ func (c *connection) Write(b []byte) (int, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *connection) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
|
func (c *connection) WriteMultiBuffer(mb buf.MultiBuffer) (int, error) {
|
||||||
defer mb.Release()
|
if c.mergingWriter == nil {
|
||||||
|
c.mergingWriter = buf.NewMergingWriter(c)
|
||||||
if c.writeBuffer == nil {
|
|
||||||
c.writeBuffer = make([]byte, 4096)
|
|
||||||
}
|
}
|
||||||
totalBytes := 0
|
return mb.Len(), c.mergingWriter.Write(mb)
|
||||||
for !mb.IsEmpty() {
|
|
||||||
nBytes, _ := mb.Read(c.writeBuffer)
|
|
||||||
totalBytes += nBytes
|
|
||||||
if _, err := c.Write(c.writeBuffer[:nBytes]); err != nil {
|
|
||||||
return totalBytes, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return totalBytes, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *connection) Close() error {
|
func (c *connection) Close() error {
|
||||||
|
|
Loading…
Reference in New Issue