NAME
Net::BitTorrent::Tracker::UDP - UDP BitTorrent Tracker Protocol (BEP 15)
SYNOPSIS
use Net::BitTorrent::Tracker::UDP;
my $tracker = Net::BitTorrent::Tracker::UDP->new(
url => 'udp://tracker.openbittorrent.com:80/announce'
);
# Announce
$tracker->perform_announce({
infohash => $bin_ih,
peer_id => $my_id,
port => 6881,
downloaded => 0,
uploaded => 0,
left => 1024
}, sub ($res) {
say 'Peers: ' . join(', ', map { $_->{ip} } @{$res->{peers}});
});
DESCRIPTION
Net::BitTorrent::Tracker::UDP implements the lightweight UDP Tracker Protocol (BEP 15). UDP is the preferred transport for BitTorrent trackers as it significantly reduces overhead on the tracker server compared to HTTP.
BitTorrent v2 Support
This module is BEP 52 compliant. It handles 32-byte SHA-256 infohashes by dynamically adjusting the binary structure of outgoing messages or by providing truncated/hashed 20-byte identifiers where necessary for legacy compatibility.
METHODS
perform_announce( \%params, [$callback] )
Sends an announce request to the UDP tracker.
$tracker->perform_announce( \%params, sub ($res) { ... } );
This method handles connection ID acquisition and retransmissions automatically.
Expected parameters:
\%params-
Standard announce parameters (infohash, peer_id, port, uploaded, downloaded, left, event).
$callback- optional-
Called with the parsed response hash containing
interval,leechers,seeders, andpeers.
perform_scrape( \@infohashes, [$callback] )
Sends a scrape request to the UDP tracker.
$tracker->perform_scrape( \@ihs, sub ($res) { ... } );
Expected parameters:
\@infohashes-
List of binary infohashes to scrape.
$callback- optional-
Called with the scrape results.
tick( )
Performs periodic maintenance.
$tracker->tick( 0.1 );
This method handles incoming packets and retransmissions for pending requests.
receive_data( $data )
Processes an incoming UDP packet.
$tracker->receive_data( $raw_packet );
Expected parameters:
url( )
Returns the tracker URL.
Specifications
BEP 15: UDP Tracker Protocol
BEP 52: The BitTorrent Protocol v2 (UDP extensions)
AUTHOR
Sanko Robinson <sanko@cpan.org>
COPYRIGHT
Copyright (C) 2008-2026 by Sanko Robinson.
This library is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0.