X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=birthday_confirm.php;h=7b5bffac08891a8b1b4cd89e48acd5e35c8290e8;hp=24c46fcc56a945922d8907ba713932cf565b98a0;hb=4b7f401f2a4680ae46ca41c57f749cfe35163660;hpb=81bfbcd72e424060ea1223b49ad92fcfa150f361 diff --git a/birthday_confirm.php b/birthday_confirm.php index 24c46fcc56..7b5bffac08 100644 --- a/birthday_confirm.php +++ b/birthday_confirm.php @@ -1,7 +1,7 @@ \n"; - - // Prepare content - $content = array(); - - // Is an entry there? - if (SQL_NUMROWS($result) == 1) { - // Ok, congratulation again! Here's your gift from us... - $data = SQL_FETCHARRAY($result, false); - - // Is the account confirmed? - if ($data['status'] == 'CONFIRMED') { - // Set mode depending on how many mails the member has to confirm - $locked = false; - if (($data['ref_payout'] > 0) && (getConfig('allow_direct_pay') != 'Y')) $locked = true; - - // Add points to account - unset($GLOBALS['ref_level']); - ADD_POINTS_REFSYSTEM('birthday_confirm', $uid, $data['points'], false, '0', $locked, strtolower(getConfig('birthday_mode'))); - - // Update mediadata if version is 0.0.4 or newer - if (GET_EXT_VERSION('mediadata') >= '0.0.4') { - // Update database - MEDIA_UPDATE_ENTRY(array('total_points'), 'add', $data['points']); - } - - // Remove entry from table - SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM `{!_MYSQL_PREFIX!}_user_birthday` WHERE userid=%s AND chk_value='%s' LIMIT 1", - array($uid, $chk), __FILE__, __LINE__); - - // "Translate" some data - $data['gender'] = translateGender($data['gender']); - $data['points'] = translateComma($data['points']); - - // Load message from template - $content['msg'] = LOAD_TEMPLATE('birthday_msg', true, $data); - } else { - // Unconfirmed / locked accounts cannot get points - $content['msg'] = sprintf(getMessage('BIRTHDAY_CANNOT_STATUS'), translateUserStatus($data['status'])); - } +// Script is installed so let's check for his confirmation link... +$userid = bigintval(getRequestParameter('userid')); + +// Only allow numbers here... +$chk = bigintval(getRequestParameter('check'), false); + +// Check if link is not clicked so far +$result = SQL_QUERY_ESC("SELECT + b.points, d.userid, d.gender, d.surname, d.family, d.status, d.ref_payout +FROM + `{?_MYSQL_PREFIX?}_user_birthday` AS b +INNER JOIN + `{?_MYSQL_PREFIX?}_user_data` AS d +ON + b.userid=d.userid +WHERE + b.userid=%s AND + b.chk_value='%s' +LIMIT 1", + array( + $userid, + $chk + ), __FILE__, __LINE__); +//* DEBUG: */ outputHtml("userid=".$userid.",chk=".$chk." (".strlen($chk).'/'.strlen(getRequestParameter('check')).'/'.SQL_NUMROWS($result).")
"); + +// Prepare content +$content = array(); + +// Is an entry there? +if (SQL_NUMROWS($result) == 1) { + // Ok, congratulation again! Here's your gift from us... + $data = SQL_FETCHARRAY($result, false); + + // Is the account confirmed? + if ($data['status'] == 'CONFIRMED') { + // Set mode depending on how many mails the member has to confirm + $locked = false; + if (($data['ref_payout'] > 0) && (getConfig('allow_direct_pay') != 'Y')) $locked = true; + + // Add points to account + // @TODO Try to rewrite the following unset() + unset($GLOBALS['ref_level']); + addPointsThroughReferalSystem('birthday_confirm', $userid, $data['points'], false, 0, $locked, strtolower(getConfig('birthday_mode'))); + + // Remove entry from table + SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM `{?_MYSQL_PREFIX?}_user_birthday` WHERE `userid`=%s AND `chk_value`='%s' LIMIT 1", + array($userid, $chk), __FILE__, __LINE__); + + // Load message from template + $content['message'] = loadTemplate('birthday_msg', true, $data); } else { - // Cannot load data! - $content['msg'] = getMessage('BIRTHDAY_CANNOT_LOAD_DATA'); + // Unconfirmed / locked accounts cannot get points + $content['message'] = getMaskedMessage('BIRTHDAY_CANNOT_STATUS', translateUserStatus($data['status'])); } +} else { + // Cannot load data! + $content['message'] = getMessage('BIRTHDAY_CANNOT_LOAD_DATA'); +} - // Free memory - SQL_FREERESULT($result); - - // Set this because we have no module in URI - $GLOBALS['module'] = 'birthday_confirm'; +// Free memory +SQL_FREERESULT($result); - // Include header - loadInclude('inc/header.php'); +// Set this because we have no module in URI +$GLOBALS['module'] = 'birthday_confirm'; - // Load birthday header template (for your banners, e.g.?) - $content['header'] = LOAD_TEMPLATE('birthday_header', true); +// Include header +loadIncludeOnce('inc/header.php'); - // Load birthday footer template (for your banners, e.g.?) - $content['footer'] = LOAD_TEMPLATE('birthday_footer', true); +// Load birthday header template (for your banners, e.g.?) +$content['header'] = loadTemplate('birthday_header', true); - // Load final template and output it - LOAD_TEMPLATE('birthday_confirm', false, $content); +// Load birthday footer template (for your banners, e.g.?) +$content['footer'] = loadTemplate('birthday_footer', true); - // Include footer - loadInclude('inc/footer.php'); -} else { - // You have to install first! - redirectToUrl('install.php'); -} +// Load final template and output it +loadTemplate('birthday_confirm', false, $content); -// Really all done here... ;-) -shutdown(); +// Include footer +loadIncludeOnce('inc/footer.php'); -// +// [EOF] ?>