diff options
Diffstat (limited to 'opentracker.c')
| -rw-r--r-- | opentracker.c | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/opentracker.c b/opentracker.c index 5e8ebc1..2fb6bf5 100644 --- a/opentracker.c +++ b/opentracker.c | |||
| @@ -315,7 +315,7 @@ SCRAPE_WORKAROUND: | |||
| 315 | } | 315 | } |
| 316 | 316 | ||
| 317 | /* Enough for http header + whole scrape string */ | 317 | /* Enough for http header + whole scrape string */ |
| 318 | if( !( reply_size = return_scrape_for_torrent( hash, SUCCESS_HTTP_HEADER_LENGTH + static_outbuf ) ) ) HTTPERROR_500; | 318 | if( !( reply_size = return_tcp_scrape_for_torrent( hash, SUCCESS_HTTP_HEADER_LENGTH + static_outbuf ) ) ) HTTPERROR_500; |
| 319 | 319 | ||
| 320 | ot_overall_tcp_successfulannounces++; | 320 | ot_overall_tcp_successfulannounces++; |
| 321 | break; | 321 | break; |
| @@ -590,7 +590,7 @@ static void handle_udp4( int64 serversocket ) { | |||
| 590 | unsigned long *outpacket = (unsigned long*)static_outbuf; | 590 | unsigned long *outpacket = (unsigned long*)static_outbuf; |
| 591 | unsigned long numwant, left, event; | 591 | unsigned long numwant, left, event; |
| 592 | uint16 port, remoteport; | 592 | uint16 port, remoteport; |
| 593 | size_t r; | 593 | size_t r, r_out; |
| 594 | 594 | ||
| 595 | r = socket_recv4( serversocket, static_inbuf, 8192, remoteip, &remoteport); | 595 | r = socket_recv4( serversocket, static_inbuf, 8192, remoteip, &remoteport); |
| 596 | 596 | ||
| @@ -647,7 +647,7 @@ static void handle_udp4( int64 serversocket ) { | |||
| 647 | if( !torrent ) | 647 | if( !torrent ) |
| 648 | return; /* XXX maybe send error */ | 648 | return; /* XXX maybe send error */ |
| 649 | 649 | ||
| 650 | outpacket[0] = htonl( 1 ); | 650 | outpacket[0] = htonl( 1 ); /* announce action */ |
| 651 | outpacket[1] = inpacket[12/4]; | 651 | outpacket[1] = inpacket[12/4]; |
| 652 | r = 8 + return_peers_for_torrent( torrent, numwant, static_outbuf + 8, 0 ); | 652 | r = 8 + return_peers_for_torrent( torrent, numwant, static_outbuf + 8, 0 ); |
| 653 | socket_send4( serversocket, static_outbuf, r, remoteip, remoteport ); | 653 | socket_send4( serversocket, static_outbuf, r, remoteip, remoteport ); |
| @@ -656,7 +656,14 @@ static void handle_udp4( int64 serversocket ) { | |||
| 656 | break; | 656 | break; |
| 657 | 657 | ||
| 658 | case 2: /* This is a scrape action */ | 658 | case 2: /* This is a scrape action */ |
| 659 | ot_overall_udp_connections--; // subtract again because we don't answer scrapes but it is also not an error | 659 | outpacket[0] = htonl( 2 ); /* scrape action */ |
| 660 | outpacket[1] = inpacket[12/4]; | ||
| 661 | |||
| 662 | for( r_out = 0; ( r_out * 20 < r - 16) && ( r_out <= 74 ); r_out++ ) | ||
| 663 | return_udp_scrape_for_torrent( (ot_hash*)( static_inbuf + 16 + 20 * r_out ), static_outbuf + 8 + 12 * r_out ); | ||
| 664 | |||
| 665 | socket_send4( serversocket, static_outbuf, 8 + 12 * r_out, remoteip, remoteport ); | ||
| 666 | ot_overall_udp_successfulannounces++; | ||
| 660 | break; | 667 | break; |
| 661 | } | 668 | } |
| 662 | } | 669 | } |
