123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813 |
- <?php
- /**
- * This file has the primary job of showing and editing people's profiles.
- * It also allows the user to change some of their or another's preferences,
- * and such things.
- *
- * Simple Machines Forum (SMF)
- *
- * @package SMF
- * @author Simple Machines http://www.simplemachines.org
- * @copyright 2013 Simple Machines and individual contributors
- * @license http://www.simplemachines.org/about/smf/license.php BSD
- *
- * @version 2.1 Alpha 1
- */
- if (!defined('SMF'))
- die('No direct access...');
- /**
- * Allow the change or view of profiles...
- *
- * @param array $post_errors = array()
- */
- function ModifyProfile($post_errors = array())
- {
- global $txt, $scripturl, $user_info, $context, $sourcedir, $user_profile, $cur_profile;
- global $modSettings, $memberContext, $profile_vars, $smcFunc, $post_errors, $options, $user_settings;
- // Don't reload this as we may have processed error strings.
- if (empty($post_errors))
- loadLanguage('Profile+Drafts');
- loadTemplate('Profile');
- require_once($sourcedir . '/Subs-Menu.php');
- // Did we get the user by name...
- if (isset($_REQUEST['user']))
- $memberResult = loadMemberData($_REQUEST['user'], true, 'profile');
- // ... or by id_member?
- elseif (!empty($_REQUEST['u']))
- $memberResult = loadMemberData((int) $_REQUEST['u'], false, 'profile');
- // If it was just ?action=profile, edit your own profile.
- else
- $memberResult = loadMemberData($user_info['id'], false, 'profile');
- // Check if loadMemberData() has returned a valid result.
- if (!is_array($memberResult))
- fatal_lang_error('not_a_user', false);
- // If all went well, we have a valid member ID!
- list ($memID) = $memberResult;
- $context['id_member'] = $memID;
- $cur_profile = $user_profile[$memID];
- // Let's have some information about this member ready, too.
- loadMemberContext($memID);
- $context['member'] = $memberContext[$memID];
- // Is this the profile of the user himself or herself?
- $context['user']['is_owner'] = $memID == $user_info['id'];
- /* Define all the sections within the profile area!
- We start by defining the permission required - then SMF takes this and turns it into the relevant context ;)
- Possible fields:
- For Section:
- string $title: Section title.
- array $areas: Array of areas within this section.
- For Areas:
- string $label: Text string that will be used to show the area in the menu.
- string $file: Optional text string that may contain a file name that's needed for inclusion in order to display the area properly.
- string $custom_url: Optional href for area.
- string $function: Function to execute for this section.
- bool $enabled: Should area be shown?
- string $sc: Session check validation to do on save - note without this save will get unset - if set.
- bool $hidden: Does this not actually appear on the menu?
- bool $password: Whether to require the user's password in order to save the data in the area.
- array $subsections: Array of subsections, in order of appearance.
- array $permission: Array of permissions to determine who can access this area. Should contain arrays $own and $any.
- */
- $profile_areas = array(
- 'info' => array(
- 'title' => $txt['profileInfo'],
- 'areas' => array(
- 'summary' => array(
- 'label' => $txt['summary'],
- 'file' => 'Profile-View.php',
- 'function' => 'summary',
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'profile_view_any',
- ),
- ),
- 'statistics' => array(
- 'label' => $txt['statPanel'],
- 'file' => 'Profile-View.php',
- 'function' => 'statPanel',
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'profile_view_any',
- ),
- ),
- 'showposts' => array(
- 'label' => $txt['showPosts'],
- 'file' => 'Profile-View.php',
- 'function' => 'showPosts',
- 'subsections' => array(
- 'messages' => array($txt['showMessages'], array('profile_view_own', 'profile_view_any')),
- 'topics' => array($txt['showTopics'], array('profile_view_own', 'profile_view_any')),
- 'disregardedtopics' => array($txt['showDisregarded'], array('profile_view_own', 'profile_view_any'), 'enabled' => $modSettings['enable_disregard'] && $context['user']['is_owner']),
- 'attach' => array($txt['showAttachments'], array('profile_view_own', 'profile_view_any')),
- ),
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'profile_view_any',
- ),
- ),
- 'showdrafts' => array(
- 'label' => $txt['drafts_show'],
- 'file' => 'Drafts.php',
- 'function' => 'showProfileDrafts',
- 'enabled' => !empty($modSettings['drafts_enabled']) && $context['user']['is_owner'],
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => array(),
- ),
- ),
- 'permissions' => array(
- 'label' => $txt['showPermissions'],
- 'file' => 'Profile-View.php',
- 'function' => 'showPermissions',
- 'permission' => array(
- 'own' => 'manage_permissions',
- 'any' => 'manage_permissions',
- ),
- ),
- 'tracking' => array(
- 'label' => $txt['trackUser'],
- 'file' => 'Profile-View.php',
- 'function' => 'tracking',
- 'subsections' => array(
- 'activity' => array($txt['trackActivity'], 'moderate_forum'),
- 'ip' => array($txt['trackIP'], 'moderate_forum'),
- 'edits' => array($txt['trackEdits'], 'moderate_forum'),
- 'logins' => array($txt['trackLogins'], array('profile_view_own', 'moderate_forum')),
- ),
- 'permission' => array(
- 'own' => 'moderate_forum',
- 'any' => 'moderate_forum',
- ),
- ),
- 'viewwarning' => array(
- 'label' => $txt['profile_view_warnings'],
- 'enabled' => in_array('w', $context['admin_features']) && $modSettings['warning_settings'][0] == 1 && $cur_profile['warning'] && (!empty($modSettings['warning_show']) && ($context['user']['is_owner'] || $modSettings['warning_show'] == 2)),
- 'file' => 'Profile-View.php',
- 'function' => 'viewWarning',
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'issue_warning',
- ),
- ),
- ),
- ),
- 'edit_profile' => array(
- 'title' => $txt['profileEdit'],
- 'areas' => array(
- 'account' => array(
- 'label' => $txt['account'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'account',
- 'enabled' => $context['user']['is_admin'] || ($cur_profile['id_group'] != 1 && !in_array(1, explode(',', $cur_profile['additional_groups']))),
- 'sc' => 'post',
- 'token' => 'profile-ac%u',
- 'password' => true,
- 'permission' => array(
- 'own' => array('profile_identity_any', 'profile_identity_own', 'manage_membergroups'),
- 'any' => array('profile_identity_any', 'manage_membergroups'),
- ),
- ),
- 'forumprofile' => array(
- 'label' => $txt['forumprofile'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'forumProfile',
- 'sc' => 'post',
- 'token' => 'profile-fp%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own', 'profile_title_own', 'profile_title_any'),
- 'any' => array('profile_extra_any', 'profile_title_any'),
- ),
- ),
- 'theme' => array(
- 'label' => $txt['theme'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'theme',
- 'sc' => 'post',
- 'token' => 'profile-th%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- 'authentication' => array(
- 'label' => $txt['authentication'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'authentication',
- 'enabled' => !empty($modSettings['enableOpenID']) || !empty($cur_profile['openid_uri']),
- 'sc' => 'post',
- 'token' => 'profile-au%u',
- 'hidden' => empty($modSettings['enableOpenID']) && empty($cur_profile['openid_uri']),
- 'password' => true,
- 'permission' => array(
- 'own' => array('profile_identity_any', 'profile_identity_own'),
- 'any' => array('profile_identity_any'),
- ),
- ),
- 'notification' => array(
- 'label' => $txt['notification'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'notification',
- 'sc' => 'post',
- 'token' => 'profile-nt%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- // Without profile_extra_own, settings are accessible from the PM section.
- 'pmprefs' => array(
- 'label' => $txt['pmprefs'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'pmprefs',
- 'enabled' => allowedTo(array('profile_extra_own', 'profile_extra_any')),
- 'sc' => 'post',
- 'token' => 'profile-pm%u',
- 'permission' => array(
- 'own' => array('pm_read'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- 'ignoreboards' => array(
- 'label' => $txt['ignoreboards'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'ignoreboards',
- 'enabled' => !empty($modSettings['allow_ignore_boards']),
- 'sc' => 'post',
- 'token' => 'profile-ib%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- 'lists' => array(
- 'label' => $txt['editBuddyIgnoreLists'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'editBuddyIgnoreLists',
- 'enabled' => !empty($modSettings['enable_buddylist']) && $context['user']['is_owner'],
- 'sc' => 'post',
- 'token' => 'profile-bl%u',
- 'subsections' => array(
- 'buddies' => array($txt['editBuddies']),
- 'ignore' => array($txt['editIgnoreList']),
- ),
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array(),
- ),
- ),
- 'groupmembership' => array(
- 'label' => $txt['groupmembership'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'groupMembership',
- 'enabled' => !empty($modSettings['show_group_membership']) && $context['user']['is_owner'],
- 'sc' => 'request',
- 'token' => 'profile-gm%u',
- 'token_type' => 'request',
- 'permission' => array(
- 'own' => array('profile_view_own'),
- 'any' => array('manage_membergroups'),
- ),
- ),
- ),
- ),
- 'profile_action' => array(
- 'title' => $txt['profileAction'],
- 'areas' => array(
- 'sendpm' => array(
- 'label' => $txt['profileSendIm'],
- 'custom_url' => $scripturl . '?action=pm;sa=send',
- 'permission' => array(
- 'own' => array(),
- 'any' => array('pm_send'),
- ),
- ),
- 'issuewarning' => array(
- 'label' => $txt['profile_issue_warning'],
- 'enabled' => in_array('w', $context['admin_features']) && $modSettings['warning_settings'][0] == 1 && (!$context['user']['is_owner'] || $context['user']['is_admin']),
- 'file' => 'Profile-Actions.php',
- 'function' => 'issueWarning',
- 'token' => 'profile-iw%u',
- 'permission' => array(
- 'own' => array('issue_warning'),
- 'any' => array('issue_warning'),
- ),
- ),
- 'banuser' => array(
- 'label' => $txt['profileBanUser'],
- 'custom_url' => $scripturl . '?action=admin;area=ban;sa=add',
- 'enabled' => $cur_profile['id_group'] != 1 && !in_array(1, explode(',', $cur_profile['additional_groups'])),
- 'permission' => array(
- 'own' => array(),
- 'any' => array('manage_bans'),
- ),
- ),
- 'subscriptions' => array(
- 'label' => $txt['subscriptions'],
- 'file' => 'Profile-Actions.php',
- 'function' => 'subscriptions',
- 'enabled' => !empty($modSettings['paid_enabled']),
- 'permission' => array(
- 'own' => array('profile_view_own'),
- 'any' => array('moderate_forum'),
- ),
- ),
- 'deleteaccount' => array(
- 'label' => $txt['deleteAccount'],
- 'file' => 'Profile-Actions.php',
- 'function' => 'deleteAccount',
- 'sc' => 'post',
- 'token' => 'profile-da%u',
- 'password' => true,
- 'permission' => array(
- 'own' => array('profile_remove_any', 'profile_remove_own'),
- 'any' => array('profile_remove_any'),
- ),
- ),
- 'activateaccount' => array(
- 'file' => 'Profile-Actions.php',
- 'function' => 'activateAccount',
- 'sc' => 'get',
- 'token' => 'profile-aa%u',
- 'select' => 'summary',
- 'permission' => array(
- 'own' => array(),
- 'any' => array('moderate_forum'),
- ),
- ),
- ),
- ),
- );
- // Let them modify profile areas easily.
- call_integration_hook('integrate_profile_areas', array(&$profile_areas));
- // Do some cleaning ready for the menu function.
- $context['password_areas'] = array();
- $current_area = isset($_REQUEST['area']) ? $_REQUEST['area'] : '';
- foreach ($profile_areas as $section_id => $section)
- {
- // Do a bit of spring cleaning so to speak.
- foreach ($section['areas'] as $area_id => $area)
- {
- // If it said no permissions that meant it wasn't valid!
- if (empty($area['permission'][$context['user']['is_owner'] ? 'own' : 'any']))
- $profile_areas[$section_id]['areas'][$area_id]['enabled'] = false;
- // Otherwise pick the right set.
- else
- $profile_areas[$section_id]['areas'][$area_id]['permission'] = $area['permission'][$context['user']['is_owner'] ? 'own' : 'any'];
- // Password required - only if not on OpenID.
- if (!empty($area['password']))
- $context['password_areas'][] = $area_id;
- }
- }
- // Is there an updated message to show?
- if (isset($_GET['updated']))
- $context['profile_updated'] = $txt['profile_updated_own'];
- // Set a few options for the menu.
- $menuOptions = array(
- 'disable_url_session_check' => true,
- 'current_area' => $current_area,
- 'extra_url_parameters' => array(
- 'u' => $context['id_member'],
- ),
- );
- // Actually create the menu!
- $profile_include_data = createMenu($profile_areas, $menuOptions);
- // No menu means no access.
- if (!$profile_include_data && (!$user_info['is_guest'] || validateSession()))
- fatal_lang_error('no_access', false);
- // Make a note of the Unique ID for this menu.
- $context['profile_menu_id'] = $context['max_menu_id'];
- $context['profile_menu_name'] = 'menu_data_' . $context['profile_menu_id'];
- // Set the selected item - now it's been validated.
- $current_area = $profile_include_data['current_area'];
- $context['menu_item_selected'] = $current_area;
- // Before we go any further, let's work on the area we've said is valid. Note this is done here just in case we ever compromise the menu function in error!
- $context['completed_save'] = false;
- $context['do_preview'] = isset($_REQUEST['preview_signature']);
- $security_checks = array();
- $found_area = false;
- foreach ($profile_areas as $section_id => $section)
- {
- // Do a bit of spring cleaning so to speak.
- foreach ($section['areas'] as $area_id => $area)
- {
- // Is this our area?
- if ($current_area == $area_id)
- {
- // This can't happen - but is a security check.
- if ((isset($section['enabled']) && $section['enabled'] == false) || (isset($area['enabled']) && $area['enabled'] == false))
- fatal_lang_error('no_access', false);
- // Are we saving data in a valid area?
- if (isset($area['sc']) && (isset($_REQUEST['save']) || $context['do_preview']))
- {
- $security_checks['session'] = $area['sc'];
- $context['completed_save'] = true;
- }
- // Do we need to perform a token check?
- if (!empty($area['token']))
- {
- $security_checks[isset($_REQUEST['save']) ? 'validateToken' : 'needsToken'] = $area['token'];
- $token_name = $area['token'] !== true ? str_replace('%u', $context['id_member'], $area['token']) : 'profile-u' . $context['id_member'];
- $token_type = isset($area['token_type']) && in_array($area['token_type'], array('request', 'post', 'get')) ? $area['token_type'] : 'post';
- }
- // Does this require session validating?
- if (!empty($area['validate']) || (isset($_REQUEST['save']) && !$context['user']['is_owner']))
- $security_checks['validate'] = true;
- // Permissions for good measure.
- if (!empty($profile_include_data['permission']))
- $security_checks['permission'] = $profile_include_data['permission'];
- // Either way got something.
- $found_area = true;
- }
- }
- }
- // Oh dear, some serious security lapse is going on here... we'll put a stop to that!
- if (!$found_area)
- fatal_lang_error('no_access', false);
- // Release this now.
- unset($profile_areas);
- // Now the context is setup have we got any security checks to carry out additional to that above?
- if (isset($security_checks['session']))
- checkSession($security_checks['session']);
- if (isset($security_checks['validate']))
- validateSession();
- if (isset($security_checks['validateToken']))
- validateToken($token_name, $token_type);
- if (isset($security_checks['permission']))
- isAllowedTo($security_checks['permission']);
- // Create a token if needed.
- if (isset($security_checks['needsToken']) || isset($security_checks['validateToken']))
- {
- createToken($token_name, $token_type);
- $context['token_check'] = $token_name;
- }
- // File to include?
- if (isset($profile_include_data['file']))
- require_once($sourcedir . '/' . $profile_include_data['file']);
- // Make sure that the area function does exist!
- if (!isset($profile_include_data['function']) || !function_exists($profile_include_data['function']))
- {
- destroyMenu();
- fatal_lang_error('no_access', false);
- }
- // Build the link tree.
- $context['linktree'][] = array(
- 'url' => $scripturl . '?action=profile' . ($memID != $user_info['id'] ? ';u=' . $memID : ''),
- 'name' => sprintf($txt['profile_of_username'], $context['member']['name']),
- );
- if (!empty($profile_include_data['label']))
- $context['linktree'][] = array(
- 'url' => $scripturl . '?action=profile' . ($memID != $user_info['id'] ? ';u=' . $memID : '') . ';area=' . $profile_include_data['current_area'],
- 'name' => $profile_include_data['label'],
- );
- if (!empty($profile_include_data['current_subsection']) && $profile_include_data['subsections'][$profile_include_data['current_subsection']][0] != $profile_include_data['label'])
- $context['linktree'][] = array(
- 'url' => $scripturl . '?action=profile' . ($memID != $user_info['id'] ? ';u=' . $memID : '') . ';area=' . $profile_include_data['current_area'] . ';sa=' . $profile_include_data['current_subsection'],
- 'name' => $profile_include_data['subsections'][$profile_include_data['current_subsection']][0],
- );
- // Set the template for this area and add the profile layer.
- $context['sub_template'] = $profile_include_data['function'];
- $context['template_layers'][] = 'profile';
- // All the subactions that require a user password in order to validate.
- $check_password = $context['user']['is_owner'] && in_array($profile_include_data['current_area'], $context['password_areas']);
- $context['require_password'] = $check_password && empty($user_settings['openid_uri']);
- // If we're in wireless then we have a cut down template...
- if (WIRELESS && $context['sub_template'] == 'summary' && WIRELESS_PROTOCOL != 'wap')
- $context['sub_template'] = WIRELESS_PROTOCOL . '_profile';
- // These will get populated soon!
- $post_errors = array();
- $profile_vars = array();
- // Right - are we saving - if so let's save the old data first.
- if ($context['completed_save'])
- {
- // Clean up the POST variables.
- $_POST = htmltrim__recursive($_POST);
- $_POST = htmlspecialchars__recursive($_POST);
- if ($check_password)
- {
- // If we're using OpenID try to revalidate.
- if (!empty($user_settings['openid_uri']))
- {
- require_once($sourcedir . '/Subs-OpenID.php');
- smf_openID_revalidate();
- }
- else
- {
- // You didn't even enter a password!
- if (trim($_POST['oldpasswrd']) == '')
- $post_errors[] = 'no_password';
- // Since the password got modified due to all the $_POST cleaning, lets undo it so we can get the correct password
- $_POST['oldpasswrd'] = un_htmlspecialchars($_POST['oldpasswrd']);
- // Does the integration want to check passwords?
- $good_password = in_array(true, call_integration_hook('integrate_verify_password', array($cur_profile['member_name'], $_POST['oldpasswrd'], false)), true);
- // Bad password!!!
- if (!$good_password && $user_info['passwd'] != sha1(strtolower($user_profile[$memID]['member_name']) . un_htmlspecialchars(stripslashes($_POST['oldpasswrd']))))
- $post_errors[] = 'bad_password';
- // Warn other elements not to jump the gun and do custom changes!
- if (in_array('bad_password', $post_errors))
- $context['password_auth_failed'] = true;
- }
- }
- // Change the IP address in the database.
- if ($context['user']['is_owner'])
- $profile_vars['member_ip'] = $user_info['ip'];
- // Now call the sub-action function...
- if ($current_area == 'activateaccount')
- {
- if (empty($post_errors))
- activateAccount($memID);
- }
- elseif ($current_area == 'deleteaccount')
- {
- if (empty($post_errors))
- {
- deleteAccount2($memID);
- redirectexit();
- }
- }
- elseif ($current_area == 'groupmembership' && empty($post_errors))
- {
- $msg = groupMembership2($profile_vars, $post_errors, $memID);
- // Whatever we've done, we have nothing else to do here...
- redirectexit('action=profile' . ($context['user']['is_owner'] ? '' : ';u=' . $memID) . ';area=groupmembership' . (!empty($msg) ? ';msg=' . $msg : ''));
- }
- // Authentication changes?
- elseif ($current_area == 'authentication')
- {
- authentication($memID, true);
- }
- elseif (in_array($current_area, array('account', 'forumprofile', 'theme', 'pmprefs')))
- saveProfileFields();
- else
- {
- $force_redirect = true;
- // Ensure we include this.
- require_once($sourcedir . '/Profile-Modify.php');
- saveProfileChanges($profile_vars, $post_errors, $memID);
- }
- call_integration_hook('integrate_profile_save', array(&$profile_vars, &$post_errors, $memID));
- // There was a problem, let them try to re-enter.
- if (!empty($post_errors))
- {
- // Load the language file so we can give a nice explanation of the errors.
- loadLanguage('Errors');
- $context['post_errors'] = $post_errors;
- }
- elseif (!empty($profile_vars))
- {
- // If we've changed the password, notify any integration that may be listening in.
- if (isset($profile_vars['passwd']))
- call_integration_hook('integrate_reset_pass', array($cur_profile['member_name'], $cur_profile['member_name'], $_POST['passwrd2']));
- updateMemberData($memID, $profile_vars);
- // What if this is the newest member?
- if ($modSettings['latestMember'] == $memID)
- updateStats('member');
- elseif (isset($profile_vars['real_name']))
- updateSettings(array('memberlist_updated' => time()));
- // If the member changed his/her birthdate, update calendar statistics.
- if (isset($profile_vars['birthdate']) || isset($profile_vars['real_name']))
- updateSettings(array(
- 'calendar_updated' => time(),
- ));
- // Anything worth logging?
- if (!empty($context['log_changes']) && !empty($modSettings['modlog_enabled']))
- {
- $log_changes = array();
- require_once($sourcedir . '/Logging.php');
- foreach ($context['log_changes'] as $k => $v)
- $log_changes[] = array(
- 'action' => $k,
- 'log_type' => 'user',
- 'extra' => array_merge($v, array(
- 'applicator' => $user_info['id'],
- 'member_affected' => $memID,
- )),
- );
- logActions($log_changes);
- }
- // Have we got any post save functions to execute?
- if (!empty($context['profile_execute_on_save']))
- foreach ($context['profile_execute_on_save'] as $saveFunc)
- $saveFunc();
- // Let them know it worked!
- $context['profile_updated'] = $context['user']['is_owner'] ? $txt['profile_updated_own'] : sprintf($txt['profile_updated_else'], $cur_profile['member_name']);
- // Invalidate any cached data.
- cache_put_data('member_data-profile-' . $memID, null, 0);
- }
- }
- // Have some errors for some reason?
- if (!empty($post_errors))
- {
- // Set all the errors so the template knows what went wrong.
- foreach ($post_errors as $error_type)
- $context['modify_error'][$error_type] = true;
- }
- // If it's you then we should redirect upon save.
- elseif (!empty($profile_vars) && $context['user']['is_owner'] && !$context['do_preview'])
- redirectexit('action=profile;area=' . $current_area . ';updated');
- elseif (!empty($force_redirect))
- redirectexit('action=profile' . ($context['user']['is_owner'] ? '' : ';u=' . $memID) . ';area=' . $current_area);
- // Call the appropriate subaction function.
- $profile_include_data['function']($memID);
- // Set the page title if it's not already set...
- if (!isset($context['page_title']))
- $context['page_title'] = $txt['profile'] . (isset($txt[$current_area]) ? ' - ' . $txt[$current_area] : '');
- }
- /**
- * Load any custom fields for this area... no area means load all, 'summary' loads all public ones.
- *
- * @param int $memID
- * @param string $area = 'summary'
- */
- function loadCustomFields($memID, $area = 'summary')
- {
- global $context, $txt, $user_profile, $smcFunc, $user_info, $settings, $scripturl;
- // Get the right restrictions in place...
- $where = 'active = 1';
- if (!allowedTo('admin_forum') && $area != 'register')
- {
- // If it's the owner they can see two types of private fields, regardless.
- if ($memID == $user_info['id'])
- $where .= $area == 'summary' ? ' AND private < 3' : ' AND (private = 0 OR private = 2)';
- else
- $where .= $area == 'summary' ? ' AND private < 2' : ' AND private = 0';
- }
- if ($area == 'register')
- $where .= ' AND show_reg != 0';
- elseif ($area != 'summary')
- $where .= ' AND show_profile = {string:area}';
- // Load all the relevant fields - and data.
- $request = $smcFunc['db_query']('', '
- SELECT
- col_name, field_name, field_desc, field_type, show_reg, field_length, field_options,
- default_value, bbc, enclose, placement
- FROM {db_prefix}custom_fields
- WHERE ' . $where,
- array(
- 'area' => $area,
- )
- );
- $context['custom_fields'] = array();
- $context['custom_fields_required'] = false;
- while ($row = $smcFunc['db_fetch_assoc']($request))
- {
- // Shortcut.
- $exists = $memID && isset($user_profile[$memID], $user_profile[$memID]['options'][$row['col_name']]);
- $value = $exists ? $user_profile[$memID]['options'][$row['col_name']] : '';
- // If this was submitted already then make the value the posted version.
- if (isset($_POST['customfield']) && isset($_POST['customfield'][$row['col_name']]))
- {
- $value = $smcFunc['htmlspecialchars']($_POST['customfield'][$row['col_name']]);
- if (in_array($row['field_type'], array('select', 'radio')))
- $value = ($options = explode(',', $row['field_options'])) && isset($options[$value]) ? $options[$value] : '';
- }
- // HTML for the input form.
- $output_html = $value;
- if ($row['field_type'] == 'check')
- {
- $true = (!$exists && $row['default_value']) || $value;
- $input_html = '<input type="checkbox" name="customfield[' . $row['col_name'] . ']" ' . ($true ? 'checked="checked"' : '') . ' class="input_check" />';
- $output_html = $true ? $txt['yes'] : $txt['no'];
- }
- elseif ($row['field_type'] == 'select')
- {
- $input_html = '<select name="customfield[' . $row['col_name'] . ']"><option value="-1"></option>';
- $options = explode(',', $row['field_options']);
- foreach ($options as $k => $v)
- {
- $true = (!$exists && $row['default_value'] == $v) || $value == $v;
- $input_html .= '<option value="' . $k . '"' . ($true ? ' selected="selected"' : '') . '>' . $v . '</option>';
- if ($true)
- $output_html = $v;
- }
- $input_html .= '</select>';
- }
- elseif ($row['field_type'] == 'radio')
- {
- $input_html = '<fieldset>';
- $options = explode(',', $row['field_options']);
- foreach ($options as $k => $v)
- {
- $true = (!$exists && $row['default_value'] == $v) || $value == $v;
- $input_html .= '<label for="customfield_' . $row['col_name'] . '_' . $k . '"><input type="radio" name="customfield[' . $row['col_name'] . ']" class="input_radio" id="customfield_' . $row['col_name'] . '_' . $k . '" value="' . $k . '" ' . ($true ? 'checked="checked"' : '') . ' />' . $v . '</label><br />';
- if ($true)
- $output_html = $v;
- }
- $input_html .= '</fieldset>';
- }
- elseif ($row['field_type'] == 'text')
- {
- $input_html = '<input type="text" name="customfield[' . $row['col_name'] . ']" ' . ($row['field_length'] != 0 ? 'maxlength="' . $row['field_length'] . '"' : '') . ' size="' . ($row['field_length'] == 0 || $row['field_length'] >= 50 ? 50 : ($row['field_length'] > 30 ? 30 : ($row['field_length'] > 10 ? 20 : 10))) . '" value="' . $value . '" class="input_text" />';
- }
- else
- {
- @list ($rows, $cols) = @explode(',', $row['default_value']);
- $input_html = '<textarea name="customfield[' . $row['col_name'] . ']" ' . (!empty($rows) ? 'rows="' . $rows . '"' : '') . ' ' . (!empty($cols) ? 'cols="' . $cols . '"' : '') . '>' . $value . '</textarea>';
- }
- // Parse BBCode
- if ($row['bbc'])
- $output_html = parse_bbc($output_html);
- elseif ($row['field_type'] == 'textarea')
- // Allow for newlines at least
- $output_html = strtr($output_html, array("\n" => '<br />'));
- // Enclosing the user input within some other text?
- if (!empty($row['enclose']) && !empty($output_html))
- $output_html = strtr($row['enclose'], array(
- '{SCRIPTURL}' => $scripturl,
- '{IMAGES_URL}' => $settings['images_url'],
- '{DEFAULT_IMAGES_URL}' => $settings['default_images_url'],
- '{INPUT}' => $output_html,
- ));
- $context['custom_fields'][] = array(
- 'name' => $row['field_name'],
- 'desc' => $row['field_desc'],
- 'type' => $row['field_type'],
- 'input_html' => $input_html,
- 'output_html' => $output_html,
- 'placement' => $row['placement'],
- 'colname' => $row['col_name'],
- 'value' => $value,
- 'show_reg' => $row['show_reg'],
- );
- $context['custom_fields_required'] = $context['custom_fields_required'] || $row['show_reg'];
- }
- $smcFunc['db_free_result']($request);
- call_integration_hook('integrate_load_custom_profile_fields', array($memID, $area));
- }
- ?>
|