userData['user_password'])) {
$this->data['user_hash'] = $this->userData['user_password'];
} else if (isset($_POST['user_hash'])) {
$this->data['user_hash'] = form_sanitizer($_POST['user_hash'], '', 'user_hash');
}
return $this->data;
}
/**
* Save User Fields
*
* @return bool - true if successful.
*/
public function saveInsert() {
$settings = fusion_get_settings();
$locale = fusion_get_locale();
$this->_method = "validate_insert";
$this->data = $this->_setEmptyFields();
if ($this->_userNameChange) {
$this->_settUserName();
}
$this->_setPassword();
$this->_setUserEmail();
/**
* For validation purposes only to show required field errors
*
* @todo - look further for optimization
*/
$quantum = new QuantumFields();
$quantum->setCategoryDb(DB_USER_FIELD_CATS);
$quantum->setFieldDb(DB_USER_FIELDS);
$quantum->setPluginFolder(INCLUDES."user_fields/");
$quantum->setPluginLocaleFolder(LOCALE.LOCALESET."user_fields/");
$quantum->load_fields();
$quantum->load_field_cats();
$quantum->setCallbackData($this->data);
$fields_input = $quantum->return_fields_input(DB_USERS, 'user_id');
if (!empty($fields_input)) {
foreach ($fields_input as $table_name => $fields_array) {
$this->data += $fields_array;
}
}
if ($this->validation == 1) {
$this->_setValidationError();
}
if (\defender::safe()) {
if ($this->emailVerification) {
$this->_setEmailVerification();
} else {
/**
* Create user
*/
dbquery_insert(DB_USERS, $this->data, 'save');
$this->_completeMessage = $locale['u160']." - ".$locale['u161'];
if (defined("ADMIN_PANEL")) {
$aidlink = fusion_get_aidlink();;
$locale = fusion_get_locale('', LOCALE.LOCALESET."admin/members_email.php");
require_once INCLUDES."sendmail_include.php";
$subject = str_replace("[SITENAME]", $settings['sitename'], $locale['email_create_subject']);
$replace_this = ["[USER_NAME]", "[PASSWORD]", "[SITENAME]", "[SITEUSERNAME]"];
$replace_with = [
$this->_userName, $this->_newUserPassword, $settings['sitename'], $settings['siteusername']
];
$message = str_replace($replace_this, $replace_with, $locale['email_create_message']);
sendemail($this->_userName, $this->_userEmail, $settings['siteusername'], $settings['siteemail'],
$subject, $message);
// Administrator complete message
$this->_completeMessage = $locale['u172'];
unset($aidlink);
} else {
// got admin activation and not
if ($this->adminActivation) {
$this->_completeMessage = $locale['u160'].$locale['u162'];
}
}
}
$this->data['new_password'] = $this->_getPasswordInput('user_password1');
if ($this->_completeMessage) {
addNotice("success", $this->_completeMessage, 'all');
}
return TRUE;
}
return FALSE;
}
/**
* Initialise empty fields
*
* @return array
*/
private function _setEmptyFields() {
$userStatus = $this->adminActivation == 1 ? 2 : 0;
/** Prepare initial variables for settings */
if ($this->_method == "validate_insert") {
// Compulsory Core Fields
return [
'user_id' => 0,
'user_hide_email' => $this->_userHideEmail,
'user_avatar' => '',
'user_posts' => 0,
'user_threads' => 0,
'user_joined' => time(),
'user_lastvisit' => 0,
'user_ip' => USER_IP,
'user_ip_type' => USER_IP_TYPE,
'user_rights' => '',
'user_groups' => '',
'user_level' => USER_LEVEL_MEMBER,
'user_status' => $userStatus,
'user_theme' => 'Default',
'user_language' => LANGUAGE,
'user_timezone' => fusion_get_settings('timeoffset'),
'user_reputation' => 0
];
} else {
return NULL;
}
}
/**
* Handle User Name Input and Validation
*/
private function _settUserName() {
$locale = fusion_get_locale();
$uban = explode(',', fusion_get_settings('user_name_ban'));
$this->_userName = "";
if (isset($_POST['user_name'])) {
$this->_userName = !empty($_POST['user_name']) ? form_sanitizer($_POST['user_name'], "", "user_name") : '';
$this->userData['user_name'] = !empty($this->userData['user_name']) ? $this->userData['user_name'] : '';
if ($this->_userName != $this->userData['user_name']) {
if (!preg_check("/^[-0-9A-Z_@\s]+$/i", $this->_userName)) {
// Check for invalid characters
\defender::stop();
\defender::setInputError('user_name');
\defender::setErrorText('user_name', $locale['u120']);
} else if (in_array($this->_userName, $uban)) {
// Check for contains username
\defender::stop();
\defender::setInputError('user_name');
\defender::setErrorText('user_name', $locale['u119']);
} else {
// Make sure the username is not used already
$name_active = dbcount("(user_id)", DB_USERS, "user_name='".$this->_userName."'");
$name_inactive = dbcount("(user_code)", DB_NEW_USERS, "user_name='".$this->_userName."'");
if ($name_active == 0 && $name_inactive == 0) {
$this->data['user_name'] = $this->_userName;
} else {
\defender::stop();
\defender::setInputError('user_name');
\defender::setErrorText('user_name', $locale['u121']);
}
}
} else {
if ($this->_method == 'validate_update') {
$this->data['user_name'] = $this->_userName;
}
}
}
}
/**
* Handle User Password Input and Validation
*/
private function _setPassword() {
$locale = fusion_get_locale();
if ($this->_method == 'validate_insert') {
$this->_newUserPassword = self::_getPasswordInput('user_password1');
$this->_newUserPassword2 = self::_getPasswordInput('user_password2');
if (!empty($this->_newUserPassword)) {
$passAuth = new PasswordAuth();
$passAuth->inputNewPassword = $this->_newUserPassword;
$passAuth->inputNewPassword2 = $this->_newUserPassword2;
$_isValidNewPassword = $passAuth->isValidNewPassword();
switch ($_isValidNewPassword) {
case '0':
// New password is valid
$this->_newUserPasswordHash = $passAuth->getNewHash();
$this->_newUserPasswordAlgo = $passAuth->getNewAlgo();
$this->_newUserPasswordSalt = $passAuth->getNewSalt();
$this->data['user_algo'] = $this->_newUserPasswordAlgo;
$this->data['user_salt'] = $this->_newUserPasswordSalt;
$this->data['user_password'] = $this->_newUserPasswordHash;
$this->_isValidCurrentPassword = 1;
if (!defined('ADMIN_PANEL') && !$this->skipCurrentPass) {
Authenticate::setUserCookie($this->userData['user_id'], $passAuth->getNewSalt(), $passAuth->getNewAlgo(), FALSE);
}
break;
case '1':
// New Password equal old password
\defender::stop();
\defender::setInputError('user_password2');
\defender::setInputError('user_password2');
\defender::setErrorText('user_password', $locale['u134'].$locale['u146'].$locale['u133']);
\defender::setErrorText('user_password2', $locale['u134'].$locale['u146'].$locale['u133']);
break;
case '2':
// The two new passwords are not identical
\defender::stop();
\defender::setInputError('user_password1');
\defender::setInputError('user_password2');
\defender::setErrorText('user_password1', $locale['u148']);
\defender::setErrorText('user_password2', $locale['u148']);
break;
case '3':
// New password contains invalid chars / symbols
\defender::stop();
\defender::setInputError('user_password1');
\defender::setErrorText('user_password1', $locale['u134'].$locale['u142']."
".$locale['u147']);
break;
}
} else {
\defender::stop();
\defender::setInputError('user_password1');
\defender::setErrorText('user_password1', $locale['u134'].$locale['u143a']);
}
} else if ($this->_method == 'validate_update') {
$this->_userPassword = self::_getPasswordInput('user_password');
$this->_newUserPassword = self::_getPasswordInput('user_password1');
$this->_newUserPassword2 = self::_getPasswordInput('user_password2');
if ($this->isAdminPanel or $this->_userPassword) {
/**
* Validation of Password
*/
$passAuth = new PasswordAuth();
$passAuth->inputPassword = $this->_userPassword;
$passAuth->inputNewPassword = $this->_newUserPassword;
$passAuth->inputNewPassword2 = $this->_newUserPassword2;
$passAuth->currentPasswordHash = $this->userData['user_password'];
$passAuth->currentAlgo = $this->userData['user_algo'];
$passAuth->currentSalt = $this->userData['user_salt'];
if ($this->isAdminPanel or $passAuth->isValidCurrentPassword()) {
// Just for validation purposes for example email change
$this->_isValidCurrentPassword = 1;
// Change new password
if (!empty($this->_newUserPassword)) {
$_isValidNewPassword = $passAuth->isValidNewPassword();
switch ($_isValidNewPassword) {
case '0':
// New password is valid
$this->_newUserPasswordHash = $passAuth->getNewHash();
$this->_newUserPasswordAlgo = $passAuth->getNewAlgo();
$this->_newUserPasswordSalt = $passAuth->getNewSalt();
$this->data['user_algo'] = $this->_newUserPasswordAlgo;
$this->data['user_salt'] = $this->_newUserPasswordSalt;
$this->data['user_password'] = $this->_newUserPasswordHash;
//if (!defined('ADMIN_PANEL') && !$this->skipCurrentPass) {
//Authenticate::setUserCookie($this->userData['user_id'], $passAuth->getNewSalt(), $passAuth->getNewAlgo(), FALSE);
//}
break;
case '1':
// New Password equal old password
\defender::stop();
\defender::setInputError('user_password');
\defender::setInputError('user_password1');
\defender::setErrorText('user_password', $locale['u134'].$locale['u146'].$locale['u133']);
\defender::setErrorText('user_password1', $locale['u134'].$locale['u146'].$locale['u133']);
break;
case '2':
// The two new passwords are not identical
\defender::stop();
\defender::setInputError('user_password1');
\defender::setInputError('user_password2');
\defender::setErrorText('user_password1', $locale['u148']);
\defender::setErrorText('user_password2', $locale['u148']);
break;
case '3':
// New password contains invalid chars / symbols
\defender::stop();
\defender::setInputError('user_password1');
\defender::setErrorText('user_password1', $locale['u134'].$locale['u142']."
".$locale['u147']);
break;
}
}
} else {
\defender::stop();
\defender::setInputError('user_password');
\defender::setErrorText('user_password', $locale['u149']);
}
}
}
}
private function _setAdminPassword() {
$locale = fusion_get_locale();
if ($this->_getPasswordInput("user_admin_password")) { // if submit current admin password
$this->_userAdminPassword = $this->_getPasswordInput("user_admin_password"); // var1
$this->_newUserAdminPassword = $this->_getPasswordInput("user_admin_password1"); // var2
$this->_newUserAdminPassword2 = $this->_getPasswordInput("user_admin_password2"); // var3
$adminpassAuth = new PasswordAuth();
if (!$this->userData['user_admin_password'] && !$this->userData['user_admin_salt']) {
// New Admin
$adminpassAuth->inputPassword = 'fake';
$adminpassAuth->inputNewPassword = $this->_userAdminPassword;
$adminpassAuth->inputNewPassword2 = $this->_newUserAdminPassword2;
$valid_current_password = TRUE;
} else {
// Old Admin changing password
$adminpassAuth->inputPassword = $this->_userAdminPassword; // var1
$adminpassAuth->inputNewPassword = $this->_newUserAdminPassword; // var2
$adminpassAuth->inputNewPassword2 = $this->_newUserAdminPassword2; // var3
$adminpassAuth->currentPasswordHash = $this->userData['user_admin_password'];
$adminpassAuth->currentAlgo = $this->userData['user_admin_algo'];
$adminpassAuth->currentSalt = $this->userData['user_admin_salt'];
$valid_current_password = $adminpassAuth->isValidCurrentPassword();
}
if ($valid_current_password) {
$this->_isValidCurrentAdminPassword = 1;
// authenticated. now do the integrity check
$_isValidNewPassword = $adminpassAuth->isValidNewPassword();
switch ($_isValidNewPassword) {
case '0':
// New password is valid
$new_admin_password = $adminpassAuth->getNewHash();
$new_admin_salt = $adminpassAuth->getNewSalt();
$new_admin_algo = $adminpassAuth->getNewAlgo();
$this->data['user_admin_algo'] = $new_admin_algo;
$this->data['user_admin_salt'] = $new_admin_salt;
$this->data['user_admin_password'] = $new_admin_password;
break;
case '1':
// new password is old password
\defender::stop();
\defender::setInputError('user_admin_password');
\defender::setInputError('user_admin_password1');
\defender::setErrorText('user_admin_password', $locale['u144'].$locale['u146'].$locale['u133']);
\defender::setErrorText('user_admin_password1', $locale['u144'].$locale['u146'].$locale['u133']);
break;
case '2':
// The two new passwords are not identical
\defender::stop();
\defender::setInputError('user_admin_password1');
\defender::setInputError('user_admin_password2');
\defender::setErrorText('user_admin_password1', $locale['u144'].$locale['u148a']);
\defender::setErrorText('user_admin_password2', $locale['u144'].$locale['u148a']);
break;
case '3':
// New password contains invalid chars / symbols
\defender::stop();
\defender::setInputError('user_admin_password1');
\defender::setErrorText('user_admin_password1', $locale['u144'].$locale['u142']."
".$locale['u147']);
break;
}
} else {
\defender::stop();
\defender::setInputError('user_admin_password');
\defender::setErrorText('user_admin_password', $locale['u149a']);
}
} else { // check db only - admin cannot save profile page without password
if (iADMIN) {
$require_valid_password = $this->userData['user_admin_password'] ? TRUE : FALSE;
if (!$require_valid_password) {
// 149 for admin
\defender::stop();
\defender::setInputError('user_admin_password');
\defender::setErrorText('user_admin_password', $locale['u149a']);
}
}
}
}
private function _getPasswordInput($field) {
return isset($_POST[$field]) && $_POST[$field] != "" ? $_POST[$field] : FALSE;
}
/**
* Handle User Email Input and Validation
*/
private function _setUserEmail() {
$locale = fusion_get_locale();
$settings = fusion_get_settings();
$this->data['user_hide_email'] = !empty($_POST['user_hide_email']) && $_POST['user_hide_email'] == 1 ? 1 : 0;
$this->_userEmail = isset($_POST['user_email']) ? form_sanitizer($_POST['user_email'], "", "user_email") : "";
$this->userData['user_email'] = !empty($this->userData['user_email']) ? $this->userData['user_email'] : '';
if ($this->_userEmail != $this->userData['user_email']) {
// override the requirements of password to change email address of a member in admin panel
if (defined('ADMIN_PANEL') && (iADMIN && checkrights('M'))) {
$this->_isValidCurrentPassword = TRUE; // changing an email in administration panel
} else if (!$this->registration) {
$this->verify_password();
}
// Require user password for email change
if ($this->_isValidCurrentPassword || $this->registration) {
// Require a valid email account
if (preg_check("/^[-0-9A-Z_\.]{1,50}@([-0-9A-Z_\.]+\.){1,50}([0-9A-Z]){2,6}$/i", $this->_userEmail)) {
if (dbcount("(blacklist_id)", DB_BLACKLIST,
":email like replace(if (blacklist_email like '%@%' or blacklist_email like '%\\%%', blacklist_email, concat('%@', blacklist_email)), '_', '\\_')",
[':email' => $this->_userEmail])) {
// this email blacklisted.
\defender::stop();
\defender::setInputError('user_email');
\defender::setErrorText('user_email', $locale['u124']);
} else {
$email_active = dbcount("(user_id)", DB_USERS, "user_email='".$this->_userEmail."'");
$email_inactive = dbcount("(user_code)", DB_NEW_USERS, "user_email='".$this->_userEmail."'");
if ($email_active == 0 && $email_inactive == 0) {
if ($this->verifyNewEmail && $settings['email_verification'] == 1 && !iSUPERADMIN) {
$this->_verifyNewEmail();
} else {
$this->data['user_email'] = $this->_userEmail;
}
} else {
// email taken
\defender::stop();
\defender::setInputError('user_email');
\defender::setErrorText('user_email', $locale['u125']);
}
}
} else {
// invalid email address
\defender::stop();
\defender::setInputError('user_email');
\defender::setErrorText('user_email', $locale['u123']); // once refresh, text lost.
}
} else {
// must have a valid password to change email
\defender::stop();
\defender::setInputError('user_email');
\defender::setErrorText('user_email', $locale['u156']);
}
}
}
/**
* To validate only when _setUserEmail is true
* Changing Email address
*/
private function verify_password() {
$locale = fusion_get_locale();
// Validation of password using user_password_verify field
$_userPassword = self::_getPasswordInput('user_password');
if ($_userPassword) {
/**
* Validation of Password
*/
$passAuth = new PasswordAuth();
$passAuth->inputPassword = $_userPassword;
$passAuth->currentAlgo = $this->userData['user_algo'];
$passAuth->currentSalt = $this->userData['user_salt'];
$passAuth->currentPasswordHash = $this->userData['user_password'];
if ($passAuth->isValidCurrentPassword()) {
$this->_isValidCurrentPassword = 1;
} else {
\defender::stop();
\defender::setInputError('user_password');
\defender::setErrorText('user_password', $locale['u149']);
}
} else {
\defender::stop();
\defender::setInputError('user_password');
\defender::setErrorText('user_password', $locale['u149']);
}
}
/**
* Handle new email verification procedures
*/
private function _verifyNewEmail() {
$settings = fusion_get_settings();
$userdata = fusion_get_userdata();
$locale = fusion_get_locale();
require_once INCLUDES."sendmail_include.php";
mt_srand((double)microtime() * 1000000);
$salt = "";
for ($i = 0; $i <= 10; $i++) {
$salt .= chr(rand(97, 122));
}
$user_code = md5($this->_userEmail.$salt);
$email_verify_link = $settings['siteurl']."edit_profile.php?code=".$user_code;
$mailbody = str_replace("[EMAIL_VERIFY_LINK]", $email_verify_link, $locale['u203']);
$mailbody = str_replace("[SITENAME]", $settings['sitename'], $mailbody);
$mailbody = str_replace("[SITEUSERNAME]", $settings['siteusername'], $mailbody);
$mailbody = str_replace("[USER_NAME]", $userdata['user_name'], $mailbody);
$mailSubject = str_replace("[SITENAME]", $settings['sitename'], $locale['u202']);
sendemail($this->_userName, $this->_userEmail, $settings['siteusername'], $settings['siteemail'], $mailSubject, $mailbody);
addNotice('warning', strtr($locale['u200'], ['(%s)' => $this->_userEmail]));
dbquery("DELETE FROM ".DB_EMAIL_VERIFY." WHERE user_id='".$this->userData['user_id']."'");
dbquery("INSERT INTO ".DB_EMAIL_VERIFY." (user_id, user_code, user_email, user_datestamp) VALUES('".$this->userData['user_id']."', '$user_code', '".$this->_userEmail."', '".time()."')");
}
// Get New Password Hash and Directly Set New Cookie if Authenticated
private function _setValidationError() {
$locale = fusion_get_locale();
$settings = fusion_get_settings();
$_CAPTCHA_IS_VALID = FALSE;
include INCLUDES."captchas/".$settings['captcha']."/captcha_check.php";
if ($_CAPTCHA_IS_VALID == FALSE) {
\defender::stop();
\defender::setInputError('user_captcha');
addNotice('danger', $locale['u194']);
}
}
/**
* Handle request for email verification
* Sends Verification code when you change email
* Sends Verification code when you register
*/
private function _setEmailVerification() {
$settings = fusion_get_settings();
$locale = fusion_get_locale();
require_once INCLUDES."sendmail_include.php";
$userCode = hash_hmac("sha1", PasswordAuth::getNewPassword(), $this->_userEmail);
$activationUrl = $settings['siteurl']."register.php?email=".$this->_userEmail."&code=".$userCode;
$message = str_replace("USER_NAME", $this->_userName, $locale['u152']);
$message = str_replace("SITENAME", $settings['sitename'], $message);
$message = str_replace("SITEUSERNAME", $settings['siteusername'], $message);
$message = str_replace("USER_PASSWORD", $this->_newUserPassword, $message);
$message = str_replace("ACTIVATION_LINK", $activationUrl, $message);
$subject = str_replace("[SITENAME]", $settings['sitename'], $locale['u151']);
if (!sendemail($this->_userName, $this->_userEmail, $settings['siteusername'], $settings['siteemail'], $subject, $message)) {
$message = strtr($locale['u154'], [
'[LINK]' => "",
'[/LINK]' => ""
]);
addNotice('warning', $locale['u153']."
".$message, 'all');
}
$userInfo = base64_encode(serialize($this->data));
if (\defender::safe()) {
dbquery("INSERT INTO ".DB_NEW_USERS."
(user_code, user_name, user_email, user_datestamp, user_info)
VALUES
('".$userCode."', '".$this->data['user_name']."', '".$this->data['user_email']."', '".TIME."', '".$userInfo."')
");
}
$this->_completeMessage = $locale['u150'];
}
/**
* Update User Fields
* @return bool
* @throws \Exception
*/
public function saveUpdate() {
$locale = fusion_get_locale();
$settings = fusion_get_settings();
$this->_method = "validate_update";
$this->_settUserName();
$this->_setPassword();
if (!defined('ADMIN_PANEL')) {
$this->_setAdminPassword();
}
$this->_setUserEmail();
if ($this->validation == 1) {
$this->_setValidationError();
}
$this->_setUserAvatar();
$this->_setUserReputation();
$quantum = new QuantumFields();
$quantum->setCategoryDb(DB_USER_FIELD_CATS);
$quantum->setFieldDb(DB_USER_FIELDS);
$quantum->setPluginFolder(INCLUDES."user_fields/");
$quantum->setPluginLocaleFolder(LOCALE.LOCALESET."user_fields/");
$quantum->load_fields();
$quantum->load_field_cats();
$quantum->setCallbackData($this->userData);
$_input = $quantum->return_fields_input(DB_USERS, 'user_id');
if (!empty($_input)) {
foreach ($_input as $input) {
$this->data += $input;
}
}
$this->data = $this->getData();
// hidden input tamper check
if (isset($_GET['section']) && $_GET['section'] > 1 && $this->userData['user_password'] !== $this->data['user_hash']) {
\defender::stop();
}
// check for password match
if (\defender::safe()) {
// Logs Username change
if ($this->_userName != $this->userData['user_name']) {
save_user_log($this->userData['user_id'], "user_name", $this->_userName, $this->userData['user_name']);
}
// Logs Email change
if ($this->_userEmail != $this->userData['user_email']) {
save_user_log($this->userData['user_id'], "user_email", $this->_userEmail, $this->userData['user_email']);
}
// Logs Field changes
$quantum->log_user_action(DB_USERS, "user_id");
// Update Table
dbquery_insert(DB_USERS, $this->data, 'update');
$this->_completeMessage = $locale['u163'];
if ($this->isAdminPanel && $this->_isValidCurrentPassword && $this->_newUserPassword && $this->_newUserPassword2) {
// inform user that password has changed. and tell him your new password
include INCLUDES."sendmail_include.php";
addNotice("success", str_replace("USER_NAME", $this->userData['user_name'], $locale['global_458']));
$input = [
"mailname" => $this->userData['user_name'],
"email" => $this->userData['user_email'],
"subject" => str_replace("[SITENAME]", $settings['sitename'], $locale['global_456']),
"message" => str_replace(
[
"[SITENAME]",
"[SITEUSERNAME]",
"USER_NAME",
"[PASSWORD]"
],
[
$settings['sitename'],
$settings['siteusername'],
$this->userData['user_name'],
$this->_newUserPassword,
],
$locale['global_457']
)
];
if (!sendemail($input['mailname'], $input['email'], $settings['siteusername'], $settings['siteemail'], $input['subject'],
$input['message'])
) {
addNotice('warning', str_replace("USER_NAME", $this->userData['user_name'], $locale['global_459']));
}
}
if (\defender::safe()) {
addNotice('success', $locale['u169']);
}
return TRUE;
}
return FALSE;
}
private function _setUserAvatar() {
if (isset($_POST['delAvatar'])) {
if ($this->userData['user_avatar'] != "" && file_exists(IMAGES."avatars/".$this->userData['user_avatar']) && is_file(IMAGES."avatars/".$this->userData['user_avatar'])) {
unlink(IMAGES."avatars/".$this->userData['user_avatar']);
}
$this->data['user_avatar'] = '';
}
if (isset($_FILES['user_avatar']) && $_FILES['user_avatar']['name']) { // uploaded avatar
if (!empty($_FILES['user_avatar']) && is_uploaded_file($_FILES['user_avatar']['tmp_name'])) {
$upload = form_sanitizer($_FILES['user_avatar'], '', 'user_avatar');
if (isset($upload['error']) && !$upload['error']) {
// ^ maybe use empty($upload['error']) also can but maybe low end php version has problem on empty.
$this->data['user_avatar'] = $upload['image_name'];
}
}
}
}
private function _setUserReputation() {
$this->data['user_reputation'] = !empty($_POST['user_reputation']) ? $_POST['user_reputation'] : 0;
}
public function setUserNameChange($value) {
$this->_userNameChange = $value;
}
public function verifyCode($value) {
$locale = fusion_get_locale();
$userdata = fusion_get_userdata();
if (!preg_check("/^[0-9a-z]{32}$/i", $value)) {
redirect(BASEDIR.'index.php');
}
$result = dbquery("SELECT * FROM ".DB_EMAIL_VERIFY." WHERE user_code=:usercode", [':usercode' => $value]);
if (dbrows($result)) {
$data = dbarray($result);
if ($data['user_id'] == $userdata['user_id']) {
if ($data['user_email'] != $userdata['user_email']) {
$result = dbquery("SELECT user_email FROM ".DB_USERS." WHERE user_email=:useremail", [':useremail' => $data['user_email']]);
if (dbrows($result) > 0) {
addNotice("danger", $locale['u164']."
\n".$locale['u121']);
} else {
$this->_completeMessage = $locale['u169'];
}
dbquery("UPDATE ".DB_USERS." SET user_email='".$data['user_email']."' WHERE user_id='".$data['user_id']."'");
dbquery("DELETE FROM ".DB_EMAIL_VERIFY." WHERE user_id='".$data['user_id']."'");
}
} else {
redirect(BASEDIR.'index.php');
}
} else {
redirect(BASEDIR.'index.php');
}
}
public function themeChanged() {
return $this->_themeChanged;
}
}