X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=e-DoKo.git;a=blobdiff_plain;f=index.php;h=f5c3d3da4e66b491cd3b79c6ba03f045522a3150;hp=1a825de1223eecbaee350a8c832f2e5cec1c8168;hb=bcf82bbe699d28a45c44c9c18d96466713e81bef;hpb=88321df4d58a8d42f484ec202b0b4ec30f2d4e97 diff --git a/index.php b/index.php index 1a825de..f5c3d3d 100644 --- a/index.php +++ b/index.php @@ -62,6 +62,7 @@ if(myisset("new")) { echo "couldn't find one of the names, please start a new game"; output_footer(); + DB_close(); exit(); } @@ -71,7 +72,7 @@ if(myisset("new")) $useridD = DB_get_userid_by_name($PlayerD); /* create random numbers */ - $randomNR = create_array_of_random_numbers(); + $randomNR = create_array_of_random_numbers($useridA,$useridB,$useridC,$useridD); $randomNRstring = join(":",$randomNR); /* get ruleset information or create new one */ @@ -80,6 +81,7 @@ if(myisset("new")) { echo "Error defining ruleset: $ruleset"; output_footer(); + DB_close(); exit(); }; @@ -92,20 +94,20 @@ if(myisset("new")) $ruleset = DB_get_ruleset_by_gameid($followup); /* just copy ruleset from old game, this way no manipulation is possible */ if($session) - mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,NULL,'1','pre',". + mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,NULL,'1','1','pre',". "'$ruleset','$session' ,NULL)"); else { /* get max session */ $max = DB_get_max_session(); $max++; - mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,NULL,'1','pre',". - "'$ruleset','$max' ,NULL)"); mysql_query("UPDATE Game SET session='".$max."' WHERE id=".DB_quote_smart($followup)); + mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,NULL,'1','1','pre',". + "'$ruleset','$max' ,NULL)"); } } else - mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,NULL,'1','pre', ". + mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,NULL,'1','1','pre', ". "'$ruleset',NULL ,NULL)"); $game_id = mysql_insert_id(); @@ -172,6 +174,7 @@ else if(myisset("cancle","me")) echo "Can't find you in the database, please check the url.
\n"; echo "perhaps the game has been cancled, check by login in here."; output_footer(); + DB_close(); exit(); } @@ -217,6 +220,7 @@ else if(myisset("me")) echo "Can't find you in the database, please check the url.
\n"; echo "perhaps the game has been cancled, check by login in here."; output_footer(); + DB_close(); exit(); } @@ -229,6 +233,7 @@ else if(myisset("me")) $mystatus = DB_get_status_by_hash($me); $mypos = DB_get_pos_by_hash($me); $myhand = DB_get_handid_by_hash($me); + $session = DB_get_session_by_gameid($gameid); /* get prefs and save them */ DB_get_PREF($myid); @@ -243,7 +248,7 @@ else if(myisset("me")) $RULES["dullen"] = $r[2]; $RULES["schweinchen"] = $r[3]; - $RULES["call"] = "1st-own-card"; + $RULES["call"] = $r[4]; /* get some infos about the game */ @@ -265,7 +270,27 @@ else if(myisset("me")) echo "Rules:
\n"; echo "10ofhearts : ".$r[2]."
\n"; echo "schweinchen: ".$r[3]."
\n"; + echo "call: ".$r[4]."
\n"; echo "\n"; + + /* output extra division in case this game is part of a session */ + if($session) + { + echo "
\n". + "This game is part of session $session: \n"; + $hashes = DB_get_hashes_by_session($session,$myid); + $i = 1; + foreach($hashes as $hash) + { + if($hash == $me) + echo "$i "; + else + echo "$i "; + $i++; + } + echo "
\n"; + } + /* does anyone have both foxes */ $GAME["schweinchen"]=0; @@ -401,35 +426,35 @@ else if(myisset("me")) " is playing solo, this game will be canceled.
\n"; DB_set_sickness_by_hash($me,"nines"); } - } - - echo " Ok, done with checking, please go to the next step of the setup.
"; - - /* move on to the next stage*/ - DB_set_hand_status_by_hash($me,'poverty'); - - /* check if everyone has reached this stage, send out email */ - $userids = DB_get_all_userid_by_gameid($gameid); - $ok=1; - foreach($userids as $user) - { - $userstat = DB_get_hand_status_by_userid_and_gameid($user,$gameid); - if($userstat!='poverty' && $userstat!='play') - $ok=0; - }; - if($ok) - foreach($userids as $user) - { - $To = DB_get_email_by_userid($user); - $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user); - if($userhash!=$me) + + echo " Ok, done with checking, please go to the next step of the setup.
"; + + /* move on to the next stage*/ + DB_set_hand_status_by_hash($me,'poverty'); + + /* check if everyone has reached this stage, send out email */ + $userids = DB_get_all_userid_by_gameid($gameid); + $ok=1; + foreach($userids as $user) + { + $userstat = DB_get_hand_status_by_userid_and_gameid($user,$gameid); + if($userstat!='poverty' && $userstat!='play') + $ok=0; + }; + if($ok) + foreach($userids as $user) { - $message = "Everyone finish the questionary in game $gameid, ". - "please visit this link now to continue: \n". - " ".$host."?me=".$userhash."\n\n" ; - mymail($To,$EmailName." finished setup",$message); - } - }; + $To = DB_get_email_by_userid($user); + $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user); + if($userhash!=$me) + { + $message = "Everyone finish the questionary in game $gameid, ". + "please visit this link now to continue: \n". + " ".$host."?me=".$userhash."\n\n" ; + mymail($To,$EmailName." finished setup in game $gameid",$message); + } + }; + }; break; @@ -468,12 +493,10 @@ else if(myisset("me")) $startplayer = DB_get_startplayer_by_gameid($gameid); /* check for different sickness and just output a general info */ - - - $nines = 0; + $nines = 0; $poverty = 0; $wedding = 0; - $solo = 0; + $solo = 0; foreach($userids as $user) { $name = DB_get_name_by_userid($user); @@ -503,7 +526,6 @@ else if(myisset("me")) /* now check which sickness comes first and set the gametype to it */ - /* gamestatus == normal, => cancel game */ if($gametype == "solo") { /* do nothing */ @@ -531,9 +553,10 @@ else if(myisset("me")) echo "The game has been canceled because ".DB_get_name_by_userid($nines). " has five or more nines and nobody is playing solo.\n"; output_footer(); + DB_close(); exit(); } - else if($poverty==1) + else if($poverty==1) /* one person has poverty */ { DB_set_gametype_by_gameid($gameid,"poverty"); $gametype = "poverty"; @@ -547,7 +570,7 @@ else if(myisset("me")) DB_set_sickness_by_gameid($gameid,1); /* who needs to be asked first */ } } - else if($poverty==2) + else if($poverty==2) /* two people have poverty */ { DB_set_gametype_by_gameid($gameid,"dpoverty"); $gametype = "dpoverty"; @@ -693,10 +716,11 @@ else if(myisset("me")) { $To = DB_get_email_by_pos_and_gameid($who,$gameid); $userhash = DB_get_hash_from_game_and_pos($gameid,$who); - + DB_set_player_by_gameid($gameid,$who); + $message = "Someone has poverty, it's your turn to decide, if you want to take the trump. Please visit:". " ".$host."?me=".$userhash."\n\n" ; - mymail($To,$EmailName." poverty",$message); + mymail($To,$EmailName." poverty (game $gameid)",$message); } /* this user is done */ @@ -772,11 +796,12 @@ else if(myisset("me")) { $To = DB_get_email_by_pos_and_gameid($who,$gameid); $userhash = DB_get_hash_from_game_and_pos($gameid,$who); - + DB_set_player_by_gameid($gameid,$who); + $message = "Someone has poverty, it's your turn to decide, ". "if you want to take the trump. Please visit:". " ".$host."?me=".$userhash."\n\n" ; - mymail($To,$EmailName." poverty",$message); + mymail($To,$EmailName." poverty (game $gameid)",$message); } } @@ -900,6 +925,7 @@ else if(myisset("me")) echo "

