コード例 #1
0
 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 />" : "") . "&nbsp;&nbsp;&raquo;&nbsp;\"" . $name . "\"";
                         }
                         CForm::__check_PushError($errors, $errMsg);
                     }
                 }
             }
         } else {
             CForm::__check_PushError($errors, GetMessage("FORM_INCORRECT_FORM_ID"));
         }
     }
     return $errors;
 }