2017-01-26 19:46:44 +00:00
|
|
|
package inbound
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"v2ray.com/core/app/proxyman"
|
|
|
|
"v2ray.com/core/common/dice"
|
|
|
|
"v2ray.com/core/common/log"
|
|
|
|
"v2ray.com/core/common/net"
|
|
|
|
"v2ray.com/core/proxy"
|
|
|
|
)
|
|
|
|
|
|
|
|
type AlwaysOnInboundHandler struct {
|
2017-01-26 19:57:18 +00:00
|
|
|
proxy proxy.Inbound
|
2017-01-26 19:46:44 +00:00
|
|
|
workers []worker
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewAlwaysOnInboundHandler(ctx context.Context, tag string, receiverConfig *proxyman.ReceiverConfig, proxyConfig interface{}) (*AlwaysOnInboundHandler, error) {
|
|
|
|
p, err := proxy.CreateInboundHandler(ctx, proxyConfig)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
h := &AlwaysOnInboundHandler{
|
|
|
|
proxy: p,
|
|
|
|
}
|
|
|
|
|
|
|
|
nl := p.Network()
|
|
|
|
pr := receiverConfig.PortRange
|
|
|
|
for port := pr.From; port <= pr.To; port++ {
|
|
|
|
if nl.HasNetwork(net.Network_TCP) {
|
|
|
|
log.Debug("Proxyman|DefaultInboundHandler: creating tcp worker on ", receiverConfig.Listen.AsAddress(), ":", port)
|
|
|
|
worker := &tcpWorker{
|
|
|
|
address: receiverConfig.Listen.AsAddress(),
|
|
|
|
port: net.Port(port),
|
|
|
|
proxy: p,
|
|
|
|
stream: receiverConfig.StreamSettings,
|
|
|
|
recvOrigDest: receiverConfig.ReceiveOriginalDestination,
|
|
|
|
tag: tag,
|
|
|
|
allowPassiveConn: receiverConfig.AllowPassiveConnection,
|
|
|
|
}
|
|
|
|
h.workers = append(h.workers, worker)
|
|
|
|
}
|
|
|
|
|
|
|
|
if nl.HasNetwork(net.Network_UDP) {
|
|
|
|
worker := &udpWorker{
|
|
|
|
tag: tag,
|
|
|
|
proxy: p,
|
|
|
|
address: receiverConfig.Listen.AsAddress(),
|
|
|
|
port: net.Port(port),
|
|
|
|
recvOrigDest: receiverConfig.ReceiveOriginalDestination,
|
|
|
|
}
|
|
|
|
h.workers = append(h.workers, worker)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return h, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *AlwaysOnInboundHandler) Start() error {
|
|
|
|
for _, worker := range h.workers {
|
|
|
|
if err := worker.Start(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *AlwaysOnInboundHandler) Close() {
|
|
|
|
for _, worker := range h.workers {
|
|
|
|
worker.Close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-26 19:57:18 +00:00
|
|
|
func (h *AlwaysOnInboundHandler) GetRandomInboundProxy() (proxy.Inbound, net.Port, int) {
|
2017-01-26 19:46:44 +00:00
|
|
|
w := h.workers[dice.Roll(len(h.workers))]
|
|
|
|
return w.Proxy(), w.Port(), 9999
|
|
|
|
}
|