1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-19 15:57:04 -05:00

Fix lint according to golangci-lint (#439)

This commit is contained in:
Loyalsoldier 2020-11-22 05:05:01 +08:00 committed by GitHub
parent f41286a0c7
commit b68f943c78
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
39 changed files with 96 additions and 137 deletions

View File

@ -5,6 +5,10 @@ run:
issues: issues:
new: true new: true
exclude-rules:
- path: _test\.go
linters:
- scopelint
linters: linters:
enable: enable:
@ -20,8 +24,6 @@ linters:
- ineffassign - ineffassign
- misspell - misspell
- nakedret - nakedret
- noctx
- nolintlint
- rowserrcheck - rowserrcheck
- scopelint - scopelint
- staticcheck - staticcheck

View File

@ -9,7 +9,6 @@ import (
"time" "time"
"google.golang.org/grpc" "google.golang.org/grpc"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/common" "v2ray.com/core/common"
"v2ray.com/core/features/routing" "v2ray.com/core/features/routing"
@ -39,7 +38,7 @@ func (s *routingServer) TestRoute(ctx context.Context, request *TestRouteRequest
return nil, err return nil, err
} }
if request.PublishResult && s.routingStats != nil { if request.PublishResult && s.routingStats != nil {
ctx, _ := context.WithTimeout(context.Background(), 4*time.Second) ctx, _ := context.WithTimeout(context.Background(), 4*time.Second) // nolint: govet
s.routingStats.Publish(ctx, route) s.routingStats.Publish(ctx, route)
} }
return AsProtobufMessage(request.FieldSelectors)(route), nil return AsProtobufMessage(request.FieldSelectors)(route), nil

View File

@ -7,7 +7,6 @@ import (
"go.starlark.net/starlark" "go.starlark.net/starlark"
"go.starlark.net/syntax" "go.starlark.net/syntax"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
"v2ray.com/core/common/strmatcher" "v2ray.com/core/common/strmatcher"
"v2ray.com/core/features/routing" "v2ray.com/core/features/routing"
@ -154,9 +153,8 @@ func NewPortMatcher(list *net.PortList, onSource bool) *PortMatcher {
func (v *PortMatcher) Apply(ctx routing.Context) bool { func (v *PortMatcher) Apply(ctx routing.Context) bool {
if v.onSource { if v.onSource {
return v.port.Contains(ctx.GetSourcePort()) return v.port.Contains(ctx.GetSourcePort())
} else {
return v.port.Contains(ctx.GetTargetPort())
} }
return v.port.Contains(ctx.GetTargetPort())
} }
type NetworkMatcher struct { type NetworkMatcher struct {

View File

@ -46,7 +46,7 @@ func (b *Buffer) Release() {
p := b.v p := b.v
b.v = nil b.v = nil
b.Clear() b.Clear()
pool.Put(p) pool.Put(p) // nolint: staticcheck
} }
// Clear clears the content of the buffer, results an empty buffer with // Clear clears the content of the buffer, results an empty buffer with

View File

@ -65,7 +65,7 @@ func Free(b []byte) {
b = b[0:cap(b)] b = b[0:cap(b)]
for i := numPools - 1; i >= 0; i-- { for i := numPools - 1; i >= 0; i-- {
if size >= poolSize[i] { if size >= poolSize[i] {
pool[i].Put(b) pool[i].Put(b) // nolint: staticcheck
return return
} }
} }

View File

@ -32,13 +32,15 @@ func ParseDestination(dest string) (Destination, error) {
Address: AnyIP, Address: AnyIP,
Port: Port(0), Port: Port(0),
} }
if strings.HasPrefix(dest, "tcp:") {
switch {
case strings.HasPrefix(dest, "tcp:"):
d.Network = Network_TCP d.Network = Network_TCP
dest = dest[4:] dest = dest[4:]
} else if strings.HasPrefix(dest, "udp:") { case strings.HasPrefix(dest, "udp:"):
d.Network = Network_UDP d.Network = Network_UDP
dest = dest[4:] dest = dest[4:]
} else if strings.HasPrefix(dest, "unix:") { case strings.HasPrefix(dest, "unix:"):
d = UnixDestination(DomainAddress(dest[5:])) d = UnixDestination(DomainAddress(dest[5:]))
return d, nil return d, nil
} }

View File

@ -14,9 +14,9 @@ import (
// CreateObject creates a new object based on the given V2Ray instance and config. The V2Ray instance may be nil. // CreateObject creates a new object based on the given V2Ray instance and config. The V2Ray instance may be nil.
func CreateObject(v *Instance, config interface{}) (interface{}, error) { func CreateObject(v *Instance, config interface{}) (interface{}, error) {
ctx := v.ctx var ctx context.Context
if v != nil { if v != nil {
ctx = context.WithValue(ctx, v2rayKey, v) ctx = context.WithValue(v.ctx, v2rayKey, v)
} }
return common.CreateObject(ctx, config) return common.CreateObject(ctx, config)
} }

View File

@ -119,11 +119,10 @@ func getHostMapping(addr *Address) *dns.Config_HostMapping {
return &dns.Config_HostMapping{ return &dns.Config_HostMapping{
Ip: [][]byte{[]byte(addr.IP())}, Ip: [][]byte{[]byte(addr.IP())},
} }
} else { }
return &dns.Config_HostMapping{ return &dns.Config_HostMapping{
ProxiedDomain: addr.Domain(), ProxiedDomain: addr.Domain(),
} }
}
} }
// Build implements Buildable // Build implements Buildable

View File

@ -166,19 +166,20 @@ func (c *InboundDetourConfig) Build() (*core.InboundHandlerConfig, error) {
receiverSettings.Listen = c.ListenOn.Build() receiverSettings.Listen = c.ListenOn.Build()
listenDS := c.ListenOn.Family().IsDomain() && (c.ListenOn.Domain()[0] == '/' || c.ListenOn.Domain()[0] == '@') listenDS := c.ListenOn.Family().IsDomain() && (c.ListenOn.Domain()[0] == '/' || c.ListenOn.Domain()[0] == '@')
listenIP := c.ListenOn.Family().IsIP() || (c.ListenOn.Family().IsDomain() && c.ListenOn.Domain() == "localhost") listenIP := c.ListenOn.Family().IsIP() || (c.ListenOn.Family().IsDomain() && c.ListenOn.Domain() == "localhost")
if listenIP { switch {
case listenIP:
// Listen on specific IP, must set PortRange // Listen on specific IP, must set PortRange
if c.PortRange == nil { if c.PortRange == nil {
return nil, newError("Listen on specific ip without port in InboundDetour.") return nil, newError("Listen on specific ip without port in InboundDetour.")
} }
// Listen on IP:Port // Listen on IP:Port
receiverSettings.PortRange = c.PortRange.Build() receiverSettings.PortRange = c.PortRange.Build()
} else if listenDS { case listenDS:
if c.PortRange != nil { if c.PortRange != nil {
// Listen on Unix Domain Socket, PortRange should be nil // Listen on Unix Domain Socket, PortRange should be nil
receiverSettings.PortRange = nil receiverSettings.PortRange = nil
} }
} else { default:
return nil, newError("unable to listen on domain address: ", c.ListenOn.Domain()) return nil, newError("unable to listen on domain address: ", c.ListenOn.Domain())
} }
} }

View File

@ -31,8 +31,7 @@ var (
/* We have to do this here because Golang's Test will also need to parse flag, before /* We have to do this here because Golang's Test will also need to parse flag, before
* main func in this file is run. * main func in this file is run.
*/ */
_ = func() error { _ = func() error { // nolint: unparam
flag.Var(&configFiles, "config", "Config file for V2Ray. Multiple assign is accepted (only json). Latter ones overrides the former ones.") flag.Var(&configFiles, "config", "Config file for V2Ray. Multiple assign is accepted (only json). Latter ones overrides the former ones.")
flag.Var(&configFiles, "c", "Short alias of -config") flag.Var(&configFiles, "c", "Short alias of -config")
flag.StringVar(&configDir, "confdir", "", "A dir with multiple json config") flag.StringVar(&configDir, "confdir", "", "A dir with multiple json config")
@ -66,7 +65,7 @@ func readConfDir(dirPath string) {
} }
} }
func getConfigFilePath() (cmdarg.Arg, error) { func getConfigFilePath() cmdarg.Arg {
if dirExists(configDir) { if dirExists(configDir) {
log.Println("Using confdir from arg:", configDir) log.Println("Using confdir from arg:", configDir)
readConfDir(configDir) readConfDir(configDir)
@ -76,24 +75,24 @@ func getConfigFilePath() (cmdarg.Arg, error) {
} }
if len(configFiles) > 0 { if len(configFiles) > 0 {
return configFiles, nil return configFiles
} }
if workingDir, err := os.Getwd(); err == nil { if workingDir, err := os.Getwd(); err == nil {
configFile := filepath.Join(workingDir, "config.json") configFile := filepath.Join(workingDir, "config.json")
if fileExists(configFile) { if fileExists(configFile) {
log.Println("Using default config: ", configFile) log.Println("Using default config: ", configFile)
return cmdarg.Arg{configFile}, nil return cmdarg.Arg{configFile}
} }
} }
if configFile := platform.GetConfigurationPath(); fileExists(configFile) { if configFile := platform.GetConfigurationPath(); fileExists(configFile) {
log.Println("Using config from env: ", configFile) log.Println("Using config from env: ", configFile)
return cmdarg.Arg{configFile}, nil return cmdarg.Arg{configFile}
} }
log.Println("Using config from STDIN") log.Println("Using config from STDIN")
return cmdarg.Arg{"stdin:"}, nil return cmdarg.Arg{"stdin:"}
} }
func GetConfigFormat() string { func GetConfigFormat() string {
@ -106,10 +105,7 @@ func GetConfigFormat() string {
} }
func startV2Ray() (core.Server, error) { func startV2Ray() (core.Server, error) {
configFiles, err := getConfigFilePath() configFiles := getConfigFilePath()
if err != nil {
return nil, err
}
config, err := core.LoadConfig(GetConfigFormat(), configFiles[0], configFiles) config, err := core.LoadConfig(GetConfigFormat(), configFiles[0], configFiles)
if err != nil { if err != nil {

View File

@ -19,6 +19,7 @@ func TestHTTPResponse(t *testing.T) {
reader := bufio.NewReader(buffer) reader := bufio.NewReader(buffer)
response, err := http.ReadResponse(reader, nil) response, err := http.ReadResponse(reader, nil)
common.Must(err) common.Must(err)
defer response.Body.Close()
if response.StatusCode != 403 { if response.StatusCode != 403 {
t.Error("expected status code 403, but got ", response.StatusCode) t.Error("expected status code 403, but got ", response.StatusCode)

View File

@ -7,7 +7,6 @@ import (
"github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp"
"github.com/miekg/dns" "github.com/miekg/dns"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/app/dispatcher" "v2ray.com/core/app/dispatcher"
dnsapp "v2ray.com/core/app/dns" dnsapp "v2ray.com/core/app/dns"

View File

@ -25,7 +25,7 @@ import (
func init() { func init() {
common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, config interface{}) (interface{}, error) { common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, config interface{}) (interface{}, error) {
d := new(DokodemoDoor) d := new(Door)
err := core.RequireFeatures(ctx, func(pm policy.Manager) error { err := core.RequireFeatures(ctx, func(pm policy.Manager) error {
return d.Init(config.(*Config), pm, session.SockoptFromContext(ctx)) return d.Init(config.(*Config), pm, session.SockoptFromContext(ctx))
}) })
@ -33,7 +33,7 @@ func init() {
})) }))
} }
type DokodemoDoor struct { type Door struct {
policyManager policy.Manager policyManager policy.Manager
config *Config config *Config
address net.Address address net.Address
@ -41,8 +41,8 @@ type DokodemoDoor struct {
sockopt *session.Sockopt sockopt *session.Sockopt
} }
// Init initializes the DokodemoDoor instance with necessary parameters. // Init initializes the Door instance with necessary parameters.
func (d *DokodemoDoor) Init(config *Config, pm policy.Manager, sockopt *session.Sockopt) error { func (d *Door) Init(config *Config, pm policy.Manager, sockopt *session.Sockopt) error {
if (config.NetworkList == nil || len(config.NetworkList.Network) == 0) && len(config.Networks) == 0 { if (config.NetworkList == nil || len(config.NetworkList.Network) == 0) && len(config.Networks) == 0 {
return newError("no network specified") return newError("no network specified")
} }
@ -56,7 +56,7 @@ func (d *DokodemoDoor) Init(config *Config, pm policy.Manager, sockopt *session.
} }
// Network implements proxy.Inbound. // Network implements proxy.Inbound.
func (d *DokodemoDoor) Network() []net.Network { func (d *Door) Network() []net.Network {
if len(d.config.Networks) > 0 { if len(d.config.Networks) > 0 {
return d.config.Networks return d.config.Networks
} }
@ -64,7 +64,7 @@ func (d *DokodemoDoor) Network() []net.Network {
return d.config.NetworkList.Network return d.config.NetworkList.Network
} }
func (d *DokodemoDoor) policy() policy.Session { func (d *Door) policy() policy.Session {
config := d.config config := d.config
p := d.policyManager.ForLevel(config.UserLevel) p := d.policyManager.ForLevel(config.UserLevel)
if config.Timeout > 0 && config.UserLevel == 0 { if config.Timeout > 0 && config.UserLevel == 0 {
@ -78,7 +78,7 @@ type hasHandshakeAddress interface {
} }
// Process implements proxy.Inbound. // Process implements proxy.Inbound.
func (d *DokodemoDoor) Process(ctx context.Context, network net.Network, conn internet.Connection, dispatcher routing.Dispatcher) error { func (d *Door) Process(ctx context.Context, network net.Network, conn internet.Connection, dispatcher routing.Dispatcher) error {
newError("processing connection from: ", conn.RemoteAddr()).AtDebug().WriteToLog(session.ExportIDToError(ctx)) newError("processing connection from: ", conn.RemoteAddr()).AtDebug().WriteToLog(session.ExportIDToError(ctx))
dest := net.Destination{ dest := net.Destination{
Network: network, Network: network,

View File

@ -12,7 +12,6 @@ import (
"sync" "sync"
"golang.org/x/net/http2" "golang.org/x/net/http2"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/common" "v2ray.com/core/common"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
@ -165,7 +164,7 @@ func setUpHTTPTunnel(ctx context.Context, dest net.Destination, target string, u
return nil, err return nil, err
} }
resp, err := http.ReadResponse(bufio.NewReader(rawConn), req) resp, err := http.ReadResponse(bufio.NewReader(rawConn), req) // nolint: bodyclose
if err != nil { if err != nil {
rawConn.Close() rawConn.Close()
return nil, err return nil, err
@ -191,7 +190,7 @@ func setUpHTTPTunnel(ctx context.Context, dest net.Destination, target string, u
wg.Done() wg.Done()
}() }()
resp, err := h2clientConn.RoundTrip(req) resp, err := h2clientConn.RoundTrip(req) // nolint: bodyclose
if err != nil { if err != nil {
rawConn.Close() rawConn.Close()
return nil, err return nil, err

View File

@ -279,7 +279,7 @@ func (s *Server) handlePlainHTTP(ctx context.Context, request *http.Request, wri
responseDone := func() error { responseDone := func() error {
responseReader := bufio.NewReaderSize(&buf.BufferedReader{Reader: link.Reader}, buf.Size) responseReader := bufio.NewReaderSize(&buf.BufferedReader{Reader: link.Reader}, buf.Size)
response, err := http.ReadResponse(responseReader, request) response, err := http.ReadResponse(responseReader, request) // nolint: bodyclose
if err == nil { if err == nil {
http_proto.RemoveHopByHopHeaders(response.Header) http_proto.RemoveHopByHopHeaders(response.Header)
if response.ContentLength >= 0 { if response.ContentLength >= 0 {

View File

@ -128,7 +128,7 @@ func (w *PacketWriter) WriteMultiBufferWithMetadata(mb buf.MultiBuffer, dest net
return nil return nil
} }
func (w *PacketWriter) writePacket(payload []byte, dest net.Destination) (int, error) { func (w *PacketWriter) writePacket(payload []byte, dest net.Destination) (int, error) { // nolint: unparam
buffer := buf.StackNew() buffer := buf.StackNew()
defer buffer.Release() defer buffer.Release()

View File

@ -1,5 +1 @@
package trojan package trojan
const (
muxCoolAddress = "v1.mux.cool"
)

View File

@ -6,20 +6,15 @@ import (
"io" "io"
"github.com/golang/protobuf/proto" "github.com/golang/protobuf/proto"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
"v2ray.com/core/common/protocol" "v2ray.com/core/common/protocol"
) )
// EncodeHeaderAddons Add addons byte to the header // EncodeHeaderAddons Add addons byte to the header
func EncodeHeaderAddons(buffer *buf.Buffer, addons *Addons) error { func EncodeHeaderAddons(buffer *buf.Buffer, addons *Addons) error {
switch addons.Flow {
default:
if err := buffer.WriteByte(0); err != nil { if err := buffer.WriteByte(0); err != nil {
return newError("failed to write addons protobuf length").Base(err) return newError("failed to write addons protobuf length").Base(err)
} }
}
return nil return nil
} }
@ -39,11 +34,6 @@ func DecodeHeaderAddons(buffer *buf.Buffer, reader io.Reader) (*Addons, error) {
if err := proto.Unmarshal(buffer.Bytes(), addons); err != nil { if err := proto.Unmarshal(buffer.Bytes(), addons); err != nil {
return nil, newError("failed to unmarshal addons protobuf value").Base(err) return nil, newError("failed to unmarshal addons protobuf value").Base(err)
} }
// Verification.
switch addons.Flow {
default:
}
} }
return addons, nil return addons, nil
@ -51,23 +41,17 @@ func DecodeHeaderAddons(buffer *buf.Buffer, reader io.Reader) (*Addons, error) {
// EncodeBodyAddons returns a Writer that auto-encrypt content written by caller. // EncodeBodyAddons returns a Writer that auto-encrypt content written by caller.
func EncodeBodyAddons(writer io.Writer, request *protocol.RequestHeader, addons *Addons) buf.Writer { func EncodeBodyAddons(writer io.Writer, request *protocol.RequestHeader, addons *Addons) buf.Writer {
switch addons.Flow {
default:
if request.Command == protocol.RequestCommandUDP { if request.Command == protocol.RequestCommandUDP {
return NewMultiLengthPacketWriter(writer.(buf.Writer)) return NewMultiLengthPacketWriter(writer.(buf.Writer))
} }
}
return buf.NewWriter(writer) return buf.NewWriter(writer)
} }
// DecodeBodyAddons returns a Reader from which caller can fetch decrypted body. // DecodeBodyAddons returns a Reader from which caller can fetch decrypted body.
func DecodeBodyAddons(reader io.Reader, request *protocol.RequestHeader, addons *Addons) buf.Reader { func DecodeBodyAddons(reader io.Reader, request *protocol.RequestHeader, addons *Addons) buf.Reader {
switch addons.Flow {
default:
if request.Command == protocol.RequestCommandUDP { if request.Command == protocol.RequestCommandUDP {
return NewLengthPacketReader(reader) return NewLengthPacketReader(reader)
} }
}
return buf.NewReader(reader) return buf.NewReader(reader)
} }

View File

@ -6,6 +6,7 @@ package encoding
import ( import (
"io" "io"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
"v2ray.com/core/common/protocol" "v2ray.com/core/common/protocol"

View File

@ -4,7 +4,6 @@ import (
"testing" "testing"
"github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp"
"v2ray.com/core/common" "v2ray.com/core/common"
"v2ray.com/core/common/buf" "v2ray.com/core/common/buf"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"

View File

@ -421,11 +421,6 @@ func (h *Handler) Process(ctx context.Context, network net.Network, connection i
return newError("failed to transfer response payload").Base(err).AtInfo() return newError("failed to transfer response payload").Base(err).AtInfo()
} }
// Indicates the end of response payload.
switch responseAddons.Flow {
default:
}
return nil return nil
} }

View File

@ -7,7 +7,6 @@ package outbound
import ( import (
"context" "context"
"time" "time"
"v2ray.com/core/proxy/vless"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/common" "v2ray.com/core/common"
@ -19,6 +18,7 @@ import (
"v2ray.com/core/common/signal" "v2ray.com/core/common/signal"
"v2ray.com/core/common/task" "v2ray.com/core/common/task"
"v2ray.com/core/features/policy" "v2ray.com/core/features/policy"
"v2ray.com/core/proxy/vless"
"v2ray.com/core/proxy/vless/encoding" "v2ray.com/core/proxy/vless/encoding"
"v2ray.com/core/transport" "v2ray.com/core/transport"
"v2ray.com/core/transport/internet" "v2ray.com/core/transport/internet"
@ -76,12 +76,6 @@ func (h *Handler) Process(ctx context.Context, link *transport.Link, dialer inte
} }
defer conn.Close() defer conn.Close()
iConn := conn
statConn, ok := iConn.(*internet.StatCouterConnection)
if ok {
iConn = statConn.Connection
}
outbound := session.OutboundFromContext(ctx) outbound := session.OutboundFromContext(ctx)
if outbound == nil || !outbound.Target.IsValid() { if outbound == nil || !outbound.Target.IsValid() {
return newError("target not specified").AtError() return newError("target not specified").AtError()
@ -143,11 +137,6 @@ func (h *Handler) Process(ctx context.Context, link *transport.Link, dialer inte
return newError("failed to transfer request payload").Base(err).AtInfo() return newError("failed to transfer request payload").Base(err).AtInfo()
} }
// Indicates the end of request payload.
switch requestAddons.Flow {
default:
}
return nil return nil
} }

View File

@ -207,7 +207,7 @@ func (c *ClientSession) DecodeResponseHeader(reader io.Reader) (*protocol.Respon
} }
if decryptedResponseHeaderLengthBinaryBuffer, err := aeadResponseHeaderLengthEncryptionAEAD.Open(nil, aeadResponseHeaderLengthEncryptionIV, aeadEncryptedResponseHeaderLength[:], nil); err != nil { if decryptedResponseHeaderLengthBinaryBuffer, err := aeadResponseHeaderLengthEncryptionAEAD.Open(nil, aeadResponseHeaderLengthEncryptionIV, aeadEncryptedResponseHeaderLength[:], nil); err != nil {
return nil, newError("Failed To Decrypt Length").Base(err) return nil, newError("Failed To Decrypt Length").Base(err)
} else { } else { // nolint: golint
common.Must(binary.Read(bytes.NewReader(decryptedResponseHeaderLengthBinaryBuffer), binary.BigEndian, &decryptedResponseHeaderLengthBinaryDeserializeBuffer)) common.Must(binary.Read(bytes.NewReader(decryptedResponseHeaderLengthBinaryBuffer), binary.BigEndian, &decryptedResponseHeaderLengthBinaryDeserializeBuffer))
decryptedResponseHeaderLength = int(decryptedResponseHeaderLengthBinaryDeserializeBuffer) decryptedResponseHeaderLength = int(decryptedResponseHeaderLengthBinaryDeserializeBuffer)
} }
@ -226,7 +226,7 @@ func (c *ClientSession) DecodeResponseHeader(reader io.Reader) (*protocol.Respon
if decryptedResponseHeaderBuffer, err := aeadResponseHeaderPayloadEncryptionAEAD.Open(nil, aeadResponseHeaderPayloadEncryptionIV, encryptedResponseHeaderBuffer, nil); err != nil { if decryptedResponseHeaderBuffer, err := aeadResponseHeaderPayloadEncryptionAEAD.Open(nil, aeadResponseHeaderPayloadEncryptionIV, encryptedResponseHeaderBuffer, nil); err != nil {
return nil, newError("Failed To Decrypt Payload").Base(err) return nil, newError("Failed To Decrypt Payload").Base(err)
} else { } else { // nolint: golint
c.responseReader = bytes.NewReader(decryptedResponseHeaderBuffer) c.responseReader = bytes.NewReader(decryptedResponseHeaderBuffer)
} }
} }

View File

@ -179,9 +179,8 @@ func (s *ServerSession) DecodeRequestHeader(reader io.Reader) (*protocol.Request
if shouldDrain { if shouldDrain {
readSizeRemain -= bytesRead readSizeRemain -= bytesRead
return nil, drainConnection(newError("AEAD read failed").Base(errorReason)) return nil, drainConnection(newError("AEAD read failed").Base(errorReason))
} else {
return nil, drainConnection(newError("AEAD read failed, drain skipped").Base(errorReason))
} }
return nil, drainConnection(newError("AEAD read failed, drain skipped").Base(errorReason))
} }
decryptor = bytes.NewReader(aeadData) decryptor = bytes.NewReader(aeadData)
s.isAEADRequest = true s.isAEADRequest = true
@ -226,9 +225,8 @@ func (s *ServerSession) DecodeRequestHeader(reader io.Reader) (*protocol.Request
return nil, drainConnection(newError("duplicated session id, possibly under replay attack, and failed to taint userHash").Base(drainErr)) return nil, drainConnection(newError("duplicated session id, possibly under replay attack, and failed to taint userHash").Base(drainErr))
} }
return nil, drainConnection(newError("duplicated session id, possibly under replay attack, userHash tainted")) return nil, drainConnection(newError("duplicated session id, possibly under replay attack, userHash tainted"))
} else {
return nil, newError("duplicated session id, possibly under replay attack, but this is a AEAD request")
} }
return nil, newError("duplicated session id, possibly under replay attack, but this is a AEAD request")
} }
s.responseHeader = buffer.Byte(33) // 1 byte s.responseHeader = buffer.Byte(33) // 1 byte
@ -288,9 +286,8 @@ func (s *ServerSession) DecodeRequestHeader(reader io.Reader) (*protocol.Request
} }
// It is possible that we are under attack described in https://github.com/v2ray/v2ray-core/issues/2523 // It is possible that we are under attack described in https://github.com/v2ray/v2ray-core/issues/2523
return nil, drainConnection(Autherr) return nil, drainConnection(Autherr)
} else {
return nil, newError("invalid auth, but this is a AEAD request")
} }
return nil, newError("invalid auth, but this is a AEAD request")
} }
if request.Address == nil { if request.Address == nil {

View File

@ -11,7 +11,6 @@ import (
"github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp"
"github.com/google/go-cmp/cmp/cmpopts" "github.com/google/go-cmp/cmp/cmpopts"
"google.golang.org/grpc" "google.golang.org/grpc"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/app/commander" "v2ray.com/core/app/commander"
"v2ray.com/core/app/policy" "v2ray.com/core/app/policy"

View File

@ -164,7 +164,7 @@ func testTCPConn(port net.Port, payloadSize int, timeout time.Duration) func() e
} }
} }
func testUDPConn(port net.Port, payloadSize int, timeout time.Duration) func() error { func testUDPConn(port net.Port, payloadSize int, timeout time.Duration) func() error { // nolint: unparam
return func() error { return func() error {
conn, err := net.DialUDP("udp", nil, &net.UDPAddr{ conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
IP: []byte{127, 0, 0, 1}, IP: []byte{127, 0, 0, 1},

View File

@ -5,7 +5,6 @@ import (
"time" "time"
"golang.org/x/sync/errgroup" "golang.org/x/sync/errgroup"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/app/log" "v2ray.com/core/app/log"
"v2ray.com/core/app/proxyman" "v2ray.com/core/app/proxyman"

View File

@ -638,6 +638,7 @@ func TestDomainSniffing(t *testing.T) {
resp, err := client.Get("https://www.github.com/") resp, err := client.Get("https://www.github.com/")
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
t.Error("unexpected status code: ", resp.StatusCode) t.Error("unexpected status code: ", resp.StatusCode)
} }

View File

@ -12,7 +12,6 @@ import (
"time" "time"
"github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp"
"v2ray.com/core" "v2ray.com/core"
"v2ray.com/core/app/proxyman" "v2ray.com/core/app/proxyman"
"v2ray.com/core/common" "v2ray.com/core/common"
@ -70,6 +69,7 @@ func TestHttpConformance(t *testing.T) {
resp, err := client.Get("http://127.0.0.1:" + httpServerPort.String()) resp, err := client.Get("http://127.0.0.1:" + httpServerPort.String())
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
t.Fatal("status: ", resp.StatusCode) t.Fatal("status: ", resp.StatusCode)
} }
@ -129,8 +129,9 @@ func TestHttpError(t *testing.T) {
Transport: transport, Transport: transport,
} }
resp, err := client.Get("http://127.0.0.1:" + dest.Port.String()) resp, err := client.Get("http://127.0.0.1:" + dest.Port.String()) // nolint: bodyclose
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 503 { if resp.StatusCode != 503 {
t.Error("status: ", resp.StatusCode) t.Error("status: ", resp.StatusCode)
} }
@ -189,6 +190,7 @@ func TestHTTPConnectMethod(t *testing.T) {
resp, err := client.Do(req) resp, err := client.Do(req)
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
t.Fatal("status: ", resp.StatusCode) t.Fatal("status: ", resp.StatusCode)
} }
@ -263,6 +265,7 @@ func TestHttpPost(t *testing.T) {
resp, err := client.Post("http://127.0.0.1:"+httpServerPort.String()+"/testpost", "application/x-www-form-urlencoded", bytes.NewReader(payload)) resp, err := client.Post("http://127.0.0.1:"+httpServerPort.String()+"/testpost", "application/x-www-form-urlencoded", bytes.NewReader(payload))
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
t.Fatal("status: ", resp.StatusCode) t.Fatal("status: ", resp.StatusCode)
} }
@ -331,6 +334,7 @@ func TestHttpBasicAuth(t *testing.T) {
{ {
resp, err := client.Get("http://127.0.0.1:" + httpServerPort.String()) resp, err := client.Get("http://127.0.0.1:" + httpServerPort.String())
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 407 { if resp.StatusCode != 407 {
t.Fatal("status: ", resp.StatusCode) t.Fatal("status: ", resp.StatusCode)
} }
@ -344,6 +348,7 @@ func TestHttpBasicAuth(t *testing.T) {
setProxyBasicAuth(req, "a", "c") setProxyBasicAuth(req, "a", "c")
resp, err := client.Do(req) resp, err := client.Do(req)
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 407 { if resp.StatusCode != 407 {
t.Fatal("status: ", resp.StatusCode) t.Fatal("status: ", resp.StatusCode)
} }
@ -357,6 +362,7 @@ func TestHttpBasicAuth(t *testing.T) {
setProxyBasicAuth(req, "a", "b") setProxyBasicAuth(req, "a", "b")
resp, err := client.Do(req) resp, err := client.Do(req)
common.Must(err) common.Must(err)
defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
t.Fatal("status: ", resp.StatusCode) t.Fatal("status: ", resp.StatusCode)
} }

View File

@ -112,7 +112,7 @@ func (h *HeaderReader) Read(reader io.Reader) (*buf.Buffer, error) {
// Parse the request // Parse the request
if req, err := readRequest(bufio.NewReader(bytes.NewReader(headerBuf.Bytes())), false); err != nil { if req, err := readRequest(bufio.NewReader(bytes.NewReader(headerBuf.Bytes())), false); err != nil {
return nil, err return nil, err
} else { } else { // nolint: golint
h.req = req h.req = req
} }

View File

@ -7,34 +7,34 @@ import (
"v2ray.com/core/common" "v2ray.com/core/common"
) )
type NoOpHeader struct{} type Header struct{}
func (NoOpHeader) Size() int32 { func (Header) Size() int32 {
return 0 return 0
} }
// Serialize implements PacketHeader. // Serialize implements PacketHeader.
func (NoOpHeader) Serialize([]byte) {} func (Header) Serialize([]byte) {}
func NewNoOpHeader(context.Context, interface{}) (interface{}, error) { func NewHeader(context.Context, interface{}) (interface{}, error) {
return NoOpHeader{}, nil return Header{}, nil
} }
type NoOpConnectionHeader struct{} type ConnectionHeader struct{}
func (NoOpConnectionHeader) Client(conn net.Conn) net.Conn { func (ConnectionHeader) Client(conn net.Conn) net.Conn {
return conn return conn
} }
func (NoOpConnectionHeader) Server(conn net.Conn) net.Conn { func (ConnectionHeader) Server(conn net.Conn) net.Conn {
return conn return conn
} }
func NewNoOpConnectionHeader(context.Context, interface{}) (interface{}, error) { func NewConnectionHeader(context.Context, interface{}) (interface{}, error) {
return NoOpConnectionHeader{}, nil return ConnectionHeader{}, nil
} }
func init() { func init() {
common.Must(common.RegisterConfig((*Config)(nil), NewNoOpHeader)) common.Must(common.RegisterConfig((*Config)(nil), NewHeader))
common.Must(common.RegisterConfig((*ConnectionConfig)(nil), NewNoOpConnectionHeader)) common.Must(common.RegisterConfig((*ConnectionConfig)(nil), NewConnectionHeader))
} }

View File

@ -23,7 +23,7 @@ var (
globalDialerAccess sync.Mutex globalDialerAccess sync.Mutex
) )
func getHTTPClient(_ context.Context, dest net.Destination, tlsSettings *tls.Config) (*http.Client, error) { func getHTTPClient(_ context.Context, dest net.Destination, tlsSettings *tls.Config) *http.Client {
globalDialerAccess.Lock() globalDialerAccess.Lock()
defer globalDialerAccess.Unlock() defer globalDialerAccess.Unlock()
@ -32,7 +32,7 @@ func getHTTPClient(_ context.Context, dest net.Destination, tlsSettings *tls.Con
} }
if client, found := globalDialerMap[dest]; found { if client, found := globalDialerMap[dest]; found {
return client, nil return client
} }
transport := &http2.Transport{ transport := &http2.Transport{
@ -81,7 +81,7 @@ func getHTTPClient(_ context.Context, dest net.Destination, tlsSettings *tls.Con
} }
globalDialerMap[dest] = client globalDialerMap[dest] = client
return client, nil return client
} }
// Dial dials a new TCP connection to the given destination. // Dial dials a new TCP connection to the given destination.
@ -91,10 +91,7 @@ func Dial(ctx context.Context, dest net.Destination, streamSettings *internet.Me
if tlsConfig == nil { if tlsConfig == nil {
return nil, newError("TLS must be enabled for http transport.").AtWarning() return nil, newError("TLS must be enabled for http transport.").AtWarning()
} }
client, err := getHTTPClient(ctx, dest, tlsConfig) client := getHTTPClient(ctx, dest, tlsConfig)
if err != nil {
return nil, err
}
opts := pipe.OptionsFromContext(ctx) opts := pipe.OptionsFromContext(ctx)
preader, pwriter := pipe.New(opts...) preader, pwriter := pipe.New(opts...)
@ -116,7 +113,7 @@ func Dial(ctx context.Context, dest net.Destination, streamSettings *internet.Me
// Disable any compression method from server. // Disable any compression method from server.
request.Header.Set("Accept-Encoding", "identity") request.Header.Set("Accept-Encoding", "identity")
response, err := client.Do(request) response, err := client.Do(request) // nolint: bodyclose
if err != nil { if err != nil {
return nil, newError("failed to dial to ", dest).Base(err).AtWarning() return nil, newError("failed to dial to ", dest).Base(err).AtWarning()
} }

View File

@ -21,7 +21,7 @@ type PacketWriter interface {
io.Writer io.Writer
} }
type KCPPacketReader struct { type KCPPacketReader struct { // nolint: golint
Security cipher.AEAD Security cipher.AEAD
Header internet.PacketHeader Header internet.PacketHeader
} }
@ -57,7 +57,7 @@ func (r *KCPPacketReader) Read(b []byte) []Segment {
return result return result
} }
type KCPPacketWriter struct { type KCPPacketWriter struct { // nolint: golint
Header internet.PacketHeader Header internet.PacketHeader
Security cipher.AEAD Security cipher.AEAD
Writer io.Writer Writer io.Writer

View File

@ -19,5 +19,5 @@ func getBuffer() []byte {
} }
func putBuffer(p []byte) { func putBuffer(p []byte) {
pool.Put(p) pool.Put(p) // nolint: staticcheck
} }

View File

@ -6,11 +6,11 @@ import (
const ( const (
// TCP_FASTOPEN is the socket option on darwin for TCP fast open. // TCP_FASTOPEN is the socket option on darwin for TCP fast open.
TCP_FASTOPEN = 0x105 TCP_FASTOPEN = 0x105 // nolint: golint,stylecheck
// TCP_FASTOPEN_SERVER is the value to enable TCP fast open on darwin for server connections. // TCP_FASTOPEN_SERVER is the value to enable TCP fast open on darwin for server connections.
TCP_FASTOPEN_SERVER = 0x01 TCP_FASTOPEN_SERVER = 0x01 // nolint: golint,stylecheck
// TCP_FASTOPEN_CLIENT is the value to enable TCP fast open on darwin for client connections. // TCP_FASTOPEN_CLIENT is the value to enable TCP fast open on darwin for client connections.
TCP_FASTOPEN_CLIENT = 0x02 TCP_FASTOPEN_CLIENT = 0x02 // nolint: golint,stylecheck
) )
func applyOutboundSocketOptions(network string, address string, fd uintptr, config *SocketConfig) error { func applyOutboundSocketOptions(network string, address string, fd uintptr, config *SocketConfig) error {

View File

@ -29,7 +29,7 @@ func getControlFunc(ctx context.Context, sockopt *SocketConfig, controllers []co
} }
} }
setReusePort(fd) setReusePort(fd) // nolint: staticcheck
for _, controller := range controllers { for _, controller := range controllers {
if err := controller(network, address, fd); err != nil { if err := controller(network, address, fd); err != nil {
@ -71,7 +71,7 @@ func (dl *DefaultListener) Listen(ctx context.Context, addr net.Addr, sockopt *S
if err != nil { if err != nil {
return nil, err return nil, err
} }
ctx = context.WithValue(ctx, address, locker) ctx = context.WithValue(ctx, address, locker) // nolint: golint,staticcheck
} }
} }

View File

@ -40,7 +40,7 @@ func ListenTCP(ctx context.Context, address net.Address, port net.Port, streamSe
} }
var listener net.Listener var listener net.Listener
var err error var err error
if port == net.Port(0) { //unix if port == net.Port(0) { // unix
listener, err = internet.ListenSystem(ctx, &net.UnixAddr{ listener, err = internet.ListenSystem(ctx, &net.UnixAddr{
Name: address.Domain(), Name: address.Domain(),
Net: "unix", Net: "unix",

View File

@ -117,8 +117,9 @@ func getGetCertificateFunc(c *tls.Config, ca []*Certificate) func(hello *tls.Cli
access.Lock() access.Lock()
for _, certificate := range c.Certificates { for _, certificate := range c.Certificates {
if !isCertificateExpired(&certificate) { cert := certificate
newCerts = append(newCerts, certificate) if !isCertificateExpired(&cert) {
newCerts = append(newCerts, cert)
} }
} }

View File

@ -10,7 +10,6 @@ import (
"time" "time"
"github.com/gorilla/websocket" "github.com/gorilla/websocket"
"v2ray.com/core/common" "v2ray.com/core/common"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
http_proto "v2ray.com/core/common/protocol/http" http_proto "v2ray.com/core/common/protocol/http"
@ -79,7 +78,7 @@ func ListenWS(ctx context.Context, address net.Address, port net.Port, streamSet
} }
var listener net.Listener var listener net.Listener
var err error var err error
if port == net.Port(0) { //unix if port == net.Port(0) { // unix
listener, err = internet.ListenSystem(ctx, &net.UnixAddr{ listener, err = internet.ListenSystem(ctx, &net.UnixAddr{
Name: address.Domain(), Name: address.Domain(),
Net: "unix", Net: "unix",
@ -92,7 +91,7 @@ func ListenWS(ctx context.Context, address net.Address, port net.Port, streamSet
if locker != nil { if locker != nil {
l.locker = locker.(*internet.FileLocker) l.locker = locker.(*internet.FileLocker)
} }
} else { //tcp } else { // tcp
listener, err = internet.ListenSystem(ctx, &net.TCPAddr{ listener, err = internet.ListenSystem(ctx, &net.TCPAddr{
IP: address.IP(), IP: address.IP(),
Port: int(port), Port: int(port),