NAME
Net::BitTorrent::Protocol::BEP03 - Core BitTorrent Peer Wire Protocol
SYNOPSIS
use Net::BitTorrent::Protocol::BEP03;
my $proto = Net::BitTorrent::Protocol::BEP03->new(
infohash => $ih,
peer_id => $id
);
# Generate initial handshake
my $out = $proto->write_buffer( );
# Process incoming bytes from the socket
$proto->receive_data( $raw_bytes );
# Send a custom message
$proto->send_message( 4, pack('N', $piece_index) ); # HAVE
DESCRIPTION
Net::BitTorrent::Protocol::BEP03 implements the foundational BitTorrent Peer Wire Protocol (BEP 03). It is a stateful, loop-agnostic parser and generator for the binary messages exchanged between peers over TCP (or uTP).
This module handles the initial handshake, reserved bit negotiation, and the framing of all standard messages (choke, unchoke, interested, have, bitfield, request, piece, etc.).
METHODS
new( %params )
Creates a new BEP03 protocol handler.
Expected parameters:
infohash-
The 20 or 32-byte binary infohash.
peer_id-
The local 20-byte binary peer ID.
reserved- optional-
The 8-byte reserved bits string.
send_handshake( )
Sends the initial protocol handshake.
$proto->send_handshake();
receive_data( $data )
Feeds raw data into the protocol parser.
$proto->receive_data( $chunk );
Expected parameters:
write_buffer( )
Returns pending messages from the output buffer.
my $out = $proto->write_buffer();
send_message( $id, [$payload] )
Queues a protocol message.
$proto->send_message( 4, pack('N', 42) ); # HAVE piece 42
Expected parameters:
send_keepalive( )
Queues a keep-alive message.
$proto->send_keepalive();
send_choke( )
Sends a CHOKE message.
send_unchoke( )
Sends an UNCHOKE message.
send_interested( )
Sends an INTERESTED message.
send_not_interested( )
Sends a NOT_INTERESTED message.
send_have( $index )
Sends a HAVE message.
Expected parameters:
send_bitfield( $data )
Sends a BITFIELD message.
Expected parameters:
set_reserved_bit( $byte, $mask )
Sets a bit in the reserved bytes of the handshake.
$proto->set_reserved_bit( 5, 0x10 );
Expected parameters:
handshake event
Emitted when a handshake is successfully received.
$proto->on( handshake => sub ( $self, $ih, $id ) { ... } );
Expected parameters:
peer_id( )
Returns the local peer ID.
reserved( )
Returns or sets the reserved bytes string.
Expected parameters:
state( )
Returns the current protocol state ('HANDSHAKE', 'OPEN', or 'CLOSED').
detected_ih( )
Returns the infohash detected during the handshake (useful for trackers/servers).
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.