Game $gameid has been cancled.

"; output_footer(); + DB_close(); exit(); } @@ -918,13 +944,15 @@ else if(myisset("me")) $startplayer = DB_get_startplayer_by_gameid($gameid); $email = DB_get_email_by_pos_and_gameid($startplayer,$gameid); $hash = DB_get_hash_from_game_and_pos($gameid,$startplayer); + $who = DB_get_userid_by_email($email); + DB_set_player_by_gameid($gameid,$who); if($hash!=$me) { /* email startplayer) */ $message = "It's your turn now in game $gameid.\n". "Use this link to play a card: ".$host."?me=".$hash."\n\n" ; - mymail($email,$EmailName."ready, set, go... ",$message); + mymail($email,$EmailName."ready, set, go... (game $gameid) ",$message); } else echo " Please, start the game.
"; @@ -986,7 +1014,8 @@ else if(myisset("me")) " Hand.party as party, ". " Hand.sickness as sickness, ". " Hand.point_call, ". - " User.last_login ". + " User.last_login, ". + " Hand.hash ". "FROM Hand ". "LEFT JOIN User ON User.id=Hand.user_id ". "WHERE Hand.game_id='".$gameid."' ". @@ -1003,13 +1032,19 @@ else if(myisset("me")) $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"; - echo " $name "; + if(!$debug) + echo " $name \n"; + else + { + echo "$name\n"; + } /* add hints for poverty, wedding, solo, etc */ if($GT=="poverty" && $party=="re") if($sickness=="poverty") @@ -1204,25 +1239,24 @@ else if(myisset("me")) { $comment = ""; - /* mark card as played */ - mysql_query("UPDATE Hand_Card SET played='true' WHERE hand_id='$handid' AND card_id=". - DB_quote_smart($card)); - /* update Game timestamp */ DB_update_game_timestamp($gameid); - /* check if a call was made */ - if(myisset("call120") && $_REQUEST["call120"] == "yes") + /* check if a call was made, must do this before we set the card status to played */ + if(myisset("call120") && $_REQUEST["call120"] == "yes" && can_call(120,$me)) $result = mysql_query("UPDATE Hand SET point_call='120' WHERE hash='$me' "); - if(myisset("call90") && $_REQUEST["call90"] == "yes") + if(myisset("call90") && $_REQUEST["call90"] == "yes" && can_call(90,$me)) $result = mysql_query("UPDATE Hand SET point_call='90' WHERE hash='$me' "); - if(myisset("call60") && $_REQUEST["call60"] == "yes") + if(myisset("call60") && $_REQUEST["call60"] == "yes" && can_call(60,$me)) $result = mysql_query("UPDATE Hand SET point_call='60' WHERE hash='$me' "); - if(myisset("call30") && $_REQUEST["call30"] == "yes") + if(myisset("call30") && $_REQUEST["call30"] == "yes" && can_call(30,$me)) $result = mysql_query("UPDATE Hand SET point_call='30' WHERE hash='$me' "); - if(myisset("call0") && $_REQUEST["call0"] == "yes") + if(myisset("call0") && $_REQUEST["call0"] == "yes" && can_call(0,$me)) $result = mysql_query("UPDATE Hand SET point_call='0' WHERE hash='$me' "); + /* mark card as played */ + mysql_query("UPDATE Hand_Card SET played='true' WHERE hand_id='$handid' AND card_id=". + DB_quote_smart($card)); /* check for schweinchen */ //echo "schweinchen = ".$GAME["schweinchen"]." --$card-
"; @@ -1331,45 +1365,42 @@ else if(myisset("me")) /* email all players */ /* individual score */ - $result = mysql_query("SELECT fullname, SUM(score), Hand.party FROM Score". - " LEFT JOIN Hand ON Hand.id=hand_id". + $result = mysql_query("SELECT fullname, IFNULL(SUM(score),0), Hand.party FROM Hand". + " LEFT JOIN Score ON Hand.id=Score.hand_id". " LEFT JOIN User ON Hand.user_id=User.id". " WHERE Hand.game_id=$gameid". " GROUP BY fullname" ); $message = "The game is over. Thanks for playing :)\n"; + $message .= "Final score:\n"; while( $r = mysql_fetch_array($result,MYSQL_NUM)) - $message .= " FINAL SCORE: ".$r[0]."(".$r[2].") ".$r[1]."\n"; - $message .= "\nIf your not in the list above your score is zero...\n\n"; + $message .= " ".$r[0]."(".$r[2].") ".$r[1]."\n"; - $result = mysql_query("SELECT Hand.party, SUM(score) FROM Score". - " LEFT JOIN Hand ON Hand.id=hand_id". + $result = mysql_query("SELECT Hand.party, IFNULL(SUM(score),0) FROM Hand". + " LEFT JOIN Score ON Hand.id=Score.hand_id". " LEFT JOIN User ON Hand.user_id=User.id". " WHERE Hand.game_id=$gameid". " GROUP BY Hand.party" ); - $message .= "\n"; + $message .= "\nTotals:\n"; while( $r = mysql_fetch_array($result,MYSQL_NUM)) - $message .= " FINAL SCORE: ".$r[0]." ".$r[1]."\n"; + $message .= " ".$r[0]." ".$r[1]."\n"; - /* check who wants to be CC'ed on the email */ - $h = array(); - $header = ""; + /* send out final email */ + $all = array(); + foreach($userids as $user) - { - $result = mysql_query("SELECT value from User_Prefs". - " WHERE user_id='$user' AND pref_key='ccemail'" ); - $r = mysql_fetch_array($result,MYSQL_NUM); - if($r && $r[0]=="yes") - $h[] = DB_get_email_by_userid($user); - } - if(sizeof($h)) - $header = "CC: ".join(",",$h)."\r\n"; - + $all[] = DB_get_email_by_userid($user); + $TO = implode(",",$all); + + $help = "\n\n (you can use reply all on this email to reach all the players.)\n"; + mymail($To,$EmailName."game over (game $gameid) part 1(2)",$message.$help); + foreach($userids as $user) { $To = DB_get_email_by_userid($user); $hash = DB_get_hash_from_gameid_and_userid($gameid,$user); - $mymessage = $message."Use this link to have a look at the game: ".$host."?me=".$hash."\n\n" ; - mymail($To,$EmailName."game over (game $gameid)",$mymessage,$header); + + $link = "Use this link to have a look at game $gameid: ".$host."?me=".$hash."\n\n" ; + mymail($To,$EmailName."game over (game $gameid) part 2(2)",$link); } } @@ -1409,11 +1440,13 @@ else if(myisset("me")) /* email next player */ $next_hash = DB_get_hash_from_game_and_pos($gameid,$next); $email = DB_get_email_by_hash($next_hash); - + $who = DB_get_userid_by_email($email); + DB_set_player_by_gameid($gameid,$who); + $message = "A card has been played in game $gameid.\n\n". "It's your turn now.\n". "Use this link to play a card: ".$host."?me=".$next_hash."\n\n" ; - mymail($email,$EmailName."a card has been played",$message); + mymail($email,$EmailName."a card has been played in game $gameid",$message); } } else @@ -1485,10 +1518,28 @@ else if(myisset("me")) echo "Your cards were:
\n"; foreach($oldcards as $card) display_card($card,$PREF["cardset"]); + + $userids = DB_get_all_userid_by_gameid($gameid); + foreach($userids as $user) + { + $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); + + if($userhash!=$me) + { + echo "
"; + + $name = DB_get_name_by_userid($user); + $oldcards = DB_get_all_hand($userhash); + $oldcards = mysort($oldcards,$gametype); + echo "$name's cards were:
\n"; + foreach($oldcards as $card) + display_card($card,$PREF["cardset"]); + } + } } echo "\n"; - /* check if we need to set status to 'gameover' is done during playing of the card */ + /* if the game is over do some extra stuff, therefore exit the swtich statement if we are still playing*/ if($mystatus=='play') break; /* the following happens only when the gamestatus is 'gameover' */ @@ -1501,22 +1552,27 @@ else if(myisset("me")) { echo "the game is over now...
\n"; - $result = mysql_query("SELECT fullname, SUM(score), Hand.party FROM Score". - " LEFT JOIN Hand ON Hand.id=hand_id". + $result = mysql_query("SELECT fullname, IFNULL(SUM(score),0), Hand.party FROM Hand". + " LEFT JOIN Score ON Hand.id=Score.hand_id". " LEFT JOIN User ON Hand.user_id=User.id". " WHERE Hand.game_id=$gameid". " GROUP BY fullname" ); + echo "Final Score:
\n". + " \n";; while( $r = mysql_fetch_array($result,MYSQL_NUM)) - echo " FINAL SCORE: ".$r[0]."(".$r[2].") ".$r[1]."
"; - - $result = mysql_query("SELECT Hand.party, SUM(score) FROM Score". - " LEFT JOIN Hand ON Hand.id=hand_id". + echo " "; + echo "
".$r[0]."(".$r[2].") ".$r[1]."
\n"; + + $result = mysql_query("SELECT Hand.party, IFNULL(SUM(score),0) FROM Hand". + " LEFT JOIN Score ON Hand.id=Score.hand_id". " LEFT JOIN User ON Hand.user_id=User.id". " WHERE Hand.game_id=$gameid". " GROUP BY Hand.party" ); + echo "Totals:
\n". + " \n"; while( $r = mysql_fetch_array($result,MYSQL_NUM)) - echo " FINAL SCORE: ".$r[0]." ".$r[1]."
\n"; - + echo " \n"; + echo "
".$r[0]." ".$r[1]."
\n"; $session = DB_get_session_by_gameid($gameid); $result = mysql_query("SELECT id,create_date FROM Game". @@ -1539,6 +1595,7 @@ else if(myisset("me")) echo "error in testing the status"; } output_footer(); + DB_close(); exit(); } /* user status page */ @@ -1602,21 +1659,6 @@ else if(myisset("me")) $result = mysql_query("INSERT INTO User_Prefs VALUES(NULL,'$uid','cardset',".DB_quote_smart($setpref).")"); echo "Ok, changed you preferences for the cards.\n"; break; - case "ccemail": - $result = mysql_query("SELECT * from User_Prefs". - " WHERE user_id='$uid' AND pref_key='ccemail'" ); - if( mysql_fetch_array($result,MYSQL_NUM)) - if($PREF["ccemail"]=="yes") - $result = mysql_query("UPDATE User_Prefs SET value=".DB_quote_smart("no"). - " WHERE user_id='$uid' AND pref_key='ccemail'" ); - else - $result = mysql_query("UPDATE User_Prefs SET value=".DB_quote_smart("yes"). - " WHERE user_id='$uid' AND pref_key='ccemail'" ); - else - $result = mysql_query("INSERT INTO User_Prefs VALUES(NULL,'$uid','ccemail',".DB_quote_smart("yes").")"); - echo "Ok, changed you preferences for being CC'ed on emails.\n"; - break; - } } else /* output default user page */ @@ -1636,12 +1678,22 @@ else if(myisset("me")) DB_update_user_timestamp($uid); echo "

