40) { bad_request("Invalid info_hash"); } } catch (Exception $e) { bad_request("Invalid info_hash"); } try { if (isset($_GET["ip"])) { $ip = urldecode($_GET["ip"]); } else if (isset($_SERVER["HTTP_X_FORWARDED_FOR"])) { $ip = $_SERVER["HTTP_X_FORWARDED_FOR"]; } else { $ip = $_SERVER["REMOTE_ADDR"]; } } catch (Exception $e) { bad_request("Invalid ip"); } if (!$ipAddr = inet_pton($ip)) { bad_request("Invalid ip"); } if (isset($_GET["port"])) { $port = intval(urldecode($_GET["port"])); } else { bad_request("No port"); } $externalIp = get_external_ip(); $date = new DateTime("now"); $now = $date->format('Y-m-d H:i:s'); $conn = new PDO("mysql:host=$DB_HOST;dbname=$DB_NAME", $DB_USER, $DB_PASS); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $stmt = $conn->prepare("REPLACE INTO `tracker` (info_hash, ip, port, update_time) VALUES (:info_hash, :ip, :port, :update_time)"); $stmt->bindValue(":info_hash", $hash, PDO::PARAM_STR); $stmt->bindValue(":ip", is_loopback($ip) ? $externalIp : $ip, PDO::PARAM_STR); $stmt->bindValue(":port", $port, PDO::PARAM_INT); $stmt->bindValue(":update_time", $now, PDO::PARAM_STR); $stmt->execute(); $peers = ''; $stmt = $conn->prepare("SELECT ip, port FROM `tracker` WHERE info_hash = :info_hash"); $stmt->bindValue(":info_hash", $hash, PDO::PARAM_STR); $stmt->execute(); $stmt->bindColumn(1, $peerIp); $stmt->bindColumn(2, $peerPort); while ($stmt->fetch(PDO::FETCH_BOUND)) { if (is_loopback($peerIp) && !is_loopback($ip)) { $peerIp = $externalIp; } else if ($peerIp == $externalIp && is_loopback($ip)) { $peerIp = ip4_loopback(); } $peers .= pack("Nn", inet_pton($peerIp), $peerPort); } $response = array( "min interval" => $ANN_MIN_INTERVAL, "interval" => $ANN_INTERVAL, "peers" => $peers, ); echo(bencode($response)); ?>