mirror of
https://github.com/e107inc/e107.git
synced 2025-01-16 20:28:28 +01:00
979 lines
27 KiB
PHP
979 lines
27 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2009 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
* User settings modify
|
|
*
|
|
* $Source: /cvs_backup/e107_0.8/usersettings.php,v $
|
|
* $Revision$
|
|
* $Date$
|
|
* $Author$
|
|
*
|
|
*/
|
|
/*
|
|
Notes:
|
|
Uses $udata initially, later curVal to hold current user data
|
|
Admin log events:
|
|
USET_01 - admin changed user data
|
|
*/
|
|
|
|
/*
|
|
if(preg_match('/^\/(.*?)\/(usersettings\.php|\/edit)(\?|\/)(\d+)$/i', $_SERVER['REQUEST_URI'], $_usersettings_matches))
|
|
{
|
|
$eplug_admin = TRUE;
|
|
}
|
|
*/
|
|
|
|
require_once ('class2.php');
|
|
|
|
// TODO - Remove all the adminEdit stuff.
|
|
|
|
/*
|
|
class usersetting_admin extends e_admin_dispatcher
|
|
{
|
|
|
|
protected $modes = array(
|
|
'main' => array(
|
|
'controller' => 'usersettings_admin_ui',
|
|
'path' => null,
|
|
'ui' => null,
|
|
'uipath' => null,
|
|
//'perm' => '0',
|
|
)
|
|
);
|
|
|
|
|
|
protected $adminMenu = array(
|
|
'main/list' => array('caption'=> LAN_MANAGE, 'perm' => '0', 'url' => '{e_ADMIN}users.php'),
|
|
'main/add' => array('caption'=> LAN_USER_QUICKADD, 'perm' => '4|U0|U1', 'url' => '{e_ADMIN}users.php'),
|
|
'main/prefs' => array('caption'=> LAN_OPTIONS, 'perm' => '4|U2', 'url' => '{e_ADMIN}users.php'),
|
|
'main/ranks' => array('caption'=> LAN_USER_RANKS, 'perm' => '4|U3', 'url' => '{e_ADMIN}users.php')
|
|
);
|
|
|
|
protected $adminMenuAliases = array(
|
|
'main/edit' => 'main/list',
|
|
'main/admin' => 'main/list',
|
|
'main/userclass'=> 'main/list',
|
|
'main/test' => 'main/list',
|
|
);
|
|
|
|
|
|
|
|
protected $menuTitle = 'users';
|
|
|
|
|
|
public function runObservers($run_header = true)
|
|
{
|
|
// Catch useraction
|
|
if (isset($_POST['updatesettings']))
|
|
{
|
|
|
|
}
|
|
|
|
return parent::runObservers($run_header);
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
class usersettings_admin_ui extends e_admin_ui
|
|
{
|
|
public function EditPage()
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
*/
|
|
|
|
include_lan(e_LANGUAGEDIR.e_LANGUAGE.'/lan_'.e_PAGE);
|
|
|
|
define("US_DEBUG",FALSE);
|
|
//define('US_DEBUG', false);
|
|
|
|
|
|
if (!USER)
|
|
{ // Must be logged in to change settings
|
|
header('location:'.e_BASE.'index.php');
|
|
exit();
|
|
}
|
|
|
|
if ((!ADMIN || !getperms("4")) && e_QUERY && e_QUERY != "update" )
|
|
{
|
|
header('location:'.e_BASE.'usersettings.php');
|
|
exit();
|
|
}
|
|
|
|
include_lan(e_LANGUAGEDIR.e_LANGUAGE.'/lan_user.php'); // Generic user-related language defines
|
|
include_lan(e_LANGUAGEDIR.e_LANGUAGE.'/lan_usersettings.php');
|
|
|
|
|
|
|
|
require_once (e_HANDLER.'ren_help.php');
|
|
require_once (e_HANDLER.'user_extended_class.php');
|
|
// require_once (e_HANDLER.'user_handler.php');
|
|
require_once(e_HANDLER.'validator_class.php');
|
|
$ue = new e107_user_extended;
|
|
|
|
$userMethods = e107::getUserSession();
|
|
|
|
require_once (e_HANDLER.'ren_help.php');
|
|
|
|
|
|
if(deftrue('BOOTSTRAP')===3)
|
|
{
|
|
$template = e107::getCoreTemplate('usersettings','', true, true); // always merge
|
|
|
|
$USERSETTINGS_MESSAGE = "{MESSAGE}";
|
|
$USERSETTINGS_MESSAGE_CAPTION = LAN_OK;
|
|
$USERSETTINGS_EDIT_CAPTION = LAN_USET_39; // 'Update User Settings'
|
|
$USERSETTINGS_EDIT = $template['edit'];
|
|
$usersettings_shortcodes = e107::getScBatch('usersettings');
|
|
|
|
$usersettings_shortcodes->wrapper('usersettings/edit');
|
|
}
|
|
else
|
|
{
|
|
include_once (e107::coreTemplatePath('usersettings')); //correct way to load a core template.
|
|
e107::scStyle($sc_style);
|
|
$usersettings_shortcodes = e107::getScBatch('usersettings');
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
e107::js('footer-inline',"
|
|
function addtext_us(sc)
|
|
{
|
|
document.getElementById('dataform').image.value = sc;
|
|
}
|
|
");
|
|
|
|
|
|
|
|
|
|
$photo_to_delete = '';
|
|
$avatar_to_delete = '';
|
|
$ue_fields = '';
|
|
$promptPassword = false;
|
|
$error = FALSE;
|
|
$extraErrors = array();
|
|
$eufVals = array();
|
|
$savePassword = '';
|
|
|
|
|
|
$inp = USERID; // Initially assume that user is modifying their own data.
|
|
$_uid = false; // FALSE if user modifying their own data; otherwise ID of data being modified
|
|
$adminEdit = FALSE; // FALSE if editing own data. TRUE if admin edit
|
|
|
|
if(is_numeric(e_QUERY))
|
|
{ // Trying to edit specific user record
|
|
if (ADMIN)
|
|
{ // Admin edit of specific record
|
|
/*
|
|
$_usersettings_matches = Array
|
|
(
|
|
[0] => /e107/usersettings.php?# OR /e107/edit/user/#
|
|
[1] => e107
|
|
[2] => usersettings.php OR edit/user
|
|
[3] => ? OR /
|
|
[4] => #
|
|
)
|
|
*/
|
|
$inp = intval(e_QUERY);
|
|
|
|
$usersettings_form_action = strstr('?', $_usersettings_matches[3]) ? e_SELF.'?'.e_QUERY : e_SELF;
|
|
|
|
$_uid = $inp;
|
|
$info = e107::user($inp);
|
|
//Only site admin is able to change setting for other admins
|
|
if(!is_array($info) || ($info['user_admin'] == 1 && (!defined('ADMINPERMS') || ADMINPERMS !== '0')) || ((!defined('ADMINPERMS') || ADMINPERMS !== '0') && !getperms('4')))
|
|
{
|
|
header('location:'.e_BASE.'index.php');
|
|
exit();
|
|
}
|
|
$adminEdit = TRUE; // Flag to indicate admin edit
|
|
}
|
|
else
|
|
{
|
|
//Non admin attempting to edit another user's ID
|
|
header('location:'.e_BASE.'index.php');
|
|
exit();
|
|
}
|
|
|
|
}
|
|
// TODO - Remove all the adminEdit stuff.
|
|
/*
|
|
|
|
if($adminEdit) // try to stay in Admin when admin is editing.
|
|
{
|
|
$mes = e107::getMessage();
|
|
$ADMIN_USERSETTINGS_EDIT = $mes->render(). "
|
|
<table class='table adminform'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
|
|
{USERNAME}
|
|
{LOGINNAME}
|
|
|
|
<tr>
|
|
<td>".LAN_USER_60.req(!$pref['disable_emailcheck'])."</td>
|
|
<td>
|
|
{EMAIL}
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_USER_63.req($pref['signup_option_realname'])."</td>
|
|
<td>
|
|
{REALNAME}
|
|
</td>
|
|
</tr>
|
|
|
|
{CUSTOMTITLE}
|
|
|
|
{PASSWORD1}
|
|
{PASSWORD_LEN}
|
|
{PASSWORD2}
|
|
|
|
|
|
<tr>
|
|
<td>".LAN_USER_83."</td>
|
|
<td><span class='defaulttext'>
|
|
{HIDEEMAIL=radio}
|
|
</span>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_USER_07.req($pref['signup_option_image'])."</td>
|
|
<td>
|
|
{AVATAR_REMOTE}
|
|
</td>
|
|
</tr>
|
|
|
|
{AVATAR_UPLOAD}
|
|
{PHOTO_UPLOAD}
|
|
|
|
{USERCLASSES}
|
|
{USEREXTENDED_ALL}
|
|
|
|
|
|
{SIGNATURE=cols=58&rows=4}
|
|
{SIGNATURE_HELP}
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".e107::getForm()->admin_button('updatesettings',LAN_UPDATE,'update')."
|
|
</div>
|
|
|
|
";
|
|
|
|
|
|
$USERSETTINGS_EDIT = $ADMIN_USERSETTINGS_EDIT;
|
|
include_lan(e_LANGUAGEDIR.e_LANGUAGE."/admin/lan_admin.php");
|
|
new usersetting_admin();
|
|
require_once (e_ADMIN."auth.php");
|
|
//e107::getAdminUI()->runPage();
|
|
}
|
|
*/
|
|
// else
|
|
{
|
|
require_once (HEADERF);
|
|
}
|
|
|
|
|
|
// Save user settings (changes only)
|
|
//-----------------------------------
|
|
|
|
if (isset($_POST['updatesettings']) || isset($_POST['SaveValidatedInfo']))
|
|
{
|
|
// $udata = e107::user($inp); //@deprecated // Get all the existing user data, including any extended fields
|
|
|
|
$udata = e107::user($inp); // Get all the existing user data, including any extended fields
|
|
$udata['user_classlist'] = $userMethods->addCommonClasses($udata, FALSE);
|
|
}
|
|
|
|
|
|
if (isset($_POST['updatesettings']))
|
|
{
|
|
if (!vartrue($pref['auth_method']))
|
|
{
|
|
$pref['auth_method'] = 'e107';
|
|
}
|
|
|
|
if ($pref['auth_method'] != 'e107')
|
|
{
|
|
$_POST['password1'] = '';
|
|
$_POST['password2'] = '';
|
|
}
|
|
|
|
// Uploaded avatar and/or photo
|
|
if ($file_userfile['error'] != 4)
|
|
{
|
|
require_once (e_HANDLER.'upload_handler.php');
|
|
require_once (e_HANDLER.'resize_handler.php');
|
|
|
|
if ($uploaded = process_uploaded_files(e_AVATAR_UPLOAD, 'prefix+ap_'.$tp->leadingZeros($udata['user_id'],7).'_', array('overwrite' => TRUE, 'file_mask'=>'jpg,png,gif', 'max_file_count' => 2)))
|
|
{
|
|
foreach ($uploaded as $upload)
|
|
{
|
|
if ($upload['name'] && ($upload['index'] == 'avatar') && $pref['avatar_upload'])
|
|
{
|
|
// avatar uploaded - give it a reference which identifies it as server-stored
|
|
// Vetting routines will do resizing and so on
|
|
$_POST['image'] = '-upload-'.$upload['name'];
|
|
}
|
|
elseif ($upload['name'] && ($upload['index'] == 'photo') && $pref['photo_upload'])
|
|
{
|
|
// photograph uploaded
|
|
$_POST['user_sess'] = '-upload-'.$upload['name'];
|
|
}
|
|
elseif (isset($upload['error']) && isset($upload['message']))
|
|
{
|
|
$extraErrors[] = $upload['message'];
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
// Now validate everything - just check everything that's been entered
|
|
$allData = validatorClass::validateFields($_POST,$userMethods->userVettingInfo, TRUE); // Do basic validation
|
|
validatorClass::dbValidateArray($allData, $userMethods->userVettingInfo, 'user', $inp); // Do basic DB-related checks
|
|
$userMethods->userValidation($allData); // Do user-specific DB checks
|
|
|
|
$savePassword = '';
|
|
|
|
if (($_POST['password1'] != '') || ($_POST['password2'] != ''))
|
|
{ // Need to validate new password here
|
|
if (!isset($allData['errors']['user_password']))
|
|
{ // No errors in password yet - may be valid
|
|
$savePassword = $allData['data']['user_password'];
|
|
unset($allData['data']['user_password']); // Delete the password value in the output array
|
|
}
|
|
}
|
|
else
|
|
{
|
|
unset($allData['errors']['user_password']); // Delete the error which an empty password field generates
|
|
}
|
|
|
|
unset($_POST['password1']);
|
|
unset($_POST['password2']);
|
|
|
|
|
|
$changedUserData = validatorClass::findChanges($allData['data'], $udata,FALSE);
|
|
|
|
|
|
e107::getMessage()->addDebug("<h5>Existing User Info</h5>".print_a($udata,true));
|
|
e107::getMessage()->addDebug('<h5>$allData</h5>'.print_a($allData['data'],true));
|
|
|
|
e107::getMessage()->addDebug("<h5>Posted Changes</h5>".print_a($changedUserData,true));
|
|
|
|
// Login Name checks - only admin can change login name
|
|
if (isset($changedUserData['user_loginname']))
|
|
{
|
|
if (ADMIN && getperms('4'))
|
|
{
|
|
if (!check_class($pref['displayname_class'], $udata['user_classlist'], $adminEdit))
|
|
{ // Display name and login name must be the same
|
|
$changedUserData['user_name'] = $changedUserData['user_loginname'];
|
|
}
|
|
}
|
|
else
|
|
{
|
|
unset($changedUserData['user_loginname']); // Just doing this is probably being kind!
|
|
$alldata['errors']['user_loginname'] = ERR_GENERIC;
|
|
$alldata['errortext']['user_loginname'] = LAN_USER_85;
|
|
}
|
|
}
|
|
|
|
|
|
// See if user just wants to delete existing photo
|
|
if (isset($_POST['user_delete_photo']))
|
|
{
|
|
$photo_to_delete = $udata['user_sess'];
|
|
$changedUserData['user_sess'] = '';
|
|
}
|
|
|
|
|
|
|
|
if ($udata['user_image'] && !isset($changedUserData['user_image']))
|
|
{
|
|
// $changedUserData['user_image'] = ''; // FIXME Deletes the user's image when no changes made.
|
|
$avatar_to_delete = str_replace('-upload-', '', $udata['user_image']);
|
|
}
|
|
|
|
// Validate Extended User Fields.
|
|
$changedEUFData = array();
|
|
if (isset($_POST['ue']))
|
|
{
|
|
$eufVals = $ue->userExtendedValidateAll($_POST['ue'], varset($_POST['hide'],TRUE)); // Validate the extended user fields
|
|
$changedEUFData['data'] = validatorClass::findChanges($eufVals['data'], $udata,FALSE);
|
|
}
|
|
|
|
|
|
// Determine whether we have an error
|
|
$error = ((isset($allData['errors']) && count($allData['errors'])) || (isset($eufVals['errors']) && count($eufVals['errors'])) || count($extraErrors));
|
|
|
|
|
|
// Update Userclass - only if its the user changing their own data (admins can do it another way)
|
|
if (isset($allData['data']['user_class']))
|
|
{
|
|
unset($changedUserData['user_class']); // We always recalculate this
|
|
if (FALSE === $adminEdit) // Make sure admin can't edit another's user classes
|
|
{
|
|
|
|
$e_userclass = e107::getUserClass();
|
|
$ucList = $e_userclass->get_editable_classes(USERCLASS_LIST,TRUE); // List of classes which this user can edit
|
|
if (count($ucList))
|
|
{
|
|
$nid = $e_userclass->mergeClassLists($udata['user_class'], $ucList, $allData['data']['user_class'], TRUE);
|
|
$nid = $e_userclass->stripFixedClasses($nid);
|
|
$nid = implode(',',$nid);
|
|
// echo "Userclass data - new: {$nid}, old: {$udata['user_baseclasslist']}, editable: ".implode(',',$ucList).", entered: {$allData['data']['user_class']}<br />";
|
|
if ($nid != $udata['user_baseclasslist'])
|
|
{
|
|
if (US_DEBUG)
|
|
{
|
|
$admin_log->e_log_event(10, debug_backtrace(), "DEBUG", "Usersettings test", "Write back classes; old list: {$udata['user_class']}; new list: ".$nid, false, LOG_TO_ROLLING);
|
|
}
|
|
$changedUserData['user_class'] = $nid;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
e107::getMessage()->addDebug("<h4>Processed Posted Changes</h4>".print_a($changedUserData,true));
|
|
|
|
// All key fields validated here
|
|
// -----------------------------
|
|
// $inp - UID of user whose data is being changed (may not be the currently logged in user)
|
|
$inp = intval($inp);
|
|
if (!$error && count($changedUserData) || count($changedEUFData))
|
|
{
|
|
$_POST['user_id'] = $inp;
|
|
$ret =e107::getEvent()->trigger('preuserset', $_POST);
|
|
|
|
if ($ret == '')
|
|
{
|
|
|
|
// Only admins can update login name - do this just in case one of the event triggers has mucked it about
|
|
if (!(ADMIN && getperms('4')))
|
|
{
|
|
unset($changedUserData['user_loginname']);
|
|
}
|
|
}
|
|
else
|
|
{ // Invalid data - from hooked in trigger event
|
|
$message = "<div style='text-align:center'>".$ret."</div>";
|
|
$caption = LAN_OK;
|
|
$error = TRUE;
|
|
}
|
|
}
|
|
} // End - update setttings
|
|
elseif (isset($_POST['SaveValidatedInfo']))
|
|
{ // Next bit only valid if user editing their own data
|
|
if (!$adminEdit && !empty($_POST['updated_data']) && !empty($_POST['currentpassword']) && !empty($_POST['updated_key']))
|
|
{ // Got some data confirmed with password entry
|
|
$new_data = base64_decode($_POST['updated_data']);
|
|
if (md5($new_data) != $_POST['updated_key'])
|
|
{ // Should only happen if someone's fooling around
|
|
echo LAN_USET_42.'<br />';
|
|
exit();
|
|
}
|
|
|
|
if (isset($_POST['updated_extended']))
|
|
{
|
|
$new_extended = base64_decode($_POST['updated_extended']);
|
|
if (md5($new_extended) != $_POST['extended_key'])
|
|
{ // Should only happen if someone's fooling around
|
|
echo LAN_USET_42.'<br />';
|
|
exit();
|
|
}
|
|
}
|
|
|
|
if ($userMethods->CheckPassword($_POST['currentpassword'], $udata['user_loginname'], $udata['user_password']) === false) // Use old data to validate
|
|
|
|
{ // Invalid password
|
|
echo "<br />".LAN_USET_22."<br />";
|
|
if(!$adminEdit)
|
|
{
|
|
require_once (FOOTERF);
|
|
}
|
|
else
|
|
{
|
|
require_once(e_ADMIN."footer.php");
|
|
}
|
|
exit();
|
|
}
|
|
$changedUserData = unserialize($new_data);
|
|
$savePassword = $_POST['currentpassword'];
|
|
if (!empty($new_extended)) $changedEUFData = unserialize($new_extended);
|
|
unset($new_data);
|
|
unset($new_extended);
|
|
if (isset($changedUserData['user_sess']))
|
|
{
|
|
$photo_to_delete = $udata['user_sess'];
|
|
}
|
|
if (isset($changedUserData['user_image']))
|
|
{
|
|
$avatar_to_delete = $udata['user_image'];
|
|
}
|
|
}
|
|
}
|
|
unset($_POST['updatesettings']);
|
|
unset($_POST['SaveValidatedInfo']);
|
|
|
|
|
|
// At this point we know the error status.
|
|
// $changedUserData has an array of core changed data, except password, which is in $savePassword if changed (or entered as confirmation).
|
|
// $eufData has extended user field data
|
|
// $changedEUFData has any changes in extended user field data
|
|
$dataToSave = !$error && (isset($changedUserData) && count($changedUserData)) || (isset($changedEUFData['data']) && count($changedEUFData['data'])) || $savePassword;
|
|
|
|
if ($dataToSave)
|
|
{
|
|
// Sort out password hashes
|
|
if ($savePassword)
|
|
{
|
|
$loginname = $changedUserData['user_loginname'] ? $changedUserData['user_loginname'] : $udata['user_loginname'];
|
|
$email = (isset($changedUserData['user_email']) && $changedUserData['user_email']) ? $changedUserData['user_email'] : $udata['user_email'];
|
|
$changedUserData['user_password'] = $sql->escape($userMethods->HashPassword($savePassword, $loginname), false);
|
|
if (varset($pref['allowEmailLogin'], FALSE))
|
|
{
|
|
$user_prefs = e107::getArrayStorage()->unserialize($udata['user_prefs']);
|
|
$user_prefs['email_password'] = $userMethods->HashPassword($savePassword, $email);
|
|
$changedUserData['user_prefs'] = e107::getArrayStorage()->serialize($user_prefs);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if ((isset($changedUserData['user_loginname']) && $userMethods->isPasswordRequired('user_loginname'))
|
|
|| (isset($changedUserData['user_email']) && $userMethods->isPasswordRequired('user_email')))
|
|
{
|
|
if ($_uid && ADMIN)
|
|
{ // Admin is changing it
|
|
$error = LAN_USET_20;
|
|
}
|
|
else
|
|
{ // User is changing their own info
|
|
$promptPassword = true;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($dataToSave && !$promptPassword)
|
|
{
|
|
$inp = intval($inp);
|
|
$message = LAN_USET_41;
|
|
|
|
// We can update the basic user record now - can just update fields from $changedUserData
|
|
if (US_DEBUG) { $admin_log->e_log_event(10, debug_backtrace(), "DEBUG", "Usersettings test", "Changed data:<br /> ".var_export($changedUserData, true), false, LOG_TO_ROLLING); }
|
|
if (isset($changedUserData) && count($changedUserData))
|
|
{
|
|
$changedData['data'] = $changedUserData;
|
|
$changedData['WHERE'] = 'user_id='.$inp;
|
|
validatorClass::addFieldTypes($userMethods->userVettingInfo,$changedData);
|
|
|
|
// print_a($changedData);
|
|
if (FALSE === $sql->db_Update('user', $changedData))
|
|
{
|
|
$message .= '<br />'.LAN_USET_43;
|
|
}
|
|
else
|
|
{
|
|
if (isset($changedUserData['user_password']) && !$adminEdit)
|
|
{
|
|
// echo "Make new cookie<br />";
|
|
$userMethods->makeUserCookie(array('user_id' => $udata['user_id'],'user_password' => $changedUserData['user_password']), FALSE); // Can't handle autologin ATM
|
|
}
|
|
}
|
|
}
|
|
|
|
// Save extended field values
|
|
if (isset($changedEUFData['data']) && count($changedEUFData['data']))
|
|
{
|
|
$ue->addFieldTypes($changedEUFData); // Add in the data types for storage
|
|
$changedEUFData['WHERE'] = '`user_extended_id` = '.$inp;
|
|
|
|
//print_a($changedEUFData);
|
|
if (false === $sql->retrieve('user_extended', 'user_extended_id', 'user_extended_id='.$inp))
|
|
{
|
|
// ***** Next line creates a record which presumably should be there anyway, so could generate an error if no test first
|
|
$sql->db_Select_gen("INSERT INTO #user_extended (user_extended_id, user_hidden_fields) values ('".$inp."', '')");
|
|
//print_a('New extended fields added: '.$inp.'<br />');
|
|
}
|
|
if (false === $sql->db_Update('user_extended', $changedEUFData))
|
|
{
|
|
$message .= '<br />Error updating EUF';
|
|
}
|
|
}
|
|
|
|
// Now see if we need to log anything. First check the options and class membership
|
|
// (Normally we would leave logging decision to the log class. But this one's a bit more complicated)
|
|
$user_logging_opts = e107::getConfig()->get('user_audit_opts');
|
|
$do_log = array();
|
|
$log_action = '';
|
|
if ($_uid)
|
|
{ // Its an admin changing someone elses data - make an admin log entry here
|
|
e107::getLog()->add('USET_01', "UID: {$udata['user_id']}. UName: {$udata['user_name']}", E_LOG_INFORMATIVE);
|
|
// Check against the class of the target user, not the admin!
|
|
if (!check_class(varset($pref['user_audit_class'], ''), $udata['user_class'])) { $user_logging_opts = array(); }
|
|
}
|
|
else
|
|
{
|
|
if (!check_class(varset($pref['user_audit_class'], ''))) { $user_logging_opts = array(); }
|
|
}
|
|
|
|
$triggerData = array();
|
|
if (count($changedUserData))
|
|
{
|
|
$triggerData = $changedUserData; // Create record for changed user data trigger
|
|
$triggerData['user_id'] = $udata['user_id'];
|
|
$triggerData['_CHANGED_BY_UID'] = USERID; // May be admin changing data
|
|
$triggerData['_CHANGED_BY_UNAME'] = USERNAME;
|
|
if (!isset($triggerData['user_name'])) { $triggerData['user_name'] = $udata['user_name']; }
|
|
}
|
|
|
|
// Now log changes if required
|
|
if (count($user_logging_opts))
|
|
{
|
|
// Start with any specific fields we're changing
|
|
if (isset($changedUserData['user_name']))
|
|
{
|
|
if (isset($user_logging_opts[USER_AUDIT_NEW_DN]))
|
|
{
|
|
$do_log['user_name'] = $changedUserData['user_name'];
|
|
$log_action = USER_AUDIT_NEW_DN;
|
|
}
|
|
unset($changedUserData['user_name']);
|
|
}
|
|
|
|
if (isset($changedUserData['user_password']))
|
|
{
|
|
if (isset($user_logging_opts[USER_AUDIT_NEW_PW]))
|
|
{ // Password has already been changed to a hashed value, so OK to leave the data
|
|
$do_log['user_password'] = $changedUserData['user_password'];
|
|
$log_action = USER_AUDIT_NEW_PW;
|
|
}
|
|
unset($changedUserData['user_password']);
|
|
}
|
|
|
|
if (isset($changedUserData['user_email']))
|
|
{
|
|
if (isset($user_logging_opts[USER_AUDIT_NEW_EML]))
|
|
{
|
|
$do_log['user_email'] = $changedUserData['user_email'];
|
|
$log_action = USER_AUDIT_NEW_EML;
|
|
}
|
|
unset($changedUserData['user_email']);
|
|
}
|
|
|
|
if (count($changedUserData) && isset($user_logging_opts[USER_AUDIT_NEW_SET]))
|
|
{
|
|
$do_log = array_merge($do_log, $changedUserData);
|
|
$log_action = USER_AUDIT_NEW_SET;
|
|
}
|
|
if (count($do_log))
|
|
{ // Got some changes to audit
|
|
// echo "Adding to audit log<br />";
|
|
if ($_uid)
|
|
{
|
|
$log_action = USER_AUDIT_ADMIN; // If an admin did the mod, different heading
|
|
// Embed a message saying who changed the data
|
|
$changedUserData['message'] = str_replace(array('--ID--', '--LOGNAME--'), array(USERID, USERNAME), LAN_USET_18);
|
|
$admin_log->user_audit($log_action, $do_log, $udata['user_id'], $udata['user_loginname']);
|
|
}
|
|
else
|
|
{
|
|
if (count($do_log) > 1) { $log_action = USER_AUDIT_NEW_SET; } // Log multiple entries to one record
|
|
$admin_log->user_audit($log_action, $do_log);
|
|
}
|
|
}
|
|
} // End of audit logging
|
|
|
|
|
|
// Now tidy up
|
|
if ($photo_to_delete)
|
|
{ // Photo may be a flat file, or in the database
|
|
delete_file($photo_to_delete);
|
|
}
|
|
if ($avatar_to_delete)
|
|
{ // Avatar may be a flat file, or in the database
|
|
delete_file($avatar_to_delete);
|
|
}
|
|
|
|
// If user has changed display name, update the record in the online table
|
|
if (isset($changedUserData['user_name']) && !$_uid)
|
|
{
|
|
$sql->db_Update('online', "online_user_id = '".USERID.".".$changedUserData['user_name']."' WHERE online_user_id = '".USERID.".".USERNAME."'");
|
|
}
|
|
|
|
|
|
|
|
|
|
e107::getEvent()->trigger('postuserset', $_POST);
|
|
if (count($triggerData))
|
|
{
|
|
e107::getEvent()->trigger('userdatachanged', $triggerData);
|
|
}
|
|
|
|
if (e_QUERY == 'update')
|
|
{
|
|
header('Location: index.php');
|
|
}
|
|
|
|
if($adminEdit && $message)
|
|
{
|
|
$mes->addSuccess($message);
|
|
}
|
|
|
|
|
|
if(isset($USERSETTINGS_MESSAGE))
|
|
{
|
|
$message = str_replace("{MESSAGE}",$message,$USERSETTINGS_MESSAGE);
|
|
}
|
|
elseif(!deftrue('BOOTSTRAP')) // backwards compatible
|
|
{
|
|
$message = "<div style='text-align:center'>".$message.'</div>';
|
|
|
|
}
|
|
|
|
$caption = (isset($USERSETTINGS_MESSAGE_CAPTION)) ? $USERSETTINGS_MESSAGE_CAPTION : LAN_OK;
|
|
|
|
} // End - if (!$error)...
|
|
|
|
|
|
if (!$error && !$promptPassword)
|
|
{
|
|
if(isset($_POST) && vartrue($changedUserData['user_name']))
|
|
{
|
|
$redirect = e107::getRedirect();
|
|
$url = e107::getUrl();
|
|
$to = $_uid ? $url->create('user/profile/edit', array('id' => $_uid, 'name' => $changedUserData['user_name'])) : $url->create('user/myprofile/edit');
|
|
if($message) e107::getMessage()->addSuccess($message, 'default', true);
|
|
$redirect->redirect($to);
|
|
}
|
|
unset($_POST);
|
|
}
|
|
|
|
|
|
if ($error)
|
|
{
|
|
// require_once (e_HANDLER.'message_handler.php');
|
|
$temp = array();
|
|
if (count($extraErrors))
|
|
{
|
|
$temp[] = implode('<br />', $extraErrors);
|
|
}
|
|
if (count($allData['errors']))
|
|
{
|
|
$temp[] = validatorClass::makeErrorList($allData,'USER_ERR_','%n - %x - %t: %v', '<br />', $userMethods->userVettingInfo);
|
|
}
|
|
if (vartrue($eufVals['errors']))
|
|
{
|
|
$temp[] = '<br />'.validatorClass::makeErrorList($eufVals,'USER_ERR_','%n - %x - %t: %v', '<br />', NULL);
|
|
}
|
|
// message_handler('P_ALERT', implode('<br />', $temp));
|
|
|
|
$errorMsg = implode('<br />', $temp);
|
|
|
|
if(deftrue('BOOTSTRAP'))
|
|
{
|
|
echo e107::getMessage()->addError($errorMsg)->render();
|
|
}
|
|
else
|
|
{
|
|
$ns->tablerender($caption, $message);
|
|
}
|
|
|
|
|
|
// $adref = $_POST['adminreturn'];
|
|
}
|
|
|
|
|
|
// --- User data has been updated here if appropriate ---
|
|
$testSessionMessage = e107::getMessage()->get(E_MESSAGE_SUCCESS, 'default', true); // only success in the session
|
|
if($testSessionMessage) $message = implode('<br />', $testSessionMessage); // we got raw message - array
|
|
|
|
if (isset($message))
|
|
{
|
|
if(deftrue('BOOTSTRAP'))
|
|
{
|
|
echo e107::getMessage()->addInfo($message)->render();
|
|
}
|
|
else
|
|
{
|
|
$ns->tablerender($caption, $message);
|
|
}
|
|
}
|
|
|
|
|
|
$uuid = ($_uid ? $_uid : USERID); // If $_uid is set, its an admin changing another user's data
|
|
|
|
|
|
if ($promptPassword)
|
|
{ // User has to enter password to validate data
|
|
$updated_data = serialize($changedUserData);
|
|
$validation_key = md5($updated_data);
|
|
$updated_data = base64_encode($updated_data);
|
|
$updated_extended = serialize($changedEUFData);
|
|
$extended_key = md5($updated_extended);
|
|
$updated_extended = base64_encode($updated_extended);
|
|
$text = "<form method='post' action='".e_SELF.(e_QUERY ? "?".e_QUERY : '')."'>
|
|
<table><tr><td style='text-align:center'>";
|
|
foreach ($_POST as $k => $v)
|
|
{
|
|
if (is_array($v))
|
|
{
|
|
foreach ($v as $sk => $sv)
|
|
{
|
|
$text .= "<input type='hidden' name='{$k}[{$sk}]' value='{$sv}' />\n";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$text .= "<input type='hidden' name='{$k}' value='{$v}' />\n";
|
|
}
|
|
}
|
|
$text .= LAN_USET_21."</td></tr><tr><td> </td></tr>
|
|
<tr><td style='text-align:center'><input type='password' name='currentpassword' value='' size='30' />";
|
|
$text .= "<input type='hidden' name='updated_data' value='{$updated_data}' /><input type='hidden' name='updated_key' value='{$validation_key}' />
|
|
<input type='hidden' name='updated_extended' value='{$updated_extended}' /><input type='hidden' name='extended_key' value='{$extended_key}' />
|
|
</td></tr>
|
|
<tr><td> </td></tr>
|
|
<tr><td style='text-align:center'><input type='submit' name='SaveValidatedInfo' value='".LAN_ENTER."' /></td></tr>
|
|
</table>
|
|
</form>";
|
|
$ns->tablerender(LAN_USET_39, $text);
|
|
if(!$adminEdit)
|
|
{
|
|
require_once (FOOTERF);
|
|
}
|
|
else
|
|
{
|
|
require_once(e_ADMIN."footer.php");
|
|
}
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------
|
|
// Re-read the user data into curVal (ready for display)
|
|
//--------------------------------------------------------
|
|
|
|
$qry = "
|
|
SELECT u.*, ue.* FROM #user AS u
|
|
LEFT JOIN #user_extended AS ue ON ue.user_extended_id = u.user_id
|
|
WHERE u.user_id=".intval($uuid);
|
|
|
|
$sql->db_Select_gen($qry);
|
|
$curVal=$sql->db_Fetch(MYSQL_ASSOC);
|
|
$curVal['user_class'] = varset($changedUserData['user_class'], $curVal['user_class']);
|
|
$curVal['userclass_list'] = $userMethods->addCommonClasses($curVal, FALSE);
|
|
|
|
if (vartrue($_POST))
|
|
{ // Fix for all the values being lost when there was an error in a field - restore from the latest $_POST values
|
|
// (Password fields have intentionally been cleared). If no error, there's an unset($_POST) to disable this block
|
|
foreach ($_POST as $key => $val)
|
|
{
|
|
if ($key != 'class') { $curVal['user_'.$key] = $tp->post_toForm($val); }
|
|
}
|
|
foreach ($_POST['ue'] as $key => $val)
|
|
{
|
|
$curVal[$key] = $tp->post_toForm($val);
|
|
}
|
|
}
|
|
|
|
//require_once (e_HANDLER."form_handler.php");
|
|
//$rs = new form;
|
|
|
|
$text = '<form method="post" action="'.$usersettings_form_action.'" id="dataform" class="form-horizontal" role="form" enctype="multipart/form-data">';
|
|
|
|
//$text = (is_numeric($_uid) ? $rs->form_open("post", e_SELF."?".e_QUERY, "dataform", "", " class='form-horizontal' role='form' enctype='multipart/form-data'") : $rs->form_open("post", e_SELF, "dataform", "", " class='form-horizontal' role='form' enctype='multipart/form-data'"));
|
|
|
|
if (e_QUERY == "update")
|
|
{
|
|
$text .= "<div class='fborder' style='text-align:center'><br />".str_replace("*", "<span class='required'>*</span>", LAN_USET_9)."<br />".LAN_USET_10."<br /><br /></div>";
|
|
}
|
|
|
|
// e107::scStyle($sc_style);
|
|
e107::getScBatch('usersettings')->setVars($curVal);
|
|
|
|
$text .= $tp->parseTemplate($USERSETTINGS_EDIT, true, $usersettings_shortcodes); //ParseSC must be set to true so that custom plugin -shortcodes can be utilized.
|
|
|
|
|
|
$text .= "<div><input type='hidden' name='_uid' value='{$uuid}' /></div>
|
|
</form>
|
|
";
|
|
|
|
$caption = (isset($USERSETTINGS_EDIT_CAPTION)) ? $USERSETTINGS_EDIT_CAPTION : LAN_USET_39; // 'Update User Settings'
|
|
|
|
$ns->tablerender($caption, $text);
|
|
|
|
if(!$adminEdit)
|
|
{
|
|
require_once (FOOTERF);
|
|
}
|
|
else
|
|
{
|
|
require_once(e_ADMIN."footer.php");
|
|
}
|
|
|
|
|
|
|
|
|
|
// If a field is required, returns a red asterisk
|
|
function req($field)
|
|
{
|
|
$ret = "";
|
|
if ($field == 2)
|
|
{
|
|
$ret = "<span class='required'> *</span>";
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
|
|
|
|
// Delete a file from the public directories. Return TRUE on success, FALSE on failure.
|
|
// Also deletes from database if appropriate.
|
|
function delete_file($fname, $dir = 'avatars/')
|
|
{
|
|
return;
|
|
/*
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
|
|
$fname = trim($fname);
|
|
if (!$fname) return false;
|
|
|
|
if (preg_match("#Binary (.*?)/#", $fname, $match))
|
|
{
|
|
return $sql -> db_Delete("rbinary", "binary_id='".$tp -> toDB($match[1])."'");
|
|
}
|
|
elseif (file_exists(e_UPLOAD.$dir.$fname))
|
|
{
|
|
unlink(e_UPLOAD.$dir.$fname);
|
|
return true;
|
|
}
|
|
return false;
|
|
*/
|
|
}
|
|
|