erdgeist
65cc45f129
Log all expansive operations to stderr
18 years ago
erdgeist
ffffd80719
Most open trackers do not have the problem of not being called often enough.. so do not introduce an extra timeout when waiting for activity. That also removes one of the last extraneous gettimeofday calls
18 years ago
erdgeist
6c1adb8fc8
since gettimeofday is rather expansive, we do only fetch time once in a 5 second period, when we are delivered a SIGALRM.
18 years ago
erdgeist
4c15dc7a70
make 64bit safe
18 years ago
denis
0d36a8754e
fixed some stat output
18 years ago
erdgeist
c350fa0b3c
New stats for s24s code, this is debug, do not use in real world
18 years ago
erdgeist
33c9c530d0
An announce with event=stopped now returns correct number of leechers and seeders. In TCP and UDP.
18 years ago
erdgeist
3e47339b6c
Added whitelisting to reimplement the WANT_CLOSED_TRACKER functionality
18 years ago
erdgeist
992058383a
Under Linux one gets SIG_ALRMs from time to time when using epoll. Ignore those.
18 years ago
erdgeist
77af0b475f
Sort of addressed a concorrency issue when receiving mutliple SIG_HUPs
18 years ago
erdgeist
afe966b644
some subnet stats... still ugly and untested.
18 years ago
erdgeist
c0b00c0bf5
* fixed "nobody " -> "nobody" fuckup when getpwnam-ing
...
* implemented basic blacklisting:
** the file specified with -b <BLACKLIST> is read and added to a blacklist vector
** if an announce hits a torrent in that blacklist vector, add_peer_to_torrent fails
** sending a SIGHUP to the program forces it to reread the blacklists
** the server returns with a 500, which is not exactly nice but does the job for now
** an adaequat "failure reason:" should be delivered... TODO
18 years ago
erdgeist
3f0a18ba08
Clean up pw-structs
18 years ago
denis
c212b48bec
add comment for udp spec location
18 years ago
denis
78b7c73eab
check for mafic udp id
18 years ago
denis
8f0aaed6b2
fixed an overflow in ot_overall_* variables
18 years ago
erdgeist
77e5241cf8
Clean up help and usage
18 years ago
erdgeist
5c18293c9c
New Makefile, incorporated some patches sent to me by Robin H. Johnson
18 years ago
erdgeist
bd4617a911
Try to figure out nobodys uid und gid using getpwnam
18 years ago
erdgeist
4e9523c489
Fix endianess issue with blessed ips. Document -A feature.
18 years ago
erdgeist
32ba028814
added the -A feature that blesses a certain IP address for administrative use (like sync)
18 years ago
erdgeist
33774078ab
Added inbound part of sync. This also meant to remove the black/whitelisting as we did by now. A more scalable way to blacklist will follow.
18 years ago
erdgeist
b38104b986
Added outbound part of sync Proposed format: d4:syncd20:<info_hash>8*N:(xxxxyy)*Nee, therefore had to refactor torrent cleanup now that it will hit all torrents once every OT_POOL_TIMEOUT units.
18 years ago
denis
bab7c0bbb1
code cleanup and more specific comments. tracker starts now also with udp port 6969 as default
18 years ago
denis
46605bcb2c
some udp scrape style cleanup
18 years ago
denis
8ac7768b96
support for udp scrape
18 years ago
denis
36413e4853
fix the stats a little for not accepting udp scrapes
18 years ago
denis
45d34960b0
udp first connect needs to be counted as a connection too
18 years ago
denis
f07ec869d8
added the udp stats to the main stats
18 years ago
denis
5bb381e20a
new modes for udp4 and tcp4 stats
18 years ago
denis
50fe661aa7
collecting stats for udp connections (2nd try)
18 years ago
denis
f2a0c36721
collecting stats for udp connections
18 years ago
denis
036e874ed4
fixed udp peerport endianess handling
18 years ago
denis
92213c286a
fixed udp remoteport handling
18 years ago
erdgeist
c00c64f9da
some 64bit and endianess issues with udp...
18 years ago
erdgeist
e75c3e25cd
make full scrapes a bit faster, increase checkback time for udp
18 years ago
erdgeist
5b55394cdc
Port is a short, not a long
18 years ago
erdgeist
5d1f07d353
Sanify handling of server sockets
18 years ago
erdgeist
0a90216686
udp is working in theory, return_peers_for_torrent accepts a switch to request an udp answer. Fixed prototypes.
18 years ago
erdgeist
175c37c3e8
Can now handle multiple ips/ports, can BIND to udp ports but not yet handle them, now checks if event=completed comes with left=0 and drops it, if it doesnt
18 years ago
erdgeist
0d6f508882
zero copy sockets do only work on page aligned buffers for page sized blocks. So remove the code that tried to take advantage of false assuming, it would work on any buffer
18 years ago
denis
222519fdff
fixed the last commit. now it really counts the scrapes and fullscrapes
18 years ago
denis
bbdc36c518
add the scrapes to the valid requests (blue mrtg line)
18 years ago
erdgeist
f9c49e9759
el cheapo vector debugging
18 years ago
erdgeist
62c59983cb
Use multiple output buffers to try to avoid copy on write when unnecessary
18 years ago
erdgeist
10a6586ad1
Try to shake off too stupid clients by sending an Bittorrent error rather than an HTTP 400
18 years ago
erdgeist
6e1ee92de6
Use signed size_t wherever appropriate
18 years ago
erdgeist
11abb03e85
size_t cant get < 0 and thus wont report errors
18 years ago
erdgeist
f0ddf30389
provide mrtg with more sane strings
18 years ago
erdgeist
5a3d6b4029
We now answer as soon as the first \n is seen
...
We do not copy input buffer to socket's input array anymore, if we find \n in first buffer
We simplified parsing of input string
We removed asserts that were needed to debug negative seeder counts
We split static input and output buffers for obvious reasons
We enlarged static output buffer to prepare multi scrape functionality
We removed -lm from Makefile, this lib was only needed, when our random algorithm worked on floats
We close fds now that come with an empty iocookie into write loop, those don't make sense
We documented query string parser in opentracker.c a lot better to help auditing
18 years ago