X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=wstracker.go;h=84af9cbfc18fc0de09a2fafd7199d7dec97f04ca;hb=702b2c77a0c499c6755e3c2865e974b10bd25448;hp=e8bde8c348c8a7ba36106ed1ae11e8f1f77d9702;hpb=aedf2583ccdeafc815223b9edae1e19e7b8d33f3;p=btrtrc.git diff --git a/wstracker.go b/wstracker.go index e8bde8c3..84af9cbf 100644 --- a/wstracker.go +++ b/wstracker.go @@ -1,17 +1,20 @@ package torrent import ( + "context" "fmt" + "net" + netHttp "net/http" "net/url" "sync" "github.com/anacrolix/log" - "github.com/anacrolix/torrent/tracker/http" "github.com/gorilla/websocket" + "github.com/pion/datachannel" "github.com/anacrolix/torrent/tracker" + httpTracker "github.com/anacrolix/torrent/tracker/http" "github.com/anacrolix/torrent/webtorrent" - "github.com/pion/datachannel" ) type websocketTrackerStatus struct { @@ -33,13 +36,16 @@ type refCountedWebtorrentTrackerClient struct { } type websocketTrackers struct { - PeerId [20]byte - Logger log.Logger - GetAnnounceRequest func(event tracker.AnnounceEvent, infoHash [20]byte) (tracker.AnnounceRequest, error) - OnConn func(datachannel.ReadWriteCloser, webtorrent.DataChannelContext) - mu sync.Mutex - clients map[string]*refCountedWebtorrentTrackerClient - Proxy http.ProxyFunc + PeerId [20]byte + Logger log.Logger + GetAnnounceRequest func(event tracker.AnnounceEvent, infoHash [20]byte) (tracker.AnnounceRequest, error) + OnConn func(datachannel.ReadWriteCloser, webtorrent.DataChannelContext) + mu sync.Mutex + clients map[string]*refCountedWebtorrentTrackerClient + Proxy httpTracker.ProxyFunc + DialContext func(ctx context.Context, network, addr string) (net.Conn, error) + WebsocketTrackerHttpHeader func() netHttp.Header + ICEServers []string } func (me *websocketTrackers) Get(url string, infoHash [20]byte) (*webtorrent.TrackerClient, func()) { @@ -47,7 +53,7 @@ func (me *websocketTrackers) Get(url string, infoHash [20]byte) (*webtorrent.Tra defer me.mu.Unlock() value, ok := me.clients[url] if !ok { - dialer := &websocket.Dialer{Proxy: me.Proxy, HandshakeTimeout: websocket.DefaultDialer.HandshakeTimeout} + dialer := &websocket.Dialer{Proxy: me.Proxy, NetDialContext: me.DialContext, HandshakeTimeout: websocket.DefaultDialer.HandshakeTimeout} value = &refCountedWebtorrentTrackerClient{ TrackerClient: webtorrent.TrackerClient{ Dialer: dialer, @@ -58,6 +64,8 @@ func (me *websocketTrackers) Get(url string, infoHash [20]byte) (*webtorrent.Tra Logger: me.Logger.WithText(func(m log.Msg) string { return fmt.Sprintf("tracker client for %q: %v", url, m) }), + WebsocketTrackerHttpHeader: me.WebsocketTrackerHttpHeader, + ICEServers: me.ICEServers, }, } value.TrackerClient.Start(func(err error) {