|  | @@ -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()
 |