mirror of
https://github.com/Oreolek/ifhub.club.git
synced 2024-07-08 01:14:24 +03:00
546 lines
17 KiB
PHP
546 lines
17 KiB
PHP
<?php
|
||
/*-------------------------------------------------------
|
||
*
|
||
* LiveStreet Engine Social Networking
|
||
* Copyright © 2008 Mzhelskiy Maxim
|
||
*
|
||
*--------------------------------------------------------
|
||
*
|
||
* Official site: www.livestreet.ru
|
||
* Contact e-mail: rus.engine@gmail.com
|
||
*
|
||
* GNU General Public License, version 2:
|
||
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
||
*
|
||
---------------------------------------------------------
|
||
*/
|
||
|
||
/**
|
||
* Обработка УРЛа вида /question/ - управление своими топиками(тип: вопрос)
|
||
*
|
||
*/
|
||
class ActionQuestion extends Action {
|
||
/**
|
||
* Главное меню
|
||
*
|
||
* @var unknown_type
|
||
*/
|
||
protected $sMenuHeadItemSelect='blog';
|
||
/**
|
||
* Меню
|
||
*
|
||
* @var unknown_type
|
||
*/
|
||
protected $sMenuItemSelect='question';
|
||
/**
|
||
* СубМеню
|
||
*
|
||
* @var unknown_type
|
||
*/
|
||
protected $sMenuSubItemSelect='add';
|
||
/**
|
||
* Текущий юзер
|
||
*
|
||
* @var unknown_type
|
||
*/
|
||
protected $oUserCurrent=null;
|
||
|
||
/**
|
||
* Инициализация
|
||
*
|
||
* @return unknown
|
||
*/
|
||
public function Init() {
|
||
/**
|
||
* Проверяем авторизован ли юзер
|
||
*/
|
||
if (!$this->User_IsAuthorization()) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('not_access'),$this->Lang_Get('error'));
|
||
return Router::Action('error');
|
||
}
|
||
$this->oUserCurrent=$this->User_GetUserCurrent();
|
||
$this->SetDefaultEvent('add');
|
||
$this->Viewer_AddHtmlTitle($this->Lang_Get('topic_question_title'));
|
||
|
||
/**
|
||
* Загружаем в шаблон JS текстовки
|
||
*/
|
||
$this->Lang_AddLangJs(array(
|
||
'topic_question_create_answers_error_max','delete'
|
||
));
|
||
}
|
||
/**
|
||
* Регистрируем евенты
|
||
*
|
||
*/
|
||
protected function RegisterEvent() {
|
||
$this->AddEvent('add','EventAdd');
|
||
$this->AddEvent('edit','EventEdit');
|
||
}
|
||
|
||
|
||
/**********************************************************************************
|
||
************************ РЕАЛИЗАЦИЯ ЭКШЕНА ***************************************
|
||
**********************************************************************************
|
||
*/
|
||
|
||
/**
|
||
* Редактирование ссылки
|
||
*
|
||
* @return unknown
|
||
*/
|
||
protected function EventEdit() {
|
||
/**
|
||
* Меню
|
||
*/
|
||
$this->sMenuSubItemSelect='';
|
||
$this->sMenuItemSelect='question';
|
||
/**
|
||
* Получаем номер топика из УРЛ и проверяем существует ли он
|
||
*/
|
||
$sTopicId=$this->GetParam(0);
|
||
if (!($oTopic=$this->Topic_GetTopicById($sTopicId))) {
|
||
return parent::EventNotFound();
|
||
}
|
||
/**
|
||
* Проверяем тип топика
|
||
*/
|
||
if ($oTopic->getType()!='question') {
|
||
return parent::EventNotFound();
|
||
}
|
||
/**
|
||
* Если права на редактирование
|
||
*/
|
||
if (!$this->ACL_IsAllowEditTopic($oTopic,$this->oUserCurrent)) {
|
||
return parent::EventNotFound();
|
||
}
|
||
/**
|
||
* Вызов хуков
|
||
*/
|
||
$this->Hook_Run('topic_edit_show',array('oTopic'=>$oTopic));
|
||
/**
|
||
* Загружаем переменные в шаблон
|
||
*/
|
||
$this->Viewer_Assign('aBlogsAllow',$this->Blog_GetBlogsAllowByUser($this->oUserCurrent));
|
||
$this->Viewer_Assign('bEditDisabled',$oTopic->getQuestionCountVote()==0 ? false : true);
|
||
$this->Viewer_AddHtmlTitle($this->Lang_Get('topic_question_title_edit'));
|
||
/**
|
||
* Устанавливаем шаблон вывода
|
||
*/
|
||
$this->SetTemplateAction('add');
|
||
/**
|
||
* Проверяем отправлена ли форма с данными(хотяб одна кнопка)
|
||
*/
|
||
if (isset($_REQUEST['submit_topic_publish']) or isset($_REQUEST['submit_topic_save'])) {
|
||
/**
|
||
* Обрабатываем отправку формы
|
||
*/
|
||
return $this->SubmitEdit($oTopic);
|
||
} else {
|
||
/**
|
||
* Заполняем поля формы для редактирования
|
||
* Только перед отправкой формы!
|
||
*/
|
||
$_REQUEST['topic_title']=$oTopic->getTitle();
|
||
$_REQUEST['topic_text']=$oTopic->getTextSource();
|
||
$_REQUEST['topic_tags']=$oTopic->getTags();
|
||
$_REQUEST['blog_id']=$oTopic->getBlogId();
|
||
$_REQUEST['topic_id']=$oTopic->getId();
|
||
$_REQUEST['topic_publish_index']=$oTopic->getPublishIndex();
|
||
$_REQUEST['topic_forbid_comment']=$oTopic->getForbidComment();
|
||
|
||
$_REQUEST['answer']=array();
|
||
$aAnswers=$oTopic->getQuestionAnswers();
|
||
foreach ($aAnswers as $aAnswer) {
|
||
$_REQUEST['answer'][]=$aAnswer['text'];
|
||
}
|
||
}
|
||
}
|
||
/**
|
||
* Добавление ссылки
|
||
*
|
||
* @return unknown
|
||
*/
|
||
protected function EventAdd() {
|
||
/**
|
||
* Меню
|
||
*/
|
||
$this->sMenuSubItemSelect='add';
|
||
/**
|
||
* Загружаем переменные в шаблон
|
||
*/
|
||
$this->Viewer_Assign('aBlogsAllow',$this->Blog_GetBlogsAllowByUser($this->oUserCurrent));
|
||
$this->Viewer_Assign('bEditDisabled',false);
|
||
$this->Viewer_AddHtmlTitle($this->Lang_Get('topic_question_title_create'));
|
||
/**
|
||
* Обрабатываем отправку формы
|
||
*/
|
||
return $this->SubmitAdd();
|
||
}
|
||
|
||
/**
|
||
* Обработка добавлени топика
|
||
*
|
||
* @return unknown
|
||
*/
|
||
protected function SubmitAdd() {
|
||
/**
|
||
* Проверяем отправлена ли форма с данными(хотяб одна кнопка)
|
||
*/
|
||
if (!isPost('submit_topic_publish') and !isPost('submit_topic_save')) {
|
||
return false;
|
||
}
|
||
/**
|
||
* Проверка корректности полей формы
|
||
*/
|
||
if (!$this->checkTopicFields()) {
|
||
return false;
|
||
}
|
||
/**
|
||
* Определяем в какой блог делаем запись
|
||
*/
|
||
$iBlogId=getRequest('blog_id');
|
||
if ($iBlogId==0) {
|
||
$oBlog=$this->Blog_GetPersonalBlogByUserId($this->oUserCurrent->getId());
|
||
} else {
|
||
$oBlog=$this->Blog_GetBlogById($iBlogId);
|
||
}
|
||
/**
|
||
* Если блог не определен выдаем предупреждение
|
||
*/
|
||
if (!$oBlog) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_create_blog_error_unknown'),$this->Lang_Get('error'));
|
||
return false;
|
||
}
|
||
/**
|
||
* Проверяем права на постинг в блог
|
||
*/
|
||
if (!$this->ACL_IsAllowBlog($oBlog,$this->oUserCurrent)) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_create_blog_error_noallow'),$this->Lang_Get('error'));
|
||
return false;
|
||
}
|
||
/**
|
||
* Проверяем разрешено ли постить топик по времени
|
||
*/
|
||
if (isPost('submit_topic_publish') and !$this->ACL_CanPostTopicTime($this->oUserCurrent)) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_time_limit'),$this->Lang_Get('error'));
|
||
return;
|
||
}
|
||
/**
|
||
* Теперь можно смело добавлять топик к блогу
|
||
*/
|
||
$oTopic=Engine::GetEntity('Topic');
|
||
$oTopic->setBlogId($oBlog->getId());
|
||
$oTopic->setUserId($this->oUserCurrent->getId());
|
||
$oTopic->setType('question');
|
||
$oTopic->setTitle(getRequest('topic_title'));
|
||
$oTopic->setText(htmlspecialchars(getRequest('topic_text')));
|
||
$oTopic->setTextShort(htmlspecialchars(getRequest('topic_text')));
|
||
$oTopic->setTextSource(getRequest('topic_text'));
|
||
$oTopic->setTags(getRequest('topic_tags'));
|
||
$oTopic->setDateAdd(date("Y-m-d H:i:s"));
|
||
$oTopic->setUserIp(func_getIp());
|
||
$oTopic->setCutText(null);
|
||
$oTopic->setTextHash(md5($oTopic->getType().$oTopic->getText().$oTopic->getTitle()));
|
||
/**
|
||
* Проверяем топик на уникальность
|
||
*/
|
||
if ($oTopicEquivalent=$this->Topic_GetTopicUnique($this->oUserCurrent->getId(),$oTopic->getTextHash())) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_create_text_error_unique'),$this->Lang_Get('error'));
|
||
return false;
|
||
}
|
||
/**
|
||
* Варианты ответов
|
||
*/
|
||
$oTopic->clearQuestionAnswer();
|
||
foreach (getRequest('answer',array()) as $sAnswer) {
|
||
$oTopic->addQuestionAnswer($sAnswer);
|
||
}
|
||
/**
|
||
* Публикуем или сохраняем
|
||
*/
|
||
if (isset($_REQUEST['submit_topic_publish'])) {
|
||
$oTopic->setPublish(1);
|
||
$oTopic->setPublishDraft(1);
|
||
} else {
|
||
$oTopic->setPublish(0);
|
||
$oTopic->setPublishDraft(0);
|
||
}
|
||
/**
|
||
* Принудительный вывод на главную
|
||
*/
|
||
$oTopic->setPublishIndex(0);
|
||
if ($this->ACL_IsAllowPublishIndex($this->oUserCurrent)) {
|
||
if (getRequest('topic_publish_index')) {
|
||
$oTopic->setPublishIndex(1);
|
||
}
|
||
}
|
||
/**
|
||
* Запрет на комментарии к топику
|
||
*/
|
||
$oTopic->setForbidComment(0);
|
||
if (getRequest('topic_forbid_comment')) {
|
||
$oTopic->setForbidComment(1);
|
||
}
|
||
/**
|
||
* Запускаем выполнение хуков
|
||
*/
|
||
$this->Hook_Run('topic_add_before', array('oTopic'=>$oTopic,'oBlog'=>$oBlog));
|
||
/**
|
||
* Добавляем топик
|
||
*/
|
||
if ($this->Topic_AddTopic($oTopic)) {
|
||
$this->Hook_Run('topic_add_after', array('oTopic'=>$oTopic,'oBlog'=>$oBlog));
|
||
/**
|
||
* Получаем топик, чтоб подцепить связанные данные
|
||
*/
|
||
$oTopic=$this->Topic_GetTopicById($oTopic->getId());
|
||
//Делаем рассылку спама всем, кто состоит в этом блоге
|
||
if ($oTopic->getPublish()==1 and $oBlog->getType()!='personal') {
|
||
$this->Topic_SendNotifyTopicNew($oBlog,$oTopic,$this->oUserCurrent);
|
||
}
|
||
/**
|
||
* Добавляем событие в ленту
|
||
*/
|
||
$this->Stream_write($oTopic->getUserId(), 'add_topic', $oTopic->getId(),$oTopic->getPublish() && $oBlog->getType()!='close');
|
||
Router::Location($oTopic->getUrl());
|
||
} else {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('system_error'));
|
||
return Router::Action('error');
|
||
}
|
||
}
|
||
/**
|
||
* Обработка редактирования топика
|
||
*
|
||
* @param unknown_type $oTopic
|
||
* @return unknown
|
||
*/
|
||
protected function SubmitEdit($oTopic) {
|
||
/**
|
||
* Проверка корректности полей формы
|
||
*/
|
||
if (!$this->checkTopicFields($oTopic)) {
|
||
return false;
|
||
}
|
||
/**
|
||
* Определяем в какой блог делаем запись
|
||
*/
|
||
$iBlogId=getRequest('blog_id');
|
||
if ($iBlogId==0) {
|
||
$oBlog=$this->Blog_GetPersonalBlogByUserId($oTopic->getUserId());
|
||
} else {
|
||
$oBlog=$this->Blog_GetBlogById($iBlogId);
|
||
}
|
||
/**
|
||
* Если блог не определен выдаем предупреждение
|
||
*/
|
||
if (!$oBlog) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_create_blog_error_unknown'),$this->Lang_Get('error'));
|
||
return false;
|
||
}
|
||
/**
|
||
* Проверяем права на постинг в блог
|
||
*/
|
||
if (!$this->ACL_IsAllowBlog($oBlog,$this->oUserCurrent)) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_create_blog_error_noallow'),$this->Lang_Get('error'));
|
||
return false;
|
||
}
|
||
/**
|
||
* Проверяем разрешено ли постить топик по времени
|
||
*/
|
||
if (isPost('submit_topic_publish') and !$oTopic->getPublishDraft() and !$this->ACL_CanPostTopicTime($this->oUserCurrent)) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_time_limit'),$this->Lang_Get('error'));
|
||
return;
|
||
}
|
||
/**
|
||
* Теперь можно смело редактировать топик
|
||
*/
|
||
$oTopic->setBlogId($oBlog->getId());
|
||
$oTopic->setText(htmlspecialchars(getRequest('topic_text')));
|
||
$oTopic->setTextShort(htmlspecialchars(getRequest('topic_text')));
|
||
$oTopic->setTextSource(getRequest('topic_text'));
|
||
$oTopic->setTags(getRequest('topic_tags'));
|
||
$oTopic->setUserIp(func_getIp());
|
||
|
||
/**
|
||
* изменяем вопрос/ответы только если еще никто не голосовал
|
||
*/
|
||
if ($oTopic->getQuestionCountVote()==0) {
|
||
$oTopic->setTitle(getRequest('topic_title'));
|
||
$oTopic->clearQuestionAnswer();
|
||
foreach (getRequest('answer',array()) as $sAnswer) {
|
||
$oTopic->addQuestionAnswer($sAnswer);
|
||
}
|
||
}
|
||
$oTopic->setTextHash(md5($oTopic->getType().$oTopic->getText().$oTopic->getTitle()));
|
||
/**
|
||
* Проверяем топик на уникальность
|
||
*/
|
||
if ($oTopicEquivalent=$this->Topic_GetTopicUnique($this->oUserCurrent->getId(),$oTopic->getTextHash())) {
|
||
if ($oTopicEquivalent->getId()!=$oTopic->getId()) {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('topic_create_text_error_unique'),$this->Lang_Get('error'));
|
||
return false;
|
||
}
|
||
}
|
||
/**
|
||
* Публикуем или сохраняем в черновиках
|
||
*/
|
||
$bSendNotify=false;
|
||
if (isset($_REQUEST['submit_topic_publish'])) {
|
||
$oTopic->setPublish(1);
|
||
if ($oTopic->getPublishDraft()==0) {
|
||
$oTopic->setPublishDraft(1);
|
||
$oTopic->setDateAdd(date("Y-m-d H:i:s"));
|
||
$bSendNotify=true;
|
||
}
|
||
} else {
|
||
$oTopic->setPublish(0);
|
||
}
|
||
/**
|
||
* Принудительный вывод на главную
|
||
*/
|
||
if ($this->ACL_IsAllowPublishIndex($this->oUserCurrent)) {
|
||
if (getRequest('topic_publish_index')) {
|
||
$oTopic->setPublishIndex(1);
|
||
} else {
|
||
$oTopic->setPublishIndex(0);
|
||
}
|
||
}
|
||
/**
|
||
* Запрет на комментарии к топику
|
||
*/
|
||
$oTopic->setForbidComment(0);
|
||
if (getRequest('topic_forbid_comment')) {
|
||
$oTopic->setForbidComment(1);
|
||
}
|
||
$this->Hook_Run('topic_edit_before', array('oTopic'=>$oTopic,'oBlog'=>$oBlog));
|
||
/**
|
||
* Сохраняем топик
|
||
*/
|
||
if ($this->Topic_UpdateTopic($oTopic)) {
|
||
$this->Hook_Run('topic_edit_after', array('oTopic'=>$oTopic,'oBlog'=>$oBlog,'bSendNotify'=>&$bSendNotify));
|
||
/**
|
||
* Добавляем событие в ленту
|
||
*/
|
||
$this->Stream_write($oTopic->getUserId(), 'add_topic', $oTopic->getId(),$oTopic->getPublish() && $oBlog->getType()!='close');
|
||
/**
|
||
* Рассылаем о новом топике подписчикам блога
|
||
*/
|
||
if ($bSendNotify) {
|
||
$this->Topic_SendNotifyTopicNew($oBlog,$oTopic,$this->oUserCurrent);
|
||
}
|
||
if (!$oTopic->getPublish() and !$this->oUserCurrent->isAdministrator() and $this->oUserCurrent->getId()!=$oTopic->getUserId()) {
|
||
Router::Location($oBlog->getUrlFull());
|
||
}
|
||
Router::Location($oTopic->getUrl());
|
||
} else {
|
||
$this->Message_AddErrorSingle($this->Lang_Get('system_error'));
|
||
return Router::Action('error');
|
||
}
|
||
}
|
||
/**
|
||
* Проверка полей формы
|
||
*
|
||
* @return unknown
|
||
*/
|
||
protected function checkTopicFields($oTopic=null) {
|
||
$this->Security_ValidateSendForm();
|
||
|
||
$bOk=true;
|
||
/**
|
||
* Проверяем есть ли блог в кторый постим
|
||
*/
|
||
if (!func_check(getRequest('blog_id',null,'post'),'id')) {
|
||
$this->Message_AddError($this->Lang_Get('topic_create_blog_error_unknown'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
}
|
||
|
||
/**
|
||
* Проверяем есть ли описание вопроса
|
||
*/
|
||
if (!func_check(getRequest('topic_text',null,'post'),'text',0,500)) {
|
||
$this->Message_AddError($this->Lang_Get('topic_question_create_text_error'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
}
|
||
|
||
/**
|
||
* проверяем заполнение вопроса/ответов только если еще никто не голосовал
|
||
*/
|
||
if (is_null($oTopic) or $oTopic->getQuestionCountVote()==0) {
|
||
/**
|
||
* Проверяем есть ли заголовок топика(вопрос)
|
||
*/
|
||
if (!func_check(getRequest('topic_title',null,'post'),'text',2,200)) {
|
||
$this->Message_AddError($this->Lang_Get('topic_question_create_title_error'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
}
|
||
/**
|
||
* Проверяем варианты ответов
|
||
*/
|
||
$aAnswers=getRequest('answer',array());
|
||
foreach ($aAnswers as $key => $sAnswer) {
|
||
if (trim($sAnswer)=='') {
|
||
unset($aAnswers[$key]);
|
||
continue;
|
||
}
|
||
if (!func_check($sAnswer,'text',1,100)) {
|
||
$this->Message_AddError($this->Lang_Get('topic_question_create_answers_error'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
break;
|
||
}
|
||
}
|
||
$_REQUEST['answer']=$aAnswers;
|
||
if (count($aAnswers)<2) {
|
||
$this->Message_AddError($this->Lang_Get('topic_question_create_answers_error_min'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
}
|
||
if (count($aAnswers)>20) {
|
||
$this->Message_AddError($this->Lang_Get('topic_question_create_answers_error_max'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Проверяем есть ли теги(метки)
|
||
*/
|
||
if (!func_check(getRequest('topic_tags',null,'post'),'text',2,500)) {
|
||
$this->Message_AddError($this->Lang_Get('topic_create_tags_error'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
}
|
||
/**
|
||
* проверяем ввод тегов
|
||
*/
|
||
$sTags=getRequest('topic_tags');
|
||
$aTags=explode(',',rtrim($sTags,"\r\n\t\0\x0B ."));
|
||
$aTagsNew=array();
|
||
foreach ($aTags as $sTag) {
|
||
$sTag=trim($sTag);
|
||
if (func_check($sTag,'text',2,50)) {
|
||
$aTagsNew[]=$sTag;
|
||
}
|
||
}
|
||
if (!count($aTagsNew)) {
|
||
$this->Message_AddError($this->Lang_Get('topic_create_tags_error_bad'),$this->Lang_Get('error'));
|
||
$bOk=false;
|
||
} else {
|
||
$_REQUEST['topic_tags']=join(',',$aTagsNew);
|
||
}
|
||
|
||
/**
|
||
* Выполнение хуков
|
||
*/
|
||
$this->Hook_Run('check_question_fields', array('bOk'=>&$bOk));
|
||
|
||
return $bOk;
|
||
}
|
||
/**
|
||
* При завершении экшена загружаем необходимые переменные
|
||
*
|
||
*/
|
||
public function EventShutdown() {
|
||
$this->Viewer_Assign('sMenuHeadItemSelect',$this->sMenuHeadItemSelect);
|
||
$this->Viewer_Assign('sMenuItemSelect',$this->sMenuItemSelect);
|
||
$this->Viewer_Assign('sMenuSubItemSelect',$this->sMenuSubItemSelect);
|
||
}
|
||
}
|
||
?>
|