NEW FEATURE: show all hands at the end of a game
[e-DoKo.git] / index.php
index c93b18f9031723bd46c46ee459a8bfc75ed4fed5..f5c3d3da4e66b491cd3b79c6ba03f045522a3150 100644 (file)
--- a/index.php
+++ b/index.php
@@ -33,6 +33,7 @@ if(DB_open()<0)
     exit(); 
   }
 
+/* done major error checking, output header of HTML page */
 output_header();
 
 /* check if we want to start a new game */
@@ -61,6 +62,7 @@ if(myisset("new"))
       {
        echo "couldn't find one of the names, please start a new game";
        output_footer();
+       DB_close();
        exit();
       }
     
@@ -70,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 */
@@ -79,6 +81,7 @@ if(myisset("new"))
       {
        echo "Error defining ruleset: $ruleset";
        output_footer();
+       DB_close();
        exit();
       };
     
@@ -91,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();
     
@@ -171,6 +174,7 @@ else if(myisset("cancle","me"))
        echo "Can't find you in the database, please check the url.<br />\n";
        echo "perhaps the game has been cancled, check by login in <a href=\"$host\">here</a>.";
        output_footer();
+       DB_close();
        exit();
       }
     
@@ -192,7 +196,7 @@ else if(myisset("cancle","me"))
        foreach($userids as $user)
          {
            $To = DB_get_email_by_userid($user);
-           mymail($To,$EmailName."game cancled (timed out)",$message);
+           mymail($To,$EmailName."game $gameid cancled (timed out)",$message);
          }
        
        /* delete everything from the dB */
@@ -216,6 +220,7 @@ else if(myisset("me"))
        echo "Can't find you in the database, please check the url.<br />\n";
        echo "perhaps the game has been cancled, check by login in <a href=\"$host\">here</a>.";
        output_footer();
+       DB_close();
        exit();
       }
 
@@ -228,20 +233,11 @@ 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 */
-    $result = mysql_query("SELECT value from User_Prefs".
-                         " WHERE user_id='$myid' AND pref_key='cardset'" );
-    $r = mysql_fetch_array($result,MYSQL_NUM);
-    if($r)
-      {
-       if($r[0]=="germancards" && (time()-strtotime( "2009-12-31 23:59:59")<0) ) /* licence only valid until then */
-         $PREF["cardset"]="altenburg";
-      else
-       $PREF["cardset"]="english";
-      }
-    else
-      $PREF["cardset"]="english";
+    DB_get_PREF($myid);
+    /* end set pref */
       
       
     /* get rule set for this game */
@@ -252,7 +248,9 @@ else if(myisset("me"))
 
     $RULES["dullen"]      = $r[2];
     $RULES["schweinchen"] = $r[3];
-    
+    $RULES["call"]        = $r[4];
+
+
     /* get some infos about the game */
     $gametype   = DB_get_gametype_by_gameid($gameid);
     $gamestatus = DB_get_game_status_by_gameid($gameid);
@@ -272,7 +270,27 @@ else if(myisset("me"))
     echo "Rules: <br />\n";
     echo "10ofhearts : ".$r[2]."<br />\n";
     echo "schweinchen: ".$r[3]."<br />\n";
+    echo "call:        ".$r[4]."<br />\n";
     echo "</div>\n";
+
+    /* output extra division in case this game is part of a session */
+    if($session)
+      {
+       echo "<div class=\"session\">\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 "<a href=\"".$host."?me=".$hash."\">$i</a> ";
+           $i++;
+         }
+       echo "</div>\n";
+      }
+
     
     /* does anyone have both foxes */
     $GAME["schweinchen"]=0; 
@@ -325,7 +343,7 @@ else if(myisset("me"))
                foreach($userids as $user)
                  {
                    $To = DB_get_email_by_userid($user);
-                   mymail($To,$EmailName."game canceled",$message);
+                   mymail($To,$EmailName."game $gameid canceled",$message);
                  }
                
                /* delete everything from the dB */
@@ -342,7 +360,7 @@ else if(myisset("me"))
                  display_card($card,$PREF["cardset"]);
                echo "</p>\n";   
                
