|
@@ -31,6 +31,7 @@ type Client struct {
|
|
|
staleMode util.StaleMode
|
|
|
workerWG sync.WaitGroup
|
|
|
timeLimit time.Duration
|
|
|
+ allowFunc func(net.Addr, net.Addr) bool
|
|
|
}
|
|
|
|
|
|
func New(cfg *Config) (*Client, error) {
|
|
@@ -47,6 +48,7 @@ func New(cfg *Config) (*Client, error) {
|
|
|
cancelCtx: cancelCtx,
|
|
|
staleMode: cfg.StaleMode,
|
|
|
timeLimit: cfg.TimeLimit,
|
|
|
+ allowFunc: cfg.AllowFunc,
|
|
|
}
|
|
|
|
|
|
lAddrPort, err := netip.ParseAddrPort(cfg.BindAddress)
|
|
@@ -89,6 +91,10 @@ func (client *Client) listen() {
|
|
|
continue
|
|
|
}
|
|
|
|
|
|
+ if !client.allowFunc(conn.LocalAddr(), conn.RemoteAddr()) {
|
|
|
+ continue
|
|
|
+ }
|
|
|
+
|
|
|
client.workerWG.Add(1)
|
|
|
go func(conn net.Conn) {
|
|
|
defer client.workerWG.Done()
|