feature: added link to game in final email, CC'ed people in final email
[e-DoKo.git] / index.php
index c93b18f9031723bd46c46ee459a8bfc75ed4fed5..e8fffb7478d36abf6d195fca5579b44a1c5a1b8e 100644 (file)
--- a/index.php
+++ b/index.php
@@ -192,7 +192,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 */
@@ -230,18 +230,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 */
@@ -325,7 +315,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 */
@@ -431,7 +421,7 @@ else if(myisset("me"))
            $userhash =DB_get_hash_from_gameid_and_userid($gameid,$user);
            if($userhash!=$me)
              {
-               $message = "Everyone finish the questionary, please visit this link now to continue: \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);
              }
@@ -526,7 +516,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 */
@@ -689,6 +679,20 @@ 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);
+                     
+                     $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);
+                   }
+
                  /* this user is done */
                  DB_set_hand_status_by_hash($me,'play');
                  break;                
@@ -703,19 +707,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 +746,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 +759,19 @@ 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);
+                             
+                             $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);
+                           }
+
                        }
                      
                      /* this user is done */
@@ -775,6 +780,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 +848,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 +885,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 */
@@ -871,7 +915,7 @@ else if(myisset("me"))
          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);
            }
@@ -933,7 +977,7 @@ else if(myisset("me"))
                            "        User.id, ".
                            "        Hand.party as party, ".
                            "        Hand.sickness as sickness, ".
-                           "        Hand.point_call as call ".
+                           "        Hand.point_call ".
                            "FROM Hand ".
                            "LEFT JOIN User ON User.id=Hand.user_id ".
                            "WHERE Hand.game_id='".$gameid."' ".
@@ -1258,11 +1302,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)
+                   {
+                     $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);
-                     mymail($To,$EmailName."game over",$message);
+                     $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);
                    }
                }
              
@@ -1303,7 +1363,8 @@ else if(myisset("me"))
                  $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".
+                 $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);            
                }
@@ -1437,6 +1498,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 +1535,8 @@ else if(myisset("me"))
        
        if($ok)
         {
+          DB_get_PREF($uid);
+
           if(myisset("setpref"))
             {
               $setpref=$_REQUEST["setpref"];
@@ -1489,6 +1553,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 */
@@ -1507,10 +1586,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>";