advLayer

package
v1.2.4-beta.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 26, 2022 License: MIT Imports: 6 Imported by: 0

Documentation

Overview

Package advLayer contains definitions and subpackages for Advanced Layer in VSI model.

An advanced layer is based on http layer. It can be websocket, http2, grpc, quic or other customized protocols that based on http and can relay arbitrary length raw []byte data.

If a protocol is not based on http layer, then maybe it should be on Proxy Layer, rather than Advanced Layer.

Index

Constants

This section is empty.

Variables

View Source
var MaxEarlyDataLen = 2048 //for ws early data

为了避免黑客攻击,我们固定earlydata最大值为2048

View Source
var ProtocolsMap = make(map[string]Creator)

The implementations should use ProtocolsMap to regiester their Creator.

Functions

func PrintAllProtocolNames

func PrintAllProtocolNames()

Types

type Client

type Client interface {
	Common

	IsEarly() bool //is 0-rtt or not.

}

type Common added in v1.2.0

type Common interface {
	Creator

	GetPath() string // for logging procedure to get the path settings. Doesn't have to be the full path, as long as different settings can be distinguished. For example, grpc's GetPath() might return its ServiceName.
}

type Conf

type Conf struct {
	TlsConf *tls.Config //for quic

	Host    string
	Addr    netLayer.Addr
	Path    string
	Headers *httpLayer.HeaderPreset
	IsEarly bool           //is 0-rtt or not; for quic and ws.
	Xver    int            //for Super, like quic, PROXY protocol
	Extra   map[string]any //quic: useHysteria, hysteria_manual, maxbyte; grpc: multiMode
}

type Creator

type Creator interface {
	ProtocolName() string
	PackageID() string //unique for each package, sub packages in v2ray_simple don't need to apply prefix, but if you want to implement your own package, you should use full git path, like github.com/somebody/mypackage

	//NewClientFromURL(url *url.URL) (Client, error)	//todo: support url
	NewClientFromConf(conf *Conf) (Client, error)
	NewServerFromConf(conf *Conf) (Server, error)

	GetDefaultAlpn() (alpn string, mustUse bool)

	CanHandleHeaders() bool //If true, there won't be an extra http header layer during the relay progress, and the matching progress of the customized http headers will be handled inside this package.

	IsMux() bool // if IsMux, if is Client, then it is a MuxClient, or it's a SingleClient; if is Server, then it is a MuxServer, or it's a SingleServer

	IsSuper() bool // quic is a super protocol, which handles transport layer dialing and tls layer handshake directly. If IsSuper, then it's a SuperMuxServer

}

Creator represents supported features of a advLayer sub-package, and it can create New Client and Server.

type MuxClient

type MuxClient interface {
	Client

	// If IsSuper, underlay should be nil; conn must be non nil when err==nil.
	//
	// If not IsSuper and underlay == nil, it will return error if it can't find any extablished connection.
	// Usually underlay  is tls.Conn.
	GetCommonConn(underlay net.Conn) (conn any, err error)

	//underlay is conn returned from  GetCommonConn
	DialSubConn(underlay any) (net.Conn, error)
}

like grpc (h2) and quic (h3)

type MuxServer

type MuxServer interface {

	//non-blocking. if fallbackChan is not nil, then it can serve for fallback feature.
	StartHandle(underlay net.Conn, newSubConnChan chan net.Conn, fallbackChan chan httpLayer.FallbackMeta)
}

like grpc

type Server

type Server interface {
	Common

	Stop()
}

type SingleClient

type SingleClient interface {
	Client

	//it's 0-rtt if payload is provided
	Handshake(underlay net.Conn, payload []byte) (net.Conn, error)
}

like ws (h1.1)

type SingleServer

type SingleServer interface {

	//如果遇到不符合握手条件但是却合法的http请求,可返回 httpLayer.FallbackMeta 和 httpLayer.ErrShouldFallback
	Handshake(underlay net.Conn) (net.Conn, error)
}

like ws

type SuperMuxServer

type SuperMuxServer interface {
	MuxServer

	//non-blocking.  Super will listen raw conn directly, and pass subStreamConn to newSubConnChan。Can stop the listening progress by closer.Close().
	StartListen() (newSubConnChan chan net.Conn, closer io.Closer)
}

like quic

Directories

Path Synopsis
Package grpc implements methods for grpc tunnel.
Package grpc implements methods for grpc tunnel.
Package grpcSimple implements grpc tunnel without importing google.golang.org/grpc.
Package grpcSimple implements grpc tunnel without importing google.golang.org/grpc.
Package quic defines functions to listen and dial quic, with some customizable congestion settings.
Package quic defines functions to listen and dial quic, with some customizable congestion settings.
Package ws implements websocket for advLayer.
Package ws implements websocket for advLayer.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL