AnonSec Shell
Server IP : 85.193.89.191  /  Your IP : 18.226.93.191
Web Server : Apache
System : Linux 956367-cx40159.tmweb.ru 3.10.0-1160.105.1.el7.x86_64 #1 SMP Thu Dec 7 15:39:45 UTC 2023 x86_64
User : bitrix ( 600)
PHP Version : 8.1.27
Disable Function : NONE
MySQL : OFF  |  cURL : OFF  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /home/bitrix/www/bitrix/components/bitrix/bizproc.workflow.setparameters/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     

Current File : /home/bitrix/www/bitrix/components/bitrix/bizproc.workflow.setparameters/component.php
<?if(!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true) die();

if (!CModule::IncludeModule("bizproc"))
	return false;

if (!$GLOBALS["USER"]->IsAuthorized())
{
	$GLOBALS["APPLICATION"]->AuthForm(GetMessage("ACCESS_DENIED"));
	die();
}

$arParams["ID"] = intval($arParams["ID"]);

$arTemplate = null;
$canWrite = false;

if ($arParams["ID"] > 0)
{
	$dbTemplatesList = CBPWorkflowTemplateLoader::GetList(
		array(),
		array('ID' => $arParams['ID']),
		false,
		false,
		array('ID', 'DOCUMENT_TYPE', 'NAME', 'DESCRIPTION', 'PARAMETERS')
	);
	if ($arTemplate = $dbTemplatesList->Fetch())
	{
		$canWrite = CBPDocument::CanUserOperateDocumentType(
			CBPCanUserOperateOperation::CreateWorkflow,
			$GLOBALS["USER"]->GetID(),
			$arTemplate["DOCUMENT_TYPE"]
		);

		$arResult["DOCUMENT_TYPE"] = $arTemplate["DOCUMENT_TYPE"];
		$arResult["NAME"] = $arTemplate["NAME"];
		$arResult['DESCRIPTION'] = $arTemplate['DESCRIPTION'];
		$arResult["PARAMETERS"] = $arTemplate["PARAMETERS"];
		$arResult["ID"] = $arTemplate["ID"];
	}
}

if (!is_array($arTemplate) || !$canWrite)
{
	$GLOBALS["APPLICATION"]->AuthForm(GetMessage("ACCESS_DENIED"));
	die();
}

$arParams["SET_TITLE"] = ($arParams["SET_TITLE"] == "N" ? "N" : "Y");
$arParams["SET_NAV_CHAIN"] = ($arParams["SET_NAV_CHAIN"] == "N" ? "N" : "Y");

$arResult["EDIT_PAGE_TEMPLATE"] = $arParams["EDIT_PAGE_TEMPLATE"];

$arResult["BackUrl"] = $_REQUEST["back_url"];
if ($arResult["BackUrl"] == '')
	$arResult["BackUrl"] = $arParams["BACK_URL"];
if ($arResult["BackUrl"] == '')
	$arResult["BackUrl"] = $APPLICATION->GetCurPageParam();

$arResult["FatalErrorMessage"] = "";
$arResult["ErrorMessage"] = "";

if ($arResult["FatalErrorMessage"] == '')
{
	if ($_REQUEST["cancel_action"] <> '')
		LocalRedirect($arResult['BackUrl']);
}

if ($arResult["FatalErrorMessage"] == '')
{
	$runtime = CBPRuntime::GetRuntime();
	$runtime->StartRuntime();
	$arResult["DocumentService"] = $runtime->GetService("DocumentService");

	if ($_SERVER["REQUEST_METHOD"] == "POST" && $_REQUEST["save_action"] <> '' && check_bitrix_sessid())
	{
		$errorMessageTmp = "";
		$arRequest = $_REQUEST;

		foreach ($_FILES as $k => $v)
		{
			if (array_key_exists("name", $v))
			{
				if (is_array($v["name"]))
				{
					$ks = array_keys($v["name"]);
					for ($i = 0, $cnt = count($ks); $i < $cnt; $i++)
					{
						$ar = array();
						foreach ($v as $k1 => $v1)
							$ar[$k1] = $v1[$ks[$i]];

						$arRequest[$k][] = $ar;
					}
				}
				else
				{
					$arRequest[$k] = $v;
				}
			}
		}

		$arKeys = array_keys($arResult["PARAMETERS"]);
		foreach ($arKeys as $variableKey)
		{
			$arErrorsTmp = array();

			$arResult["PARAMETERS"][$variableKey]["Default"] = $arResult["DocumentService"]->GetFieldInputValue(
				$arResult["DOCUMENT_TYPE"],
				$arResult["PARAMETERS"][$variableKey],
				$variableKey,
				$arRequest,
				$arErrorsTmp
			);

			if (count($arErrorsTmp) > 0)
			{
				foreach ($arErrorsTmp as $e)
				{
					$errorMessageTmp .= GetMessage("BPWFSP_ARGUMENT_ERROR",
						array('#PARAM#' => $arResult["PARAMETERS"][$variableKey]['Name'], '#ERROR#' => $e["message"])
					).' ';
				}
			}

			if (empty($arErrorsTmp))
			{
				$required = !(!$arResult["PARAMETERS"][$variableKey]['Required'] || is_int($arResult["PARAMETERS"][$variableKey]['Required'])
					&& ($arResult["PARAMETERS"][$variableKey]['Required'] == 0) || (mb_strtoupper($arResult["PARAMETERS"][$variableKey]['Required']) == "N"));

				if ($required
					&& (is_array($arResult["PARAMETERS"][$variableKey]["Default"]) && count($arResult["PARAMETERS"][$variableKey]["Default"]) <= 0
						|| !is_array($arResult["PARAMETERS"][$variableKey]["Default"]) && $arResult["PARAMETERS"][$variableKey]["Default"] === null)
				)
				{
					$errorMessageTmp .= GetMessage("BPWFSP_ARGUMENT_NULL", array('#PARAM#' => $arResult["PARAMETERS"][$variableKey]['Name'])).' ';
				}
			}
		}

		$errorMessageTmp = trim($errorMessageTmp);

		if ($errorMessageTmp == '')
		{
			CBPWorkflowTemplateLoader::Update($arResult["ID"], array("PARAMETERS" => $arResult["PARAMETERS"]));
			LocalRedirect($arResult['BackUrl']);
		}
		else
		{
			$arResult["ErrorMessage"] .= $errorMessageTmp;
		}
	}
}

$this->IncludeComponentTemplate();

if ($arResult["FatalErrorMessage"] == '')
{
	if ($arParams["SET_TITLE"] == "Y")
		$APPLICATION->SetTitle(str_replace("#NAME#", $arResult["NAME"], GetMessage("BPWFSP_PAGE_TITLE")));

	if ($arParams["SET_NAV_CHAIN"] == "Y")
		$APPLICATION->AddChainItem(str_replace("#NAME#", $arResult["NAME"], GetMessage("BPWFSP_PAGE_TITLE")));
}
else
{
	if ($arParams["SET_TITLE"] == "Y")
		$APPLICATION->SetTitle(GetMessage("BPWFSP_ERROR"));
	if ($arParams["SET_NAV_CHAIN"] == "Y")
		$APPLICATION->AddChainItem(GetMessage("BPWFSP_ERROR"));
}

Anon7 - 2022
AnonSec Team