function __FPF_AddEntityInForumFiles(&$arCustomFile, $arParams = null) { static $arFileParams = array(); if ($arParams !== null) { $arFileParams = $arParams; } $arFiles = array(array("FILE_ID" => $arCustomFile["fileID"])); if (!is_array($arCustomFile) || !isset($arCustomFile['fileID'])) { return false; } elseif (!CForumFiles::CheckFields($arFiles, $arFileParams, "NOT_CHECK_DB")) { $ex = $GLOBALS["APPLICATION"]->GetException(); return $ex ? $ex->GetString() : "File upload error."; } elseif (!empty($arFiles)) { $GLOBALS["APPLICATION"]->RestartBuffer(); CForumFiles::Add($arCustomFile['fileID'], $arFileParams); } }
public static function OnFileUploadToMFI(&$arCustomFile, $arParams = null) { static $arFileParams = array(); if ($arParams !== null) { $arFileParams = $arParams; } $arFiles = array(array("FILE_ID" => $arCustomFile["fileID"])); if (!is_array($arCustomFile) || !isset($arCustomFile['fileID'])) { return false; } elseif (!CForumFiles::CheckFields($arFiles, $arFileParams, "NOT_CHECK_DB", array("FORUM" => $arFileParams["ALLOW"]))) { $ex = $GLOBALS["APPLICATION"]->GetException(); $res = $ex ? $ex->GetString() : "File upload error."; return $res; } elseif (!empty($arFiles)) { $GLOBALS["APPLICATION"]->RestartBuffer(); CForumFiles::Add($arCustomFile["fileID"], $arFileParams); } }
private function prepareFields(array &$params, ErrorCollection $errorCollectionParam) { $result = array("FORUM_ID" => $this->topic["FORUM_ID"], "TOPIC_ID" => $this->topic["ID"], "POST_MESSAGE" => trim($params["POST_MESSAGE"]), "AUTHOR_ID" => $params["AUTHOR_ID"], "AUTHOR_NAME" => trim($params["AUTHOR_NAME"]), "AUTHOR_EMAIL" => trim($params["AUTHOR_EMAIL"]), "USE_SMILES" => $params["USE_SMILES"] == "Y" ? "Y" : "N", "APPROVED" => $this->topic["APPROVED"], "XML_ID" => $this->getEntity()->getXmlId()); $errorCollection = new ErrorCollection(); if (strlen($result["POST_MESSAGE"]) <= 0) { $errorCollection->addOne(new Error(Loc::getMessage("FORUM_CM_ERR_EMPTY_TEXT"), self::ERROR_PARAMS_MESSAGE)); } if (strlen($result["AUTHOR_NAME"]) <= 0 && $result["AUTHOR_ID"] > 0) { $result["AUTHOR_NAME"] = self::getUserName($result["AUTHOR_ID"]); } if (strlen($result["AUTHOR_NAME"]) <= 0) { $errorCollection->addOne(new Error(Loc::getMessage("FORUM_CM_ERR_EMPTY_AUTHORS_NAME"), self::ERROR_PARAMS_MESSAGE)); } if (is_array($params["FILES"]) && in_array($this->forum["ALLOW_UPLOAD"], array("Y", "F", "A"))) { $result["FILES"] = array(); foreach ($params["FILES"] as $key => $val) { if (intval($val["FILE_ID"]) > 0) { $val["del"] = $val["del"] == "Y" ? "Y" : ""; } $result["FILES"][$key] = $val; } $res = array("FORUM_ID" => $this->forum["ID"], "TOPIC_ID" => $this->topic["ID"], "MESSAGE_ID" => 0, "USER_ID" => $result["AUTHOR_ID"], "FORUM" => $this->forum); if (!\CForumFiles::CheckFields($result["FILES"], $res, "NOT_CHECK_DB")) { $text = "File upload error."; if (($ex = $this->getApplication()->getException()) && $ex) { $text = $ex->getString(); } $errorCollection->addOne(new Error($text, self::ERROR_PARAMS_MESSAGE)); } } if ($result["APPROVED"] != "N") { $result["APPROVED"] = $this->forum["MODERATION"] != "Y" || $this->getEntity()->canModerate() ? "Y" : "N"; } if ($errorCollection->hasErrors()) { $errorCollectionParam->add($errorCollection->toArray()); return false; } else { $GLOBALS["USER_FIELD_MANAGER"]->EditFormAddFields("FORUM_MESSAGE", $result); $params = $result; return true; } }
function SocnetEMailMessageAdd($arMessageFields, $ACTION_VARS) { if (!is_array($arMessageFields["FORUM_EMAIL_FILTER"])) { return false; } if (!CModule::IncludeModule("socialnetwork")) { return false; } $arParams = $arMessageFields["FORUM_EMAIL_FILTER"]; if (!CSocNetFeatures::IsActiveFeature(SONET_ENTITY_GROUP, $arParams["SOCNET_GROUP_ID"], "forum")) { return false; } // Найдем кто отправитель $message_email = strlen($arMessageFields["FIELD_REPLY_TO"]) > 0 ? $arMessageFields["FIELD_REPLY_TO"] : $arMessageFields["FIELD_FROM"]; $message_email_addr = strtolower(CMailUtil::ExtractMailAddress($message_email)); $o = "LAST_LOGIN"; $b = "DESC"; $res = CUser::GetList($o, $b, array("ACTIVE" => "Y", "EMAIL" => $message_email_addr)); if (($arUser = $res->Fetch()) && strtolower(CMailUtil::ExtractMailAddress($arUser["EMAIL"])) == $message_email_addr) { $AUTHOR_USER_ID = $arUser["ID"]; } elseif ($arParams["NOT_MEMBER_POST"] == "Y") { $AUTHOR_USER_ID = false; } else { CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_ERROR", "MESSAGE" => GetMessage("FORUM_MAIL_ERROR1") . ": " . $message_email_addr)); return false; } if ($arParams["NOT_MEMBER_POST"] != "Y") { // Проверим права доступа if (CSocNetFeaturesPerms::CanPerformOperation($AUTHOR_USER_ID, SONET_ENTITY_GROUP, $arParams["SOCNET_GROUP_ID"], "forum", "full")) { $PERMISSION = "Y"; } elseif (CSocNetFeaturesPerms::CanPerformOperation($AUTHOR_USER_ID, SONET_ENTITY_GROUP, $arParams["SOCNET_GROUP_ID"], "forum", "newtopic")) { $PERMISSION = "M"; } elseif (CSocNetFeaturesPerms::CanPerformOperation($AUTHOR_USER_ID, SONET_ENTITY_GROUP, $arParams["SOCNET_GROUP_ID"], "forum", "answer")) { $PERMISSION = "I"; } else { CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_ERROR", "MESSAGE" => GetMessage("FORUM_MAIL_ERROR2") . " " . $arUser["LOGIN"] . " [" . $AUTHOR_USER_ID . "] (" . $message_email_addr . ")")); return false; } } $body = $arMessageFields["BODY"]; //$body = preg_replace("/(\r\n)+/", "\r\n", $body); $p = strpos($body, "\r\nFrom:"); if ($p > 0) { $body = substr($body, 0, $p) . "\r\n[CUT]" . substr($body, $p) . "[/CUT]"; } $subject = $arMessageFields["SUBJECT"]; // обрежем все RE и FW $subject = trim(preg_replace('#^\\s*((RE[0-9\\[\\]]*:\\s*)|(FW:\\s*))+(.*)$#i', '\\4', $subject)); if ($subject == '') { $subject = GetMessage("FORUM_MAIL_EMPTY_TOPIC_TITLE") . " " . rand(); } // Найдем какая тема $arFields = array(); $FORUM_ID = IntVal($arParams["FORUM_ID"]); $SOCNET_GROUP_ID = IntVal($arParams["SOCNET_GROUP_ID"]); $TOPIC_ID = 0; global $DB; if ($arMessageFields["IN_REPLY_TO"] != '') { $dbTopic = $DB->Query("SELECT FT.ID FROM b_forum_topic FT INNER JOIN b_forum_message FM ON FM.TOPIC_ID=FT.ID WHERE FM.XML_ID='" . $DB->ForSQL($arMessageFields["IN_REPLY_TO"], 255) . "' AND FT.FORUM_ID=" . $FORUM_ID . " AND FT.SOCNET_GROUP_ID=" . $SOCNET_GROUP_ID); if ($arTopic = $dbTopic->Fetch()) { $TOPIC_ID = $arTopic["ID"]; } } if ($arParams["USE_SUBJECT"] == "Y" && $TOPIC_ID <= 0) { $dbTopic = $DB->Query("SELECT ID FROM b_forum_topic WHERE TITLE='" . $DB->ForSQL($subject, 255) . "' AND FORUM_ID=" . $FORUM_ID . " AND SOCNET_GROUP_ID=" . $SOCNET_GROUP_ID); // ограничить по старости? if ($arTopic = $dbTopic->Fetch()) { $TOPIC_ID = $arTopic["ID"]; } } if ($AUTHOR_USER_ID > 0) { if ($TOPIC_ID < 0 && $PERMISSION <= "I") { CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_ERROR", "MESSAGE" => GetMessage("FORUM_MAIL_ERROR3") . " " . $arUser["LOGIN"] . " [" . $AUTHOR_USER_ID . "] (" . $message_email_addr . ")")); return false; } $bSHOW_NAME = true; $res = CForumUser::GetByUSER_ID($AUTHOR_USER_ID); if ($res) { $bSHOW_NAME = $res["SHOW_NAME"] == "Y"; } if ($bSHOW_NAME) { $AUTHOR_NAME = $arUser["NAME"] . (strlen($arUser["NAME"]) <= 0 || strlen($arUser["LAST_NAME"]) <= 0 ? "" : " ") . $arUser["LAST_NAME"]; } if (strlen(Trim($AUTHOR_NAME)) <= 0) { $AUTHOR_NAME = $arUser["LOGIN"]; } } else { $AUTHOR_NAME = $arMessageFields["FIELD_FROM"]; $arFields["AUTHOR_EMAIL"] = $arMessageFields["FIELD_FROM"]; } $arFields["NEW_TOPIC"] = "N"; if ($PERMISSION >= "Q") { $arFields["APPROVED"] = "Y"; } else { $arFields["APPROVED"] = $arParams["MODERATION"] == "Y" ? "N" : "Y"; } // Добавим новую тему if ($TOPIC_ID <= 0) { $arTopicFields = array("TITLE" => $subject, "FORUM_ID" => $FORUM_ID, "USER_START_ID" => $AUTHOR_USER_ID, "OWNER_ID" => $AUTHOR_USER_ID, "SOCNET_GROUP_ID" => $SOCNET_GROUP_ID); $arTopicFields["XML_ID"] = $arMessageFields["MSG_ID"]; $arTopicFields["APPROVED"] = $arFields['APPROVED']; $arTopicFields["USER_START_NAME"] = $AUTHOR_NAME; $arTopicFields["LAST_POSTER_NAME"] = $AUTHOR_NAME; $TOPIC_ID = CForumTopic::Add($arTopicFields); if (IntVal($TOPIC_ID) <= 0) { CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_ERROR", "MESSAGE" => GetMessage("FORUM_MAIL_ERROR4"))); return false; } $arFields["NEW_TOPIC"] = "Y"; } // Добавим сообщение $arFields["POST_MESSAGE"] = $body; // Аттаченные файлы $arFILES = array(); $rsAttach = CMailAttachment::GetList(array(), array("MESSAGE_ID" => $arMessageFields["ID"])); while ($arAttach = $rsAttach->Fetch()) { $filename = CTempFile::GetFileName(md5(uniqid("")) . ".tmp"); CheckDirPath($filename); if (file_put_contents($filename, $arAttach["FILE_DATA"]) !== false) { $arFile = array("name" => $arAttach["FILE_NAME"], "type" => $arAttach["CONTENT_TYPE"], "size" => @filesize($filename), "tmp_name" => $filename, "MODULE_ID" => "forum"); $arFilter = array("FORUM_ID" => $FORUM_ID); $arFiles = array($arFile); if (CForumFiles::CheckFields($arFiles, $arFilter)) { $arFILES[] = $arFiles[0]; } else { $oError = $GLOBALS["APPLICATION"]->GetException(); CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_ERROR", "MESSAGE" => GetMessage("FORUM_MAIL_ERROR6") . " (" . $arAttach["FILE_NAME"] . "): " . ($oError && $oError->GetString() ? $oError->GetString() : ""))); } } } if (count($arFILES) > 0) { $arFields["FILES"] = $arFILES; } $arFields["AUTHOR_NAME"] = $AUTHOR_NAME; $arFields["AUTHOR_ID"] = $AUTHOR_USER_ID; $arFields["FORUM_ID"] = $FORUM_ID; $arFields["TOPIC_ID"] = $TOPIC_ID; $arFields["XML_ID"] = $arMessageFields["MSG_ID"]; $arFields["SOURCE_ID"] = "EMAIL"; $arRes = array(); if (!empty($arMessageFields["FIELD_FROM"])) { $arRes[] = "From: " . $arMessageFields["FIELD_FROM"]; } if (!empty($arMessageFields["FIELD_TO"])) { $arRes[] = "To: " . $arMessageFields["FIELD_TO"]; } if (!empty($arMessageFields["FIELD_CC"])) { $arRes[] = "Cc: " . $arMessageFields["FIELD_CC"]; } if (!empty($arMessageFields["FIELD_BCC"])) { $arRes[] = "Bcc: " . $arMessageFields["FIELD_BCC"]; } $arRes[] = "Subject: " . $arMessageFields["SUBJECT"]; $arRes[] = "Date: " . $arMessageFields["FIELD_DATE"]; $arFields["MAIL_HEADER"] = implode("\r\n", $arRes); preg_match_all('#Received:\\s+from\\s+(.*)by.*#i', $arMessageFields["HEADER"], $regs); if (is_array($regs) && is_array($regs[1])) { $arFields["AUTHOR_IP"] = $arFields["AUTHOR_REAL_IP"] = '<email: ' . $regs[1][count($regs[1]) - 1] . '>'; } else { $arFields["AUTHOR_IP"] = $arFields["AUTHOR_REAL_IP"] = '<email: no address>'; } /* $AUTHOR_IP = ForumGetRealIP(); $AUTHOR_IP_tmp = $AUTHOR_IP; $AUTHOR_REAL_IP = $_SERVER['REMOTE_ADDR']; if (COption::GetOptionString("forum", "FORUM_GETHOSTBYADDR", "N") == "Y") { $AUTHOR_IP = @gethostbyaddr($AUTHOR_IP); if ($AUTHOR_IP_tmp==$AUTHOR_REAL_IP) $AUTHOR_REAL_IP = $AUTHOR_IP; else $AUTHOR_REAL_IP = @gethostbyaddr($AUTHOR_REAL_IP); } $arFields["AUTHOR_IP"] = ($AUTHOR_IP!==False) ? $AUTHOR_IP : "<no address>"; $arFields["AUTHOR_REAL_IP"] = ($AUTHOR_REAL_IP!==False) ? $AUTHOR_REAL_IP : "<no address>"; */ $strErrorMessage = ''; $MESSAGE_ID = CForumMessage::Add($arFields, false); if (intVal($MESSAGE_ID) <= 0) { $str = $GLOBALS['APPLICATION']->GetException(); if ($str && $str->GetString()) { $strErrorMessage .= "[" . $str->GetString() . "]"; } if ($arFields["NEW_TOPIC"] == 'Y') { CForumTopic::Delete($TOPIC_ID); } CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_ERROR", "MESSAGE" => GetMessage("FORUM_MAIL_ERROR5") . " " . $strErrorMessage)); } if ($MESSAGE_ID > 0) { CMailLog::AddMessage(array("MAILBOX_ID" => $arMessageFields["MAILBOX_ID"], "MESSAGE_ID" => $arMessageFields["ID"], "FILTER_ID" => $arParams["MAIL_FILTER_ID"], "LOG_TYPE" => "FILTER_COMPLETE", "MESSAGE" => GetMessage("FORUM_MAIL_OK") . " " . $MESSAGE_ID . " (TID#" . $TOPIC_ID . ")")); CForumMessage::SendMailMessage($MESSAGE_ID, array(), false, "NEW_FORUM_MESSAGE"); $dbSite = CSite::GetById($arMessageFields["LID"]); if ($arSite = $dbSite->Fetch()) { $lang = $arSite['LANGUAGE_ID']; } else { $lang = $LANGUAGE_ID; } $parser = new forumTextParser(); $arForum = CForumNew::GetByID($FORUM_ID); $arAllow = array("HTML" => "N", "ANCHOR" => "N", "BIU" => "N", "IMG" => "N", "LIST" => "N", "QUOTE" => "N", "CODE" => "N", "FONT" => "N", "SMILES" => "N", "UPLOAD" => $arForum["ALLOW_UPLOAD"], "NL2BR" => "N", "TABLE" => "N", "ALIGN" => "N"); if ($arFields["NEW_TOPIC"] == "Y") { $arFieldsForSocnet = array("ENTITY_TYPE" => SONET_ENTITY_GROUP, "ENTITY_ID" => $SOCNET_GROUP_ID, "EVENT_ID" => "forum", "=LOG_DATE" => $GLOBALS["DB"]->CurrentTimeFunction(), "TITLE_TEMPLATE" => str_replace("#AUTHOR_NAME#", $AUTHOR_NAME, CForumEmail::GetLangMessage("FORUM_MAIL_SOCNET_TITLE_TOPIC", $lang)), "TITLE" => $subject, "MESSAGE" => $parser->convert($body, $arAllow), "TEXT_MESSAGE" => $parser->convert4mail($body), "URL" => CComponentEngine::MakePathFromTemplate($arParams["URL_TEMPLATES_MESSAGE"], array("UID" => $AUTHOR_USER_ID, "FID" => $FORUM_ID, "TID" => $TOPIC_ID, "MID" => $MESSAGE_ID)), "PARAMS" => serialize(array("PATH_TO_MESSAGE" => CComponentEngine::MakePathFromTemplate($arParams["URL_TEMPLATES_MESSAGE"], array("TID" => $TOPIC_ID)))), "MODULE_ID" => false, "CALLBACK_FUNC" => false, "SOURCE_ID" => $MESSAGE_ID, "RATING_TYPE_ID" => "FORUM_TOPIC", "RATING_ENTITY_ID" => intval($TOPIC_ID)); if (intVal($AUTHOR_USER_ID) > 0) { $arFieldsForSocnet["USER_ID"] = $AUTHOR_USER_ID; } $logID = CSocNetLog::Add($arFieldsForSocnet, false); if (intval($logID) > 0) { CSocNetLog::Update($logID, array("TMP_ID" => $logID)); CSocNetLogRights::SetForSonet($logID, $arFieldsForSocnet["ENTITY_TYPE"], $arFieldsForSocnet["ENTITY_ID"], "forum", "view", true); CSocNetLog::SendEvent($logID, "SONET_NEW_EVENT", $logID); } } else { $dbForumMessage = CForumMessage::GetList(array("ID" => "ASC"), array("TOPIC_ID" => $TOPIC_ID)); if ($arForumMessage = $dbForumMessage->Fetch()) { $dbRes = CSocNetLog::GetList(array("ID" => "DESC"), array("EVENT_ID" => "forum", "SOURCE_ID" => $arForumMessage["ID"]), false, false, array("ID", "TMP_ID")); if ($arRes = $dbRes->Fetch()) { $log_id = $arRes["TMP_ID"]; } else { $dbFirstMessage = CForumMessage::GetList(array("ID" => "ASC"), array("TOPIC_ID" => $arForumMessage["TOPIC_ID"]), false, 1); if ($arFirstMessage = $dbFirstMessage->Fetch()) { $arTopic = CForumTopic::GetByID($arFirstMessage["TOPIC_ID"]); $sFirstMessageText = COption::GetOptionString("forum", "FILTER", "Y") == "Y" ? $arFirstMessage["POST_MESSAGE_FILTER"] : $arFirstMessage["POST_MESSAGE"]; $sFirstMessageURL = CComponentEngine::MakePathFromTemplate($arParams["URL_TEMPLATES_MESSAGE"], array("UID" => $arFirstMessage["AUTHOR_ID"], "FID" => $arFirstMessage["FORUM_ID"], "TID" => $arFirstMessage["TOPIC_ID"], "MID" => $arFirstMessage["ID"])); $arFieldsForSocnet = array("ENTITY_TYPE" => SONET_ENTITY_GROUP, "ENTITY_ID" => $SOCNET_GROUP_ID, "EVENT_ID" => "forum", "LOG_DATE" => $arFirstMessage["POST_DATE"], "LOG_UPDATE" => $arFirstMessage["POST_DATE"], "TITLE_TEMPLATE" => str_replace("#AUTHOR_NAME#", $arFirstMessage["AUTHOR_NAME"], GetMessage("SONET_FORUM_LOG_TOPIC_TEMPLATE")), "TITLE" => $arTopic["TITLE"], "MESSAGE" => $parser->convert($sFirstMessageText, $arAllow), "TEXT_MESSAGE" => $parser->convert4mail($sFirstMessageText), "URL" => $sFirstMessageURL, "PARAMS" => serialize(array("PATH_TO_MESSAGE" => CComponentEngine::MakePathFromTemplate($arParams["URL_TEMPLATES_MESSAGE"], array("TID" => $arFirstMessage["TOPIC_ID"])))), "MODULE_ID" => false, "CALLBACK_FUNC" => false, "SOURCE_ID" => $arFirstMessage["ID"], "RATING_TYPE_ID" => "FORUM_TOPIC", "RATING_ENTITY_ID" => intval($arFirstMessage["TOPIC_ID"])); if (intVal($arFirstMessage["AUTHOR_ID"]) > 0) { $arFieldsForSocnet["USER_ID"] = $arFirstMessage["AUTHOR_ID"]; } $log_id = CSocNetLog::Add($arFieldsForSocnet, false); if (intval($log_id) > 0) { CSocNetLog::Update($log_id, array("TMP_ID" => $log_id)); CSocNetLogRights::SetForSonet($log_id, $arFieldsForSocnet["ENTITY_TYPE"], $arFieldsForSocnet["ENTITY_ID"], "forum", "view", true); } } } if (intval($log_id) > 0) { $arFieldsForSocnet = array("ENTITY_TYPE" => SONET_ENTITY_GROUP, "ENTITY_ID" => $SOCNET_GROUP_ID, "EVENT_ID" => "forum", "LOG_ID" => $log_id, "=LOG_DATE" => $GLOBALS["DB"]->CurrentTimeFunction(), "MESSAGE" => $parser->convert($body, $arAllow), "TEXT_MESSAGE" => $parser->convert4mail($body), "URL" => CComponentEngine::MakePathFromTemplate($arParams["URL_TEMPLATES_MESSAGE"], array("UID" => $AUTHOR_USER_ID, "FID" => $FORUM_ID, "TID" => $TOPIC_ID, "MID" => $MESSAGE_ID)), "MODULE_ID" => false, "SOURCE_ID" => $MESSAGE_ID, "RATING_TYPE_ID" => "FORUM_POST", "RATING_ENTITY_ID" => intval($MESSAGE_ID)); if (intVal($AUTHOR_USER_ID) > 0) { $arFieldsForSocnet["USER_ID"] = $AUTHOR_USER_ID; } CSocNetLogComments::Add($arFieldsForSocnet); } } } } }
public static function UpdateCrmActivityComment($arFields) { if (!isset($arFields["SOURCE_ID"]) || intval($arFields["SOURCE_ID"]) <= 0) { return false; } $ufFileID = array(); $ufDocID = array(); $dbResult = CSocNetLog::GetList(array(), array("ID" => $arFields["LOG_ID"]), false, false, array('ID', 'ENTITY_ID')); if ($arLog = $dbResult->Fetch()) { $dbCrmActivity = CCrmActivity::GetList(array(), array('ID' => $arLog['ENTITY_ID'], 'CHECK_PERMISSIONS' => 'N')); if (($arCrmActivity = $dbCrmActivity->Fetch()) && $arCrmActivity['TYPE_ID'] == CCrmActivityType::Task && CModule::IncludeModule("forum")) { $messageId = intval($arFields["SOURCE_ID"]); if ($arForumMessage = CForumMessage::GetByID($messageId)) { $arFieldsMessage = array("POST_MESSAGE" => $arFields["TEXT_MESSAGE"], "USE_SMILES" => "Y", "APPROVED" => "Y", "SONET_PERMS" => array("bCanFull" => true)); $GLOBALS["USER_FIELD_MANAGER"]->EditFormAddFields("SONET_COMMENT", $arTmp); if (is_array($arTmp)) { if (array_key_exists("UF_SONET_COM_DOC", $arTmp)) { $GLOBALS["UF_FORUM_MESSAGE_DOC"] = $arTmp["UF_SONET_COM_DOC"]; } elseif (array_key_exists("UF_SONET_COM_FILE", $arTmp)) { $arFieldsMessage["FILES"] = array(); foreach ($arTmp["UF_SONET_COM_FILE"] as $file_id) { $arFieldsMessage["FILES"][$file_id] = array("FILE_ID" => $file_id); } if (!empty($arFieldsMessage["FILES"])) { $arFileParams = array("FORUM_ID" => $arForumMessage["FORUM_ID"], "TOPIC_ID" => $arForumMessage["TOPIC_ID"]); if (CForumFiles::CheckFields($arFieldsMessage["FILES"], $arFileParams, "NOT_CHECK_DB")) { CForumFiles::Add(array_keys($arFieldsMessage["FILES"]), $arFileParams); } } } } $messageID = ForumAddMessage("EDIT", $arForumMessage["FORUM_ID"], $arForumMessage["TOPIC_ID"], $messageId, $arFieldsMessage, $sError, $sNote); unset($GLOBALS["UF_FORUM_MESSAGE_DOC"]); // get UF DOC value and FILE_ID there if ($messageID > 0) { $dbAddedMessageFiles = CForumFiles::GetList(array("ID" => "ASC"), array("MESSAGE_ID" => $messageID)); while ($arAddedMessageFiles = $dbAddedMessageFiles->Fetch()) { $ufFileID[] = $arAddedMessageFiles["FILE_ID"]; } $ufDocID = $GLOBALS["USER_FIELD_MANAGER"]->GetUserFieldValue("FORUM_MESSAGE", "UF_FORUM_MESSAGE_DOC", $messageID, LANGUAGE_ID); } } else { $sError = GetMessage("CRM_SL_UPDATE_COMMENT_SOURCE_ERROR"); } return array("ERROR" => $sError, "NOTES" => $sNote, "UF" => array("FILE" => $ufFileID, "DOC" => $ufDocID)); } } return array("NO_SOURCE" => "Y"); }
function Save(&$arFields, $arParams, $bCheckFields = true) { global $DB; if ($bCheckFields && !CForumFiles::CheckFields($arFields, $arParams, "ADD")) { return false; } $arFiles = array(); $arParams = is_array($arParams) ? $arParams : array($arParams); $strUploadDir = !is_set($arParams, "upload_dir") ? "forum/upload" : $arParams["upload_dir"]; $arParams = array("FORUM_ID" => intVal($arParams["FORUM_ID"]), "USER_ID" => intVal($arParams["USER_ID"]), "TOPIC_ID" => 0, "MESSAGE_ID" => 0); foreach ($arFields as $key => $val) { $val["MODULE_ID"] = "forum"; $val["FILE_ID"] = intVal($val["FILE_ID"]); $val["old_file"] = intVal($val["old_file"]); if ($val["FILE_ID"] <= 0 && $val["old_file"] > 0) { $val["FILE_ID"] = $val["old_file"]; } $old_file = $val["FILE_ID"]; unset($val["old_file"]); if (!empty($val["name"])) { $res = CFile::SaveFile($val, $strUploadDir, true, true); $DB->Commit(); if ($res > 0) { CForumFiles::Add($res, $arParams); $arFiles[$res] = $arParams; } if (($res > 0 || !empty($val["del"])) && $old_file > 0) { CFile::Delete($old_file); unset($arFields[$key]); } } elseif (!empty($val["del"])) { CFile::Delete($val["FILE_ID"]); unset($arFields[$key]); } else { $arFiles[$val["FILE_ID"]] = $val; } } return $arFiles; }
function ForumAddMessage($MESSAGE_TYPE, $FID, $TID, $MID, $arFieldsG, &$strErrorMessage, &$strOKMessage, $iFileSize = false, $captcha_word = "", $captcha_sid = 0, $captcha_code = "") { global $USER, $DB, $APPLICATION; $APPLICATION->ResetException(); $aMsg = array(); $bUpdateTopic = False; $bAddEditNote = $MESSAGE_TYPE == "EDIT"; $arParams = array("PERMISSION" => false); $arUserGroups = $USER->GetUserGroupArray(); // ************ External Permission ********************************* if (!empty($arFieldsG["PERMISSION_EXTERNAL"])) { $arParams["PERMISSION"] = CForumNew::GetUserPermission($FID, $arUserGroups); $arParams["PERMISSION"] = $arParams["PERMISSION"] < "Q" ? $arFieldsG["PERMISSION_EXTERNAL"] : $arParams["PERMISSION"]; unset($arFieldsG["PERMISSION_EXTERNAL"]); } elseif (!empty($arFieldsG["SONET_PERMS"])) { $arParams["PERMISSION"] = CForumNew::GetUserPermission($FID, $arUserGroups); if ($arParams["PERMISSION"] < "Q") { if ($arFieldsG["SONET_PERMS"]["bCanFull"] === true) { $arParams["PERMISSION"] = "Y"; } elseif ($arFieldsG["SONET_PERMS"]["bCanNew"] === true) { $arParams["PERMISSION"] = "M"; } elseif ($arFieldsG["SONET_PERMS"]["bCanWrite"] === true) { $arParams["PERMISSION"] = "I"; } else { $arParams["PERMISSION"] = "A"; } } unset($arFieldsG["SONET_PERMS"]); } $DB->StartTransaction(); if (!in_array($MESSAGE_TYPE, array("NEW", "EDIT", "REPLY"))) { $aMsg[] = array("id" => "MESSAGE_TYPE", "text" => GetMessage("ADDMES_NO_TYPE") . "."); } $MID = intval($MID); $TID = intval($TID); $FID = intval($FID); $arFieldsG["EDIT_ADD_REASON"] = $arFieldsG["EDIT_ADD_REASON"] == "Y" ? "Y" : "N"; if ($MID > 0) { $arMessage = CForumMessage::GetByID($MID, array("FILTER" => "N")); if ($arMessage) { $TID = IntVal($arMessage["TOPIC_ID"]); $FID = IntVal($arMessage["FORUM_ID"]); } } $arTopic = array(); if ($TID > 0) { $arTopic = CForumTopic::GetByID($TID); if ($arTopic) { $FID = IntVal($arTopic["FORUM_ID"]); } } $arForum = CForumNew::GetByID($FID); //************************* Input params ************************************************************************** if ($MESSAGE_TYPE == "NEW" && !CForumTopic::CanUserAddTopic($FID, $arUserGroups, $USER->GetID(), $arForum, $arParams["PERMISSION"])) { $aMsg[] = array("id" => "PERMISSION", "text" => GetMessage("ADDMESS_NO_PERMS2NEW") . "."); } elseif ($MESSAGE_TYPE == "EDIT" && !CForumMessage::CanUserUpdateMessage($MID, $arUserGroups, $USER->GetID(), $arParams["PERMISSION"])) { $aMsg[] = array("id" => "PERMISSION", "text" => GetMessage("ADDMESS_NO_PERMS2EDIT") . "."); } elseif ($MESSAGE_TYPE == "REPLY" && !CForumMessage::CanUserAddMessage($TID, $arUserGroups, $USER->GetID(), $arParams["PERMISSION"])) { $aMsg[] = array("id" => "PERMISSION", "text" => GetMessage("ADDMESS_NO_PERMS2REPLY") . "."); } if ($MESSAGE_TYPE == "NEW" || $MESSAGE_TYPE == "EDIT" && array_intersect_key($arFieldsG, array("TITLE" => "", "DESCRIPTION" => "", "ICON" => "", "TAGS" => "", "OWNER_ID" => "", "SOCNET_GROUP_ID" => "")) && CForumTopic::CanUserUpdateTopic($TID, $arUserGroups, $USER->GetID(), $arParams["PERMISSION"])) { $bUpdateTopic = True; } if ($MESSAGE_TYPE == "EDIT" && (ForumCurrUserPermissions($FID, $arParams) > "Q" && $arFieldsG["EDIT_ADD_REASON"] == "N")) { $bAddEditNote = false; } //*************************!CAPTCHA******************************************************************************** if (!$USER->IsAuthorized() && $arForum["USE_CAPTCHA"] == "Y") { include_once $_SERVER["DOCUMENT_ROOT"] . "/bitrix/modules/main/classes/general/captcha.php"; $cpt = new CCaptcha(); if (strlen($captcha_code) > 0) { $captchaPass = COption::GetOptionString("main", "captcha_password", ""); if (!$cpt->CheckCodeCrypt($captcha_word, $captcha_code, $captchaPass)) { $aMsg[] = array("id" => "CAPTCHA", "text" => GetMessage("FORUM_POSTM_CAPTCHA") . "."); } } else { if (!$cpt->CheckCode($captcha_word, $captcha_sid)) { $aMsg[] = array("id" => "CAPTCHA", "text" => GetMessage("FORUM_POSTM_CAPTCHA") . "."); } } } //*************************!CAPTCHA******************************************************************************** $arFieldsG["POST_MESSAGE"] = trim($arFieldsG["POST_MESSAGE"]); if (empty($arFieldsG["POST_MESSAGE"])) { $aMsg[] = array("id" => "POST_MESSAGE", "text" => GetMessage("ADDMESS_INPUT_MESSAGE") . "."); } if ($bUpdateTopic && is_set($arFieldsG, "TITLE")) { $arFieldsG["TITLE"] = trim($arFieldsG["TITLE"]); if (empty($arFieldsG["TITLE"])) { $aMsg[] = array("id" => "TITLE", "text" => GetMessage("ADDMESS_INPUT_TITLE") . "."); } } //*************************!QUOTA********************************************************************************** /* if (empty($aMsg)) { $quota = new CDiskQuota(); if ($MESSAGE_TYPE=="EDIT") { if (!$quota->checkDiskQuota(strLen($arFieldsG["POST_MESSAGE"]) - strLen($arMessage["POST_MESSAGE"]))) { if (!$quota->LAST_ERROR) $aMsg[] = array("id" => "QUOTA", "text" => GetMessage("MAIN_QUOTA_BAD")."( ".COption::GetOptionInt("main", "disk_space")." )."); else $aMsg[] = array("id" => "QUOTA", "text" => $quota->LAST_ERROR); } } elseif (!$quota->checkDiskQuota($arFieldsG["POST_MESSAGE"])) { if (!$quota->LAST_ERROR) $aMsg[] = array("id" => "QUOTA", "text" => GetMessage("MAIN_QUOTA_BAD")."( ".COption::GetOptionInt("main", "disk_space")." )."); else $aMsg[] = array("id" => "QUOTA", "text" => $quota->LAST_ERROR); } }*/ //*************************!QUOTA********************************************************************************** if (empty($aMsg)) { // *************************!ATTACH_IMG***************************************************************************** if (is_set($arFieldsG, "ATTACH_IMG") && empty($arFieldsG["ATTACH_IMG"]["name"]) && empty($arFieldsG["ATTACH_IMG"]["del"])) { unset($arFieldsG["ATTACH_IMG"]); } if (is_set($arFieldsG, "ATTACH_IMG")) { $arFieldsG["ATTACH_IMG"]["FILE_ID"] = $arMessage["ATTACH_IMG"]; $arFieldsG["FILES"] = array($arFieldsG["ATTACH_IMG"]); } unset($arFieldsG["ATTACH_IMG"]); if (!empty($arFieldsG["FILES"]) && is_array($arFieldsG["FILES"])) { foreach ($arFieldsG["FILES"] as $key => $val) { if (intVal($val["FILE_ID"]) > 0) { $arFieldsG["FILES"][$key]["del"] = $val["del"] == "Y" ? "Y" : ""; } } $res = array("FORUM_ID" => $arForum["ID"], "TOPIC_ID" => 0, "MESSAGE_ID" => 0, "USER_ID" => $USER->GetID()); if (!in_array($arForum["ALLOW_UPLOAD"], array("Y", "F", "A"))) { unset($arFieldsG["FILES"]); } elseif (!CForumFiles::CheckFields($arFieldsG["FILES"], $res, "NOT_CHECK_DB")) { if ($ex = $APPLICATION->GetException()) { $aMsg[] = array("id" => "FILE", "text" => $ex->GetString()); } else { $aMsg[] = array("id" => "FILE", "text" => "File upload error."); } } } } //*************************/ATTACH_IMG***************************************************************************** if (empty($aMsg) && ($MESSAGE_TYPE == "NEW" || $MESSAGE_TYPE == "REPLY")) { $AUTHOR_ID = IntVal($USER->GetParam("USER_ID")); if ($USER->IsAuthorized()) { $res = CForumUser::GetByUSER_ID($USER->GetID()); $bSHOW_NAME = !empty($res) ? $res["SHOW_NAME"] == "Y" : true; $arFieldsG["AUTHOR_NAME"] = $bSHOW_NAME ? trim($USER->GetFullName()) : ""; $arFieldsG["AUTHOR_NAME"] = !empty($arFieldsG["AUTHOR_NAME"]) ? $arFieldsG["AUTHOR_NAME"] : $USER->GetLogin(); } if (empty($arFieldsG["AUTHOR_NAME"])) { $aMsg[] = array("id" => "AUTHOR_NAME", "text" => GetMessage("ADDMESS_INPUT_AUTHOR") . "."); } } elseif (empty($aMsg) && $MESSAGE_TYPE == "EDIT") { $AUTHOR_ID = IntVal($arMessage["AUTHOR_ID"]); if (is_set($arFieldsG, "AUTHOR_NAME") && empty($arFieldsG["AUTHOR_NAME"])) { if ($AUTHOR_ID <= 0) { $aMsg[] = array("id" => "AUTHOR_NAME", "text" => GetMessage("ADDMESS_INPUT_AUTHOR") . "."); } else { $res = CForumUser::GetByUSER_ID($AUTHOR_ID); $bSHOW_NAME = !empty($res) ? $res["SHOW_NAME"] == "Y" : true; if ($USER->GetID() == $AUTHOR_ID) { $arFieldsG["AUTHOR_NAME"] = $bSHOW_NAME ? trim($USER->GetFullName()) : ""; $arFieldsG["AUTHOR_NAME"] = !empty($arFieldsG["AUTHOR_NAME"]) ? $arFieldsG["AUTHOR_NAME"] : $USER->GetLogin(); } else { $res = CForumUser::GetByUSER_IDEx($AUTHOR_ID); if ($res) { $arFieldsG["AUTHOR_NAME"] = trim($bSHOW_NAME ? $res["NAME"] . " " . $res["LAST_NAME"] : ""); $arFieldsG["AUTHOR_NAME"] = !empty($arFieldsG["AUTHOR_NAME"]) ? $arFieldsG["AUTHOR_NAME"] : $res["LOGIN"]; } else { unset($arFieldsG["AUTHOR_NAME"]); } } } } if ($USER->IsAuthorized()) { $res = CForumUser::GetByUSER_ID($USER->GetID()); $bSHOW_NAME = !empty($res) ? $res["SHOW_NAME"] == "Y" : true; $arFieldsG["EDITOR_NAME"] = $bSHOW_NAME ? trim($USER->GetFullName()) : ""; $arFieldsG["EDITOR_NAME"] = !empty($arFieldsG["EDITOR_NAME"]) ? $arFieldsG["EDITOR_NAME"] : $USER->GetLogin(); } if ($bAddEditNote && empty($arFieldsG["EDITOR_NAME"])) { $aMsg[] = array("id" => "EDITOR_NAME", "text" => GetMessage("ADDMESS_INPUT_EDITOR") . "."); } } //*************************/Input params *************************************************************************** //************************* Actions ******************************************************************************** //************************* Add/edit topic ************************************************************************* if (empty($aMsg)) { // The longest step by time. Actualization of topic, user and forum statistic info (~0.7-0.8 sec) if ($MESSAGE_TYPE == "EDIT" && ($arMessage["APPROVED"] == "Y" || $arMessage["APPROVED"] == "N")) { $arFieldsG["APPROVED"] = $arMessage["APPROVED"]; } elseif (!empty($arTopic) && $arTopic["APPROVED"] != "Y") { $arFieldsG["APPROVED"] = "N"; } else { $arFieldsG["APPROVED"] = $arForum["MODERATION"] == "Y" ? "N" : "Y"; if (ForumCurrUserPermissions($FID, $arParams) >= "Q") { $arFieldsG["APPROVED"] = "Y"; } } if ($bUpdateTopic) { $arFields = array(); foreach (array("TITLE", "TITLE_SEO", "DESCRIPTION", "ICON", "TAGS") as $key) { if (is_set($arFieldsG, $key)) { $arFields[$key] = $arFieldsG[$key]; } } if ($MESSAGE_TYPE == "NEW") { $arFields["FORUM_ID"] = $FID; $arFields["USER_START_ID"] = $AUTHOR_ID; $arFields["USER_START_NAME"] = $arFieldsG["AUTHOR_NAME"]; $arFields["LAST_POSTER_NAME"] = $arFieldsG["AUTHOR_NAME"]; $arFields["APPROVED"] = $arFieldsG["APPROVED"]; $arFields["OWNER_ID"] = $arFieldsG["OWNER_ID"]; $arFields["SOCNET_GROUP_ID"] = $arFieldsG["SOCNET_GROUP_ID"]; if (is_set($arFieldsG, "TOPIC_XML_ID")) { $arFields["XML_ID"] = $arFieldsG["TOPIC_XML_ID"]; } $TID = CForumTopic::Add($arFields); if (IntVal($TID) <= 0) { $aMsg[] = array("id" => "TOPIC_ID", "text" => GetMessage("ADDMESS_ERROR_ADD_TOPIC") . "."); } } else { if (is_set($arFieldsG, "AUTHOR_NAME")) { if ($arTopic["LAST_MESSAGE_ID"] == $MID && $arMessage["LAST_POSTER_NAME"] != $arFieldsG["AUTHOR_NAME"]) { $arFields["LAST_POSTER_NAME"] = $arFieldsG["AUTHOR_NAME"]; } if ($arTopic["ABS_LAST_MESSAGE_ID"] == $MID && $arMessage["ABS_LAST_POSTER_NAME"] != $arFieldsG["AUTHOR_NAME"]) { $arFields["ABS_LAST_POSTER_NAME"] = $arFieldsG["AUTHOR_NAME"]; } if ($arTopic["USER_START_NAME"] == $arMessage["USER_START_NAME"] && $arTopic["USER_START_NAME"] != $arFieldsG["AUTHOR_NAME"]) { $arFields["USER_START_NAME"] = $arFieldsG["AUTHOR_NAME"]; } } if (!empty($arFields)) { $TID1 = CForumTopic::Update($TID, $arFields); if (intval($TID1) <= 0) { $aMsg[] = array("id" => "TOPIC_ID", "text" => GetMessage("ADDMESS_ERROR_EDIT_TOPIC") . "."); } else { foreach ($arFields as $key => $val) { if ($arFields[$key] != $arTopic[$key]) { $res_log[$key] = $arFields[$key]; $res_log["before" . $key] = $arTopic[$key]; } } if (!empty($res_log)) { $arTopic = CForumTopic::GetByID($TID); $res_log['FORUM_ID'] = $arTopic['FORUM_ID']; CForumEventLog::Log("topic", "edit", $TID, serialize($res_log)); } } if (is_set($arFieldsG, "AUTHOR_NAME") && $arForum["LAST_MESSAGE_ID"] == $MID && $arForum["LAST_POSTER_NAME"] != $arFieldsG["AUTHOR_NAME"]) { $arFieldsForum = array("LAST_POSTER_NAME" => $arFieldsG["AUTHOR_NAME"]); if ($arForum["ABS_LAST_MESSAGE_ID"] == $MID) { $arFieldsForum["LAST_POSTER_NAME"] = $arFieldsG["AUTHOR_NAME"]; } CForumNew::Update($arForum["ID"], $arFieldsForum); } } } } } //*************************/Add/edit topic ************************************************************************* //************************* Add/edit message *********************************************************************** if (empty($aMsg)) { $arFields = array("POST_MESSAGE" => $arFieldsG["POST_MESSAGE"], "USE_SMILES" => $arFieldsG["USE_SMILES"] == "Y" ? "Y" : "N", "APPROVED" => $arFieldsG["APPROVED"]); if (is_set($arFieldsG, "ATTACH_IMG")) { $arFields["ATTACH_IMG"] = $arFieldsG["ATTACH_IMG"]; } elseif (is_set($arFieldsG, "FILES")) { $arFields["FILES"] = $arFieldsG["FILES"]; } if (is_set($arFieldsG, "PARAM1")) { $arFields["PARAM1"] = $arFieldsG["PARAM1"]; } if (is_set($arFieldsG, "PARAM2")) { $arFields["PARAM2"] = $arFieldsG["PARAM2"]; } /* elseif ($MESSAGE_TYPE != "NEW") { $db_res = CForumMessage::GetList(array(), array("TOPIC_ID" => $TID, "NEW_TOPIC" => "Y")); if ($db_res && $res = $db_res->Fetch()) $res["PARAM2"] = $res["PARAM2"]; }*/ $GLOBALS["USER_FIELD_MANAGER"]->EditFormAddFields("FORUM_MESSAGE", $arFields); if ($MESSAGE_TYPE == "NEW" || $MESSAGE_TYPE == "REPLY") { $arFields["AUTHOR_NAME"] = $arFieldsG["AUTHOR_NAME"]; $arFields["AUTHOR_EMAIL"] = $arFieldsG["AUTHOR_EMAIL"]; $arFields["AUTHOR_ID"] = $AUTHOR_ID; $arFields["FORUM_ID"] = $FID; $arFields["TOPIC_ID"] = $TID; $AUTHOR_IP = ForumGetRealIP(); $AUTHOR_IP_tmp = $AUTHOR_IP; $AUTHOR_REAL_IP = $_SERVER['REMOTE_ADDR']; if (COption::GetOptionString("forum", "FORUM_GETHOSTBYADDR", "N") == "Y") { $AUTHOR_IP = @gethostbyaddr($AUTHOR_IP); $AUTHOR_REAL_IP = $AUTHOR_IP_tmp == $AUTHOR_REAL_IP ? $AUTHOR_IP : @gethostbyaddr($AUTHOR_REAL_IP); } $arFields["AUTHOR_IP"] = $AUTHOR_IP !== False ? $AUTHOR_IP : "<no address>"; $arFields["AUTHOR_REAL_IP"] = $AUTHOR_REAL_IP !== False ? $AUTHOR_REAL_IP : "<no address>"; $arFields["NEW_TOPIC"] = $MESSAGE_TYPE == "NEW" ? "Y" : "N"; $arFields["GUEST_ID"] = $_SESSION["SESS_GUEST_ID"]; $MID = CForumMessage::Add($arFields, false); if (intVal($MID) <= 0) { $str = $APPLICATION->GetException(); if ($str && $str->GetString()) { $aMsg[] = array("id" => "MESSAGE_ID", "text" => $str->GetString()); } else { $aMsg[] = array("id" => "MESSAGE_ID", "text" => GetMessage("ADDMESS_ERROR_ADD_MESSAGE") . "."); } if ($MESSAGE_TYPE == "NEW") { CForumTopic::Delete($TID); $TID = 0; } } } else { if (empty($AUTHOR_ID)) { if (is_set($arFieldsG, "AUTHOR_NAME")) { $arFields["AUTHOR_NAME"] = $arFieldsG["AUTHOR_NAME"]; } if (is_set($arFieldsG, "AUTHOR_EMAIL")) { $arFields["AUTHOR_EMAIL"] = $arFieldsG["AUTHOR_EMAIL"]; } } if ($bAddEditNote) { $arFields["EDITOR_NAME"] = $arFieldsG["EDITOR_NAME"]; $arFields["EDITOR_EMAIL"] = $arFieldsG["EDITOR_EMAIL"]; $arFields["EDIT_REASON"] = $arFieldsG["EDIT_REASON"]; $arFields["EDIT_DATE"] = ""; if ($GLOBALS["USER"]->IsAuthorized()) { $arFields["EDITOR_ID"] = $GLOBALS["USER"]->GetID(); } } $MID1 = CForumMessage::Update($MID, $arFields); if (IntVal($MID1) <= 0) { $ex = $GLOBALS['APPLICATION']->GetException(); if ($ex) { $aMsg[] = array("id" => "MESSAGE_ID", "text" => $ex->GetString()); } else { $aMsg[] = array("id" => "MESSAGE_ID", "text" => GetMessage("ADDMESS_ERROR_EDIT_MESSAGE") . "."); } } elseif ($AUTHOR_ID == $GLOBALS["USER"]->GetId() && COption::GetOptionString("forum", "LOGS", "Q") < "U") { } else { $res_log = array(); foreach ($arFields as $key => $val) { if ($arFields[$key] != $arMessage[$key]) { if ($key == "FILES" || $key == "ATTACH_IMG") { $res_log[$key] = GetMessage("F_ATTACH_IS_MODIFIED"); continue; } $res_log["BeforeMessage"] = $arMessage[$key]; $res_log["AfterMessage"] = $arFields[$key]; } } if (!empty($res_log)) { $arMessage = CForumMessage::GetByID($MID); $TID = $arMessage['TOPIC_ID']; $res_log['FORUM_ID'] = $arMessage['FORUM_ID']; $arTopic = CForumTopic::GetByID($TID); $res_log['TITLE'] = $arTopic['TITLE']; $res_log['TOPIC_ID'] = $TID; $res_log = serialize($res_log); CForumEventLog::Log("message", "edit", $MID, $res_log); } } } } //*************************/Add/edit message *********************************************************************** if (empty($aMsg)) { $DB->Commit(); } else { $DB->Rollback(); } if (empty($aMsg) && CModule::IncludeModule("statistic")) { $F_EVENT1 = $arForum["EVENT1"]; $F_EVENT2 = $arForum["EVENT2"]; $F_EVENT3 = $arForum["EVENT3"]; if (empty($F_EVENT3)) { $arForumSite_tmp = CForumNew::GetSites($FID); if (defined("ADMIN_SECTION") && ADMIN_SECTION === true) { $arForumSiteCode_tmp = array_keys($arForumSite_tmp); $F_EVENT3 = CForumNew::PreparePath2Message(empty($arForumSite_tmp[$arForumSiteCode_tmp[0]]) ? '' : $arForumSite_tmp[$arForumSiteCode_tmp[0]], array("FORUM_ID" => $FID, "TOPIC_ID" => $TID, "MESSAGE_ID" => $MID)); } else { $F_EVENT3 = CForumNew::PreparePath2Message(empty($arForumSite_tmp[SITE_ID]) ? '' : $arForumSite_tmp[SITE_ID], array("FORUM_ID" => $FID, "TOPIC_ID" => $TID, "MESSAGE_ID" => $MID)); } } CStatistics::Set_Event($F_EVENT1, $F_EVENT2, $F_EVENT3); } if (empty($aMsg)) { $arNote = array(); if ($MESSAGE_TYPE == "NEW" || $MESSAGE_TYPE == "REPLY") { CForumMessage::SendMailMessage($MID, array(), false, "NEW_FORUM_MESSAGE"); $arNote = array("id" => $MESSAGE_TYPE, "text" => GetMessage("ADDMESS_SUCCESS_ADD") . ". \n"); } else { CForumMessage::SendMailMessage($MID, array(), false, "EDIT_FORUM_MESSAGE"); $arNote = array("id" => "EDIT", "text" => GetMessage("ADDMESS_SUCCESS_EDIT") . ". \n"); } if ($arFieldsG["APPROVED"] != "Y") { $arNote["id"] .= "_NOT_APPROVED"; $arNote["text"] .= GetMessage("ADDMESS_AFTER_MODERATE") . ". \n"; } if (is_array($strOKMessage)) { $strOKMessage[] = $arNote; } else { $strOKMessage .= $arNote["text"]; } return $MID; } $e = new CAdminException($aMsg); $strErrorMessage = $e->GetString(); return false; }