Commit Graph

65 Commits (8bf40b6717c5a5bca4bf6c6a1fefe2b1c7d2f29a)

Author SHA1 Message Date
denis 1968f47d74 silenced some clang warnings 13 years ago
erdgeist 85df3dbc01 Open syslog connection before dropping privileges 14 years ago
erdgeist d42bf5a031 ** struct ot_workstruct gets ritcher (and will become even ritcher soon).
This is where we encapsulate all per-request data from peer to hash to peer_id, so that it is
available everywhere without passing hundreds of pointers down the stack. Most functions that
do work down the stack now accept an ot_workstruct and some flags. So it can end up in the
stats/event-handler where it will be the default parameter in the future.

** peer_id is now being copied by default and moved to ot_workstruct
So it is available in stats and subsequent functions.

** sync scrape madness is gone
SYNC_SCRAPE was intended to sync tracker state that would normally be lost on restarts i.e.
downloaded counts per torrent. The way was to push it in the tracker cloud after finding all
neighbouring trackers.
This is madness. It never was tested and can be done per tracker by fetching
stats/mode=statedump from time to time and starting opentracker with the -l option later.

** livesync thread has its own ot_workstruct now
So it can behave like ot_udp and ot_http against trackerlogic.c and get rid of the first half
of the embarrassing global variables. The sending half will be fixed soon [tm].

** stats can log completed events
The author recognizes the needs of original content distributors to keep track of the amount
of times a work has been downloaded. While not feasible and used on openbittorrent and other
open and anonymous tracker installations, a tracker user can now choose to send those events
to syslog.
15 years ago
erdgeist 3baa1abc56 Fix white spaces 15 years ago
erdgeist 66cda4bc75 Add our own time stamps to the completed logs. 15 years ago
erdgeist fc48cbed01 Fix segfault in stats?mode=everything, an additional errorcode was not commited to ot_stats 15 years ago
erdgeist f4409df68a Allow logging of completed events to syslog 15 years ago
erdgeist 26bf39da89 #define closed too early 15 years ago
erdgeist 0bf88427c6 Add spotting woodpeckers, thanks to Vasya P. again 15 years ago
erdgeist 6eeb16123c Cleanup s24s code, remove an ugly mem leak, thanks to Vasya P. for pointing at the bug and suggesting a fix 15 years ago
erdgeist 4c4303a156 Temporary feature: log amount of numwants. See if we can save traffic if we reduce max numwant to something less than 200 15 years ago
erdgeist 517adde681 Limit shifting in s24s cleanup code to a non-overflowing size 15 years ago
erdgeist 6073127ad0 Add some subnet debugging features 15 years ago
erdgeist 531ebd4949 Make opentracker return tracker id in stats=everything request 16 years ago
erdgeist 877e3cfbb0 Remove unnecessary =NULL initialization of static pointers. 16 years ago
erdgeist 2a94892890 Display v4 addresses in v4 mode nicer 16 years ago
erdgeist 6c19143bc1 Major rewrite of live bad network logging. You can now limit logging to any netmask. HTTP interface for that coming soon. 16 years ago
erdgeist a713514a78 Make our stats xml validate again 16 years ago
erdgeist 91f5fa20a7 include overall completed count in stats 16 years ago
erdgeist bd6695bded Fix XML syntax 16 years ago
erdgeist c7ed890222 Fix white spaces
Introduce loading tracker states with -l
Alter tracker state to a human readable form
16 years ago
erdgeist a58bce83ad Found some minor issues in busy network detection code. 16 years ago
erdgeist eec51a872c Re-implement logging busy networks to handle v6 API.
Implement a state dump for later reparsing.
16 years ago
erdgeist 255ac58971 Add a everything stats page. So you won't have to remember what all those switches were.
Remove the prepared Add/Remove-Torrent count until we implement it.
Remove the start/stop count until we implement it.
16 years ago
erdgeist 9297967f85 Add a stat option the count bucket stalls
Add an iterator for all torrents. It's slower but for stats it's okay.
Move some stats collection stuff to the new iterator. More to come.
Start a "report all stats" page.
Start fixing the code to identify "busy" networks.
Add the concept of hosts allowed to proxy.
Add a parser for the X-Forwarded-For: HTTP header.
Clean up HTTP Header handling code. (Remove some left overs of now vanished sync code).
16 years ago
erdgeist 4c0d5c1c08 Formatting 16 years ago
erdgeist f8185878fb Make snprintf write to the correct location 16 years ago
erdgeist de5dbad258 This memmove was for real... 16 years ago
erdgeist 66c906d5d3 Add comments, rename our struct http_data h to cookie, all clientsockets to sock, all size_t from socket_recvs to byte_count. Make signal handler set default handler for the second SIGINT 16 years ago
erdgeist 131211b4da V6 16 years ago
erdgeist 8bdc0d73f6 Make opentracker ANSI C again. 16 years ago
erdgeist 2df09905f5 * opentracker now drops permissions in correct order and really chroots() if ran as root
* lock passing between add_peer_to_torrent and return_peers_for_torrent is now avoided by providing a more general add_peer_to_torrent_and_return_peers function that can be used with NULL parameters to not return any peers (in sync case)
* in order to keep a fast overview how many torrents opentracker maintains, every mutex_bucket_unlock operation expects an additional integer parameter that tells ot_mutex.c how many torrents have been added or removed. A function mutex_get_torrent_count has been introduced.
16 years ago
erdgeist c6947b160f Handle program end more politely 16 years ago
erdgeist 76da780220 fix size of 0 issue 16 years ago
denis bfbb5ecb44 stats fuer sync 16 years ago
erdgeist 334c6e4bbb The BIG refactoring [tm]. Too many changes to count them. If it doesn't suite you, revert to last version. 16 years ago
erdgeist ff6c0339c1 Bugfix: Number of Pools << Number of Buckets 16 years ago
erdgeist bb1c5d2805 Add stats about when peers renew their announces. 16 years ago
erdgeist daaee855b2 Whitespace fixes 16 years ago
erdgeist 511a92e321 First vector has size 1, not 0 in debug vector 16 years ago
erdgeist e89a8aaf58 Move more complicated stats code to its own thread 16 years ago
erdgeist f4283be677 Fix debug output for addresses >127 16 years ago
erdgeist e534db03c6 added live sync code
added a config file parser
added tracker id
changed WANT_CLOSED_TRACKER and WANT_BLACKLIST into WANT_ACCESS_WHITE and WANT_ACCESS_BLACK
changed WANT_TRACKER_SYNC to WANT_SYNC_BATCH and added WANT_SYNC_LIVE
added an option to switch off fullscrapes

cleaned up many internal hardcoded values, like PROTO_FLAG,
16 years ago
erdgeist 90184649d0 Embarrasing counter direction bug :) 17 years ago
erdgeist 572df73443 Forgot to #ifdef some code only interesting when doing live network logging. 17 years ago
erdgeist 408c5f98ed Introducing live busy network detection. 17 years ago
erdgeist 57387588ed Enable revision watching from the internet 17 years ago
erdgeist c28cf398fd Introduce some kind of versioning 17 years ago
erdgeist d9ed6c22bd Forgot to unlock bucket in case of malloc error, thanks to Astro for reporting. 17 years ago
denis 65c3b24045 add support for more stats:
1. stats for added and removed torrents
2. stats for start and stopped events from peers

this should help to detect DoS attacks and is useful for
profiling
17 years ago