"github.com/anacrolix/torrent/mse"
pp "github.com/anacrolix/torrent/peer_protocol"
"github.com/anacrolix/torrent/tracker"
- _ "github.com/anacrolix/torrent/tracker/udp"
. "github.com/anacrolix/torrent/util"
)
"github.com/anacrolix/torrent"
"github.com/anacrolix/torrent/tracker"
- _ "github.com/anacrolix/torrent/tracker/http"
- _ "github.com/anacrolix/torrent/tracker/udp"
)
func argSpec(arg string) (ts *torrent.TorrentSpec, err error) {
-package http
+package tracker
import (
"bytes"
"net/url"
"strconv"
- "github.com/anacrolix/torrent/util"
-
"github.com/anacrolix/libtorgo/bencode"
- "github.com/anacrolix/torrent/tracker"
+ "github.com/anacrolix/torrent/util"
)
func init() {
- tracker.RegisterClientScheme("http", NewClient)
+ RegisterClientScheme("http", NewClient)
}
type client struct {
url url.URL
}
-func NewClient(url *url.URL) tracker.Client {
+func NewClient(url *url.URL) Client {
return &client{
url: *url,
}
Peers interface{} `bencode:"peers"`
}
-func (r *response) UnmarshalPeers() (ret []tracker.Peer, err error) {
+func (r *response) UnmarshalPeers() (ret []Peer, err error) {
s, ok := r.Peers.(string)
if !ok {
err = fmt.Errorf("unsupported peers value type: %T", r.Peers)
if err != nil {
return
}
- ret = make([]tracker.Peer, 0, len(cp))
+ ret = make([]Peer, 0, len(cp))
for _, p := range cp {
- ret = append(ret, tracker.Peer{net.IP(p.IP[:]), int(p.Port)})
+ ret = append(ret, Peer{net.IP(p.IP[:]), int(p.Port)})
}
return
}
-func (me *client) Announce(ar *tracker.AnnounceRequest) (ret tracker.AnnounceResponse, err error) {
+func (me *client) Announce(ar *AnnounceRequest) (ret AnnounceResponse, err error) {
q := make(url.Values)
q.Set("info_hash", string(ar.InfoHash[:]))
q.Set("peer_id", string(ar.PeerId[:]))
q.Set("uploaded", strconv.FormatInt(ar.Uploaded, 10))
q.Set("downloaded", strconv.FormatInt(ar.Downloaded, 10))
q.Set("left", strconv.FormatInt(ar.Left, 10))
- if ar.Event != tracker.None {
+ if ar.Event != None {
q.Set("event", ar.Event.String())
}
// http://stackoverflow.com/questions/17418004/why-does-tracker-server-not-understand-my-request-bittorrent-protocol
-package udp_tracker
+package tracker
import (
"bytes"
"net"
"net/url"
"time"
-
- "github.com/anacrolix/torrent/tracker"
)
type Action int32
Seeders int32
}
-type Peer struct {
- IP [4]byte
- Port uint16
-}
-
func init() {
- tracker.RegisterClientScheme("udp", newClient)
+ RegisterClientScheme("udp", newClient)
}
-func newClient(url *url.URL) tracker.Client {
- return &client{
- url: url,
+func newClient(url *url.URL) Client {
+ return &udpClient{
+ url: *url,
}
}
return
}
-type client struct {
+type udpClient struct {
contiguousTimeouts int
connectionIdReceived time.Time
connectionId int64
socket net.Conn
- url *url.URL
+ url url.URL
}
-func (c *client) URL() string {
+func (c *udpClient) URL() string {
return c.url.String()
}
-func (c *client) String() string {
+func (c *udpClient) String() string {
return c.URL()
}
-func (c *client) Announce(req *tracker.AnnounceRequest) (res tracker.AnnounceResponse, err error) {
+func (c *udpClient) Announce(req *AnnounceRequest) (res AnnounceResponse, err error) {
if !c.connected() {
- err = tracker.ErrNotConnected
+ err = ErrNotConnected
return
}
reqURI := c.url.RequestURI()
default:
return
}
- res.Peers = append(res.Peers, tracker.Peer{
+ res.Peers = append(res.Peers, Peer{
IP: p.IP[:],
Port: int(p.Port),
})
// body is the binary serializable request body. trailer is optional data
// following it, such as for BEP 41.
-func (c *client) write(h *RequestHeader, body interface{}, trailer []byte) (err error) {
+func (c *udpClient) write(h *RequestHeader, body interface{}, trailer []byte) (err error) {
buf := &bytes.Buffer{}
err = binary.Write(buf, binary.BigEndian, h)
if err != nil {
// args is the binary serializable request body. trailer is optional data
// following it, such as for BEP 41.
-func (c *client) request(action Action, args interface{}, options []byte) (responseBody *bytes.Reader, err error) {
+func (c *udpClient) request(action Action, args interface{}, options []byte) (responseBody *bytes.Reader, err error) {
tid := newTransactionId()
err = c.write(&RequestHeader{
ConnectionId: c.connectionId,
return
}
-func (c *client) connected() bool {
+func (c *udpClient) connected() bool {
return !c.connectionIdReceived.IsZero() && time.Now().Before(c.connectionIdReceived.Add(time.Minute))
}
-func (c *client) Connect() (err error) {
+func (c *udpClient) Connect() (err error) {
if c.connected() {
return nil
}
-package udp_tracker
+package tracker
import (
"bytes"
"syscall"
"testing"
- "github.com/anacrolix/torrent/tracker"
+ "github.com/anacrolix/torrent/util"
)
// Ensure net.IPs are stored big-endian, to match the way they're read from
}
func TestMarshalAnnounceResponse(t *testing.T) {
- w := bytes.NewBuffer(nil)
- if err := binary.Write(w, binary.BigEndian, []Peer{{[4]byte{127, 0, 0, 1}, 2}, {[4]byte{255, 0, 0, 3}, 4}}); err != nil {
+ w := bytes.Buffer{}
+ peers := util.CompactPeers{{[4]byte{127, 0, 0, 1}, 2}, {[4]byte{255, 0, 0, 3}, 4}}
+ err := peers.WriteBinary(&w)
+ if err != nil {
t.Fatalf("error writing udp announce response addrs: %s", err)
}
if w.String() != "\x7f\x00\x00\x01\x00\x02\xff\x00\x00\x03\x00\x04" {
if testing.Short() {
t.SkipNow()
}
- tr, err := tracker.New("udp://tracker.openbittorrent.com:80/announce")
+ tr, err := New("udp://tracker.openbittorrent.com:80/announce")
if err != nil {
t.Skip(err)
}
if err := tr.Connect(); err != nil {
t.Skip(err)
}
- req := tracker.AnnounceRequest{
+ req := AnnounceRequest{
NumWant: -1,
- Event: tracker.Started,
+ Event: Started,
}
rand.Read(req.PeerId[:])
copy(req.InfoHash[:], []uint8{0xa3, 0x56, 0x41, 0x43, 0x74, 0x23, 0xe6, 0x26, 0xd9, 0x38, 0x25, 0x4a, 0x6b, 0x80, 0x49, 0x10, 0xa6, 0x67, 0xa, 0xc1})
if testing.Short() {
t.SkipNow()
}
- req := tracker.AnnounceRequest{
- Event: tracker.Stopped,
+ req := AnnounceRequest{
+ Event: Stopped,
}
rand.Read(req.PeerId[:])
rand.Read(req.InfoHash[:])
} {
go func(url string) {
defer wg.Done()
- tr, err := tracker.New(url)
+ tr, err := New(url)
if err != nil {
t.Fatal(err)
}
t.Fatal(err)
}
log.Print("connected")
- _, err = cl.Announce(&tracker.AnnounceRequest{})
+ _, err = cl.Announce(&AnnounceRequest{})
if err != nil {
t.Fatal(err)
}
n, _, _ := conn.ReadFrom(b[:])
r = bytes.NewReader(b[:n])
read(r, &h)
- read(r, &tracker.AnnounceRequest{})
+ read(r, &AnnounceRequest{})
all, _ := ioutil.ReadAll(r)
if string(all) != "\x02\x09/announce" {
t.FailNow()
"encoding"
"encoding/binary"
"fmt"
+ "io"
"github.com/anacrolix/libtorgo/bencode"
)
return
}
+func (me CompactPeers) WriteBinary(w io.Writer) error {
+ return binary.Write(w, binary.BigEndian, me)
+}
+
type CompactPeer struct {
IP [4]byte
Port uint16