X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=e-DoKo.git;a=blobdiff_plain;f=functions.php;h=a9ea34bc9570e9efee9bc50ee96a799a0b040c54;hp=39cc2a5555c8d9ddc23503b01a1f33bd4263bad9;hb=5db5f9e9ee3544b1a2b82ad1dc4e250530dd8e64;hpb=9afea8fd89c0c849f361d488569612b5b3fa3c34 diff --git a/functions.php b/functions.php index 39cc2a5..a9ea34b 100644 --- a/functions.php +++ b/functions.php @@ -1,17 +1,69 @@ Setup not completed"; + echo "You need to set \$ADMIN_NAME in config.php."; + output_footer(); + exit(); + } + if(!isset($ADMIN_EMAIL)) + { + output_header(); + echo "

Setup not completed

"; + 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(); + } + if(!isset($DB_work)) + { + output_header(); + echo "

Setup not completed

"; + 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(); + } + if($DB_work) + { + output_header(); + echo "Working on the database...please check back later."; + output_footer(); + exit(); + } + + return; +} + function mymail($To,$Subject,$message,$header="") -{ - global $debug; +{ + global $debug,$EMAIL_REPLY; + + if(isset($EMAIL_REPLY)) + $header .= "From: e-DoKo daemon <$EMAIL_REPLY>\r\n"; if($debug) { $message = str_replace("\n","
\n",$message); $message = ereg_replace("[[:alpha:]]+://[^<>[:space:]]+[[:alnum:]/]", "\\0", $message); - + echo "
To: $To
"; - if($header != "") + if($header != "") echo $header."
"; echo "Subject: $Subject
$message
\n"; } @@ -31,16 +83,23 @@ function myisset() $ok = 1; $args = func_get_args(); - + foreach($args as $arg) { $ok = $ok * isset($_REQUEST[$arg]); /*echo "$arg: ok = $ok
"; - */ + */ } return $ok; } +function myerror($message) +{ + echo "".htmlspecialchars($message)."\n"; + mymail($ADMIN_EMAIL,$EmailName." Error in Code",$message); + return; +} + function pos_array($c,$arr) { $ret = 0; @@ -58,26 +117,26 @@ function pos_array($c,$arr) 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; } @@ -89,8 +148,8 @@ function compare_cards($a,$b,$game) 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) @@ -125,13 +184,13 @@ function compare_cards($a,$b,$game) 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; @@ -173,35 +232,35 @@ function compare_cards($a,$b,$game) 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) ) @@ -231,7 +290,7 @@ function count_nines($cards) else if($c == "41" || $c == "42") $nines++; else if($c == "47" || $c == "48") $nines++; } - + return $nines; } @@ -252,7 +311,7 @@ function count_trump($cards) /* count each trump */ foreach($cards as $c) - if( (int)($c) <27) + if( (int)($c) <27) $trump++; switch($RULES["schweinchen"]) @@ -276,158 +335,12 @@ function count_trump($cards) return $trump; } -function card_to_name($card) -{ - switch($card) - { - case 1: - case 2: - return "ten of hearts"; - case 3: - case 4: - return "queen of clubs"; - case 5: - case 6: - return "queen of spades"; - case 7: - case 8: - return "queen of hearts"; - case 9: - case 10: - return "queen of diamonds"; - case 11: - case 12: - return "jack of clubs"; - case 13: - case 14: - return "jack of spades"; - case 15: - case 16: - return "jack of hearts"; - case 17: - case 18: - return "jack of diamonds"; - case 19: - case 20: - return "ace of diamonds"; - case 21: - case 22: - return "ten of diamonds"; - case 23: - case 24: - return "king of diamonds"; - case 25: - case 26: - return "nine of diamonds";; - case 27: - case 28: - return "ace of clubs"; - case 29: - case 30: - return "ten of clubs"; - case 31: - case 32: - return "king of clubs"; - case 33: - case 34: - return "nine of clubs"; - case 35: - case 36: - return "ace of spades"; - case 37: - case 38: - return "ten of spades"; - case 39: - case 40: - return "king of spades"; - case 41: - case 42: - return "nine of spades"; - case 43: - case 44: - return "ace of hearts"; - case 45: - case 46: - return "king of hearts"; - case 47: - case 48: - return "nine of hearts"; - default: - return "something went wrong, please contact the admin. Error: code1. $card
"; - } -} - -function card_value($card) -{ - switch($card) - { - case 3: /* clubes */ - case 4: - case 5: /* spades */ - case 6: - case 7: /* hearts */ - case 8: - case 9: /* diamonds */ - case 10: - return 3; - case 11: /* clubes */ - case 12: - case 13: /* spades */ - case 14: - case 15: /* hearts */ - case 16: - case 17: /* diamonds */ - case 18: - return 2; - case 19: /* diamonds */ - case 20: - case 27: /* clubs */ - case 28: - case 35: /* spades */ - case 36: - case 43: /* hearts */ - case 44: - return 11; - case 1: /* heart */ - case 2: - case 21: /* diamonds */ - case 22: - case 29: /* clubs */ - case 30: - case 37: /* spades */ - case 38: - return 10; - case 23: /* diamonds */ - case 24: - case 31: /* clubs */ - case 32: - case 39: /* spades */ - case 40: - case 45: /* hearts */ - case 46: - return 4; - case 25: /* diamonds */ - case 26: - case 33: /* clubs */ - case 34: - case 41: /* spades */ - case 42: - case 47: /* hearts */ - case 48: - return 0; - default: - echo "something went wrong, please contact the admin. ErrorCode: 2 - $card
"; - return 0; - } -} - - -function create_array_of_random_numbers() +function create_array_of_random_numbers($useridA,$useridB,$useridC,$useridD) { global $debug; $r = array(); - + if($debug) { $r[ 0]=1; $r[12]=47; $r[24]=13; $r[36]=37; @@ -445,18 +358,33 @@ function create_array_of_random_numbers() } else { + /* 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($r); + + /* shuffle using a better random generator than the standard one */ + for ($i = 0; $i <48; $i++) + { + $j = @mt_rand(0, $i); + $tmp = $r[$i]; + $r[$i] = $r[$j]; + $r[$j] = $tmp; + } }; return $r; } - - - function display_cards($me,$myturn) { return; @@ -478,7 +406,7 @@ function return_timezone($offset) default: $zone = "Europe/London"; } - + return $zone; } @@ -524,10 +452,10 @@ function same_type($card,$c) 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; } @@ -544,7 +472,7 @@ function set_gametype($gametype) 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'); @@ -553,7 +481,7 @@ function set_gametype($gametype) $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'); } @@ -583,7 +511,7 @@ function set_gametype($gametype) $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'); @@ -592,13 +520,13 @@ function set_gametype($gametype) $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(); @@ -607,13 +535,13 @@ function set_gametype($gametype) $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'); @@ -622,7 +550,7 @@ function set_gametype($gametype) $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; @@ -650,25 +578,31 @@ function can_call($what,$hash) { global $RULES; - /*TODO: check if this already has been call by teammate */ - $gameid = DB_get_gameid_by_hash($hash); $gametype = DB_get_gametype_by_gameid($gameid); + $oldcall = DB_get_call_by_hash($hash); + $pcall = DB_get_partner_call_by_hash($hash); + + 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; }; @@ -684,12 +618,273 @@ function can_call($what,$hash) return 1; break; case "9-cards": - if( ($what/10) <= $NRcards + $offset) - return 1; + + if($oldcall!=NULL && $pcall!=NULL) + $mincall = ($oldcall>$pcall) ? $pcall : $oldcall; + else if($oldcall!=NULL) + $mincall = $oldcall; + else if ($pcall!=NULL) + $mincall = $pcall; + else + $mincall = -1; + + if( 12 <= ($NRcards + $offset)) + { + return 1; + } + else if ( 9 <= ($NRcards + $offset)) + { + if( ($mincall>=0 && $mincall==120) ) + return 1; + } + else if ( 6 <= ($NRcards + $offset)) + { + if( ($mincall>=0 && $mincall<=90 && $what<=60 ) ) + return 1; + } + else if ( 3 <= ($NRcards + $offset)) + { + if( ($mincall>=0 && $mincall<=60 && $what<=30 ) ) + return 1; + } + else if ( 0 <= ($NRcards + $offset)) + { + if( ($mincall>=0 && $mincall<=30 && $what==0 ) ) + return 1; + }; break; } return 0; } +function display_table () +{ + global $gameid, $GT, $debug,$host; + + $result = mysql_query("SELECT User.fullname as name,". + " Hand.position as position, ". + " User.id, ". + " Hand.party as party, ". + " Hand.sickness as sickness, ". + " Hand.point_call, ". + " User.last_login, ". + " Hand.hash ". + "FROM Hand ". + "LEFT JOIN User ON User.id=Hand.user_id ". + "WHERE Hand.game_id='".$gameid."' ". + "ORDER BY position ASC"); + + echo "
\n". + " \"table\"\n"; + while($r = mysql_fetch_array($result,MYSQL_NUM)) + { + $name = $r[0]; + $pos = $r[1]; + $user = $r[2]; + $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); + + echo "
\n"; + if(!$debug) + echo " $name \n"; + else + echo " $name\n"; + + /* add hints for poverty, wedding, solo, etc */ + if($GT=="poverty" && $party=="re") + if($sickness=="poverty") + { + $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); + $cards = DB_get_all_hand($userhash); + $trumpNR = count_trump($cards); + if($trumpNR) + echo " \"poverty"; + else + echo " \"poverty"; + } + else + echo " \"poverty\" />"; + + if($GT=="dpoverty") + if($party=="re") + if($sickness=="poverty") + { + $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); + $cards = DB_get_all_hand($userhash); + $trumpNR = count_trump($cards); + if($trumpNR) + echo " \"poverty"; + else + echo " \"poverty"; + } + else + echo " \"poverty\" />"; + else + if($sickness=="poverty") + { + $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); + $cards = DB_get_all_hand($userhash); + $trumpNR = count_trump($cards); + if($trumpNR) + echo " \"poverty2"; + else + echo " \"poverty2"; + } + else + echo " \"poverty2\" />"; + + if($GT=="wedding" && $party=="re") + if($sickness=="wedding") + echo " \"wedding\""; + else + echo " \"wedding"; + + if(ereg("solo",$GT) && $party=="re") + { + if(ereg("queen",$GT)) + echo " \"$GT\""; + else if(ereg("jack",$GT)) + echo " \"$GT\""; + else if(ereg("club",$GT)) + echo " \"$GT\""; + else if(ereg("spade",$GT)) + echo " \"$GT\""; + else if(ereg("heart",$GT)) + echo " \"$GT\""; + else if(ereg("trumpless",$GT)) + echo " \"$GT\""; + else if(ereg("trump",$GT)) + echo " \"$GT\""; + } + + /* add point calls */ + if($call!=NULL) + { + if($party=="re") + echo " \"re\""; + else + echo " \"contra\""; + switch($call) + { + case "0": + echo " \"0\""; + break; + case "30": + echo " \"30\""; + break; + case "60": + echo " \"60\""; + break; + case "90": + echo " \"90\""; + break; + } + } + + echo "
\n"; + echo " local time\n"; + echo " last login\n"; + echo "
\n"; + + } + echo "
\n"; /* end output table */ + + + return; +} + + +function display_user_menu() +{ + global $wiki,$myid,$host; + echo "
\n". + " Go to my user page "; + + $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'" ); + if(mysql_num_rows($result)) + echo "
It's your turn in these games:
\n"; + + while( $r = mysql_fetch_array($result,MYSQL_NUM)) + { + echo "game ".DB_format_gameid($r[1])."
\n"; + } + + echo "
Start a new game\n"; + + echo "
Statistics\n"; + + echo + "
Report bugs in the wiki\n"; + echo "
\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 = "
\n\n \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.= " \n"; + } + $output.=" \n \n"; + + /* get points and generate table */ + foreach($gameids as $gameid) + { + $output.=" \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.=" \n"; + } + $output.=" \n \n"; + } + + $output.="
".substr($r[1],0,2)." P
".$player[$key]['points']."".abs($re_score); + + /* check for solo */ + if(DB_get_gametype_by_gameid($gameid)=="solo") + $output.= " S"; + $output.="
\n"; + + return $output; +} + ?>