these are your games that haven't started yet:
\n"; - $result = mysql_query("SELECT Hand.hash,Hand.game_id,Game.mod_date from Hand". + $result = mysql_query("SELECT Hand.hash,Hand.game_id,Game.mod_date,Game.player from Hand". " LEFT JOIN Game On Hand.game_id=Game.id". " WHERE Hand.user_id='$uid' AND Game.status='pre'" ); while( $r = mysql_fetch_array($result,MYSQL_NUM)) { echo "game #".$r[1]." "; + if($r[3]) + { + if($r[3]==$uid) + echo "(it's your turn)\n"; + else + { + $name = DB_get_name_by_userid($r[3]); + echo "(it's $name's turn)\n"; + }; + } if(time()-strtotime($r[2]) > 60*60*24*30) echo " The game has been running for over a month.". " Do you want to cancel it? yes". @@ -1651,12 +1703,22 @@ else if(myisset("me")) echo "

\n"; echo "

these are the games you are playing in:
\n"; - $result = mysql_query("SELECT Hand.hash,Hand.game_id,Game.mod_date from Hand". + $result = mysql_query("SELECT Hand.hash,Hand.game_id,Game.mod_date,Game.player from Hand". " LEFT JOIN Game On Hand.game_id=Game.id". " WHERE Hand.user_id='$uid' AND Game.status='play'" ); while( $r = mysql_fetch_array($result,MYSQL_NUM)) { echo "game #".$r[1]." "; + if($r[3]) + { + if($r[3]==$uid) + echo "(it's your turn)\n"; + else + { + $name = DB_get_name_by_userid($r[3]); + echo "(it's $name's turn)\n"; + }; + } if(time()-strtotime($r[2]) > 60*60*24*30) echo " The game has been running for over a month.". " Do you want to cancel it? yes". @@ -1667,15 +1729,15 @@ else if(myisset("me")) echo "

and these are your games that are already done:
Game: \n"; + $output=array(); $result = mysql_query("SELECT hash,game_id from Hand WHERE user_id='$uid' AND status='gameover'" ); while( $r = mysql_fetch_array($result,MYSQL_NUM)) - echo "#".$r[1]." , "; - echo "

\n"; + $output[]= "#".$r[1]." "; + echo implode(", ",$output)."

\n"; $names = DB_get_all_names(); echo "

registered players:
\n"; - foreach ($names as $name) - echo "$name, \n"; + echo implode(", ",$names)."\n"; echo "

\n"; echo "

Want to start a new game? Visit this page.

"; @@ -1687,6 +1749,7 @@ else if(myisset("me")) } }; output_footer(); + DB_close(); exit(); } /* page for registration */ @@ -1731,7 +1794,14 @@ else if(myisset("me")) $game = mysql_fetch_array($r,MYSQL_NUM); $done = mysql_fetch_array($r,MYSQL_NUM); } - output_home_page($pre[0],$game[0],$done[0]); + + $r=mysql_query("SELECT AVG(datediff(mod_date,create_date)) FROM Game where status='gameover' "); + if($r) + $avgage= mysql_fetch_array($r,MYSQL_NUM); + else + $avgage[0]=0; + + output_home_page($pre[0],$game[0],$done[0],$avgage[0]); } output_footer();