return
}
}
+ cl.AddDHTNodes(spec.DhtNodes)
cl.lock()
defer cl.unlock()
+ for _, url := range spec.Webseeds {
+ t.addWebSeed(url)
+ }
if spec.ChunkSize != 0 {
t.setChunkSize(pp.Integer(spec.ChunkSize))
}
func (cl *Client) AddTorrent(mi *metainfo.MetaInfo) (T *Torrent, err error) {
T, _, err = cl.AddTorrentSpec(TorrentSpecFromMetaInfo(mi))
- var ss []string
- slices.MakeInto(&ss, mi.Nodes)
- cl.AddDHTNodes(ss)
- for _, url := range mi.UrlList {
- T.addWebSeed(url)
- }
return
}
"github.com/anacrolix/torrent/storage"
)
-// Specifies a new torrent for adding to a client. There are helpers for
-// magnet URIs and torrent metainfo files.
+// Specifies a new torrent for adding to a client. There are helpers for magnet URIs and torrent
+// metainfo files.
type TorrentSpec struct {
// The tiered tracker URIs.
Trackers [][]string
InfoBytes []byte
// The name to use if the Name field from the Info isn't available.
DisplayName string
- // The chunk size to use for outbound requests. Defaults to 16KiB if not
- // set.
+ Webseeds []string
+ DhtNodes []string
+
+ // The chunk size to use for outbound requests. Defaults to 16KiB if not set.
ChunkSize int
Storage storage.ClientImpl
}
Trackers: [][]string{m.Trackers},
DisplayName: m.DisplayName,
InfoHash: m.InfoHash,
+ Webseeds: m.Params["ws"],
+ // TODO: What's the parameter for DHT nodes or bootstrap peers in a magnet link?
}
return
}
-func TorrentSpecFromMetaInfo(mi *metainfo.MetaInfo) (spec *TorrentSpec) {
- info, _ := mi.UnmarshalInfo()
- spec = &TorrentSpec{
- Trackers: mi.AnnounceList,
+func TorrentSpecFromMetaInfo(mi *metainfo.MetaInfo) *TorrentSpec {
+ info, err := mi.UnmarshalInfo()
+ if err != nil {
+ panic(err)
+ }
+ return &TorrentSpec{
+ Trackers: mi.UpvertedAnnounceList(),
+ InfoHash: mi.HashInfoBytes(),
InfoBytes: mi.InfoBytes,
DisplayName: info.Name,
- InfoHash: mi.HashInfoBytes(),
+ Webseeds: mi.UrlList,
+ DhtNodes: func() (ret []string) {
+ ret = make([]string, len(mi.Nodes))
+ for _, node := range mi.Nodes {
+ ret = append(ret, string(node))
+ }
+ return
+ }(),
}
- if spec.Trackers == nil && mi.Announce != "" {
- spec.Trackers = [][]string{{mi.Announce}}
- }
- return
}