erdgeist
31eada6168
Reenabled syncing
17 years ago
erdgeist
b19bbd6a85
Number of buckets is 1024 now
...
Clean all torrents now only cleans one bucket at a time
All torrents that are being worked upon in an announce are being cleaned on demoand
torrent's peer lists now keep extra counts for seeds and peers to speed up scrape and announce
Sync has gone for now. I will think up a new way to implement. The old one was way to slow.
17 years ago
erdgeist
ab9246618b
some clients chose to accidently send negative numwants
17 years ago
erdgeist
1fce733ea0
Accept clients that forget to spell announce at all...
17 years ago
erdgeist
69c6e2bc99
This uTorrent/1600 client requires some... measures :/ I dont like the workaround.
17 years ago
erdgeist
ac57c3d5d6
Now measure the time a clean_all_torrents takes
17 years ago
erdgeist
6876e16242
assume anything looking like GET /a to be an announce...
17 years ago
erdgeist
3aa286d9b8
Last fix was not enough to get rid off those 1600er buggers.
17 years ago
erdgeist
00972c6c68
Work around the stupid utorrent 1600 bug. That'll be removed after a while.
17 years ago
erdgeist
0de8b53fdd
Now the Holzhammer: GET /an is announce, GET /sc is scrape. Period.
17 years ago
erdgeist
6b2307015f
now accept more classes of announce fuckups
17 years ago
erdgeist
42210450f3
Just one more typo
17 years ago
erdgeist
2cbb480865
Just one more typo
17 years ago
erdgeist
886421d2d5
Work around more typos that might end up in torrent files as announce urls
17 years ago
erdgeist
2b715b89f1
Debug code sometimes copied too much data
17 years ago
erdgeist
ddd85ec7e0
Fixed one leak from struct_http
17 years ago
erdgeist
8098adb48e
Be even more stupidistas-tolerant
17 years ago
erdgeist
84f8738b82
Fix debug output
17 years ago
erdgeist
d768bf6e81
Enable _DEBUG_HTTPERROR to avoid warning...
17 years ago
erdgeist
53bce09735
Include time since startup in full scrape debug output
17 years ago
erdgeist
c59e44ba94
Now limit full scrape to requests sending exactly "GET /scrape HTTP/"
17 years ago
erdgeist
41019c79d8
Introducing multiscrape
17 years ago
erdgeist
d5876ebb6b
Prevent url-decoding for debug by using a temp buffer
17 years ago
erdgeist
271ff156ec
Those stupid "announce ?info_hash" torrents get really annoying. Fix it in announce and scrape.
17 years ago
erdgeist
1b0859411e
be more verbose about what full scrape consumers deliver in their http requests
17 years ago
erdgeist
714ea1b88e
give opentracker the missing header file
17 years ago
erdgeist
f56e40c24e
Must not dealloc mmaped buffers with free()
17 years ago
erdgeist
d25cf9307e
Fix misunderstandig of what libowfat thinks are seconds and what I did...
17 years ago
erdgeist
e1f122f7d1
Since array and io_batch are in a union, and we also have time-outing writable sockets, we need to mark, which of the union is used. Also remove the blessed flag from struct http, since its rarely used and can be done in a seperate memcmp.
17 years ago
erdgeist
6eb441d8a0
Cannot access members after they are freed :/
17 years ago
erdgeist
b86e6382a1
Save a lot of work when skipping through uninteresting http request parameters
17 years ago
erdgeist
32f17413fa
Increase send timeout. Also use an own variable for that.
17 years ago
erdgeist
28de135098
io_timeout is absolute, not relative :/
17 years ago
erdgeist
d1c57d90dd
Free iobatches on timeout
17 years ago
erdgeist
8e78ac7012
HEADS UP: you need to check out the latest libowfat! Huge allocations are now taken from mmap()ed regions, not from heap anymore
17 years ago
erdgeist
1e6b48cbc0
Sockets we write to now do also timeout
17 years ago
erdgeist
28d88e3380
Exclude empty torrents from full scrape, also try to shrink full scrape buffer after it is full
17 years ago
erdgeist
3dc470d672
fixed line breaks in log
17 years ago
erdgeist
65cc45f129
Log all expansive operations to stderr
17 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
17 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.
17 years ago
erdgeist
4c15dc7a70
make 64bit safe
17 years ago
denis
0d36a8754e
fixed some stat output
17 years ago
erdgeist
c350fa0b3c
New stats for s24s code, this is debug, do not use in real world
17 years ago
erdgeist
33c9c530d0
An announce with event=stopped now returns correct number of leechers and seeders. In TCP and UDP.
17 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