derp/derphttp: fix nil pointer dereference when closing a netcheck client

NewNetcheckClient only initializes a subset of fields of derphttp.Client,
and the Close() call added by #5707 was result in a nil pointer dereference.
Make Close() safe to call when using NewNetcheckClient() too.

Fixes #5919

Signed-off-by: Mihai Parparita <mihai@tailscale.com>
This commit is contained in:
Mihai Parparita 2022-10-13 11:10:11 -07:00 committed by Mihai Parparita
parent 4ec6d41682
commit b2855cfd86

View File

@ -96,7 +96,7 @@ func NewRegionClient(privateKey key.NodePrivate, logf logger.Logf, getRegion fun
return c return c
} }
// NewNetcheckClient returns a Client that's only able to have its DialRegion method called. // NewNetcheckClient returns a Client that's only able to have its DialRegionTLS method called.
// It's used by the netcheck package. // It's used by the netcheck package.
func NewNetcheckClient(logf logger.Logf) *Client { func NewNetcheckClient(logf logger.Logf) *Client {
return &Client{logf: logf} return &Client{logf: logf}
@ -985,7 +985,9 @@ func (c *Client) isClosed() bool {
// Close closes the client. It will not automatically reconnect after // Close closes the client. It will not automatically reconnect after
// being closed. // being closed.
func (c *Client) Close() error { func (c *Client) Close() error {
c.cancelCtx() // not in lock, so it can cancel Connect, which holds mu if c.cancelCtx != nil {
c.cancelCtx() // not in lock, so it can cancel Connect, which holds mu
}
c.mu.Lock() c.mu.Lock()
defer c.mu.Unlock() defer c.mu.Unlock()