-               check_for_sickness($me,$mycards);
+               output_check_for_sickness($me,$mycards);
                
                /* move on to the next stage*/
                DB_set_hand_status_by_hash($me,'check');
@@ -408,34 +426,35 @@ else if(myisset("me"))
                " is playing solo, this game will be canceled.<br />\n";
              DB_set_sickness_by_hash($me,"nines");
            }
-       }
-
-      echo " Ok, done with checking, please go to the <a href=\"$host?me=$me\">next step of the setup</a>.<br />";
-
-      /* 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 <a href=\"$host?me=$me\">next step of the setup</a>.<br />";
+         
+         /* 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, 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;
 
@@ -460,7 +479,9 @@ else if(myisset("me"))
       if(!$ok)
        {
          echo "This step can only be handled after everyone finished the last step. ".
-           "Seems like this is not the case, so you need to wait a bit... you will get an email once that is the case, please use the link in that email to continue the game.<br />";
+              "Seems like this is not the case, so you need to wait a bit... ".
+              "you will get an email once that is the case, please use the link in ".
+              "that email to continue the game.<br />";
        }
       else
        {
@@ -472,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);
@@ -507,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 */
@@ -526,7 +544,7 @@ else if(myisset("me"))
              foreach($userids as $user)
                {
                  $To = DB_get_email_by_userid($user);
-                 mymail($To,$EmailName."game canceled",$message);
+                 mymail($To,$EmailName."game $gameid canceled",$message);
                }
              
              /* delete everything from the dB */
@@ -535,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";
@@ -551,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";
@@ -689,6 +708,21 @@ else if(myisset("me"))
                  else
                    DB_set_sickness_by_gameid($gameid,$who+$add);
 
+                 /* email next player */
+                 $who = DB_get_sickness_by_gameid($gameid);
+                 if($who>9) $who = $who/10;
+                 
+                 if($who<=4)
+                   {
+                     $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 (game $gameid)",$message);
+                   }
+
                  /* this user is done */
                  DB_set_hand_status_by_hash($me,'play');
                  break;                
@@ -703,19 +737,6 @@ else if(myisset("me"))
                  /* copy trump from player A to B */
                  $result = mysql_query("UPDATE Hand_Card SET hand_id='$myhand' WHERE hand_id='$userhand' AND card_id<'27'" );
                  
-                 /* set re/contra, if it is  not already set */
-                 $party = DB_get_party_by_hash($me);
-                 if(!$party)
-                   {
-                     foreach($userids as $user)
-                       {
-                         $hash = DB_get_hash_from_gameid_and_userid($gameid,$user);
-                         if($user == $trump || $user == $myid)
-                           DB_set_party_by_hash($hash,"re");
-                         else
-                           DB_set_party_by_hash($hash,"contra");
-                       }
-                   }
                  /* add hidden button with trump in it to get to the next point */
                  echo "<form action=\"index.php\" method=\"post\">\n";
                  echo "  <input type=\"hidden\" name=\"exchange\" value=\"-1\" />\n";
@@ -755,6 +776,7 @@ else if(myisset("me"))
                          $add = 1;
                          $who = $who/10;
 
+                         /* whom to ask next */
                          $firstsick  = DB_get_sickness_by_pos_and_gameid($mypos+1,$gameid);
                          $secondsick = DB_get_sickness_by_pos_and_gameid($mypos+2,$gameid);
 
@@ -767,6 +789,21 @@ else if(myisset("me"))
                              else
                                DB_set_sickness_by_gameid($gameid,$who+$add*3);
                            };
+
+                         /* email next player */
+                         $who = DB_get_sickness_by_gameid($gameid);
+                         if($who<=4)
+                           {
+                             $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 (game $gameid)",$message);
+                           }
+
                        }
                      
                      /* this user is done */
@@ -775,6 +812,33 @@ else if(myisset("me"))
                      $hash = DB_get_hash_from_gameid_and_userid($gameid,$trump);
                      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;
