X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=e-DoKo.git;a=blobdiff_plain;f=include%2Ffunctions.php;h=998ca028756b82489361877d49ed1436c5c05f99;hp=f982029a4947035c7e0346007ef791cbf7b90592;hb=6e7ed2d202da016b9a74256371369cc41201df2e;hpb=f7e3acc9f015115707b7b6d59d8ebdb2522b9d0d
diff --git a/include/functions.php b/include/functions.php
index f982029..998ca02 100644
--- a/include/functions.php
+++ b/include/functions.php
@@ -1,4 +1,23 @@
+ *
+ * This file is part of e-DoKo.
+ *
+ * e-DoKo is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * e-DoKo is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with e-DoKo. If not, see .
+ *
+ */
+
/* make sure that we are not called from outside the scripts,
* use a variable defined in config.php to check this
*/
@@ -54,10 +73,70 @@ function config_check()
return;
}
-function mymail($To,$Subject,$message,$header="")
+function mymail($uid,$subject,$message)
{
+ global $EmailName;
+
+ /* do we send the email right away or save it in the database? */
+ $send_now = 1;
+
+ /* add standard header and footer */
+ $subject = "$EmailName".$subject;
+
+ /* standard goodbye */
+ $footer = "\nHave a nice day\n".
+ " your E-Doko service department\n\n".
+ "-- \n".
+ "You can change your mail delivery mode in the preference menu.\n".
+ 'web: http://doko.nubati.net '.
+ 'help: http://wiki.nubati.net/EmailDoko '.
+ 'bugs: http://wiki.nubati.net/EmailDokoIssues';
+
+ if(is_array($uid))
+ {
+ /* send email to more than one person */
+
+ $header = "Hello all\n\n";
+
+ foreach($uid as $user)
+ {
+ $all[] = DB_get_email('userid',$user);
+ }
+ $To = implode(",",$all);
+ }
+ else
+ {
+ /* standard greeting */
+ $name = DB_get_name('userid',$uid);
+ $header = "Hello $name\n\n";
+
+ $To = DB_get_email('userid',$uid);
+
+ /* check if user wants email right away or if we should save it in
+ * the database for later delivery
+ */
+
+ $PREF = DB_get_PREF($uid);
+ if( $PREF['digest'] != 'digest-off' )
+ $send_now = 0;
+ }
+
+ if($send_now)
+ sendmail($To,$subject,$header.$message.$footer);
+ else
+ {
+ /* store email in database */
+ DB_digest_insert_email($To,$message);
+ }
+}
+
+function sendmail($To,$Subject,$message)
+{
+ /* this function sends the mail or outputs to the screen in case of debugging */
global $debug,$EMAIL_REPLY;
+ $header = "";
+
if(isset($EMAIL_REPLY))
$header .= "From: e-DoKo daemon <$EMAIL_REPLY>\r\n";
@@ -104,7 +183,7 @@ function myisset()
function myerror($message)
{
echo "".htmlspecialchars($message)."\n";
- mymail($ADMIN_EMAIL,$EmailName." Error in Code",$message);
+ sendmail($ADMIN_EMAIL,$EmailName." Error in Code",$message);
return;
}
@@ -648,19 +727,36 @@ function sort_comp_low_high($a,$b)
function can_call($what,$hash)
{
+ /* figure out if a person can make a call:
+ $what in 0,30,60,90,120 = points of the call
+ $hash = the hash of the person who wants to make the call
+
+ return values:
+ 0 can't make that call
+ 1 can make the call
+ 2 can make the call, but this is the last chance to do so...
+ */
+
global $RULES;
+ /* get some information
+ */
$gameid = DB_get_gameid_by_hash($hash);
$gametype = DB_get_gametype_by_gameid($gameid);
- $oldcall = DB_get_call_by_hash($hash);
- $pcall = DB_get_partner_call_by_hash($hash);
+ $oldcall = DB_get_call_by_hash($hash); /* did the person already made a call? */
+ $pcall = DB_get_partner_call_by_hash($hash); /* did the partner already made a call */
- if( ($pcall!=NULL && $what >= $pcall) ||
- ($oldcall!=NULL && $what >=$oldcall) )
+
+ /* you're call must be better than the one you or your partner already made
+ */
+ if( ($pcall!=NULL && ($what >= $pcall))
+ || ($oldcall!=NULL && ($what >=$oldcall)) )
{
return 0;
}
+ /* for some rules we need to know how many cards people have
+ */
$NRcards = count(DB_get_hand($hash));
$NRallcards = 0;
@@ -670,7 +766,8 @@ function can_call($what,$hash)
$NRallcards += count(DB_get_hand($user));
};
- /* in case of a wedding, everything will be delayed by an offset */
+ /* in case of a wedding, everything will be delayed by an offset
+ */
$offset = 0;
if($gametype=="wedding")
{
@@ -679,18 +776,34 @@ function can_call($what,$hash)
return 0;
};
+ /* now check if the call is allowed depending on the rule set
+ */
switch ($RULES["call"])
{
case "1st-own-card":
- if( 4-($what/30) >= 12 - ($NRcards + $offset))
+ /* calls can be made before/while you play your card...
+ * first card = 120, second card = 90, etc.
+ */
+ if( 4-($what/30) == 12 - ($NRcards + $offset))
+ return 2;
+ if( 4-($what/30) > 12 - ($NRcards + $offset))
return 1;
break;
case "5th-card":
- if( 27+4*($what/30) <= $NRallcards + $offset*4)
+ /* you can make the first call anytime during the first trick
+ */
+ if( 27+4*($what/30) == $NRallcards + $offset*4)
+ return 2;
+ if( 27+4*($what/30) < $NRallcards + $offset*4)
return 1;
break;
case "9-cards":
+ /* you can call 120 with 12 cards, 90 with 9 or more cards, 60 with 6 or more, etc.
+ * you can't skip a call though
+ */
+ /* figure out last call
+ */
if($oldcall!=NULL && $pcall!=NULL)
$mincall = ($oldcall>$pcall) ? $pcall : $oldcall;
else if($oldcall!=NULL)
@@ -700,26 +813,51 @@ function can_call($what,$hash)
else
$mincall = -1;
- if( 12 <= ($NRcards + $offset))
+
+ if( 12 == ($NRcards + $offset))
+ {
+ return 2;
+ }
+ else if( 12 < ($NRcards + $offset))
{
return 1;
}
- else if ( 9 <= ($NRcards + $offset))
+ else if ( 9 == ($NRcards + $offset))
+ {
+ if( ($mincall>=0 && $mincall==120) )
+ return 2;
+ }
+ else if ( 9 < ($NRcards + $offset))
{
if( ($mincall>=0 && $mincall==120) )
return 1;
}
- else if ( 6 <= ($NRcards + $offset))
+ else if ( 6 == ($NRcards + $offset))
+ {
+ if( ($mincall>=0 && $mincall<=90 && $what<=60 ) )
+ return 2;
+ }
+ else if ( 6 < ($NRcards + $offset))
{
if( ($mincall>=0 && $mincall<=90 && $what<=60 ) )
return 1;
}
- else if ( 3 <= ($NRcards + $offset))
+ else if ( 3 == ($NRcards + $offset))
+ {
+ if( ($mincall>=0 && $mincall<=60 && $what<=30 ) )
+ return 2;
+ }
+ else if ( 3 < ($NRcards + $offset))
{
if( ($mincall>=0 && $mincall<=60 && $what<=30 ) )
return 1;
}
- else if ( 0 <= ($NRcards + $offset))
+ else if ( 0 == ($NRcards + $offset))
+ {
+ if( ($mincall>=0 && $mincall<=30 && $what==0 ) )
+ return 2;
+ }
+ else if ( 0 < ($NRcards + $offset))
{
if( ($mincall>=0 && $mincall<=30 && $what==0 ) )
return 1;
@@ -743,7 +881,8 @@ function display_table ()
" Hand.point_call, ".
" User.last_login, ".
" Hand.hash, ".
- " User.timezone ".
+ " User.timezone, ".
+ " User.email ".
"FROM Hand ".
"LEFT JOIN User ON User.id=Hand.user_id ".
"WHERE Hand.game_id='".$gameid."' ".
@@ -761,10 +900,14 @@ function display_table ()
$call = $r[5];
$hash = $r[7];
$timezone = $r[8];
+ $email = $r[9];
+ $wins = DB_get_number_of_tricks($gameid,$pos);
date_default_timezone_set($defaulttimezone);
$lastlogin = strtotime($r[6]);
date_default_timezone_set($timezone);
$timenow = strtotime(date("Y-m-d H:i:s"));
+ $gravatar = "$name
";
+
echo "
\n";
@@ -777,10 +920,10 @@ function display_table ()
$comment = $vacation[2];
$title = "begin: $start end: $stop $comment";
- echo "
$name (on vacation until $stop) \n";
+ echo "
$gravatar (on vacation until $stop) \n";
}
else
- echo " $name \n";
+ echo " $gravatar \n";
if($debug)
echo"\n";
@@ -882,8 +1025,24 @@ function display_table ()
echo "
\n";
echo "
".
- "".
+ "".
"\n";
+
+ /* show how many tricks the person made */
+ switch($wins)
+ {
+ case 0:
+ echo "#tricks 0"; break;
+ case 1:
+ echo "#tricks 1"; break;
+ case 2:
+ case 3:
+ case 4:
+ echo "#tricks few"; break;
+ default:
+ echo "#tricks many"; break;
+ }
+
echo "
\n";
}
@@ -902,7 +1061,7 @@ function display_user_menu($id)
" LEFT JOIN Game On Hand.game_id=Game.id".
" WHERE Hand.user_id='$id'".
" AND ( Game.player='$id' OR ISNULL(Game.player) )".
- " AND Game.status<>'gameover'".
+ " AND ( Game.status='pre' OR Game.status='play' )".
" ORDER BY Game.session" );
$i=0;
@@ -1213,4 +1372,49 @@ function check_vacation($userid)
return NULL;
}
+function cancel_game($why,$gameid)
+{
+ $gameid = DB_quote_smart($gameid);
+
+ /* update the game table */
+ switch($why)
+ {
+ case 'timedout':
+ DB_query("UPDATE Game SET status='cancel-timedout' WHERE id=$gameid");
+ break;
+ case 'nines':
+ DB_query("UPDATE Game SET status='cancel-nines' WHERE id=$gameid");
+ break;
+ case 'trump':
+ DB_query("UPDATE Game SET status='cancel-trump' WHERE id=$gameid");
+ break;
+ case 'noplay':
+ DB_query("UPDATE Game SET status='cancel-noplay' WHERE id=$gameid");
+ break;
+ }
+ /* set each player to gameover */
+ $result = DB_query("SELECT id FROM Hand WHERE game_id=".DB_quote_smart($gameid));
+ while($r = DB_fetch_array($result))
+ {
+ $id = $r[0];
+ DB_query("UPDATE Hand SET status='gameover' WHERE id=".DB_quote_smart($id));
+ }
+
+ return;
+}
+
+function get_user_token($userid)
+{
+
+ $token = NULL;
+
+ $date = DB_get_user_creation_date($userid);
+ $name = DB_get_name('userid',$userid);
+
+ if($date && $name)
+ $token = md5("token".$name.$date);
+
+ return $token;
+}
+
?>