Change: use nop packet conn for reject
This commit is contained in:
parent
a5f270e40e
commit
8e330640ea
1 changed files with 35 additions and 18 deletions
|
@ -2,7 +2,6 @@ package outbound
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
|
||||||
"io"
|
"io"
|
||||||
"net"
|
"net"
|
||||||
"time"
|
"time"
|
||||||
|
@ -17,12 +16,12 @@ type Reject struct {
|
||||||
|
|
||||||
// DialContext implements C.ProxyAdapter
|
// DialContext implements C.ProxyAdapter
|
||||||
func (r *Reject) DialContext(ctx context.Context, metadata *C.Metadata, opts ...dialer.Option) (C.Conn, error) {
|
func (r *Reject) DialContext(ctx context.Context, metadata *C.Metadata, opts ...dialer.Option) (C.Conn, error) {
|
||||||
return NewConn(&NopConn{}, r), nil
|
return NewConn(&nopConn{}, r), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// ListenPacketContext implements C.ProxyAdapter
|
// ListenPacketContext implements C.ProxyAdapter
|
||||||
func (r *Reject) ListenPacketContext(ctx context.Context, metadata *C.Metadata, opts ...dialer.Option) (C.PacketConn, error) {
|
func (r *Reject) ListenPacketContext(ctx context.Context, metadata *C.Metadata, opts ...dialer.Option) (C.PacketConn, error) {
|
||||||
return nil, errors.New("match reject rule")
|
return newPacketConn(newNopPacketConn(), r), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewReject() *Reject {
|
func NewReject() *Reject {
|
||||||
|
@ -35,30 +34,48 @@ func NewReject() *Reject {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
type NopConn struct{}
|
type nopConn struct{}
|
||||||
|
|
||||||
func (rw *NopConn) Read(b []byte) (int, error) {
|
func (rw *nopConn) Read(b []byte) (int, error) {
|
||||||
return 0, io.EOF
|
return 0, io.EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
func (rw *NopConn) Write(b []byte) (int, error) {
|
func (rw *nopConn) Write(b []byte) (int, error) {
|
||||||
return 0, io.EOF
|
return 0, io.EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close is fake function for net.Conn
|
func (rw *nopConn) Close() error { return nil }
|
||||||
func (rw *NopConn) Close() error { return nil }
|
func (rw *nopConn) LocalAddr() net.Addr { return nil }
|
||||||
|
func (rw *nopConn) RemoteAddr() net.Addr { return nil }
|
||||||
|
func (rw *nopConn) SetDeadline(time.Time) error { return nil }
|
||||||
|
func (rw *nopConn) SetReadDeadline(time.Time) error { return nil }
|
||||||
|
func (rw *nopConn) SetWriteDeadline(time.Time) error { return nil }
|
||||||
|
|
||||||
// LocalAddr is fake function for net.Conn
|
type nopPacketConn struct {
|
||||||
func (rw *NopConn) LocalAddr() net.Addr { return nil }
|
ch chan struct{}
|
||||||
|
}
|
||||||
|
|
||||||
// RemoteAddr is fake function for net.Conn
|
func (npc *nopPacketConn) WriteTo(b []byte, addr net.Addr) (n int, err error) {
|
||||||
func (rw *NopConn) RemoteAddr() net.Addr { return nil }
|
return len(b), nil
|
||||||
|
}
|
||||||
|
|
||||||
// SetDeadline is fake function for net.Conn
|
func (npc *nopPacketConn) ReadFrom(b []byte) (int, net.Addr, error) {
|
||||||
func (rw *NopConn) SetDeadline(time.Time) error { return nil }
|
<-npc.ch
|
||||||
|
return 0, nil, io.EOF
|
||||||
|
}
|
||||||
|
|
||||||
// SetReadDeadline is fake function for net.Conn
|
func (npc *nopPacketConn) Close() error {
|
||||||
func (rw *NopConn) SetReadDeadline(time.Time) error { return nil }
|
close(npc.ch)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// SetWriteDeadline is fake function for net.Conn
|
func (npc *nopPacketConn) LocalAddr() net.Addr { return &net.UDPAddr{IP: net.IPv4zero, Port: 0} }
|
||||||
func (rw *NopConn) SetWriteDeadline(time.Time) error { return nil }
|
func (npc *nopPacketConn) SetDeadline(time.Time) error { return nil }
|
||||||
|
func (npc *nopPacketConn) SetReadDeadline(time.Time) error { return nil }
|
||||||
|
func (npc *nopPacketConn) SetWriteDeadline(time.Time) error { return nil }
|
||||||
|
|
||||||
|
func newNopPacketConn() *nopPacketConn {
|
||||||
|
return &nopPacketConn{
|
||||||
|
ch: make(chan struct{}),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue