X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=e-DoKo.git;a=blobdiff_plain;f=index.php;h=40708f8359c3767cc30382dbae508a4f08ed1e5b;hp=dd1ce58889d298ef2ef1ba658b8be8ec21fa19b9;hb=046b683603f1c49460079595f819591b1918c9a2;hpb=7128076b9409b55551f206d875218fc8f70bb273 diff --git a/index.php b/index.php index dd1ce58..40708f8 100644 --- a/index.php +++ b/index.php @@ -1,49 +1,43 @@ \n"; echo "Rules:
\n"; - echo "10ofhearts : ".$r[2]."
\n"; - echo "schweinchen: ".$r[3]."
\n"; - echo "call: ".$r[4]."
\n"; + echo "10ofhearts : ".$RULES["dullen"] ."
\n"; + echo "schweinchen: ".$RULES["schweinchen"] ."
\n"; + echo "call: ".$RULES["call"] ."
\n"; echo "\n"; /* output extra division in case this game is part of a session */ @@ -318,24 +318,30 @@ else if(myisset("me")) switch($mystatus) { case 'start': - check_want_to_play($me); - /* move on to the next stage*/ - DB_set_hand_status_by_hash($me,'init'); - break; + if( !myisset("in") ) + { + output_check_want_to_play($me); + break; + } + else + { + /* move on to the next stage*/ + DB_set_hand_status_by_hash($me,'init'); + } case 'init': /* first check if everything went ok in the last step * if not, send user back, if yes, check what he did */ if( !myisset("in") ) { - echo "

you need to answer the question.

"; + echo "

You need to answer the question.

"; DB_set_hand_status_by_hash($me,'start'); } else { if($_REQUEST["in"] == "no") { - /* cancle the game */ + /* cancel the game */ $message = "Hello, \n\n". "the game has been canceled due to the request of one of the players.\n"; @@ -351,7 +357,7 @@ else if(myisset("me")) } else { - echo "thanks for joining the game..."; + echo "Thanks for joining the game..."; $mycards = DB_get_hand($me); sort($mycards); @@ -372,17 +378,20 @@ else if(myisset("me")) /* ok, user is in the game, saw his cards and selected his vorbehalt * so first we check what he selected */ - echo "Processing what you selected in the last step...
"; - if(!myisset("solo","wedding","poverty","nines") ) { /* all these variables have a pre-selected default, * so we should never get here, - * unless a user tries to cheat ;) */ - echo "something went wrong...please contact the admin."; + * unless a user tries to cheat ;) + * can also happen if user reloads the page! + */ + echo "

You need to answer the questions.

