2 /************************************************************************
3 * MXChange v0.2.1 Start: 10/03/2004 *
4 * =============== Last change: 10/03/2004 *
6 * -------------------------------------------------------------------- *
7 * File : birthday_confirm.php *
8 * -------------------------------------------------------------------- *
9 * Short description : Birthday bonus confirmation link *
10 * -------------------------------------------------------------------- *
11 * Kurzbeschreibung : Geburtstagsgutschrift bestaetigen *
12 * -------------------------------------------------------------------- *
14 * -------------------------------------------------------------------- *
15 * Copyright (c) 2003 - 2008 by Roland Haeder *
16 * For more information visit: http://www.mxchange.org *
18 * This program is free software; you can redistribute it and/or modify *
19 * it under the terms of the GNU General Public License as published by *
20 * the Free Software Foundation; either version 2 of the License, or *
21 * (at your option) any later version. *
23 * This program is distributed in the hope that it will be useful, *
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
26 * GNU General Public License for more details. *
28 * You should have received a copy of the GNU General Public License *
29 * along with this program; if not, write to the Free Software *
30 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
32 ************************************************************************/
34 // Load security stuff here (Oh, I hope this is not unsecure? Am I paranoia??? ;-) )
35 require_once("inc/libs/security_functions.php");
37 // Init "action" and "what"
38 global $what, $action;
39 $GLOBALS['what'] = ""; $GLOBALS['action'] = "";
40 if (!empty($_GET['action'])) $GLOBALS['action'] = secureString($_GET['action']);
41 if (!empty($_GET['what'])) $GLOBALS['what'] = secureString($_GET['what']);
44 $GLOBALS['module'] = "birthday_confirm"; $CSS = -1;
46 // Load the required file(s)
47 require ("inc/config.php");
49 if (defined('mxchange_installed') && (mxchange_installed))
51 // Script is installed so let's check for his confirmation link...
52 $uid = strip_tags(bigintval($_GET['uid']));
54 // Only allow numbers here...
55 $chk = strip_tags(bigintval($_GET['check']));
57 // .. only first 32 numbers
58 $chk = substr($chk, 0, 32);
60 // Check if link is not clicked so far
61 $result = SQL_QUERY_ESC("SELECT DISTINCT b.points, d.sex, d.surname, d.family, d.status
62 FROM "._MYSQL_PREFIX."_user_birthday AS b
63 LEFT JOIN "._MYSQL_PREFIX."_user_data AS d
65 WHERE b.userid=%d AND b.chk_value='%s' LIMIT 1",
66 array($uid, $chk), __FILE__, __LINE__);
68 if (SQL_NUMROWS($result) == 1)
70 // Ok, congratulation again! Here's your gift from us...
71 list($GIFT, $salut, $sname, $fname, $status) = SQL_FETCHROW($result);
72 if ($status == "CONFIRMED")
74 // Set mode depending on how many mails the member has to confirm
76 if (($ref_payout > 0) && ($CONFIG['allow_direct_pay'] == "N")) $locked = true;
78 // Add points to account
79 ADD_POINTS_REFSYSTEM($uid, $GIFT, false, "0", $locked, strtolower($CONFIG['birthday_mode']));
81 // Remove entry from table
82 $result = SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_user_birthday WHERE userid=%d LIMIT 1",
83 array($uid), __FILE__, __LINE__);
85 // Update mediadata if version is 0.0.4 or newer
86 if (GET_EXT_VERSION("mediadata") >= "0.0.4")
89 MEDIA_UPDATE_ENTRY(array("total_points"), "add", $GIFT);
92 // Transfer data to constants for the template
93 define('__SALUT', TRANSLATE_SEX($salut));
94 define('__SNAME', $sname);
95 define('__FNAME', $fname);
96 define('__GIFT' , $GIFT);
98 // Load message from template
99 define('__MSG', LOAD_TEMPLATE("birthday_msg", true));
103 // Unconfirmed / locked accounts cannot get points
104 define('__MSG', BIRTHDAY_CANNOT_STATUS_1.TRANSLATE_STATUS($status).BIRTHDAY_CANNOT_STATUS_2);
110 define('__MSG', BIRTHDAY_CANNOT_LOAD_DATA);
114 SQL_FREERESULT($result);
116 // Set this because we have no module in URI
117 $GLOBALS['module'] = "birthday_confirm";
120 include(PATH."inc/header.php");
122 // Load birthday header template (for your banners, e.g.?)
123 define('__BIRTHDAY_HEADER', LOAD_TEMPLATE("birthday_header", true));
125 // Load birthday footer template (for your banners, e.g.?)
126 define('__BIRTHDAY_FOOTER', LOAD_TEMPLATE("birthday_footer", true));
128 // Load final template and output it
129 LOAD_TEMPLATE("birthday_confirm");
132 include(PATH."inc/footer.php");
136 // You have to configure first!
137 LOAD_URL(URL."/install.php");
139 // Really all done here... ;-)