+                     foreach($userids as $user)
+                       {
+                         $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user);
+                         $party=DB_get_party_by_hash($userhash);
+                         if($party=="re")
+                           $re_set=1;
+                       }
+                     if($re_set)
+                       {
+                         DB_set_party_by_hash($me,"contra");
+                         DB_set_party_by_hash($hash,"contra");
+                       }
+                     else
+                       {
+                         foreach($userids as $user)
+                           {
+                             $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user);
+                             if($userhash==$hash||$userhash==$me)
+                               DB_set_party_by_hash($userhash,"re");
+                             else
+                               DB_set_party_by_hash($userhash,"contra");
+                           }
+                       }
+
+
                      break;
                    }
                  else
@@ -816,10 +880,22 @@ else if(myisset("me"))
                    }
                  echo "I don't want to take any trump: ".
                    "<a href=\"index.php?me=$me&amp;trump=no\">yes</a> <br />";
+
+                 echo "Your cards are: <br />\n";
+                 $mycards = DB_get_hand($me);
+                 sort($mycards);
+                 echo "<p class=\"mycards\" style=\"margin-top:8em;\">your cards are: <br />\n";
+                 foreach($mycards as $card) 
+                   display_card($card,$PREF["cardset"]);
+                 echo "</p>\n";   
                }
              else
                {
-                 echo "it's not your turn yet to decide if you want to take the trump or not.";
+                 $mysick = DB_get_sickness_by_userid_and_gameid($myid,$gameid);
+                 if($mysick=="poverty")
+                   echo "The others are asked if they want to take your trump, you have to wait (you'll get an email).";
+                 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 
@@ -841,7 +917,7 @@ else if(myisset("me"))
          foreach($userids as $user)
            {
              $To = DB_get_email_by_userid($user);
-             mymail($To,$EmailName."game cancled (poverty not resolved)",$message);
+             mymail($To,$EmailName."game $gameid cancled (poverty not resolved)",$message);
            }
          
          /* delete everything from the dB */
@@ -849,6 +925,7 @@ else if(myisset("me"))
          
          echo "<p style=\"background-color:red\";>Game $gameid has been cancled.<br /><br /></p>";
          output_footer();
+         DB_close();
          exit();
        }
 
@@ -867,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.\n".
+             $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, <a href=\"$host?me=$me\">start</a> the game.<br />";  
@@ -922,7 +1001,8 @@ else if(myisset("me"))
       /* has the game started? No, then just wait here...*/
       if($gamestatus == 'pre')
        {
-         echo "You finished the setup, but not everyone else finished it...so you need to wait for the others. Just wait for the an email... <br />";
+         echo "You finished the setup, but not everyone else finished it... ".
+              "so you need to wait for the others. Just wait for the an email... <br />";
          break; /* not sure this works... the idea is that you can 
                  * only  play a card after everyone is ready to play */
        }
@@ -933,7 +1013,9 @@ else if(myisset("me"))
                            "        User.id, ".
                            "        Hand.party as party, ".
                            "        Hand.sickness as sickness, ".
-                           "        Hand.point_call as call ".
+                           "        Hand.point_call, ".
+                           "        User.last_login, ".
+                           "        Hand.hash        ".
                            "FROM Hand ".
                            "LEFT JOIN User ON User.id=Hand.user_id ".
                            "WHERE Hand.game_id='".$gameid."' ".
@@ -947,31 +1029,62 @@ else if(myisset("me"))
          $pos   = $r[1];
          $user  = $r[2];
          $party = $r[3];
-         $sickness= $r[4];
-         $call  = $r[5];
-         
+         $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 " <span class=\"table".($pos-1)."\">\n";
-         echo " $name ";
+         if(!$debug)
+           echo " $name \n";
+         else
+           {
+             echo "<a href=\"".$host."?me=".$hash."\">$name</a>\n";
+           }
          /* add hints for poverty, wedding, solo, etc */
          if($GT=="poverty" && $party=="re")
            if($sickness=="poverty")
-             echo "(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 < trump back)";
+               else
+                 echo "(poverty <)";
+             }
            else
              echo "(poverty >)";
 
          if($GT=="dpoverty")
            if($party=="re")
              if($sickness=="poverty")
-               echo "(poverty A <)";
+               {
+               $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user);
+               $cards = DB_get_all_hand($userhash);
+               $trumpNR = count_trump($cards);
+               if($trumpNR)
+                 echo "(poverty A < trump back)";
+               else
+                 echo "(poverty A <)";
+               }
              else
                echo "(poverty A >)";
            else
              if($sickness=="poverty")
