function Check($WEB_FORM_ID, $arrVALUES = false, $RESULT_ID = false, $CHECK_RIGHTS = "Y", $RETURN_ARRAY = "N") { $err_mess = CAllForm::err_mess() . "<br>Function: Check<br>Line: "; global $DB, $APPLICATION, $USER, $_REQUEST, $HTTP_POST_VARS, $HTTP_GET_VARS, $HTTP_POST_FILES; if ($arrVALUES === false) { $arrVALUES = $_REQUEST; } $RESULT_ID = intval($RESULT_ID); $errors = $RETURN_ARRAY == "Y" ? array() : ""; $WEB_FORM_ID = intval($WEB_FORM_ID); if ($WEB_FORM_ID > 0) { // получаем данные по форме $WEB_FORM_ID = CForm::GetDataByID($WEB_FORM_ID, $arForm, $arQuestions, $arAnswers, $arDropDown, $arMultiSelect, "ALL"); $WEB_FORM_ID = intval($WEB_FORM_ID); if ($WEB_FORM_ID > 0) { // провер¤ем права $F_RIGHT = $CHECK_RIGHTS == "Y" ? CForm::GetPermission($WEB_FORM_ID) : 30; if ($F_RIGHT < 10) { CForm::__check_PushError($errors, GetMessage("FORM_ACCESS_DENIED_FOR_FORM_WRITE")); } else { $NOT_ANSWER = "NOT_ANSWER"; // проходим по вопросам foreach ($arQuestions as $key => $arQuestion) { $arAnswerValues = array(); $FIELD_ID = $arQuestion["ID"]; if ($arQuestion["TITLE_TYPE"] == "html") { $FIELD_TITLE = strip_tags($arQuestion["TITLE"]); } else { $FIELD_TITLE = $arQuestion["TITLE"]; } if ($arQuestion["ADDITIONAL"] != "Y") { // провер¤ем вопросы формы $FIELD_SID = $arQuestion["SID"]; $FIELD_REQUIRED = $arQuestion["REQUIRED"]; // массив полей: N - поле не отвечено; Y - поле отвечено; if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "N"; } $startType = ""; $bCheckValidators = true; // проходим по ответам if (is_array($arAnswers[$FIELD_SID])) { foreach ($arAnswers[$FIELD_SID] as $key => $arAnswer) { $ANSWER_ID = 0; $FIELD_TYPE = $arAnswer["FIELD_TYPE"]; $FIELD_PARAM = $arAnswer["FIELD_PARAM"]; if ($startType == "") { $startType = $FIELD_TYPE; } else { $bCheckValidators &= $startType == $FIELD_TYPE; } switch ($FIELD_TYPE) { case "radio": case "dropdown": $fname = "form_" . $FIELD_TYPE . "_" . $FIELD_SID; $arAnswerValues[] = $arrVALUES[$fname]; $ANSWER_ID = intval($arrVALUES[$fname]); if ($ANSWER_ID > 0 && $ANSWER_ID == $arAnswer["ID"]) { if ($FIELD_REQUIRED == "Y" && !preg_match("/" . $NOT_ANSWER . "/i", $FIELD_PARAM)) { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; } } break; case "checkbox": case "multiselect": $fname = "form_" . $FIELD_TYPE . "_" . $FIELD_SID; if (is_array($arrVALUES[$fname]) && count($arrVALUES[$fname]) > 0) { $arAnswerValues = $arrVALUES[$fname]; reset($arrVALUES[$fname]); foreach ($arrVALUES[$fname] as $ANSWER_ID) { $ANSWER_ID = intval($ANSWER_ID); if ($ANSWER_ID > 0 && $ANSWER_ID == $arAnswer["ID"]) { if ($FIELD_REQUIRED == "Y" && !preg_match("/" . $NOT_ANSWER . "/i", $FIELD_PARAM)) { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } } } break; case "text": case "textarea": case "password": case "hidden": $fname = "form_" . $FIELD_TYPE . "_" . $arAnswer["ID"]; $ANSWER_ID = intval($arAnswer["ID"]); $USER_TEXT = $arrVALUES[$fname]; $arAnswerValues[] = $arrVALUES[$fname]; if (strlen(trim($USER_TEXT)) > 0) { if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } break; case "url": $fname = "form_" . $FIELD_TYPE . "_" . $arAnswer["ID"]; $arAnswerValues[] = $arrVALUES[$fname]; $ANSWER_ID = intval($arAnswer["ID"]); $USER_TEXT = $arrVALUES[$fname]; if (strlen($USER_TEXT) > 0) { if (!preg_match("/^(http|https|ftp):\\/\\//i", $USER_TEXT)) { CForm::__check_PushError($errors, GetMessage('FORM_ERROR_BAD_URL'), $FIELD_SID); } if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } break; case "email": $fname = "form_" . $FIELD_TYPE . "_" . $arAnswer["ID"]; $arAnswerValues[] = $arrVALUES[$fname]; $ANSWER_ID = intval($arAnswer["ID"]); $USER_TEXT = $arrVALUES[$fname]; if (strlen($USER_TEXT) > 0) { if (!check_email($USER_TEXT)) { CForm::__check_PushError($errors, GetMessage('FORM_ERROR_BAD_EMAIL'), $FIELD_SID); } if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } break; case "date": $fname = "form_" . $FIELD_TYPE . "_" . $arAnswer["ID"]; $arAnswerValues[] = $arrVALUES[$fname]; $USER_DATE = $arrVALUES[$fname]; if (strlen($USER_DATE) > 0) { if (!CheckDateTime($USER_DATE)) { CForm::__check_PushError($errors, str_replace("#FIELD_NAME#", $FIELD_TITLE, GetMessage("FORM_INCORRECT_DATE_FORMAT")), $FIELD_SID); } if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } break; case "image": $fname = "form_" . $FIELD_TYPE . "_" . $arAnswer["ID"]; $fname_del = $arrVALUES["form_" . $FIELD_TYPE . "_" . $arAnswer["ID"] . "_del"]; $ANSWER_ID = intval($arAnswer["ID"]); $arIMAGE = isset($arrVALUES[$fname]) ? $arrVALUES[$fname] : $HTTP_POST_FILES[$fname]; if (is_array($arIMAGE) && strlen($arIMAGE["tmp_name"]) > 0) { $arIMAGE["MODULE_ID"] = "form"; if (strlen(CFile::CheckImageFile($arIMAGE)) > 0) { CForm::__check_PushError($errors, str_replace("#FIELD_NAME#", $FIELD_TITLE, GetMessage("FORM_INCORRECT_FILE_TYPE")), $FIELD_SID); } else { $arAnswerValues[] = $arIMAGE; } if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } elseif ($RESULT_ID > 0 && $fname_del != "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } break; case "file": $fname = "form_" . $FIELD_TYPE . "_" . $arAnswer["ID"]; $fname_del = $arrVALUES["form_" . $FIELD_TYPE . "_" . $arAnswer["ID"] . "_del"]; $arFILE = isset($arrVALUES[$fname]) ? $arrVALUES[$fname] : $HTTP_POST_FILES[$fname]; if (is_array($arFILE) && strlen($arFILE["tmp_name"]) > 0) { $arAnswerValues[] = $arFILE; if ($FIELD_REQUIRED == "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } } elseif ($RESULT_ID > 0 && $fname_del != "Y") { $REQUIRED_FIELDS[$FIELD_SID] = "Y"; break; } break; } } } } else { $FIELD_TYPE = $arQuestion["FIELD_TYPE"]; $fname = "form_date_ADDITIONAL_" . $arQuestion["ID"]; $arAnswerValues = array($arrVALUES[$fname]); $bCheckValidators = true; switch ($FIELD_TYPE) { case "date": $USER_DATE = $arrVALUES[$fname]; if (strlen($USER_DATE) > 0) { if (!CheckDateTime($USER_DATE)) { CForm::__check_PushError($errors, str_replace("#FIELD_NAME#", $FIELD_TITLE, GetMessage("FORM_INCORRECT_DATE_FORMAT")), $FIELD_SID); } } break; } } // check custom validators if ($bCheckValidators) { if ($arQuestion["ADDITIONAL"] == "Y" || is_array($arAnswers[$FIELD_SID])) { $rsValidatorList = CFormValidator::GetList($FIELD_ID, array("TYPE" => $FIELD_TYPE), $by = "C_SORT", $order = "ASC"); while ($arValidator = $rsValidatorList->Fetch()) { if (!CFormValidator::Execute($arValidator, $arQuestion, $arAnswers[$FIELD_SID], $arAnswerValues)) { if ($e = $APPLICATION->GetException()) { CForm::__check_PushError($errors, str_replace("#FIELD_NAME#", $FIELD_TITLE, $e->GetString()), $FIELD_SID); } } } } } } if ($arForm["USE_CAPTCHA"] == "Y" && !$RESULT_ID && !defined('ADMIN_SECTION')) { if (!$GLOBALS["APPLICATION"]->CaptchaCheckCode($arrVALUES["captcha_word"], $arrVALUES["captcha_sid"])) { CForm::__check_PushError($errors, GetMessage("FORM_WRONG_CAPTCHA")); } } //echo "<pre>"; print_r($REQUIRED_FIELDS); echo "</pre>"; if (is_array($REQUIRED_FIELDS) && count($REQUIRED_FIELDS) > 0) { foreach ($REQUIRED_FIELDS as $key => $value) { if ($value == "N") { if (strlen($arQuestions[$key]["RESULTS_TABLE_TITLE"]) > 0) { $title = $arQuestions[$key]["RESULTS_TABLE_TITLE"]; } else { $title = $arQuestions[$key]["TITLE_TYPE"] == "html" ? strip_tags($arQuestions[$key]["TITLE"]) : $arQuestions[$key]["TITLE"]; } if ($RETURN_ARRAY == 'N') { $EMPTY_REQUIRED_NAMES[] = $title; } else { CForm::__check_PushError($errors, GetMessage("FORM_EMPTY_REQUIRED_FIELDS") . ' ' . $title, $key); } } } } if ($RETURN_ARRAY == 'N') { if (is_array($EMPTY_REQUIRED_NAMES) && count($EMPTY_REQUIRED_NAMES) > 0) { $errMsg = ""; $errMsg .= GetMessage("FORM_EMPTY_REQUIRED_FIELDS") . "<br />"; foreach ($EMPTY_REQUIRED_NAMES as $key => $name) { $errMsg .= ($key != 0 ? "<br />" : "") . " » \"" . $name . "\""; } CForm::__check_PushError($errors, $errMsg); } } } } else { CForm::__check_PushError($errors, GetMessage("FORM_INCORRECT_FORM_ID")); } } return $errors; }