if ($_SERVER["REQUEST_METHOD"] == "POST") { $valid_result = User::ValidateShortName($_POST["member_shortname"]); if ($valid_result != null) { $failure = true; $failure_message = $valid_result; } else { if ($_POST["member_realname"] == null && $_POST["member_shortname"] == null && $_POST["member_longname"] == null && $_POST["member_birthdate"] == null && $_POST["member_email"] == null) { $failure = true; $failure_message = "Please change one of the options"; } else { $CurrentUser->RealName = $_POST["member_realname"]; $CurrentUser->ShortName = $_POST["member_shortname"]; $CurrentUser->LongName = $_POST["member_longname"]; $CurrentUser->BirthDate = $_POST["member_birthdate"]; $CurrentUser->EmailAddress = $_POST["member_email"]; $CurrentUser->ProfileVisibility = UserProfileVisibility::FromIndex($_POST["member_profile_visibility"]); $result = $CurrentUser->Update(); global $MySQL; if (!$result) { $failure = true; if ($MySQL->errno != 0) { $failure_message = $MySQL->errno . ": " . $MySQL->error; } else { $failure_message = mmo_error_get(); } } else { $lang = Language::GetByID($_POST["member_language_id"]); $lang->SetDefaultForUser($CurrentUser); // force refresh the user information $CurrentUser = User::GetCurrent(); if ($MySQL->errno != 0) {
public static function GetByAssoc($values, $allusers = false) { $user = new User(); $user->ID = $values["user_ID"]; $user->UserName = $values["user_LoginID"]; $user->ShortName = $values["user_URLName"]; $user->LongName = $values["user_DisplayName"]; $user->EmailAddress = $values["user_EmailAddress"]; $user->BirthDate = $values["user_BirthDate"]; $user->RealName = $values["user_RealName"]; $user->Theme = Theme::GetByID($values["user_ThemeID"]); $user->ConsecutiveLoginCount = $values["user_ConsecutiveLoginCount"]; $user->ConsecutiveLoginFailures = $values["user_ConsecutiveLoginFailures"]; $user->LastLoginDate = $values["user_LastLoginTimestamp"]; $user->RegistrationDate = $values["user_RegistrationTimestamp"]; $user->RegistrationIPAddress = $values["user_RegistrationIPAddress"]; if (isset($_SESSION["CurrentUserID"])) { $user->IsAuthenticated = $_SESSION["CurrentUserID"] == $user->ID; } else { $user->IsAuthenticated = false; } $user->Language = Language::GetByID($values["user_LanguageID"]); $user->ProfileVisibility = UserProfileVisibility::FromIndex($values["user_ProfileVisibility"]); $presence = new UserPresence(); $presence->Status = $values["user_PresenceStatus"]; $presence->Message = $values["user_PresenceMessage"]; $user->Presence = $presence; $user->StartPage = StartPage::GetByID($values["user_StartPageID"]); $user->LastLoginDate = $values["user_LastLoginTimestamp"]; if (!$allusers) { // check for blocked users if (isset($_SESSION["CurrentUserID"])) { if ($user->ID != $_SESSION["CurrentUserID"]) { if (!$user->IsVisible()) { return null; } } } } return $user; }