preamble
<?php
// connect to mysql and select the database
include 'localsettings.php';
// workaround for bt settings change Feb 9 2004
ini_set(allow_url_fopen,1);
// check that we have a team and player
if ((!$_GET["P"]) || (!$_GET["T"])) {
echo "Team or Player is not set<p>";
echo "Start at <a href=\"index.php\">the main page</a><p>";
exit(0);
}
$DefTeam = $_GET["T"];
$DefPlayer = $_GET["P"];
$LOGIN = $DefTeam;
// look up this team's password in the database
$sql = "SELECT * FROM MWGames, MWMoves WHERE GameName = Game AND TeamName = '$DefTeam'";
$result = mysql_query($sql, $db);
if ((!$result) || (mysql_num_rows($result)==0)) {
// invalid team name
$NoTeamMsg = "There is no team in the db by the name of $DefTeam<p>";
$NoTeamMsg .= "Query was $sql<p>";
$PASSWORD = "slsjf87sjdf823js3823"; // so the authentication will fail
} else {
$myrow = mysql_fetch_array($result);
$PASSWORD = $myrow["Password"];
$PlayerData = $myrow["PlayerData"];
$GameData = $myrow["GameData"];
}
// require entry of the team name and password
if ( (!isset($_SERVER['PHP_AUTH_USER'])) || ! (($_SERVER['PHP_AUTH_USER'] == $LOGIN) && ( $_SERVER['PHP_AUTH_PW'] == "$PASSWORD" )) ) {
header("WWW-Authenticate: Basic realm=\"Enter password for $LOGIN\"");
header("HTTP/1.0 401 Unauthorized");
echo "Authorization Required...<p>";
echo $NoTeamMsg; // in case we failed with a bad team name
if ($LOGIN == "demo") { echo "Username=demo($LOGIN), Password=demo($PASSWORD)<BR>pw=" . $_SERVER['PHP_AUTH_PW'] . "<BR>"; }
exit;
}
// Game settings - may change from time to time, but, hopefully, not every game
// Each new game must be manually added to the MWGames table of the database
$GameDataFields = explode("|", $GameData);
$BoardURL = "http://minutewar.gpsgames.org/$GameDataFields[0]/board.txt";
$BoardHTMURL = "http://minutewar.gpsgames.org/$GameDataFields[0]/board.htm";
$GameEngineURL = "http://minutewar.gpsgames.org/cgi-bin/$GameDataFields[0]/mw.pl";
$TimeBetweenCaptures = $GameDataFields[1]; //seconds
$DefaultOffsets = $GameDataFields[2];
$DrawType = $GameDataFields[3];
// should read the above two lines from board.html, but I'm too lazy right now :)
// Now that we know the password, we can retrieve the MoveData
$sql = "SELECT DECODE(MoveData, '".$_SERVER['PHP_AUTH_PW']."') as MD FROM MWMoves WHERE TeamName = '$DefTeam'";
$result = mysql_query($sql, $db);
if ((!$result) || (mysql_num_rows($result)==0)) {
// select failed
echo "Failed to retrieve move data from database<p>";
echo "Query was $sql<p>";
} else {
$myrow = mysql_fetch_array($result);
$MoveData = stripslashes($myrow["MD"]);
}
$MoveDelimiter = "|EOM|"; // used to separate different move records
//Team colors
$CellColor["!New"] = "#000000";
$CellColor["ENew"] = "#FF0099";
$CellColor["NNew"] = "#33CC00";
$CellColor["SNew"] = "#FFFF00";
$CellColor["WNew"] = "#6699FF";
$CellColor["!Old"] = "#000000";
$CellColor["EOld"] = "#FF99CC";
$CellColor["NOld"] = "#99FF00";
$CellColor["SOld"] = "#FFFF99";
$CellColor["WOld"] = "#99CCFF";
$CellColor[""] = "White";
$CellColor["0"] = "White";
//Individual colors
$CellColor["1New"] = "#0066FF";
$CellColor["2New"] = "#FF0000";
$CellColor["3New"] = "#00FF00";
$CellColor["4New"] = "#FFFF00";
$CellColor["5New"] = "#00FFFF";
$CellColor["6New"] = "#FF00FF";
$CellColor["7New"] = "#CCCCFF";
$CellColor["8New"] = "#FF9999";
$CellColor["9New"] = "#99FF99";
$CellColor["10New"] = "#FFFFCC";
$CellColor["11New"] = "#CCFFFF";
$CellColor["12New"] = "#FF99FF";
$CellColor["13New"] = "#9999FF";
$CellColor["14New"] = "#993333";
$CellColor["15New"] = "#339933";
$CellColor["16New"] = "#CCCC66";
$CellColor["17New"] = "#339999";
$CellColor["18New"] = "#993399";
$CellColor["19New"] = "#CCCCCC";
$CellColor["1Old"] = "#99CCFF";
$CellColor["2Old"] = "#FF99CC";
$CellColor["3Old"] = "#99FF00";
$CellColor["4Old"] = "#FFFF99";
$CellColor["5Old"] = "#FFCC33";
$CellColor["6Old"] = "#CC9999";
$CellColor["7Old"] = "#CCCC66";
$CellColor["8Old"] = "#CCCCCC";
//load default offsets and locations
if ($PlayerData) {
$PlayerList = explode("\n",$PlayerData);
for ($i=0; $i<count($PlayerList)-1; $i++) {
$PlayerFields = explode("|",$PlayerList[$i]);
$Deflts["LatOff"][$PlayerFields[0]] = $PlayerFields[1];
$Deflts["LonOff"][$PlayerFields[0]] = $PlayerFields[2];
$Deflts["LatHem"][$PlayerFields[0]] = $PlayerFields[3];
$Deflts["LonHem"][$PlayerFields[0]] = $PlayerFields[4];
$Deflts["LatDeg"][$PlayerFields[0]] = $PlayerFields[5];
$Deflts["LonDeg"][$PlayerFields[0]] = $PlayerFields[6];
$Deflts["Email"][$PlayerFields[0]] = $PlayerFields[7];
$Deflts["LatMin"][$PlayerFields[0]] = $PlayerFields[8];
$Deflts["LonMin"][$PlayerFields[0]] = $PlayerFields[9];
}
}
// simple function to apply offsets
function FindSquare($Player, $Lat, $Lon) {
global $Deflts;
// 5/4/04 added '+60' in two places below to fix a bug with negative offsets
return ((floor($Lat)+$Deflts["LatOff"][$Player]+60) % 60)."x".((floor($Lon) + $Deflts["LonOff"][$Player]+60) % 60);
}
?>