"; + DB_set_hand_status_by_hash($me,'init'); } else { + echo "Processing what you selected in the last step...
"; + /* check if this sickness needs to be handled first */ $gametype = DB_get_gametype_by_gameid($gameid); $startplayer = DB_get_startplayer_by_gameid($gameid); @@ -434,26 +443,34 @@ else if(myisset("me")) /* check if everyone has reached this stage, send out email */ $userids = DB_get_all_userid_by_gameid($gameid); - $ok=1; + $ok = 1; foreach($userids as $user) { $userstat = DB_get_hand_status_by_userid_and_gameid($user,$gameid); if($userstat!='poverty' && $userstat!='play') - $ok=0; + { + $ok = 0; + DB_set_player_by_gameid($gameid,$user); + } }; 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) - { - $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); - } - }; + { + /* reset player = everyone has to do something now */ + DB_set_player_by_gameid($gameid,NULL); + + foreach($userids as $user) + { + $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; @@ -464,16 +481,16 @@ else if(myisset("me")) * set that one in the Game table * tell people about it. */ - echo "
Checking if someone else selected solo, nines or wedding or poverty.
"; + echo "
Checking if someone else selected solo, nines, wedding or poverty.
"; /* check if everyone has reached this stage */ $userids = DB_get_all_userid_by_gameid($gameid); - $ok=1; + $ok = 1; foreach($userids as $user) { $userstat = DB_get_hand_status_by_userid_and_gameid($user,$gameid); if($userstat!='poverty' && $userstat!='play') - $ok=0; + $ok = 0; }; if(!$ok) @@ -499,7 +516,7 @@ else if(myisset("me")) $solo = 0; foreach($userids as $user) { - $name = DB_get_name_by_userid($user); + $name = DB_get_name_by_userid($user); $usersick = DB_get_sickness_by_userid_and_gameid($user,$gameid); if($usersick == 'nines') { @@ -532,13 +549,13 @@ else if(myisset("me")) } else if($nines) { - /* cancle game */ + /* cancel game */ /* TODO: should we keep statistics of this? */ $message = "Hello, \n\n". - "the game has been canceled because ".DB_get_name_by_userid($nines). - " has five or more nines and nobody is playing solo.\n"; - - /* TODO: add info about redeal in case this is a game of a series */ + " the game has been canceled because ".DB_get_name_by_userid($nines). + " has five or more nines and nobody is playing solo.\n\n". + " To redeal either start a new game or, in case the game was part of a tournament, \n". + " go to the last game and use the link at the bottom of the page to redeal."; $userids = DB_get_all_userid_by_gameid($gameid); foreach($userids as $user) @@ -560,7 +577,7 @@ else if(myisset("me")) { DB_set_gametype_by_gameid($gameid,"poverty"); $gametype = "poverty"; - $who=DB_get_sickness_by_gameid($gameid); + $who = DB_get_sickness_by_gameid($gameid); if(!$who) { $firstsick = DB_get_sickness_by_pos_and_gameid(1,$gameid); @@ -574,7 +591,7 @@ else if(myisset("me")) { DB_set_gametype_by_gameid($gameid,"dpoverty"); $gametype = "dpoverty"; - $who=DB_get_sickness_by_gameid($gameid); + $who = DB_get_sickness_by_gameid($gameid); if(!$who) { $firstsick = DB_get_sickness_by_pos_and_gameid(1,$gameid); @@ -606,7 +623,7 @@ else if(myisset("me")) foreach($userids as $user) { /* userids are sorted by position... - * so output whatever the firstone has, then whatever the next one has + * so output whatever the first one has, then whatever the next one has * stop when the sickness is the same as the gametype */ @@ -763,7 +780,8 @@ else if(myisset("me")) $r = mysql_fetch_array($result,MYSQL_NUM); if(!$r) { - die("error in poverty"); + myerror("error in poverty"); + die(); }; if($r[0]==12) { @@ -803,7 +821,6 @@ else if(myisset("me")) " ".$host."?me=".$userhash."\n\n" ; mymail($To,$EmailName." poverty (game $gameid)",$message); } - } /* this user is done */ @@ -813,13 +830,13 @@ else if(myisset("me")) DB_set_hand_status_by_hash($hash,'play'); /* set party to re, unless we had dpoverty, in that case check if we need to set re/contra*/ - $re_set=0; + $re_set = 0; foreach($userids as $user) { - $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user); - $party=DB_get_party_by_hash($userhash); + $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); + $party = DB_get_party_by_hash($userhash); if($party=="re") - $re_set=1; + $re_set = 1; } if($re_set) { @@ -830,7 +847,7 @@ else if(myisset("me")) { foreach($userids as $user) { - $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user); + $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); if($userhash==$hash||$userhash==$me) DB_set_party_by_hash($userhash,"re"); else @@ -864,22 +881,21 @@ else if(myisset("me")) { foreach($userids as $user) { - $name = DB_get_name_by_userid($user); + $name = DB_get_name_by_userid($user); $usersick = DB_get_sickness_by_userid_and_gameid($user,$gameid); if($usersick=="poverty") { - $hash =DB_get_hash_from_gameid_and_userid($gameid,$user); - $cards=DB_get_hand($hash); - $nrtrump=count_trump($cards); + $hash = DB_get_hash_from_gameid_and_userid($gameid,$user); + $cards = DB_get_hand($hash); + $nrtrump = count_trump($cards); /* count trump */ if($nrtrump<4) echo "Player $name has $nrtrump trump. Do you want to take them?". "yes
"; } } - echo "I don't want to take any trump: ". - "yes
"; + echo "No,way I take those trump...
"; echo "Your cards are:
\n"; $mycards = DB_get_hand($me); @@ -897,69 +913,64 @@ else if(myisset("me")) else echo "it's not your turn yet to decide if you want to take the trump or not."; } - /* - * yes, display number of trump and user's hand, ask if he wants to take it - * no, set whom-to-ask to next player, email next player, cancle game if no next player - * yes -> link to new page:display all cards, ask for N return cards - * set re/contra - * - */ }; - } - /* check if no one wanted to take trump, in that case the gamesickness would be set to 5 or 50 */ - $who = DB_get_sickness_by_gameid($gameid); - if($who==5 || $who==50) - { - $message = "Hello, \n\n". - "Game $gameid has been cancled since nobody wanted to take the trump.\n"; - - $userids = DB_get_all_userid_by_gameid($gameid); - foreach($userids as $user) + /* check if no one wanted to take trump, in that case the gamesickness would be set to 5 or 50 */ + $who = DB_get_sickness_by_gameid($gameid); + if($who==5 || $who==50) { - $To = DB_get_email_by_userid($user); - mymail($To,$EmailName."game $gameid cancled (poverty not resolved)",$message); + $message = "Hello, \n\n". + "Game $gameid has been cancled since nobody wanted to take the trump.\n"; + + $userids = DB_get_all_userid_by_gameid($gameid); + foreach($userids as $user) + { + $To = DB_get_email_by_userid($user); + mymail($To,$EmailName."game $gameid cancled (poverty not resolved)",$message); + } + + /* delete everything from the dB */ + DB_cancel_game($me); + + echo "

Game $gameid has been cancled.

"; + output_footer(); + DB_close(); + exit(); } - /* delete everything from the dB */ - DB_cancel_game($me); - - echo "

Game $gameid has been cancled.

"; - output_footer(); - DB_close(); - exit(); - } - - /* check if all players are ready to play */ - $ok=1; - foreach($userids as $user) - if(DB_get_hand_status_by_userid_and_gameid($user,$gameid)!='play') - $ok=0; - - if($ok) - { - /* only set this after all poverty, etc. are handled*/ - DB_set_game_status_by_gameid($gameid,'play'); - - /* email startplayer */ - $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); + /* check if all players are ready to play */ + $ok = 1; + foreach($userids as $user) + if(DB_get_hand_status_by_userid_and_gameid($user,$gameid)!='play') + { + $ok = 0; + DB_set_player_by_gameid($gameid,$user); + } - if($hash!=$me) + if($ok) { - /* 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... (game $gameid) ",$message); + /* only set this after all poverty, etc. are handled*/ + DB_set_game_status_by_gameid($gameid,'play'); + + /* email startplayer */ + $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... (game $gameid) ",$message); + } + else + echo " Please, start the game.
"; } else - echo " Please, start the game.
"; + echo "\n
"; } - else - echo "\n
"; - break; case 'play': case 'gameover': @@ -974,14 +985,14 @@ else if(myisset("me")) */ $gametype = DB_get_gametype_by_gameid($gameid); - $GT = $gametype; + $GT = $gametype; if($gametype=="solo") { $gametype = DB_get_solo_by_gameid($gameid); - $GT = $gametype." ".$GT; + $GT = $gametype." ".$GT; } else - $gametype="normal"; + $gametype = "normal"; set_gametype($gametype); /* this sets the $CARDS variable */ @@ -1050,56 +1061,91 @@ else if(myisset("me")) if($sickness=="poverty") { $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user); - $cards = DB_get_all_hand($userhash); - $trumpNR = count_trump($cards); + $cards = DB_get_all_hand($userhash); + $trumpNR = count_trump($cards); if($trumpNR) - echo "(poverty < trump back)"; + echo "\"poverty"; else - echo "(poverty <)"; + echo "\"poverty"; } else - echo "(poverty >)"; + 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); + $cards = DB_get_all_hand($userhash); + $trumpNR = count_trump($cards); if($trumpNR) - echo "(poverty A < trump back)"; + echo "\"poverty"; else - echo "(poverty A <)"; + echo "\"poverty"; } else - echo "(poverty A >)"; + 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); + $cards = DB_get_all_hand($userhash); + $trumpNR = count_trump($cards); if($trumpNR) - echo "(poverty B < trump back)"; + echo "\"poverty2"; else - echo "(poverty B <)"; + echo "\"poverty2"; } else - echo "(poverty B >)"; + echo "\"poverty2\" />"; if($GT=="wedding" && $party=="re") if($sickness=="wedding") - echo "(wedding +)"; + echo "\"wedding\""; else - echo "(wedding)"; + echo "\"wedding"; if(ereg("solo",$GT) && $party=="re") - echo "($GT)"; + { + 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) - echo " $party $call "; + { + 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: ".date("Y-m-d H:i:s")."
\n"; @@ -1109,12 +1155,28 @@ else if(myisset("me")) } echo "\n"; + /* get time from the last action of the game */ + $result = mysql_query("SELECT mod_date from Game WHERE id='$gameid' " ); + $r = mysql_fetch_array($result,MYSQL_NUM); + $gameend = time() - strtotime($r[0]); + + /* handel comments in case player didn't play a card, allow comments a week after the end of the game */ + if( (!myisset("card") && $mystatus=='play') || ($mystatus=='gameover' && ($gameend < 60*60*24*7)) ) + if(myisset("comment")) + { + $comment = $_REQUEST["comment"]; + $playid = DB_get_current_playid($gameid); + + if($comment != "") + DB_insert_comment($comment,$playid,$myid); + }; + /* get everything relevant to display the tricks */ $result = mysql_query("SELECT Hand_Card.card_id as card,". " Hand.position as position,". " Play.sequence as sequence, ". " Trick.id, ". - " Comment.comment, ". + " GROUP_CONCAT(CONCAT('',User.fullname,': ',Comment.comment,'') SEPARATOR '\n' ), ". " Play.create_date, ". " Hand.user_id ". "FROM Trick ". @@ -1122,10 +1184,11 @@ else if(myisset("me")) "LEFT JOIN Hand_Card ON Play.hand_card_id=Hand_Card.id ". "LEFT JOIN Hand ON Hand_Card.hand_id=Hand.id ". "LEFT JOIN Comment ON Play.id=Comment.play_id ". + "LEFT JOIN User On User.id=Comment.user_id ". "WHERE Trick.game_id='".$gameid."' ". - "ORDER BY Trick.id,sequence ASC"); - $trickNR = 1; - + "GROUP BY Trick.id, sequence ". + "ORDER BY Trick.id, sequence ASC"); + $trickNR = 1; $lasttrick = DB_get_max_trickid($gameid); $play = array(); /* needed to calculate winner later */ @@ -1206,14 +1269,14 @@ else if(myisset("me")) /* whos turn is it? */ if($seq==4) { - $winner = get_winner($play,$gametype); /* returns the position */ - $next = $winner; + $winner = get_winner($play,$gametype); /* returns the position */ + $next = $winner; $firstcard = ""; /* new trick, no first card */ } else { $next = $pos+1; - if($next==5) $next=1; + if($next==5) $next = 1; } /* my turn?, display cards as links, ask for comments*/ @@ -1221,7 +1284,7 @@ else if(myisset("me")) $myturn = 1; else $myturn = 0; - + /* do we want to play a card? */ if(myisset("card") && $myturn) { @@ -1237,8 +1300,6 @@ else if(myisset("me")) if($handcardid) /* everything ok, play card */ { - $comment = ""; - /* update Game timestamp */ DB_update_game_timestamp($gameid); @@ -1258,26 +1319,26 @@ else if(myisset("me")) mysql_query("UPDATE Hand_Card SET played='true' WHERE hand_id='$handid' AND card_id=". DB_quote_smart($card)); + /* get trick id or start new trick */ + $a = DB_get_current_trickid($gameid); + $trickid = $a[0]; + $sequence = $a[1]; + $tricknr = $a[2]; + + $playid = DB_play_card($trickid,$handcardid,$sequence); + /* check for schweinchen */ - //echo "schweinchen = ".$GAME["schweinchen"]." --$card-
"; if($card == 19 || $card == 20 ) { $GAME["schweinchen"]++; if($GAME["schweinchen"]==3 && $RULES["schweinchen"]=="second" ) - $comment="Schweinchen! "; + DB_insert_comment("Schweinchen! ",$playid,$myid); if($RULES["schweinchen"]=="both" ) - $comment="Schweinchen! "; - if ($debug) echo "schweinchen = ".$GAME["schweinchen"]." ---
"; + DB_insert_comment("Schweinchen! ",$playid,$myid); + if ($debug) + echo "schweinchen = ".$GAME["schweinchen"]." ---
"; } - /* get trick id or start new trick */ - $a = DB_get_current_trickid($gameid); - $trickid = $a[0]; - $sequence = $a[1]; - $tricknr = $a[2]; - - $playid = DB_play_card($trickid,$handcardid,$sequence); - /* if sequence == 4 check who one in case of wedding */ if($sequence == 4 && $GT == "wedding") { @@ -1313,19 +1374,45 @@ else if(myisset("me")) } } } - + + /* if sequence == 4, set winner of the trick, count points and set the next player */ + if($sequence==4) + { + $play = DB_get_cards_by_trick($trickid); + $winner = get_winner($play,$gametype); /* returns the position */ + + if($winner>0) + mysql_query("UPDATE Trick SET winner='$winner' WHERE id='$trickid'"); + else + echo "ERROR during scoring"; + + if($debug) + echo "DEBUG: position $winner won the trick
"; + + /* who is the next player? */ + $next = $winner; + } + else + { + $next = DB_get_pos_by_hash($me)+1; + } + if($next==5) $next=1; + /* check for coment */ if(myisset("comment")) { - $comment.=$_REQUEST["comment"]; + $comment = $_REQUEST["comment"]; + if($comment != "") + DB_insert_comment($comment,$playid,$myid); }; - if($comment != "") - DB_insert_comment($comment,$playid,$myid); - + /* display played card */ echo "
"; echo " you played
"; + /* display comments */ display_card($card,$PREF["cardset"]); + if($comment!="") + echo "
Your comment:
".$comment."\n"; echo "
\n"; /*check if we still have cards left, else set status to gameover */ @@ -1347,109 +1434,67 @@ else if(myisset("me")) $done=0; if($done) + DB_set_game_status_by_gameid($gameid,"gameover"); + + /* email next player, if game is still running */ + if(DB_get_game_status_by_gameid($gameid)=='play') { - DB_set_game_status_by_gameid($gameid,"gameover"); - /* get score for last trick - * all other tricks are handled a few lines further down*/ - $play = DB_get_cards_by_trick($trickid); - $winner = get_winner($play,$gametype); /* returns the position */ - /* get points of last trick and save it */ - $points = 0; - foreach($play as $card) - $points = $points + card_value($card["card"]); - $winnerid = DB_get_handid_by_gameid_and_position($gameid,$winner); - if($winnerid>0) - mysql_query("INSERT INTO Score VALUES (NULL, '$gameid', '$winnerid', '$points')"); - else - echo "ERROR during scoring"; + $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); - /* email all players */ + $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 in game $gameid",$message); + } + else /* send out final email */ + { /* individual score */ - $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"; + $result = mysql_query("SELECT User.fullname, IFNULL(SUM(Card.points),0), Hand.party FROM Hand". + " LEFT JOIN Trick ON Trick.winner=Hand.position AND Trick.game_id=Hand.game_id". + " LEFT JOIN User ON User.id=Hand.user_id". + " LEFT JOIN Play ON Trick.id=Play.trick_id". + " LEFT JOIN Hand_Card ON Hand_Card.id=Play.hand_card_id". + " LEFT JOIN Card ON Card.id=Hand_Card.card_id". + " WHERE Hand.game_id='$gameid'". + " GROUP BY User.fullname" ); + $message = "The game is over. Thanks for playing :)\n"; $message .= "Final score:\n"; while( $r = mysql_fetch_array($result,MYSQL_NUM)) $message .= " ".$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" ); + $result = mysql_query("SELECT Hand.party, IFNULL(SUM(Card.points),0) FROM Hand". + " LEFT JOIN Trick ON Trick.winner=Hand.position AND Trick.game_id=Hand.game_id". + " LEFT JOIN User ON User.id=Hand.user_id". + " LEFT JOIN Play ON Trick.id=Play.trick_id". + " LEFT JOIN Hand_Card ON Hand_Card.id=Play.hand_card_id". + " LEFT JOIN Card ON Card.id=Hand_Card.card_id". + " WHERE Hand.game_id='$gameid'". + " GROUP BY Hand.party" ); $message .= "\nTotals:\n"; while( $r = mysql_fetch_array($result,MYSQL_NUM)) $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); - } - } - - - /* email next player */ - if(DB_get_game_status_by_gameid($gameid)=='play') - { - if($sequence==4) - { - $play = DB_get_cards_by_trick($trickid); - $winner = get_winner($play,$gametype); /* returns the position */ - - /* get points of last trick and save it, last trick is handled - * a few lines further up */ - $points = 0; - foreach($play as $card) - $points = $points + card_value($card["card"]); - $winnerid = DB_get_handid_by_gameid_and_position($gameid,$winner); - if($winnerid>0) - mysql_query("INSERT INTO Score VALUES (NULL, '$gameid', '$winnerid', '$points')"); - else - echo "ERROR during scoring"; - - if($debug) - echo "DEBUG: $winner got $points
"; - - /* who is the next player? */ - $next = $winner; - } - else - { - $next = DB_get_pos_by_hash($me)+1; + $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); } - if($next==5) $next=1; - - /* 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 in game $gameid",$message); } } else @@ -1466,7 +1511,7 @@ else if(myisset("me")) $mycards = mysort($mycards,$gametype); echo "
\n"; - if($myturn && !myisset("card")) + if($myturn && !myisset("card") && $mystatus=='play' ) { echo "Hello ".$myname.", it's your turn!
\n"; echo "Your cards are:
\n"; @@ -1485,48 +1530,73 @@ else if(myisset("me")) display_link_card($card,$PREF["cardset"]); } - if( can_call(120,$me) ) - echo " re/contra (120):". - " "; - if( can_call(90,$me) ) - echo " 90:". - " "; - if( can_call(60,$me) ) - echo " 60:". - " "; - if( can_call(30,$me) ) - echo " 30:". - " "; - if( can_call(0,$me) ) - echo " 0:". - " ". - " no call:". - " "; - - echo "
\nA short comments:\n"; + output_form_calls($me); + + echo "
\nA short comment:\n"; echo "\n"; - echo "\n"; + echo "\n"; echo "\n"; } - else if($mystatus=='play') - { + else if($mystatus=='play' ) + { echo "Your cards are:
\n"; foreach($mycards as $card) display_card($card,$PREF["cardset"]); + + echo "
\n"; + output_form_calls($me); + echo "
\nA short comment:\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } else if($mystatus=='gameover') { + /* get time from the last action of the game */ + $result = mysql_query("SELECT mod_date from Game WHERE id='$gameid' " ); + $r = mysql_fetch_array($result,MYSQL_NUM); + $gameend = time() - strtotime($r[0]); + + if( $gameend < 60*60*24*7 ) + { + echo "
\n"; + echo "
\nA short comment:\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + } + $oldcards = DB_get_all_hand($me); $oldcards = mysort($oldcards,$gametype); 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"; /* 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' */ /* check if game is over, display results */ if(DB_get_game_status_by_gameid($gameid)=='play') @@ -1537,21 +1607,28 @@ else if(myisset("me")) { echo "the game is over now...
\n"; - $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" ); + $result = mysql_query("SELECT User.fullname, IFNULL(SUM(Card.points),0), Hand.party FROM Hand". + " LEFT JOIN Trick ON Trick.winner=Hand.position AND Trick.game_id=Hand.game_id". + " LEFT JOIN User ON User.id=Hand.user_id". + " LEFT JOIN Play ON Trick.id=Play.trick_id". + " LEFT JOIN Hand_Card ON Hand_Card.id=Play.hand_card_id". + " LEFT JOIN Card ON Card.id=Hand_Card.card_id". + " WHERE Hand.game_id='$gameid'". + " GROUP BY User.fullname" ); echo "Final Score:
\n". " \n";; while( $r = mysql_fetch_array($result,MYSQL_NUM)) 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". + + $result = mysql_query("SELECT Hand.party, IFNULL(SUM(Card.points),0) FROM Hand". + " LEFT JOIN Trick ON Trick.winner=Hand.position AND Trick.game_id=Hand.game_id". + " LEFT JOIN User ON User.id=Hand.user_id". + " LEFT JOIN Play ON Trick.id=Play.trick_id". + " LEFT JOIN Hand_Card ON Hand_Card.id=Play.hand_card_id". + " LEFT JOIN Card ON Card.id=Hand_Card.card_id". + " WHERE Hand.game_id='$gameid'". " GROUP BY Hand.party" ); echo "Totals:
\n". " \n"; @@ -1564,53 +1641,99 @@ else if(myisset("me")) " WHERE session=$session". " ORDER BY create_date DESC". " LIMIT 1"); - $r=-1; + $r = -1; if($result) $r = mysql_fetch_array($result,MYSQL_NUM); if(!$session || $gameid==$r[0]) { - /* suggest a new game with the same people in it, just rotated once */ + /* suggest a new game with the same people in it, just rotated once (unless last game was solo) */ $names = DB_get_all_names_by_gameid($gameid); - output_ask_for_new_game($names[1],$names[2],$names[3],$names[0],$gameid); + $type = DB_get_gametype_by_gameid($gameid); + + if($type=="solo") + output_ask_for_new_game($names[0],$names[1],$names[2],$names[3],$gameid); + else + output_ask_for_new_game($names[1],$names[2],$names[3],$names[0],$gameid); } } break; default: - echo "error in testing the status"; + myerror("error in testing the status"); } output_footer(); DB_close(); exit(); } /* user status page */ - else if(myisset("email","password")) +else if( myisset("email","password") || isset($_SESSION["name"]) ) { /* test id and password, should really be done in one step */ - $email = $_REQUEST["email"]; - $password = $_REQUEST["password"]; + if(!isset($_SESSION["name"])) + { + $email = $_REQUEST["email"]; + $password = $_REQUEST["password"]; + } + else + { + $name = $_SESSION["name"]; + $email = DB_get_email_by_name($name); + $password = DB_get_passwd_by_name($name); + }; - if(myisset("forgot")) { - $ok=1; + $ok = 1; $uid = DB_get_userid_by_email($email); if(!$uid) - $ok=0; + $ok = 0; if($ok) { - echo "Hmm, you forgot your passwort...nothing I can do at the moment:( "; - echo " you need to email Arun for now... in the future it will be all automated and an "; - echo "email with a new password will go to $email."; + /* check how many entries in recovery table */ + $number = DB_get_number_of_passwords_recovery($uid); + + /* if less than N recent ones, add a new one and send out email */ + if( $number < 5 ) + { + echo "Ok, I send you a new password.
"; + if($number >1) + echo "N.B. You tried this already $number times during the last day and it will only work ". + " 5 times during a day.
"; + echo "The new password will be valid for one day, make sure you reset it to something else.
"; + echo "Back to the main page."; + + $TIME = (string) time(); /* to avoid collisions */ + $hash = md5("Anewpassword".$email.$TIME); + $newpw = substr($hash,1,8); + + $message = "Someone (hopefully you) requested a new password. \n". + "You can use this email and the following password: \n". + " $newpw \n". + "to log into the server. The new password is valid for 24h, so make\n". + "sure you reset your password to something new. Your old password will\n". + " also still be valid until you set a new one\n"; + mymail($email,$EmailName."recovery ",$message); + + DB_set_recovery_password($uid,md5($newpw)); + } + else + { + echo "Sorry you already tried 5 times during the last 24h.
". + "You need to use one of those passwords or wait to get a new one.
"; + echo "Back to the main page."; + } } else { if($email=="") - echo "you need to give me an email address!"; + echo "You need to give me an email address!
". + "Please try again."; else - echo "couldn't find a player with this email, please contact Arun, if you think this is a mistake"; + echo "Couldn't find a player with this email!
". + "Please contact Arun, if you think this is a mistake
". + "or else try again."; } } else @@ -1619,10 +1742,10 @@ else if(myisset("me")) if(strlen($password)!=32) $password = md5($password); - $ok=1; + $ok = 1; $uid = DB_get_userid_by_email_and_password($email,$password); if(!$uid) - $ok=0; + $ok = 0; if($ok) { @@ -1641,34 +1764,63 @@ else if(myisset("me")) $result = mysql_query("UPDATE User_Prefs SET value=".DB_quote_smart($setpref). " WHERE user_id='$uid' AND pref_key='cardset'" ); else - $result = mysql_query("INSERT INTO User_Prefs VALUES(NULL,'$uid','cardset',".DB_quote_smart($setpref).")"); + $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 if(myisset("passwd")) + { + if( $_REQUEST["passwd"]=="ask" ) + { + /* reset password form*/ + output_password_recovery($email,$password); + } + else if($_REQUEST["passwd"]=="set") + { + /* reset password */ + $ok = 1; + + /* check if old password matches */ + $oldpasswd = md5($_REQUEST["password0"]); + if(!( ($password == $oldpasswd) || DB_check_recovery_passwords($oldpasswd,$email) )) + $ok = -1; + /* check if new passwords are types the same twice */ + if($_REQUEST["password1"] != $_REQUEST["password2"] ) + $ok = -2; + + switch($ok) + { + case '-2': + echo "The new passwords don't match.
"; + break; + case '-1': + echo "The old password is not correct.
"; + break; + case '1': + echo "Changed the password.
"; + mysql_query("UPDATE User SET password='".md5($_REQUEST["password1"]). + "' WHERE id=".DB_quote_smart($uid)); + break; + } + /* set password */ } } else /* output default user page */ { - $time = DB_get_user_timestamp($uid); - $unixtime =strtotime($time); + $time = DB_get_user_timestamp($uid); + $unixtime = strtotime($time); - $offset = DB_get_user_timezone($uid); - $zone = return_timezone($offset); + $offset = DB_get_user_timezone($uid); + $zone = return_timezone($offset); date_default_timezone_set($zone); + + $myname = DB_get_name_by_email($email); + $_SESSION["name"] = $myname; + + if(isset($_SESSION["name"])) + output_status($_SESSION["name"]); /* display links to settings */ output_user_settings($email,$password); @@ -1677,23 +1829,21 @@ else if(myisset("me")) DB_update_user_timestamp($uid); - echo "

these are your games that haven't started yet:
\n"; + echo "

These are your games that haven't started yet:
\n"; $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 || $r[3]==NULL) + echo "(it's your turn)\n"; + else { - 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"; - }; - } + $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". @@ -1702,7 +1852,7 @@ else if(myisset("me")) } echo "

\n"; - echo "

these are the games you are playing in:
\n"; + echo "

These are the games you are playing in:
\n"; $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'" ); @@ -1728,15 +1878,15 @@ else if(myisset("me")) echo "

\n"; - echo "

and these are your games that are already done:
Game: \n"; - $output=array(); + 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)) - $output[]= "#".$r[1]." "; + $output[] = "#".$r[1]." "; echo implode(", ",$output)."

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

registered players:
\n"; + echo "

Registered players:
\n"; echo implode(", ",$names)."\n"; echo "

\n"; @@ -1745,45 +1895,13 @@ else if(myisset("me")) } else { - echo "sorry email and password don't match
"; + echo "Sorry email and password don't match. Please try again.
"; } }; output_footer(); DB_close(); exit(); } -/* page for registration */ - else if(myisset("register") ) - { - output_register(); - } -/* new user wants to register */ - else if(myisset("Rfullname","Remail","Rpassword","Rtimezone") ) - { - $ok=1; - if(DB_get_userid_by_name($_REQUEST["Rfullname"])) - { - echo "please chose another name
"; - $ok=0; - } - if(DB_get_userid_by_email($_REQUEST["Remail"])) - { - echo "this email address is already used ?!
"; - $ok=0; - } - if($ok) - { - $r=mysql_query("INSERT INTO User VALUES(NULL,".DB_quote_smart($_REQUEST["Rfullname"]). - ",".DB_quote_smart($_REQUEST["Remail"]). - ",".DB_quote_smart(md5($_REQUEST["Rpassword"])). - ",".DB_quote_smart($_REQUEST["Rtimezone"]).",NULL)"); - - if($r) - echo " added you to the database"; - else - echo " something went wrong"; - } - } /* default login page */ else {