diff --git a/html/bt/announce.php b/html/bt/announce.php
new file mode 100755
index 0000000000..31d2119579
--- /dev/null
+++ b/html/bt/announce.php
@@ -0,0 +1,100 @@
+$error));
+ exit;
+}
+
+$info_hash = rawurldecode($_GET["info_hash"]);
+if (strlen($info_hash)<20) throw new IllegalArgumentException("Malformed infohash key (length ".strlen($info_hash).")");
+$peer_id = $_GET["peer_id"];
+if (strlen($peer_id)<20) throw new IllegalArgumentException("Malformed peer ID (".strlen($peer_id).")");
+$port = $_GET["port"];
+if (!is_numeric($port)) throw new IllegalArgumentException("Non-numeric port supplied");
+$event = $_GET["event"];
+$ip = $_GET["ip"];
+$uploaded = $_GET["uploaded"];
+if (!$uploaded) $uploaded = 0;
+if (!is_numeric($uploaded)) throw new IllegalArgumentException("Non-numeric upload amount specified");
+$downloaded = $_GET["downloaded"]; if (!$downloaded) $downloaded = 0;
+if (!is_numeric($downloaded)) throw new IllegalArgumentException("Non-numeric download amount specified");
+
+if (!$ip){
+ $ip = $_SERVER["REMOTE_ADDR"];
+}
+
+// Is the IP banned?
+db_init();
+if (isIPBanned($ip)){
+ trackerError("Banned IP: ".$ip);
+}
+
+// Check that the info_hash is one that we allow:
+$queryHandle = mysql_query("SELECT * from bittorrent_files where info_hash=\"".process_user_text($info_hash)."\""); echo mysql_error();
+if (!mysql_num_rows($queryHandle)){
+ trackerError("The tracker does not allow tracking of this file:".$info_hash);
+}
+$infoHashObject = mysql_fetch_object($queryHandle);
+
+// If the peer is actively doing something let's update the DB
+if ($event=="started" || $event=="stopped" || $event=="completed"){
+ mysql_query("REPLACE into bittorrent_peers SET fileid=".$infoHashObject->id.", peerid=\"".process_user_text($peer_id)."\", ip=\"".process_user_text($ip)."\", port=\"".process_user_text($port)."\", status=\"".$event."\", uploaded=".process_user_text($uploaded).", downloaded=".process_user_text($downloaded).", timestamp=".time());
+ echo mysql_error();
+} else {
+ mysql_query("REPLACE delayed into bittorrent_peers SET fileid=".$infoHashObject->id.", peerid=\"".process_user_text($peer_id)."\", ip=\"".process_user_text($ip)."\", port=\"".process_user_text($port)."\", uploaded=".process_user_text($uploaded).", downloaded=".process_user_text($downloaded).", timestamp=".time());
+ echo mysql_error();
+}
+
+// Always send back a random selection of peers who are downloading a file with the same info_hash
+$queryHandle = mysql_query("SELECT * from bittorrent_peers WHERE fileid = ".$infoHashObject->id." order by RAND() limit ".MAX_INFO_HASH_PEERS); echo mysql_error();
+$peerList = array();
+while ($dbPeer = mysql_fetch_object($queryHandle)){
+ $peer = array("peer id"=>$dbPeer->peerid, "ip"=>$dbPeer->ip, "port"=>intval($dbPeer->port));
+ $peerList[] = new BElement(BDictionary::toEncoded($peer));
+}
+
+// Get some statistical counts
+$queryHandle = mysql_query("SELECT count(fileid) as complete from bittorrent_peers where fileid = '".$infoHashObject->id."' and status='completed'");
+$data = mysql_fetch_object($queryHandle);
+$complete = intval($data->complete);
+$queryHandle = mysql_query("SELECT count(fileid) as incomplete from bittorrent_peers where fileid = '".$infoHashObject->id."' and status!='completed'");
+$data = mysql_fetch_object($queryHandle);
+$incomplete = intval($data->incomplete);
+
+
+$peersElement = new BElement(BList::toEncoded($peerList));
+$out = BDictionary::toEncoded(array("interval"=>DEFAULT_CONNECTION_INTERVAL, "complete"=>$complete, "incomplete"=>$incomplete, "peers"=>$peersElement));
+
+// Echo the answer to stdout
+echo $out;
+$fh = fopen(TRACKER_LOGFILE, "a");
+fputs($fh, date(DATE_ATOM, time())." ".$_SERVER["REMOTE_ADDR"]." - ".$event."\n");
+fclose($fh);
+
+// ------------------------------------------------------
+// Check if the database needs cleaning
+$cache_args = "tracker_timer";
+$cacheddata=get_cached_data(DB_CLEAN_TTL,$cache_args);
+if ($cacheddata){ //If we have got the timer in cache
+ // Do nothing
+} else { //if not do queries etc to clean DB
+ // TODO: update the bittorrent_statistics table here before deleting entries
+ mysql_query("DELETE from bittorrent_files where timestamp<".(time()-TORRENT_TTL)); echo mysql_error();
+ mysql_query("DELETE from bittorrent_peers where timestamp<".(time()-PEER_TTL)); echo mysql_error();
+ mysql_query("DELETE from bittorrent_ipbans where timestamp<".time()); echo mysql_error();
+ // And reset the timer in the cache
+ set_cache_data(serialize(time()),$cache_args); //save data in cache
+};
+
+?>
\ No newline at end of file