page_title = t("%name Profile", array("name" => $user->display_name())); $v->content = new View("user_profile.html"); $v->content->user = $user; $v->content->contactable = !$user->guest && $user->id != identity::active_user()->id && $user->email; $v->content->editable = identity::is_writable() && !$user->guest && $user->id == identity::active_user()->id; $event_data = (object)array("user" => $user, "content" => array()); module::event("show_user_profile", $event_data); $v->content->info_parts = $event_data->content; print $v; } public function contact($id) { $user = identity::lookup_user($id); print user_profile::get_contact_form($user); } public function send($id) { access::verify_csrf(); $user = identity::lookup_user($id); $form = user_profile::get_contact_form($user); if ($form->validate()) { Sendmail::factory() ->to($user->email) ->subject(html::clean($form->message->subject->value)) ->header("Mime-Version", "1.0") ->header("Content-type", "text/html; charset=UTF-8") ->reply_to($form->message->reply_to->value) ->message(html::purify($form->message->message->value)) ->send(); message::success(t("Sent message to %user_name", array("user_name" => $user->display_name()))); json::reply(array("result" => "success")); } else { json::reply(array("result" => "error", "html" => (string)$form)); } } }