-               echo "(poverty B <)";
+               {
+               $userhash = DB_get_hash_from_gameid_and_userid($gameid,$user);
+               $cards = DB_get_all_hand($userhash);
+               $trumpNR = count_trump($cards);
+               if($trumpNR)
+                 echo "(poverty B < trump back)";
+               else
+                 echo "(poverty B <)";
+               }
              else
                echo "(poverty B >)";
              
@@ -980,12 +1093,17 @@ else if(myisset("me"))
                echo "(wedding  +)";
              else
                echo "(wedding)";
+         
+         if(ereg("solo",$GT) && $party=="re")
+            echo "($GT)";
+
          /* add point calls */
          if($call!=NULL)
            echo " $party $call ";
 
          echo "<br />\n";
-         echo " local time: ".date("Y-m-d H:i:s")."\n";
+         echo " local time: ".date("Y-m-d H:i:s")."<br />\n";
+         echo " last login: ".date("Y-m-d H:i:s",$lastlogin)."<br />\n";
          echo " </span>\n";
 
        }
@@ -996,7 +1114,9 @@ else if(myisset("me"))
                            "       Hand.position as position,".
                            "       Play.sequence as sequence, ".
                            "       Trick.id, ".
-                           "       Comment.comment ".
+                           "       Comment.comment, ".
+                           "       Play.create_date, ".
+                           "       Hand.user_id ".
                            "FROM Trick ".
                            "LEFT JOIN Play ON Trick.id=Play.trick_id ".
                            "LEFT JOIN Hand_Card ON Play.hand_card_id=Hand_Card.id ".
@@ -1022,7 +1142,13 @@ else if(myisset("me"))
          $seq     = $r[2];
          $trick   = $r[3];
          $comment = $r[4];
-         
+         $timeplayed = strtotime($r[5]);
+         $user    = $r[6];
+
+         $offset = DB_get_user_timezone($user);
+         $zone   = return_timezone($offset);
+         date_default_timezone_set($zone);
+
          /* check if first schweinchen has been played */
          if($r[0] == 19 || $r[0] == 20 )
            $GAME["schweinchen"]++;
@@ -1113,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-<br />";
@@ -1240,29 +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";
+                 
+                 /* send out final email */
+                 $all = array();
+
+                 foreach($userids as $user)
+                   $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);
-                     mymail($To,$EmailName."game over",$message);
+                     $To   = DB_get_email_by_userid($user);
+                     $hash = DB_get_hash_from_gameid_and_userid($gameid,$user);
+                     
+                     $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);
                    }
                }
              
@@ -1302,10 +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);
-                 
-                 $message = "It's your turn  now.\n".
+                 $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
@@ -1355,7 +1496,9 @@ else if(myisset("me"))
                " <input type=\"radio\" name=\"call30\" value=\"yes\" /> ";
          if( can_call(0,$me) )
              echo " 0:".
-               " <input type=\"radio\" name=\"call0\" value=\"yes\" /> ";
+               " <input type=\"radio\" name=\"call0\" value=\"yes\" /> ".
+               " no call:".
+               " <input type=\"radio\" name=\"call0\" value=\"no\" /> ";
 
          echo "<br />\nA short comments:<input name=\"comment\" type=\"text\" size=\"30\" maxlength=\"50\" />\n";
          echo "<input type=\"hidden\" name=\"me\" value=\"$me\" />\n";
@@ -1375,10 +1518,28 @@ else if(myisset("me"))
          echo "Your cards were: <br />\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 "<br />";
+                 
+                  $name = DB_get_name_by_userid($user);
+                  $oldcards = DB_get_all_hand($userhash);
+                  $oldcards = mysort($oldcards,$gametype);
+                  echo "$name's cards were: <br />\n";
+                  foreach($oldcards as $card)
+                    display_card($card,$PREF["cardset"]);
+                }
+            }
        }
       echo "</div>\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' */
