Commit Graph

648 Commits (9f615bbebfd9c5a896ddc7cace680ec45d2c2501)
 

Author SHA1 Message Date
erdgeist 1d821b95cb Lot of Gehacktes around this keyword scanner. Don't return a match if string to compare is shorter than key from table.
erdgeist de5dbad258 This memmove was for real...
erdgeist b019607ba5 Limit comparison of strings to the length of the shorter string
erdgeist 2d3718151d Fix a pointer arithmetic issue leading to incorrect peer data being copied. Allocate correct size for debugbuffer. Expect exact values on find keywords, not only prefix match.
erdgeist 0b875273d4 Remove debug message
erdgeist f12fa4c362 Use a self pipe to wake from io_wait when a thread finished his work.
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
erdgeist 4ced0484ab Some premature optimization lead to always only 8bytes of ot_peers being copied
erdgeist 02b3abbab6 Make v4 and v6 modes v4/v6-ONLY
erdgeist 930495a0db We sent an incorrect reply dictionary vor v6 announces
erdgeist d1a452e98a fix parser
erdgeist 131211b4da V6
erdgeist 779d6c235f * http and udp routines now use thread local buffers passed in workstruct containers. In other words they do not use static_buffer anymore and are considered to be thread safe.
* the new workstruct also introduces a well defined buffer and result passing path
* a new function scan_find_keywords is a wrapper around scan_urlencoded_query that maps keys in url to values passed in an array of ot_keywords structs
* this new function cleans up much of url parameter parsing work, where read_ptr and write_ptr have been introduced rather than the confusing char *c, *data variables
* I now use memcmp instead of byte_diff to allow compiler to optimize constant size string compares
* got rid of UTORRENT_1600_WORKAROUND
* livesync_ticker is now only called from one (currently main) thread to avoid race conditions
erdgeist 8bdc0d73f6 Make opentracker ANSI C again.
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.
erdgeist 548e2b8338 Introduce new flag WANT_SYNC_SCRAPE
erdgeist 20257202af Fix incorrect prototype for accesslist_deinit
erdgeist 38c073e6dd minor white space
erdgeist 5c99e50e25 minoe white space
erdgeist 3ee8991200 Fix badly formed bencoded answer to stopped events
erdgeist 3df5e476d0 Fix: Did not time stamp a torrent correctly, that once timed out and came back to life
erdgeist 6d4845149c Propose a scrape sync protocol.
erdgeist a9ab9b0c0d Make all torrents in their buckets sorted again.
erdgeist bca8bee623 Fix: auto increment in += is not a post increment...
erdgeist 5f5007883e Fix post increase on wrong pointer type.
erdgeist 5a0146f810 Used wrong variable as offset into hash to copy
erdgeist c6947b160f Handle program end more politely
erdgeist ad8c9ee1ef Avoid cast warning on 64bit machines
erdgeist 08c7162783 Renamed OT_FLAG to OT_PEERFLAG to make code easier to read
Introduced READ16/32 and WRITE16/32 makros to abstract loading/storing from unaligned addresses away on cpu's that can actually load/store everywhere
Removed all unnecessary memmoves, especially where it only moved 6 bytes in inner loop. I replaced them with WRITE16/32(READ16/32()) makros
erdgeist a4ed31d517 Format for full scrapes was not parsed correctly.
erdgeist 256f2c6f98 Make mutex_lock_bucket_by_hash generic to any OT_BUCKET_COUNT
erdgeist 258cae746f Forgot one define READ32
erdgeist 5fb58458f6 Tidy up unnecessary includes
erdgeist 08d9c342d4 Add specialized vector functions to handle peers in sorted lists
Assume that compare_size is a mulptiple of 4 in all non-specialized cases and load int32_t to compare.
erdgeist 23be5c4d55 Let's give a damn about syntactical correctness of peer's http strings. It's too expensive on both sides to check and to reject.
erdgeist 7120799379 Now enforce that peers do not come back before our interval by giving out a 'min interval' in responses.
erdgeist 405ef01dd3 printf is buffered, write not. Use printf for all.
erdgeist 76da780220 fix size of 0 issue
erdgeist eda3ae7f91 Add debug code to spot peers that come back too early
erdgeist 2c7c10138b Add debug code to store peer id
erdgeist e2199cc504 New peer flag to see, whether peer came from announce or sync
erdgeist 0523b429ae Aid spotting bad clients...
denis bfbb5ecb44 stats fuer sync
erdgeist 566e8267e1 Live Sync for peers that do not come back too early.
erdgeist 334c6e4bbb The BIG refactoring [tm]. Too many changes to count them. If it doesn't suite you, revert to last version.
erdgeist ff6c0339c1 Bugfix: Number of Pools << Number of Buckets
erdgeist 272abf8430 Try to use much less memory and hope for speedups
erdgeist 18b6e9b212 Spread the amount of time spent in cleanup about 2 minutes
erdgeist 9c0b23e28d Add stats about when peers renew their announces.
erdgeist 3f5468672b Never let vectors shrink below their minimal capacity