?> <?php if ($pagination) { ?> <div class="discuss-pagination"> <?php echo $pagination->getPagesLinks(); ?> </div> <?php } else { ?> <div> <a href="<?php echo DiscussRouter::getCategoryRoute($category->id); ?> "><?php echo JText::_('COM_EASYDISCUSS_SHOW_MORE_POSTS'); ?> <i class="icon-chevron-right"></i> </a> </div> <?php } ?> </div> <?php if ($system->config->get('layout_board_stats')) { echo DiscussHelper::getBoardStatistics(); }
</span> <div class="discuss-status"> <i class="edy-icon-locked edy-state" rel="ed-tooltip" data-placement="top" data-original-title="Locked"></i> <i class="edy-icon-resolved edy-state" rel="ed-tooltip" data-placement="top" data-original-title="Resolved"></i> <i class="edy-icon-featured edy-state" rel="ed-tooltip" data-placement="top" data-original-title="Featured"></i> <i class="edy-icon-favorited edy-state" rel="ed-tooltip" data-placement="top" data-original-title="Favorited"></i> </div> </div> </div> <div class="dc-mod-bd"> <div class="discuss-category small"> <i class="edy-icon-category"></i> - <a href="<?php echo DiscussRouter::getCategoryRoute($post->category_id); ?> "> <?php echo $post->category; ?> </a> </div> <div class="discuss-date small"> <i class="edy-icon-clock"></i> <?php echo $post->duration; ?> </div> </div><!-- bd --> <div class="dc-mod-ft"> <div class="discuss-statistic small">
public static function accessNestedCategories($arr, &$html, $deep = '0', $default = '0', $type = 'select', $linkDelimiter = '', $disableContainers = false) { $config = DiscussHelper::getConfig(); if (isset($arr->childs) && is_array($arr->childs)) { $sup = '<sup>|_</sup>'; $space = ''; $ld = empty($linkDelimiter) ? '>' : $linkDelimiter; if ($type == 'select' || $type == 'list') { $deep++; for ($d = 0; $d < $deep; $d++) { $space .= ' '; } } if ($type == 'list' && !empty($arr->childs)) { $html .= '<ul>'; } for ($j = 0; $j < count($arr->childs); $j++) { $child = $arr->childs[$j]; switch ($type) { case 'select': $selected = $child->id == $default ? ' selected="selected"' : ''; if (!$default) { $selected = $child->default ? ' selected="selected"' : ''; } $disabled = ''; $style = ''; // @rule: Test if the category should just act as a container if ($disableContainers) { $disabled = $child->container ? ' disabled="disabled"' : ''; $style = $disabled ? ' style="font-weight:700;"' : ''; } $html .= '<option value="' . $child->id . '" ' . $selected . $disabled . $style . '>' . $space . $sup . $child->title . '</option>'; break; case 'list': $expand = !empty($child->childs) ? '<span onclick="EasyDiscuss.$(this).parents(\'li:first\').toggleClass(\'expand\');">[+] </span>' : ''; $html .= '<li><div>' . $space . $sup . $expand . '<a href="' . DiscussRouter::getCategoryRoute($child->id) . '">' . $child->title . '</a> <b>(' . $child->count . ')</b></div>'; break; case 'listlink': $str = '<li><a href="' . DiscussRouter::getCategoryRoute($child->id) . '">'; $str .= empty($html) ? $child->title : $ld . ' ' . $child->title; $str .= '</a></li>'; $html .= $str; break; default: $str = '<a href="' . DiscussRouter::getCategoryRoute($child->id) . '">'; //str .= (empty($html)) ? $child->title : $ld . ' ' . $child->title; $str .= empty($html) ? $child->title : $ld . ' ' . $child->title; $str .= '</a></li>'; $html .= $str; } if (!$config->get('layout_category_one_level', 0)) { DiscussHelper::accessNestedCategories($child, $html, $deep, $default, $type, $linkDelimiter, $disableContainers); } if ($type == 'list') { $html .= '</li>'; } } if ($type == 'list' && !empty($arr->childs)) { $html .= '</ul>'; } } else { return false; } }
/** * Processes user subscription. * * @since 3.0 * @access public * @param null */ public function subscribe() { JRequest::checkToken('request') or jexit('Invalid Token'); $app = JFactory::getApplication(); $my = JFactory::getUser(); $config = DiscussHelper::getConfig(); // Get variables from post. $type = JRequest::getVar('type', null); $name = JRequest::getVar('subscribe_name', ''); $email = JRequest::getVar('subscribe_email', ''); $interval = JRequest::getVar('subscription_interval', ''); $cid = JRequest::getInt('cid', 0); $redirect = JRequest::getVar('redirect', ''); if (empty($redirect)) { $redirect = DiscussRouter::_('index.php?option=com_easydiscuss', false); if ($type == 'category' && $cid) { $redirect = DiscussRouter::getCategoryRoute($cid, false); } } else { $redirect = base64_decode($url); } // Apply filtering on the name. $filter = JFilterInput::getInstance(); $name = $filter->clean($name, 'STRING'); $email = JString::trim($email); $name = JString::trim($name); if (!JMailHelper::isEmailAddress($email)) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_INVALID_EMAIL'), 'error'); $app->redirect($redirect); $app->close(); } // Check for empty email if (empty($email)) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_EMAIL_IS_EMPTY'), 'error'); $app->redirect($redirect); $app->close(); } // Check for empty name if (empty($name)) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_NAME_IS_EMPTY'), 'error'); $app->redirect($redirect); $app->close(); } $model = DiscussHelper::getModel('Subscribe'); $subscription = $model->isSiteSubscribed($type, $email, $cid); $data = array(); $data['type'] = $type; $data['userid'] = $my->id; $data['email'] = $email; $data['cid'] = $cid; $data['member'] = $my->id ? '1' : '0'; $data['name'] = $my->id ? $my->name : $name; $data['interval'] = $interval; if ($subscription) { // Perhaps the user tried to change the subscription interval. if ($subscription->interval == $interval) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_SUBSCRIPTION_UPDATED_SUCCESSFULLY'), 'success'); $app->redirect($redirect); return $app->close(); } // User changed their subscription interval. if (!$model->updateSiteSubscription($subscription->id, $data)) { //if($model->updateSiteSubscription($subRecord['id'], $subscription_info)) DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_SUBSCRIPTION_FAILED'), 'error'); $app->redirect($redirect); return $app->close(); } // If the user already has an existing subscription, just let them know that their subscription is already updated. $intervalMessage = JText::_('COM_EASYDISCUSS_SUBSCRIPTION_INTERVAL_' . strtoupper($interval)); DiscussHelper::setMessageQueue(JText::sprintf('COM_EASYDISCUSS_SUBSCRIPTION_UPDATED', $intervalMessage), 'success'); $app->redirect($redirect); return $app->close(); } // Only new records are added here. if (!$model->addSubscription($data)) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_SUBSCRIPTION_FAILED'), 'error'); $app->redirect($redirect); return $app->close(); } DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_SUBSCRIPTION_UPDATED_SUCCESSFULLY'), 'success'); $app->redirect($redirect); return $app->close(); }
public function tab() { // always reset the limitstart. JRequest::setVar('limitstart', 0); $type = JRequest::getVar('type'); $profileId = JRequest::getVar('id'); $ajax = DiscussHelper::getHelper('ajax'); $model = DiscussHelper::getModel('Posts'); $tagsModel = DiscussHelper::getModel('Tags'); $config = DiscussHelper::getConfig(); $template = new DiscussThemes(); $html = ''; $pagination = null; switch ($type) { case 'tags': $tags = $tagsModel->getTagCloud('', '', '', $profileId); $template->set('tags', $tags); $html = $template->fetch('profile.tags.php'); break; case 'questions': $posts = $model->getPostsBy('user', $profileId); $posts = DiscussHelper::formatPost($posts); $pagination = $model->getPagination(); $template->set('posts', $posts); $html = $template->fetch('profile.questions.php'); break; case 'unresolved': $posts = $model->getUnresolvedFromUser($profileId); $posts = DiscussHelper::formatPost($posts); $pagination = $model->getPagination(); $posts = Discusshelper::getPostStatusAndTypes($posts); $template->set('posts', $posts); $html = $template->fetch('profile.unresolved.php'); break; case 'favourites': if (!$config->get('main_favorite')) { return false; } $posts = $model->getData(true, 'latest', null, 'favourites', '', null, 'all', $profileId); $posts = DiscussHelper::formatPost($posts); $posts = Discusshelper::getPostStatusAndTypes($posts); $template->set('posts', $posts); $html = $template->fetch('profile.favourites.php'); break; case 'replies': $posts = $model->getRepliesFromUser($profileId); $posts = DiscussHelper::formatPost($posts); $pagination = $model->getPagination(); $posts = Discusshelper::getPostStatusAndTypes($posts); $template->set('posts', $posts); $html = $template->fetch('profile.replies.php'); break; case 'tabEasyBlog': $helperFile = JPATH_ROOT . '/components/com_easyblog/helpers/helper.php'; if (!JFile::exists($helperFile)) { $html = JText::_('COM_EASYDISCUSS_EASYBLOG_DOES_NOT_EXIST'); } else { require_once $helperFile; require_once JPATH_ROOT . '/components/com_easyblog/router.php'; $blogModel = EasyBlogHelper::getModel('Blog'); $blogs = $blogModel->getBlogsBy('blogger', $profileId); $blogs = EasyBlogHelper::formatBlog($blogs); $ebConfig = EasyBlogHelper::getConfig(); $user = JFactory::getUser($profileId); $template->set('user', $user); $template->set('ebConfig', $ebConfig); $template->set('blogs', $blogs); // Load EasyBlog's language file JFactory::getLanguage()->load('com_easyblog', JPATH_ROOT); $html = $template->fetch('profile.blogs.php'); } break; case 'tabKomento': $helperFile = JPATH_ROOT . '/components/com_komento/helpers/helper.php'; if (!JFile::exists($helperFile)) { $html = JText::_('COM_EASYDISCUSS_KOMENTO_DOES_NOT_EXIST'); } else { require_once $helperFile; $commentsModel = Komento::getModel('comments'); $commentHelper = Komento::getHelper('comment'); $options = array('sort' => 'latest', 'userid' => $profileId, 'threaded' => 0); $comments = $commentsModel->getComments('all', 'all', $options); foreach ($comments as &$comment) { $comment = $commentHelper->process($comment); } $feedUrl = Komento::getHelper('router')->getFeedUrl('all', 'all', $profileId); JFactory::getLanguage()->load('com_komento', JPATH_ROOT); $template->set('feedUrl', $feedUrl); $template->set('comments', $comments); $html = $template->fetch('profile.comments.php'); } break; case 'subscriptions': $subModel = DiscussHelper::getModel('subscribe'); $rows = $subModel->getSubscriptions(); $subs = array(); if ($rows) { foreach ($rows as $row) { $obj = new stdClass(); $obj->id = $row->id; $obj->type = $row->type; $obj->unsublink = Discusshelper::getUnsubscribeLink($row, false); switch ($row->type) { case 'site': $obj->title = ''; $obj->link = ''; break; case 'post': $post = DiscussHelper::getTable('Post'); $post->load($row->cid); $obj->title = $post->title; $obj->link = DiscussRouter::_('index.php?option=com_easydiscuss&view=post&id=' . $post->id); break; case 'category': $category = DiscussHelper::getTable('Category'); $category->load($row->cid); $obj->title = $category->title; $obj->link = DiscussRouter::getCategoryRoute($category->id); break; case 'user': $profile = DiscussHelper::getTable('Profile'); $profile->load($row->cid); $obj->title = $profile->getName(); $obj->link = $profile->getLink(); break; default: unset($obj); break; } if (!empty($obj)) { $obj->title = DiscussStringHelper::escape($obj->title); $subs[$row->type][] = $obj; unset($obj); } } } $template->set('subscriptions', $subs); $html = $template->fetch('profile.subscriptions.php'); break; default: break; } if ($pagination) { $filterArr = array(); $filterArr['viewtype'] = $type; $filterArr['id'] = $profileId; $pagination = $pagination->getPagesLinks('profile', $filterArr, true); } $ajax->success($html, $pagination); $ajax->send(); }
/** * Handles POST request for new discussions * * @since 3.0 * @access public */ public function submit() { JRequest::checkToken('request') or jexit('Invalid Token'); $config = DiscussHelper::getConfig(); $my = JFactory::getUser(); $app = JFactory::getApplication(); $acl = DiscussHelper::getHelper('ACL'); // If guest posting is disallowed in the settings, they shouldn't be able to create a discussion at all. if (!$my->id && !$acl->allowed('add_question', '0')) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_POST_PLEASE_LOGIN'), DISCUSS_QUEUE_ERROR); $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss', false)); return $app->close(); } // If user is disallowed in the acl, they shouldn't be able to create a discussion at all. if ($my->id && !$acl->allowed('add_question', '0')) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_SYSTEM_INSUFFICIENT_PERMISSIONS'), DISCUSS_QUEUE_ERROR); $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss', false)); return $app->close(); } // Get values from the posted form. $data = JRequest::get('post'); if (isset($data['mod_post_topic_category_id'])) { $data['category_id'] = $data['mod_post_topic_category_id']; unset($data['mod_post_topic_category_id']); } // Run validation on the posted data. if (!$this->_fieldValidate($data)) { $files = JRequest::getVar('filedata', array(), 'FILES'); $data['attachments'] = $files; DiscussHelper::storeSession($data, 'NEW_POST_TOKEN'); $app->redirect(DiscussRouter::getAskRoute(null, false)); } // get id if available $id = JRequest::getInt('id', 0); // bind the table $post = DiscussHelper::getTable('Post'); $post->load($id); // set is new value $isNew = !$post->id ? true : false; // If the post is edited and it doesn't have private the user might be switching from private -> non private if (!$isNew && !isset($data['private'])) { $post->private = false; } // Perform captcha validation $state = EDC::validateCaptcha($data); if (!$state) { // Store the data into the session EDC::storeSession($data, 'NEW_POST_TOKEN'); // Set error message EDC::setMessageQueue(JText::_('COM_EASYDISCUSS_INVALID_CAPTCHA'), DISCUSS_QUEUE_ERROR); if ($isNew) { $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss&view=ask', false)); } else { $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss&view=ask&id=' . $post->id, false)); } } $previousTags = array(); if (!$isNew) { //check if admin or is owner before allowing edit. $isMine = DiscussHelper::isMine($post->user_id); $isAdmin = DiscussHelper::isSiteAdmin(); $isEditor = $acl->allowed('edit_question'); if (!$my->id && !$isMine && !$isAdmin && !$isEditor) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_NO_PERMISSION_TO_PERFORM_THE_REQUESTED_ACTION'), DISCUSS_QUEUE_ERROR); $this->setRedirect(DiscussRouter::_('index.php?option=com_easydiscuss&view=post&id=' . $id, false)); return; } // If this is an edited post, we need to remove existing tags and add them back again. $postsTagsModel = $this->getModel('PostsTags'); $tmppreviousTags = $postsTagsModel->getPostTags($id); if (!empty($tmppreviousTags)) { foreach ($tmppreviousTags as $previoustag) { $previousTags[] = $previoustag->id; } } if ($acl->allowed('add_tag', '0')) { $postsTagsModel->deletePostTag($id); } } // Get raw content from request as we may need to respect the html codes. $content = JRequest::getVar('dc_reply_content', '', 'post', 'none', JREQUEST_ALLOWRAW); if (empty($content)) { // if there is no content from component, get from module quick question $content = JRequest::getVar('quick_question_reply_content', '', 'post', 'none', JREQUEST_ALLOWRAW); } // some joomla editor htmlentity the content before it send to server. so we need // to do the god job to fix the content. $content = DiscussHelper::getHelper('String ')->unhtmlentities($content); // Ensure that the posted content is respecting the correct values. $data['dc_reply_content'] = $content; // Cleanup alias. $alias = DiscussHelper::wordFilter($data['title']); $data['alias'] = DiscussHelper::getAlias($alias, 'post', $post->id); // Detect the poster type. $data['user_type'] = empty($my->id) ? 'guest' : 'member'; // Akismet configurations. if ($config->get('antispam_akismet') && $config->get('antispam_akismet_key')) { require_once DISCUSS_CLASSES . '/akismet.php'; $params = array($data['title'], $data['dc_reply_content']); foreach ($params as $param) { $akismet = new Akismet(DISCUSS_JURIROOT, $config->get('antispam_akismet_key'), array('author' => $my->name, 'email' => $my->email, 'website' => DISCUSS_JURIROOT, 'body' => urlencode($param), 'alias' => '')); // Detect if there's any errors in Akismet. if (!$akismet->errorsExist() && $akismet->isSpam()) { DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_AKISMET_SPAM_DETECTED'), DISCUSS_QUEUE_ERROR); $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss&view=ask', false)); return $app->close(); } } } // Get previous status before binding. $prevPostStatus = $post->published; // If post is being edited, do not change the owner of the item. if (!$post->id) { $data['user_id'] = !$post->user_id ? $my->id : $post->user_id; } // Check permission to modify assignee $category = DiscussHelper::getTable('Category'); $access = $post->getAccess($category); if ($access->canAssign()) { $assignment = DiscussHelper::getTable('PostAssignment'); $assignment->load($post->id); // Add new record if assignee was changed if (array_key_exists('assignee_id', $data) && $assignment->assignee_id != $data['assignee_id']) { $newAssignment = DiscussHelper::getTable('PostAssignment'); $newAssignment->post_id = $post->id; $newAssignment->assignee_id = (int) $data['assignee_id']; $newAssignment->assigner_id = (int) JFactory::getUser()->id; if (!$newAssignment->store()) { $ajax->fail('Storing failed'); return $ajax->send(); } } } $data['content_type'] = DiscussHelper::getEditorType('question'); // Bind posted data against the table. $post->bind($data, true); // Set all post to be published by default. $post->published = DISCUSS_ID_PUBLISHED; // Detect if post should be moderated. if ($config->get('main_moderatepost') && !DiscussHelper::isSiteAdmin($post->user_id) && !DiscussHelper::isModerateThreshold($post->user_id)) { $post->published = DISCUSS_ID_PENDING; } // Bind posted parameters such as custom tab contents. $post->bindParams($data); // Check for maximum length of content if category has specific settings. $category = DiscussHelper::getTable('Category'); $category->load($post->category_id); // If there's a maximum content length specified per category base, then we need to check against the content. if ($category->getParam('maxlength')) { $length = JString::strlen($post->content); if ($length > $category->getParam('maxlength_size', 1000)) { DiscussHelper::storeSession($data, 'NEW_POST_TOKEN'); DiscussHelper::setMessageQueue(JText::sprintf('COM_EASYDISCUSS_MAXIMUM_LENGTH_EXCEEDED', $category->getParam('maxlength_size', 1000)), DISCUSS_QUEUE_ERROR); $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss&view=ask', false)); return $app->close(); } } // If user tries to submit in a container, throw an error. if ($category->container) { DiscussHelper::storeSession($data, 'NEW_POST_TOKEN'); DiscussHelper::setMessageQueue(JText::_('COM_EASYDISCUSS_NOT_ALLOWED_TO_POST_INTO_CONTAINER'), DISCUSS_QUEUE_ERROR); $app->redirect(DiscussRouter::_('index.php?option=com_easydiscuss&view=ask', false)); return $app->close(); } // @trigger: onBeforeSave DiscussEventsHelper::importPlugin('content'); DiscussEventsHelper::onContentBeforeSave('post', $post, $isNew); // If password is disabled, do not allow users to set password. if (!$config->get('main_password_protection')) { $post->password = ''; } // Detect user's ip address. $ip = JRequest::getVar('REMOTE_ADDR', '', 'SERVER'); $post->ip = $ip; // Try to store the post object. if (!$post->store()) { DiscussHelper::setMessageQueue($post->getError(), DISCUSS_QUEUE_ERROR); $app->redirect(DiscussRouter::getAskRoute($category->id, false)); return $app->close(); } // API: References. $reference = JRequest::getWord('reference', ''); $referenceId = JRequest::getInt('reference_id', 0); if (!empty($reference) && !empty($referenceId)) { $referenceTable = DiscussHelper::getTable('PostsReference'); $referenceTable->extension = $reference; $referenceTable->post_id = $post->id; $referenceTable->reference_id = $referenceId; $referenceTable->store(); } //Clear off previous records before storing $ruleModel = DiscussHelper::getModel('CustomFields'); $ruleModel->deleteCustomFieldsValue($post->id, 'update'); // Process custom fields. $fieldIds = JRequest::getVar('customFields'); if (!empty($fieldIds)) { foreach ($fieldIds as $fieldId) { $fields = JRequest::getVar('customFieldValue_' . $fieldId); if (!empty($fields)) { // Cater for custom fields select list // To detect if there is no value selected for the select list custom fields if (in_array('defaultList', $fields)) { $tempKey = array_search('defaultList', $fields); $fields[$tempKey] = ''; } } $post->bindCustomFields($fields, $fieldId); } } // @trigger: onAfterSave DiscussEventsHelper::onContentAfterSave('post', $post, $isNew); // The category_id for the replies should change too $post->moveChilds($post->id, $post->category_id); // Process poll items. if ($config->get('main_polls')) { $polls = JRequest::getVar('pollitems'); if (!is_array($polls)) { $polls = array($polls); } // If the post is being edited and // there is only 1 poll item which is also empty, // we need to delete existing polls tied to this post. if (count($polls) == 1 && empty($polls[0]) && !$isNew) { $post->removePoll(); } if (count($polls) > 0) { $hasPolls = false; foreach ($polls as $poll) { // As long as there is 1 valid poll, we need to store them. if (!empty($poll)) { $hasPolls = true; break; } } if ($hasPolls) { // Check if the multiple polls checkbox is it checked? $multiplePolls = JRequest::getVar('multiplePolls', '0'); // Get the poll question here. $pollQuestion = JRequest::getVar('poll_question', ''); // Try to detect which poll items needs to be removed. $removePolls = JRequest::getVar('pollsremove'); // Get the poll items. $pollItems = JRequest::getVar('pollitems'); $pollItemsOri = JRequest::getVar('pollitemsOri'); // Store the polls now. $post->bindPolls($isNew, $pollItems, $removePolls, $multiplePolls, $pollQuestion, $pollItemsOri); } } } // Bind file attachments if ($acl->allowed('add_attachment') && $config->get('attachment_questions')) { $post->bindAttachments(); } // Detect if the current post should be moderated or not. $isModerate = $post->published == DISCUSS_ID_PENDING ? true : false; // Process auto posting for posts that are really published and is in a public category. if ($post->published == DISCUSS_ID_PUBLISHED && $category->canPublicAccess()) { $post->autopost(); } // Detect known names in the post. $names = DiscussHelper::getHelper('String')->detectNames($post->content); if ($names) { foreach ($names as $name) { $name = JString::str_ireplace('@', '', $name); $id = DiscussHelper::getUserId($name); if (!$id || $id == $post->get('user_id')) { continue; } $notification = DiscussHelper::getTable('Notifications'); $notification->bind(array('title' => JText::sprintf('COM_EASYDISCUSS_MENTIONED_QUESTION_NOTIFICATION_TITLE', $post->get('title')), 'cid' => $post->get('id'), 'type' => DISCUSS_NOTIFICATIONS_MENTIONED, 'target' => $id, 'author' => $post->get('user_id'), 'permalink' => 'index.php?option=com_easydiscuss&view=post&id=' . $post->get('id'))); $notification->store(); } } if (($isNew || $prevPostStatus == DISCUSS_ID_PENDING) && $post->published == DISCUSS_ID_PUBLISHED) { $post->ping(); } $notify = DiscussHelper::getNotification(); // badwords filtering for email data. $post->title = DiscussHelper::wordFilter($post->title); $post->content = DiscussHelper::wordFilter($post->content); if ($acl->allowed('add_tag', '0')) { //@task: Save tags $postTagModel = $this->getModel('PostsTags'); $tags = JRequest::getVar('tags', '', 'POST'); if (!empty($tags)) { $tagModel = $this->getModel('Tags'); foreach ($tags as $tag) { if (!empty($tag)) { $tagTable = DiscussHelper::getTable('Tags'); //@task: Only add tags if it doesn't exist. if (!$tagTable->exists($tag)) { $tagTable->set('title', JString::trim($tag)); $tagTable->set('alias', DiscussHelper::getAlias($tag, 'tag')); $tagTable->set('created', DiscussHelper::getDate()->toMySQL()); $tagTable->set('published', 1); $tagTable->set('user_id', $my->id); $tagTable->store(); } else { $tagTable->load($tag, true); } $postTagInfo = array(); //@task: Store in the post tag $postTagTable = DiscussHelper::getTable('PostsTags'); $postTagInfo['post_id'] = $post->id; $postTagInfo['tag_id'] = $tagTable->id; $postTagTable->bind($postTagInfo); $postTagTable->store(); } } } } // prepare email content and information. $profile = DiscussHelper::getTable('Profile'); $profile->load($my->id); // For use within the emails. $emailData = array(); $emailData['postTitle'] = $post->title; $emailData['postAuthor'] = $profile->id ? $profile->getName() : $post->poster_name; $emailData['postAuthorAvatar'] = $profile->getAvatar(); $emailData['postLink'] = DiscussRouter::getRoutedURL('index.php?option=com_easydiscuss&view=post&id=' . $post->id, false, true); $emailContent = $post->content; if ($post->content_type != 'html') { // the content is bbcode. we need to parse it. $emailContent = EasyDiscussParser::bbcode($emailContent); $emailContent = EasyDiscussParser::removeBrTag($emailContent); } // If post is html type we need to strip off html codes. if ($post->content_type == 'html') { $emailContent = strip_tags($post->content); } $emailContent = $post->trimEmail($emailContent); $attachments = $post->getAttachments(); $emailData['attachments'] = $attachments; $emailData['postContent'] = $emailContent; $emailData['post_id'] = $post->id; $emailData['cat_id'] = $post->category_id; $emailData['emailTemplate'] = 'email.subscription.site.new.php'; $emailData['emailSubject'] = JText::sprintf('COM_EASYDISCUSS_NEW_QUESTION_ASKED', $post->id, $post->title); if ($isModerate) { // Generate hashkeys to map this current request $hashkey = DiscussHelper::getTable('HashKeys'); $hashkey->uid = $post->id; $hashkey->type = DISCUSS_QUESTION_TYPE; $hashkey->store(); require_once DISCUSS_HELPERS . '/router.php'; $approveURL = DiscussHelper::getExternalLink('index.php?option=com_easydiscuss&controller=posts&task=approvePost&key=' . $hashkey->key); $rejectURL = DiscussHelper::getExternalLink('index.php?option=com_easydiscuss&controller=posts&task=rejectPost&key=' . $hashkey->key); $emailData['moderation'] = '<div style="display:inline-block;width:100%;padding:20px;border-top:1px solid #ccc;padding:20px 0 10px;margin-top:20px;line-height:19px;color:#555;font-family:\'Lucida Grande\',Tahoma,Arial;font-size:12px;text-align:left">'; $emailData['moderation'] .= '<a href="' . $approveURL . '" style="display:inline-block;padding:5px 15px;background:#fc0;border:1px solid #caa200;border-bottom-color:#977900;color:#534200;text-shadow:0 1px 0 #ffe684;font-weight:bold;box-shadow:inset 0 1px 0 #ffe064;-moz-box-shadow:inset 0 1px 0 #ffe064;-webkit-box-shadow:inset 0 1px 0 #ffe064;border-radius:2px;moz-border-radius:2px;-webkit-border-radius:2px;text-decoration:none!important">' . JText::_('COM_EASYDISCUSS_EMAIL_APPROVE_POST') . '</a>'; $emailData['moderation'] .= ' ' . JText::_('COM_EASYDISCUSS_OR') . ' <a href="' . $rejectURL . '" style="color:#477fda">' . JText::_('COM_EASYDISCUSS_REJECT') . '</a>'; $emailData['moderation'] .= '</div>'; $emailData['emailTemplate'] = 'email.subscription.site.moderate.php'; $emailData['emailSubject'] = JText::sprintf('COM_EASYDISCUSS_NEW_QUESTION_MODERATE', $post->id, $post->title); } else { // If this is a private post, do not notify anyone if (!$post->private && $category->canPublicAccess()) { // Notify site subscribers if ($config->get('main_sitesubscription') && ($isNew || $prevPostStatus == DISCUSS_ID_PENDING) && $post->published == DISCUSS_ID_PUBLISHED && !$config->get('notify_all')) { DiscussHelper::getHelper('Mailer')->notifySubscribers($emailData, array($my->email)); } // Notify category subscribers if ($config->get('main_ed_categorysubscription') && ($isNew || $prevPostStatus == DISCUSS_ID_PENDING) && $post->published == DISCUSS_ID_PUBLISHED && !$config->get('notify_all')) { DiscussHelper::getHelper('Mailer')->notifySubscribers($emailData, array($my->email)); } // Notify EVERYBODY if ($config->get('notify_all') && !$isModerate) { DiscussHelper::getHelper('Mailer')->notifyAllMembers($emailData, array($my->email)); } } } // Notify admins and category moderators if ($isNew || $prevPostStatus == DISCUSS_ID_PENDING) { DiscussHelper::getHelper('Mailer')->notifyAdministrators($emailData, array($my->email), $config->get('notify_admin'), $config->get('notify_moderator')); } // @rule: Jomsocial activity integrations & points & ranking if (($isNew || $prevPostStatus == DISCUSS_ID_PENDING) && $post->published == DISCUSS_ID_PUBLISHED && !$post->private) { DiscussHelper::getHelper('jomsocial')->addActivityQuestion($post); DiscussHelper::getHelper('easysocial')->createDiscussionStream($post); // Add notification to subscribers DiscussHelper::getHelper('easysocial')->notify('new.discussion', $post); // Add logging for user. DiscussHelper::getHelper('History')->log('easydiscuss.new.discussion', $my->id, JText::sprintf('COM_EASYDISCUSS_BADGES_HISTORY_NEW_POST', $post->title), $post->id); DiscussHelper::getHelper('Badges')->assign('easydiscuss.new.discussion', $my->id); DiscussHelper::getHelper('Points')->assign('easydiscuss.new.discussion', $my->id); // Assign badge for EasySocial DiscussHelper::getHelper('EasySocial')->assignBadge('create.question', $my->id, JText::sprintf('COM_EASYDISCUSS_BADGES_HISTORY_NEW_POST', $post->title)); // assign new ranks. DiscussHelper::getHelper('ranks')->assignRank($my->id, $config->get('main_ranking_calc_type')); // aup DiscussHelper::getHelper('Aup')->assign(DISCUSS_POINTS_NEW_DISCUSSION, $my->id, $post->title); } $message = $isNew ? JText::_('COM_EASYDISCUSS_POST_STORED') : JText::_('COM_EASYDISCUSS_EDIT_SUCCESS'); $state = 'success'; // Let's set our custom message here. if (!$post->isPending()) { DiscussHelper::setMessageQueue($message, $state); } $redirect = JRequest::getVar('redirect', ''); if (!empty($redirect)) { $redirect = base64_decode($redirect); return $this->setRedirect($redirect); } $redirectionOption = $config->get('main_post_redirection'); switch ($redirectionOption) { case 'default': $redirect = DiscussRouter::getPostRoute($post->id, false); break; case 'home': $redirect = DiscussRouter::_('index.php?option=com_easydiscuss&view=index', false); break; case 'mainCategory': $redirect = DiscussRouter::_('index.php?option=com_easydiscuss&view=categories', false); break; case 'currentCategory': $redirect = DiscussRouter::getCategoryRoute($post->category_id, false); break; default: $redirect = DiscussRouter::getPostRoute($post->id, false); break; } $this->setRedirect($redirect); }