X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Fmodules%2Fmember%2Fwhat-nickname.php;h=5312676f6671a0ecc4adaf927cac5746049b2b04;hb=49a9663311b732d12ba0c53af2f9eb39a7850fbc;hp=7680b89d3e55593cdaa9a69396b721a1d509e590;hpb=09f5758c42a33a56bdd461c946ffe759a59c54aa;p=mailer.git diff --git a/inc/modules/member/what-nickname.php b/inc/modules/member/what-nickname.php index 7680b89d3e..5312676f66 100644 --- a/inc/modules/member/what-nickname.php +++ b/inc/modules/member/what-nickname.php @@ -14,12 +14,10 @@ * $Date:: $ * * $Tag:: 0.2.1-FINAL $ * * $Author:: $ * - * Needs to be in all Files and every File needs "svn propset * - * svn:keywords Date Revision" (autoprobset!) at least!!!!!! * * -------------------------------------------------------------------- * * Copyright (c) 2003 - 2009 by Roland Haeder * - * Copyright (c) 2009, 2010 by Mailer Developer Team * - * For more information visit: http://www.mxchange.org * + * Copyright (c) 2009 - 2012 by Mailer Developer Team * + * For more information visit: http://mxchange.org * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -39,16 +37,16 @@ // Some security stuff... if (!defined('__SECURITY')) { - die(); + exit(); } elseif (!isMember()) { redirectToIndexMemberOnlyModule(); } // Add description as navigation point -addMenuDescription('member', __FILE__); +addYouAreHereLink('member', __FILE__); if ((!isExtensionActive('nickname')) && (!isAdmin())) { - loadTemplate('admin_settings_saved', false, generateExtensionInactiveNotInstalledMessage('nickname')); + displayMessage('{%pipe,generateExtensionInactiveNotInstalledMessage=nickname%}'); return; } // END - if @@ -56,43 +54,62 @@ $isValid = false; if (isFormSent()) { // Nickname was submitted so let's check if it is not already in use - if (isPostRequestParameterSet('nickname')) { + if (isPostRequestElementSet('nickname')) { // Check if nickname is valid - $PATTERN = '[' . getConfig('nickname_pattern') . ']{' . getConfig('nickname_len') . ',}'; - if (ereg($PATTERN, postRequestParameter('nickname'), $array)) { + if (preg_match('/[' . getConfig('nickname_pattern') . ']{' . getConfig('nickname_len') . ',}/', postRequestElement('nickname'), $array)) { // Entered nickname is valid? - $isValid = ($array[0] == postRequestParameter('nickname')); + $isValid = (($array[0] == postRequestElement('nickname')) && (isNicknameUsed(postRequestElement('nickname')))); } // END - if } // END - if } // END - if if ($isValid === true) { + // Nickname already in use which is the default + $content = '{--MEMBER_NICKNAME_ALREADY_IN_USE--}'; + // Look for nickname in database (we only need just one entry so don't worry about the "LIMIT 1" !) - $result = SQL_QUERY_ESC("SELECT `userid` FROM `{?_MYSQL_PREFIX?}_user_data` WHERE `nickname`='%s' AND `userid` != '%s' LIMIT 1", - array(postRequestParameter('nickname'), getMemberId()), __FILE__, __LINE__); - if (SQL_NUMROWS($result) == '0') { + $result = SQL_QUERY_ESC("SELECT `userid` FROM `{?_MYSQL_PREFIX?}_user_data` WHERE `nickname`='%s' AND `userid` != %s LIMIT 1", + array( + postRequestElement('nickname'), + getMemberId() + ), __FILE__, __LINE__); + + // Is it not in use? + if (SQL_HASZERONUMS($result)) { + // Prepare array + $filterData = array( + 'history_subject' => 'NICKNAME_CHANGED', + 'history_userid' => getMemberId(), + 'history_value' => postRequestElement('nickname') + ); + + // Run filter chain + runFilterChain('add_history_entry', $filterData); + // Nickname not in use, so set it now SQL_QUERY_ESC("UPDATE `{?_MYSQL_PREFIX?}_user_data` SET `nickname`='%s' WHERE `userid`=%s LIMIT 1", - array(postRequestParameter('nickname'), getMemberId()), __FILE__, __LINE__); - $content = getMessage('NICKNAME_SAVED'); - } else { - // Free result - SQL_FREERESULT($result); + array( + postRequestElement('nickname'), + getMemberId() + ), __FILE__, __LINE__); + + // Change message + $content = '{--MEMBER_NICKNAME_SAVED--}'; + } // END - if - // Nickname already in use! - $content = getMessage('NICKNAME_ALREADY_IN_USE'); - } + // Free result + SQL_FREERESULT($result); // Load template - loadTemplate('admin_settings_saved', false, $content); + displayMessage($content); } else { // Do we have already submit the form? - if (isPostRequestParameterSet('nickname')) { - loadTemplate('admin_settings_saved', false, '
{--NICKNAME_IS_INVALID--}
'); + if (isPostRequestElementSet('nickname')) { + loadTemplate('admin_settings_unsaved', false, '{--MEMBER_NICKNAME_IS_INVALID--}'); } // END - if // Load Template - loadTemplate('member_nickname_form', false, getNickname(getMemberId())); + loadTemplate('member_nickname_form'); } // [EOF]