added output of average time for a game on the homepage
[e-DoKo.git] / index.php
index 06205023096e422c38841610073ae41b00ec9219..0bb04d4c0044e4f37e234a3cd17d58e9191783b7 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 */
@@ -230,18 +231,8 @@ else if(myisset("me"))
     $myhand   = DB_get_handid_by_hash($me);
 
     /* 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 +243,9 @@ else if(myisset("me"))
 
     $RULES["dullen"]      = $r[2];
     $RULES["schweinchen"] = $r[3];
-    
+    $RULES["call"]        = "1st-own-card";
+
+
     /* get some infos about the game */
     $gametype   = DB_get_gametype_by_gameid($gameid);
     $gamestatus = DB_get_game_status_by_gameid($gameid);
@@ -342,7 +335,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');
@@ -431,8 +424,9 @@ else if(myisset("me"))
            $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" ;
+               $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);
              }
          };
@@ -460,7 +454,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
        {
@@ -777,8 +773,9 @@ else if(myisset("me"))
                              $To       = DB_get_email_by_pos_and_gameid($who,$gameid);
                              $userhash = DB_get_hash_from_game_and_pos($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" ;
+                             $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);
                            }
 
@@ -976,7 +973,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 */
        }
@@ -987,7 +985,8 @@ else if(myisset("me"))
                            "        User.id, ".
                            "        Hand.party as party, ".
                            "        Hand.sickness as sickness, ".
-                           "        Hand.point_call ".
+                           "        Hand.point_call, ".
+                           "        User.last_login ".
                            "FROM Hand ".
                            "LEFT JOIN User ON User.id=Hand.user_id ".
                            "WHERE Hand.game_id='".$gameid."' ".
@@ -1001,8 +1000,9 @@ 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]);
          
          $offset = DB_get_user_timezone($user);
          $zone   = return_timezone($offset);
@@ -1013,19 +1013,43 @@ else if(myisset("me"))
          /* 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 >)";
              
@@ -1034,12 +1058,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";
 
        }
@@ -1050,7 +1079,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 ".
@@ -1076,7 +1107,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"]++;
@@ -1312,11 +1349,27 @@ else if(myisset("me"))
                  $message .= "\n";
                  while( $r = mysql_fetch_array($result,MYSQL_NUM))
                    $message .= " FINAL SCORE: ".$r[0]." ".$r[1]."\n";
-
+                 
+                 /* check who wants to be CC'ed on the email */
+                 $h = array();
+                 $header = "";
                  foreach($userids as $user)
                    {
-                     $To = DB_get_email_by_userid($user);
-                     mymail($To,$EmailName."game over (game $gameid)",$message);
+                     $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";
+                 
+                 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);
                    }
                }
              
@@ -1410,7 +1463,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";
@@ -1492,6 +1547,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"))
        {
@@ -1528,6 +1584,8 @@ else if(myisset("me"))
        
        if($ok)
         {
+          DB_get_PREF($uid);
+
           if(myisset("setpref"))
             {
               $setpref=$_REQUEST["setpref"];
@@ -1544,6 +1602,21 @@ 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 */
@@ -1562,10 +1635,25 @@ 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 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(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".
                                     " 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>";
@@ -1636,14 +1724,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();