output_header();
echo "<h1>Setup not completed</h1>";
echo "You need to set \$ADMIN_NAME in config.php.";
- output_footer();
- exit();
- }
+ output_footer();
+ exit();
+ }
if(!isset($ADMIN_EMAIL))
{
output_header();
echo "<h1>Setup not completed</h1>";
echo "You need to set \$ADMIN_EMAIL in config.php. ".
"If something goes wrong an email will be send to this address.";
- output_footer();
- exit();
+ output_footer();
+ exit();
}
if(!isset($DB_work))
{
echo "You need to set \$DB_work in config.php. ".
"If this is set to 1, the game will be suspended and one can work safely on the database.".
"The default should be 0 for the game to work.";
- output_footer();
- exit();
+ output_footer();
+ exit();
}
- if($DB_work)
+ if($DB_work)
{
output_header();
- echo "Working on the database...please check back later.";
- output_footer();
- exit();
+ echo "Working on the database...please check back later.";
+ output_footer();
+ exit();
}
-
+
return;
}
function mymail($To,$Subject,$message,$header="")
-{
+{
global $debug,$EMAIL_REPLY;
if(isset($EMAIL_REPLY))
$message = str_replace("\n","<br />\n",$message);
$message = ereg_replace("[[:alpha:]]+://[^<>[:space:]]+[[:alnum:]/]",
"<a href=\"\\0\">\\0</a>", $message);
-
+
echo "<br />To: $To<br />";
- if($header != "")
+ if($header != "")
echo $header."<br />";
echo "Subject: $Subject <br />$message<br />\n";
}
/* returns 1 if all names passed as args are defined by a GET or POST statement,
* else return 0
*/
-
+
$ok = 1;
$args = func_get_args();
-
+
foreach($args as $arg)
{
$ok = $ok * isset($_REQUEST[$arg]);
/*echo "$arg: ok = $ok <br />";
- */
+ */
}
return $ok;
}
function pos_array($c,$arr)
{
$ret = 0;
-
+
$i = 0;
foreach($arr as $a)
{
return $ret;
}
-function is_trump($c)
-{
+function is_trump($c)
+{
global $CARDS;
if(in_array($c,$CARDS["trump"]))
return 1;
- else
+ else
return 0;
}
-function is_same_suite($c1,$c2)
+function is_same_suite($c1,$c2)
{
global $CARDS;
-
+
if(in_array($c1,$CARDS["trump"] ) && in_array($c2,$CARDS["trump"] ) ) return 1;
if(in_array($c1,$CARDS["clubs"] ) && in_array($c2,$CARDS["clubs"] ) ) return 1;
if(in_array($c1,$CARDS["hearts"] ) && in_array($c2,$CARDS["hearts"] ) ) return 1;
if(in_array($c1,$CARDS["spades"] ) && in_array($c2,$CARDS["spades"] ) ) return 1;
if(in_array($c1,$CARDS["diamonds"]) && in_array($c2,$CARDS["diamonds"]) ) return 1;
-
+
return 0;
}
global $RULES;
global $GAME;
- /* first map all cards to the odd number,
- * this insure that the first card wins the trick
+ /* first map all cards to the odd number,
+ * this insure that the first card wins the trick
* if they are the same card
*/
if( $a/2 - (int)($a/2) != 0.5)
if($a==1 && $b==1) /* both 10 of hearts */
return 0; /* second one wins.*/
}
-
+
/* normal case */
if(is_trump($a) && is_trump($b) && $a<=$b)
return 1;
else if(is_trump($a) && is_trump($b) )
return 0;
- else
+ else
{ /*$a is not a trump */
if(is_trump($b))
return 0;
return 1;
else
return 0;
-
+
/* not the same suit and no trump: a wins */
return 1;
- }
+ }
}
-}
+}
function get_winner($p,$mode)
{
/* get all 4 cards played in a trick, in the order they are played */
$tmp = $p[1];
$c1 = $tmp["card"];
- $c1pos = $tmp["pos"];
+ $c1pos = $tmp["pos"];
$tmp = $p[2];
$c2 = $tmp["card"];
- $c2pos = $tmp["pos"];
+ $c2pos = $tmp["pos"];
$tmp = $p[3];
$c3 = $tmp["card"];
- $c3pos = $tmp["pos"];
+ $c3pos = $tmp["pos"];
$tmp = $p[4];
$c4 = $tmp["card"];
- $c4pos = $tmp["pos"];
+ $c4pos = $tmp["pos"];
/* first card is better than all the rest */
if( compare_cards($c1,$c2,$mode) && compare_cards($c1,$c3,$mode) && compare_cards($c1,$c4,$mode) )
- return $c1pos;
+ return $c1pos;
/* second card is better than first and better than the rest */
if( !compare_cards($c1,$c2,$mode) && compare_cards($c2,$c3,$mode) && compare_cards($c2,$c4,$mode) )
else if($c == "41" || $c == "42") $nines++;
else if($c == "47" || $c == "48") $nines++;
}
-
+
return $nines;
}
/* count each trump */
foreach($cards as $c)
- if( (int)($c) <27)
+ if( (int)($c) <27)
$trump++;
switch($RULES["schweinchen"])
global $debug;
$r = array();
-
+
if($debug)
{
$r[ 0]=1; $r[12]=47; $r[24]=13; $r[36]=37;
}
else
{
- /* check if we can find a game were non of the player was involved and return
- * cards insted
+ /* check if we can find a game were non of the player was involved and return
+ * cards insted
*/
$userstr = "'".implode("','",array($useridA,$useridB,$useridC,$useridD))."'";
$randomnumbers = DB_get_unused_randomnumbers($userstr);
$randomnumbers = explode(":",$randomnumbers);
-
+
if(sizeof($randomnumbers)==48)
return $randomnumbers;
-
+
/* need to create new numbers */
for($i=0;$i<48;$i++)
$r[$i]=$i+1;
-
+
/* shuffle using a better random generator than the standard one */
for ($i = 0; $i <48; $i++)
{
return;
}
-function return_timezone($offset)
-{
- switch($offset)
- {
- case '1':
- $zone = "Europe/Berlin";
- break;
- case '-8':
- $zone = "America/Vancouver";
- break;
- case '13':
- $zone = "Pacific/Auckland";
- break;
- default:
- $zone = "Europe/London";
- }
-
- return $zone;
-}
-
function have_suit($cards,$c)
{
global $CARDS;
else if(in_array($c,$CARDS["diamonds"]))
$suite = $CARDS["diamonds"];
- /* card is the same suid return 1 */
+ /* card is the same suid return 1 */
if(in_array($card,$suite))
return 1;
-
+
return 0;
}
case "dpoverty":
case "trump":
case "silent":
- $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','19','20','21','22','23','24','25','26');
$CARDS["diamonds"] = array();
$CARDS["clubs"] = array('27','28','29','30','31','32','33','34');
$CARDS["foxes"] = array('19','20');
if($RULES["dullen"]=='none')
{
- $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','19','20','21','22','23','24','25','26');
$CARDS["hearts"] = array('43','44','1','2','45','46','47','48');
}
$CARDS["foxes"] = array();
break;
case "club":
- $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','27','28','29','30','31','32','33','34');
$CARDS["clubs"] = array();
$CARDS["spades"] = array('35','36','37','38','39','40','41','42');
$CARDS["foxes"] = array();
if($RULES["dullen"]=='none')
{
- $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','27','28','29','30','31','32','33','34');
$CARDS["hearts"] = array('43','44','1','2','45','46','47','48');
}
break;
case "spade":
- $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','35','36','37','38','39','40','41','42');
$CARDS["clubs"] = array('27','28','29','30','31','32','33','34');
$CARDS["spades"] = array();
$CARDS["foxes"] = array();
if($RULES["dullen"]=='none')
{
- $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','35','36','37','38','39','40','41','42');
$CARDS["hearts"] = array('43','44','1','2','45','46','47','48');
}
break;
case "heart":
- $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','43','44','45','46','47','48');
$CARDS["clubs"] = array('27','28','29','30','31','32','33','34');
$CARDS["spades"] = array('35','36','37','38','39','40','41','42');
$CARDS["foxes"] = array();
if($RULES["dullen"]=='none')
{
- $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
+ $CARDS["trump"] = array('3','4','5','6','7','8','9','10','11','12','13','14','15','16',
'17','18','43','44','1','2','45','46','47','48');
}
break;
$oldcall = DB_get_call_by_hash($hash);
$pcall = DB_get_partner_call_by_hash($hash);
- if( ($pcall!=NULL && $what >= $pcall) ||
+ if( ($pcall!=NULL && $what >= $pcall) ||
($oldcall!=NULL && $what >=$oldcall) )
{
return 0;
}
$NRcards = count(DB_get_hand($hash));
-
+
$NRallcards = 0;
for ($i=1;$i<5;$i++)
{
$user = DB_get_hash_from_game_and_pos($gameid,$i);
$NRallcards += count(DB_get_hand($user));
};
-
+
/* in case of a wedding, everything will be delayed by an offset */
$offset = 0;
if($gametype=="wedding")
{
- $offset = DB_get_sickness_by_gameid($gameid);
+ $offset = DB_get_sickness_by_gameid($gameid);
if ($offset <0) /* not resolved */
return 0;
};
return 1;
break;
case "9-cards":
-
+
if($oldcall!=NULL && $pcall!=NULL)
$mincall = ($oldcall>$pcall) ? $pcall : $oldcall;
else if($oldcall!=NULL)
function display_table ()
{
- global $gameid, $GT, $debug,$host;
+ global $gameid, $GT, $debug,$INDEX,$defaulttimezone;
$result = mysql_query("SELECT User.fullname as name,".
" Hand.position as position, ".
" Hand.sickness as sickness, ".
" Hand.point_call, ".
" User.last_login, ".
- " Hand.hash ".
+ " Hand.hash, ".
+ " User.timezone ".
"FROM Hand ".
"LEFT JOIN User ON User.id=Hand.user_id ".
"WHERE Hand.game_id='".$gameid."' ".
"ORDER BY position ASC");
-
+
echo "<div class=\"table\">\n".
- " <img src=\"pics/table.png\" alt=\"table\" />\n";
+ " <img class=\"table\" src=\"pics/table.png\" alt=\"table\" />\n";
while($r = mysql_fetch_array($result,MYSQL_NUM))
{
$name = $r[0];
$party = $r[3];
$sickness = $r[4];
$call = $r[5];
- $lastlogin = strtotime($r[6]);
$hash = $r[7];
-
- $offset = DB_get_user_timezone($user);
- $zone = return_timezone($offset);
- date_default_timezone_set($zone);
-
+ $timezone = $r[8];
+ date_default_timezone_set($defaulttimezone);
+ $lastlogin = strtotime($r[6]);
+ date_default_timezone_set($timezone);
+ $timenow = strtotime(date("Y-m-d H:i:s"));
+
echo " <div class=\"table".($pos-1)."\">\n";
if(!$debug)
echo " $name \n";
else
- echo " <a href=\"".$host."?me=".$hash."\">$name</a>\n";
+ echo " <a href=\"".$INDEX."?me=".$hash."\">$name</a>\n";
/* add hints for poverty, wedding, solo, etc */
if($GT=="poverty" && $party=="re")
}
else
echo " <img src=\"pics/button/poverty_partner_button.png\" class=\"button\" alt=\"poverty >\" />";
-
+
if($GT=="dpoverty")
if($party=="re")
if($sickness=="poverty")
}
else
echo " <img src=\"pics/button/poverty2_partner_button.png\" class=\"button\" alt=\"poverty2 >\" />";
-
+
if($GT=="wedding" && $party=="re")
if($sickness=="wedding")
echo " <img src=\"pics/button/wedding_button.png\" class=\"button\" alt=\"wedding\" />";
else
echo " <img src=\"pics/button/wedding_partner_button.png\" class=\"button\" alt=\"wedding partner\" />";
-
+
if(ereg("solo",$GT) && $party=="re")
{
if(ereg("queen",$GT))
else if(ereg("trump",$GT))
echo " <img src=\"pics/button/trumpsolo_button.png\" class=\"button\" alt=\"$GT\" />";
}
-
+
/* add point calls */
if($call!=NULL)
{
break;
}
}
-
+
echo " <br />\n";
- echo " <span title=\"".date("Y-m-d H:i:s")."\">local time</span>\n";
+ echo " <span title=\"".date("Y-m-d H:i:s",$timenow). "\">local time</span>\n";
echo " <span title=\"".date("Y-m-d H:i:s",$lastlogin)."\">last login</span>\n";
echo " </div>\n";
-
+
}
echo "</div>\n"; /* end output table */
-
-
+
+
return;
}
function display_user_menu()
{
- global $wiki,$myid,$host;
+ global $wiki,$myid,$INDEX,$STATS;
echo "<div class=\"usermenu\">\n".
- "<a href=\"index.php\"> go to my user page </a>";
+ "<a href=\"".$INDEX."\"> Go to my user page </a>";
$result = mysql_query("SELECT Hand.hash,Hand.game_id,Game.player from Hand".
" LEFT JOIN Game On Hand.game_id=Game.id".
" WHERE Hand.user_id='$myid'".
" AND Game.player='$myid'".
- " AND Game.status<>'gameover'" );
+ " AND Game.status<>'gameover'".
+ " ORDER BY Game.session" );
if(mysql_num_rows($result))
echo "<hr />It's your turn in these games:<br />\n";
while( $r = mysql_fetch_array($result,MYSQL_NUM))
{
- echo "<a href=\"".$host."?me=".$r[0]."\">game ".DB_format_gameid($r[1])." </a><br />\n";
+ echo "<a href=\"".$INDEX."?me=".$r[0]."\">game ".DB_format_gameid($r[1])." </a><br />\n";
}
-
- echo "<hr /> <a href=\"".$host."?new\">start a new game</a>\n";
-
+
+ echo "<hr /> <a href=\"".$INDEX."?new\">Start a new game</a>\n";
+
+ echo "<hr /> <a href=\"".$STATS."\">Statistics</a>\n";
echo
- "<hr />Report bugs in the <a href=\"". $wiki."\">wiki</a>\n";
+ "<hr />Report bugs in the <a href=\"".$wiki."\">wiki</a>\n";
echo "</div>\n";
return;
}
+function generate_score_table($session)
+{
+
+ /* get all ids */
+ $gameids = DB_get_gameids_of_finished_games_by_session($session);
+
+ if($gameids == NULL)
+ return "";
+
+ $output = "<div class=\"scoretable\">\n<table class=\"score\">\n <tr>\n";
+
+
+ /* get player id, names... from the first game */
+ $player = array();
+ $result = mysql_query("SELECT User.id, User.fullname from Hand".
+ " LEFT JOIN User On Hand.user_id=User.id".
+ " WHERE Hand.game_id=".$gameids[0]);
+ while( $r = mysql_fetch_array($result,MYSQL_NUM))
+ {
+ $player[] = array( 'id' => $r[0], 'points' => 0 );
+ $output.= " <td> ".substr($r[1],0,2)." </td>\n";
+ }
+ $output.=" <td>P</td>\n </tr>\n";
+
+ /* get points and generate table */
+ foreach($gameids as $gameid)
+ {
+ $output.=" <tr>\n";
+
+ $re_score = DB_get_score_by_gameid($gameid);
+ foreach($player as $key=>$pl)
+ {
+ $party = DB_get_party_by_gameid_and_userid($gameid,$pl['id']);
+ if($party == "re")
+ if(DB_get_gametype_by_gameid($gameid)=="solo")
+ $player[$key]['points'] += 3*$re_score;
+ else
+ $player[$key]['points'] += $re_score;
+ else if ($party == "contra")
+ $player[$key]['points'] -= $re_score;
+
+ $output.=" <td>".$player[$key]['points']."</td>\n";
+ }
+ $output.=" <td>".abs($re_score);
+
+ /* check for solo */
+ if(DB_get_gametype_by_gameid($gameid)=="solo")
+ $output.= " S";
+ $output.="</td>\n </tr>\n";
+ }
+
+ $output.="</table></div>\n";
+
+ return $output;
+}
+
?>