/** * (non-PHPdoc) * @see data/DataEditControl#BuildPostedDataObject() */ protected function BuildPostedDataObject() { # Prepare swear filter require_once 'text/bad-language-filter.class.php'; $o_filter = new BadLanguageFilter(); # Build object $user = AuthenticationManager::GetUser(); $user->SetName($o_filter->Filter($_POST['known_as'])); $user->SetFirstName($o_filter->Filter($_POST['first_name'])); $user->SetLastName($o_filter->Filter($_POST['last_name'])); $user->SetRequestedEmail($_POST['email']); $user->SetPassword($_POST['password1']); $user->SetRequestedPassword($_POST['password2']); $user->SetAutoSignIn(isset($_POST['remember_me'])); $this->SetDataObject($user); }
function SendCommentsSubscriptions(ReviewItem $review_item, ForumMessage $message) { # get all subscriptions for this item if (AuthenticationManager::GetUser()->IsSignedIn() and $review_item->GetId()) { $s_person = $this->GetSettings()->GetTable('User'); $s_sub = $this->GetSettings()->GetTable('EmailSubscription'); # join to item's table to get the title, regardless of message title $s_sql = ''; switch ($review_item->GetType()) { case ContentType::STOOLBALL_MATCH: $matches = $this->GetSettings()->GetTable('Match'); $s_sql = "SELECT {$matches}.match_title AS title, {$s_person}.email\n\t\t\t\t\tFROM ({$s_person} INNER JOIN {$s_sub} ON {$s_person}.user_id = {$s_sub}.user_id AND {$s_sub}.item_type = " . ContentType::STOOLBALL_MATCH . ")\n\t\t\t\t\tINNER JOIN {$matches} ON {$s_sub}.item_id = {$matches}.match_id AND {$s_sub}.item_type = " . ContentType::STOOLBALL_MATCH . "\n\t\t\t\t\tWHERE {$s_sub}.item_id = " . Sql::ProtectNumeric($review_item->GetId()) . " AND {$s_person}.user_id <> " . Sql::ProtectNumeric(AuthenticationManager::GetUser()->GetId()); break; } if ($s_sql) { # if there's at least one person, build email require_once 'Zend/Mail.php'; $email = new Zend_Mail('UTF-8'); if ($this->GetEmailAddresses($s_sql, $email)) { $o_filter = new BadLanguageFilter(); $s_title = $o_filter->Filter($this->s_review_item_title); unset($o_filter); $s_title = StringFormatter::PlainText($s_title); # send the email $email->addTo($this->GetSettings()->GetSubscriptionEmailTo()); $email->setFrom($this->GetSettings()->GetSubscriptionEmailFrom(), $this->GetSettings()->GetSubscriptionEmailFrom()); $email->setSubject("Email alert: '" . $s_title . "'"); $email->setBodyText($this->GetHeader() . trim(AuthenticationManager::GetUser()->GetName()) . ' has just commented on a page at ' . $this->GetSettings()->GetSiteName() . ' for which you subscribed to an email alert.' . "\n\n" . "The page is called '" . $s_title . "' - here's an excerpt of the new comments:\n\n" . $message->GetExcerpt() . "\n\n" . 'View the new comments at' . "\n" . $review_item->GetNavigateUrl() . '#message' . $message->GetId() . $this->GetFooter()); try { $email->send(); } catch (Zend_Mail_Transport_Exception $e) { # Do nothing - email not that important so, if it fails, fail silently rather than raising a fatal error } } } } }
/** * Saves personal information about a user * @param User $user * @return void */ public function SavePersonalInfo(User $user) { # Prepare filter require_once 'text/bad-language-filter.class.php'; $language = new BadLanguageFilter(); $users = $this->GetSettings()->GetTable('User'); $s_sql = 'UPDATE ' . $users . ' SET ' . 'date_changed = ' . gmdate('U') . ', ' . "gender = " . ($user->GetGender() ? $this->SqlString($user->GetGender()) : "NULL") . ", " . "occupation = " . $this->SqlString($language->Filter($user->GetOccupation())) . ", " . "interests = " . $this->SqlHtmlString($language->Filter($user->GetInterests())) . ", " . "location = " . $this->SqlString($language->Filter($user->GetLocation())) . " " . 'WHERE user_id = ' . Sql::ProtectNumeric($user->GetId(), false); $this->Lock(array($users)); $this->GetDataConnection()->query($s_sql); $this->Unlock(); }