@@ -1391,22 +1552,27 @@ else if(myisset("me"))
        {
          echo "the game is over now...<br />\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:<br />\n".
+           " <table>\n";;
          while( $r = mysql_fetch_array($result,MYSQL_NUM))
-           echo " FINAL SCORE: ".$r[0]."(".$r[2].") ".$r[1]."<br />";
-         
-         $result = mysql_query("SELECT Hand.party, SUM(score) FROM Score".
-                               " LEFT JOIN Hand ON Hand.id=hand_id".
+           echo "  <tr><td>  ".$r[0]."</td><td>(".$r[2].")</td><td> ".$r[1]."</td></tr>";
+         echo "</table>\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:<br />\n".
+           " <table> \n";
          while( $r = mysql_fetch_array($result,MYSQL_NUM))
-           echo " FINAL SCORE: ".$r[0]." ".$r[1]."<br />\n";
-
+           echo "  <tr><td>".$r[0]."</td><td> ".$r[1]."</td></tr>\n";
+         echo "</table>\n";
          
          $session = DB_get_session_by_gameid($gameid);
          $result  = mysql_query("SELECT id,create_date FROM Game".
@@ -1429,6 +1595,7 @@ else if(myisset("me"))
       echo "error in testing the status";
     }
     output_footer();
+    DB_close();
     exit();
  } 
 /* user status page */ 
@@ -1437,6 +1604,7 @@ else if(myisset("me"))
      /* test id and password, should really be done in one step */
      $email     = $_REQUEST["email"];
      $password  = $_REQUEST["password"];
+     
 
      if(myisset("forgot"))
        {
@@ -1473,6 +1641,8 @@ else if(myisset("me"))
        
        if($ok)
         {
+          DB_get_PREF($uid);
+
           if(myisset("setpref"))
             {
               $setpref=$_REQUEST["setpref"];
@@ -1507,13 +1677,48 @@ else if(myisset("me"))
               
               DB_update_user_timestamp($uid);
               
+              echo "<p>these are your games that haven't started yet:<br />\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 "<a href=\"".$host."?me=".$r[0]."\">game #".$r[1]." </a>";
+                  if($r[3])
+                    {
+                      if($r[3]==$uid)
+                        echo "(it's <strong>your</strong> 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? <a href=\"$host?cancle=1&amp;me=".$r[0]."\">yes</a>".
+                      " (clicking here is final and can't be restored)";
+                  echo "<br />";
+                }
+              echo "</p>\n";
+
               echo "<p>these are the games you are playing in:<br />\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<>'gameover'" );
+                                    " WHERE Hand.user_id='$uid' AND Game.status='play'" );
               while( $r = mysql_fetch_array($result,MYSQL_NUM))
                 {
                   echo "<a href=\"".$host."?me=".$r[0]."\">game #".$r[1]." </a>";
+                  if($r[3])
+                    {
+                      if($r[3]==$uid)
+                        echo "(it's <strong>your</strong> 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? <a href=\"$host?cancle=1&amp;me=".$r[0]."\">yes</a>".
@@ -1524,15 +1729,15 @@ else if(myisset("me"))
               
               
               echo "<p>and these are your games that are already done:<br />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 "<a href=\"".$host."?me=".$r[0]."\">#".$r[1]." </a>, ";
-              echo "</p>\n";
+                $output[]= "<a href=\"".$host."?me=".$r[0]."\">#".$r[1]." </a>";
+              echo implode(", ",$output)."</p>\n";
               
               $names = DB_get_all_names();
               echo "<p>registered players:<br />\n";
-              foreach ($names as $name)
-                echo "$name, \n";
+              echo implode(", ",$names)."\n";
               echo "</p>\n";
               
               echo "<p>Want to start a new game? Visit <a href=\"".$host."?new\">this page.</a></p>";
@@ -1544,6 +1749,7 @@ else if(myisset("me"))
         }
      };
      output_footer();
+     DB_close();
      exit();
    }
 /* page for registration */
@@ -1581,14 +1787,21 @@ else if(myisset("me"))
 /* default login page */
  else
    { 
-     $pre=0;$game=0;$done=0;
+     $pre[0]=0;$game[0]=0;$done[0]=0;
      $r=mysql_query("SELECT COUNT(id) FROM Game GROUP BY status");
      if($r) {
-       $pre = mysql_fetch_array($r,MYSQL_NUM);     
+       $pre  = mysql_fetch_array($r,MYSQL_NUM);     
        $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();