Switch back files from CrLf to Lf

This commit is contained in:
Pierre Goiffon
2018-10-04 17:43:03 +02:00
parent d7cf339ab5
commit 33e8b6a64c
5 changed files with 4608 additions and 4608 deletions

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -1,208 +1,208 @@
<?php <?php
// Copyright (C) 2010-2018 Combodo SARL // Copyright (C) 2010-2018 Combodo SARL
// //
// This file is part of iTop. // This file is part of iTop.
// //
// iTop is free software; you can redistribute it and/or modify // iTop is free software; you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by // it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or // the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version. // (at your option) any later version.
// //
// iTop is distributed in the hope that it will be useful, // iTop is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of // but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details. // GNU Affero General Public License for more details.
// //
// You should have received a copy of the GNU Affero General Public License // You should have received a copy of the GNU Affero General Public License
// along with iTop. If not, see <http://www.gnu.org/licenses/> // along with iTop. If not, see <http://www.gnu.org/licenses/>
/** /**
* Does load data from XML files (currently used in the setup only) * Does load data from XML files (currently used in the setup only)
* *
* @copyright Copyright (C) 2010-2018 Combodo SARL * @copyright Copyright (C) 2010-2018 Combodo SARL
* @license http://opensource.org/licenses/AGPL-3.0 * @license http://opensource.org/licenses/AGPL-3.0
*/ */
/** /**
* This page is called to perform "asynchronously" the setup actions * This page is called to perform "asynchronously" the setup actions
* parameters * parameters
* 'operation': one of 'compile_data_model', 'update_db_schema', 'after_db_creation', 'file' * 'operation': one of 'compile_data_model', 'update_db_schema', 'after_db_creation', 'file'
* *
* if 'operation' == 'update_db_schema': * if 'operation' == 'update_db_schema':
* 'mode': install | upgrade * 'mode': install | upgrade
* *
* if 'operation' == 'after_db_creation': * if 'operation' == 'after_db_creation':
* 'mode': install | upgrade * 'mode': install | upgrade
* *
* if 'operation' == 'file': * if 'operation' == 'file':
* 'file': string Name of the file to load * 'file': string Name of the file to load
* 'session_status': string 'start', 'continue' or 'end' * 'session_status': string 'start', 'continue' or 'end'
* 'percent': integer 0..100 the percentage of completion once the file has been loaded * 'percent': integer 0..100 the percentage of completion once the file has been loaded
*/ */
define('SAFE_MINIMUM_MEMORY', 64*1024*1024); define('SAFE_MINIMUM_MEMORY', 64*1024*1024);
require_once('../approot.inc.php'); require_once('../approot.inc.php');
require_once(APPROOT.'/application/utils.inc.php'); require_once(APPROOT.'/application/utils.inc.php');
require_once(APPROOT.'/setup/setuppage.class.inc.php'); require_once(APPROOT.'/setup/setuppage.class.inc.php');
require_once(APPROOT.'/setup/moduleinstaller.class.inc.php'); require_once(APPROOT.'/setup/moduleinstaller.class.inc.php');
ini_set('max_execution_time', max(3600, ini_get('max_execution_time'))); // Under Windows SQL/backup operations are part of the timeout and require extra time ini_set('max_execution_time', max(3600, ini_get('max_execution_time'))); // Under Windows SQL/backup operations are part of the timeout and require extra time
date_default_timezone_set('Europe/Paris'); // Just to avoid a warning if the timezone is not set in php.ini date_default_timezone_set('Europe/Paris'); // Just to avoid a warning if the timezone is not set in php.ini
$sMemoryLimit = trim(ini_get('memory_limit')); $sMemoryLimit = trim(ini_get('memory_limit'));
if (empty($sMemoryLimit)) if (empty($sMemoryLimit))
{ {
// On some PHP installations, memory_limit does not exist as a PHP setting! // On some PHP installations, memory_limit does not exist as a PHP setting!
// (encountered on a 5.2.0 under Windows) // (encountered on a 5.2.0 under Windows)
// In that case, ini_set will not work, let's keep track of this and proceed with the data load // In that case, ini_set will not work, let's keep track of this and proceed with the data load
SetupPage::log_info("No memory limit has been defined in this instance of PHP"); SetupPage::log_info("No memory limit has been defined in this instance of PHP");
} }
else else
{ {
// Check that the limit will allow us to load the data // Check that the limit will allow us to load the data
// //
$iMemoryLimit = utils::ConvertToBytes($sMemoryLimit); $iMemoryLimit = utils::ConvertToBytes($sMemoryLimit);
if (!utils::IsMemoryLimitOk($iMemoryLimit, SAFE_MINIMUM_MEMORY)) if (!utils::IsMemoryLimitOk($iMemoryLimit, SAFE_MINIMUM_MEMORY))
{ {
if (ini_set('memory_limit', SAFE_MINIMUM_MEMORY) === FALSE) if (ini_set('memory_limit', SAFE_MINIMUM_MEMORY) === FALSE)
{ {
SetupPage::log_error("memory_limit is too small: $iMemoryLimit and can not be increased by the script itself."); SetupPage::log_error("memory_limit is too small: $iMemoryLimit and can not be increased by the script itself.");
} }
else else
{ {
SetupPage::log_info("memory_limit increased from $iMemoryLimit to ".SAFE_MINIMUM_MEMORY."."); SetupPage::log_info("memory_limit increased from $iMemoryLimit to ".SAFE_MINIMUM_MEMORY.".");
} }
} }
} }
define('PHP_FATAL_ERROR_TAG', 'phpfatalerror'); define('PHP_FATAL_ERROR_TAG', 'phpfatalerror');
/** /**
* Handler for register_shutdown_function, to catch PHP errors * Handler for register_shutdown_function, to catch PHP errors
*/ */
function ShutdownCallback() function ShutdownCallback()
{ {
$error = error_get_last(); $error = error_get_last();
$bIsErrorToReport = (($error !== null) && ($error['type'] & (E_ERROR | E_PARSE | E_CORE_ERROR | E_COMPILE_ERROR | E_USER_ERROR))); $bIsErrorToReport = (($error !== null) && ($error['type'] & (E_ERROR | E_PARSE | E_CORE_ERROR | E_COMPILE_ERROR | E_USER_ERROR)));
if (!$bIsErrorToReport) if (!$bIsErrorToReport)
{ {
return; return;
} }
$errno = $error["type"]; $errno = $error["type"];
$errfile = $error["file"]; $errfile = $error["file"];
$errline = $error["line"]; $errline = $error["line"];
$errstr = $error["message"]; $errstr = $error["message"];
$sLogMessage = "PHP error occured : msg=$errstr, no=$errno, file=$errfile, line=$errline"; $sLogMessage = "PHP error occured : msg=$errstr, no=$errno, file=$errfile, line=$errline";
SetupPage::log_error("Setup error: $sLogMessage"); SetupPage::log_error("Setup error: $sLogMessage");
echo '<'.PHP_FATAL_ERROR_TAG.'>'.$sLogMessage.'</'.PHP_FATAL_ERROR_TAG.'>'; echo '<'.PHP_FATAL_ERROR_TAG.'>'.$sLogMessage.'</'.PHP_FATAL_ERROR_TAG.'>';
} }
function FatalErrorCatcher($sOutput) function FatalErrorCatcher($sOutput)
{ {
if (preg_match('|<'.PHP_FATAL_ERROR_TAG.'>.*</'.PHP_FATAL_ERROR_TAG.'>|s', $sOutput, $aMatches)) if (preg_match('|<'.PHP_FATAL_ERROR_TAG.'>.*</'.PHP_FATAL_ERROR_TAG.'>|s', $sOutput, $aMatches))
{ {
header("HTTP/1.0 500 Internal server error."); header("HTTP/1.0 500 Internal server error.");
$errors = ''; $errors = '';
foreach ($aMatches as $sMatch) foreach ($aMatches as $sMatch)
{ {
$errors .= strip_tags($sMatch)."\n"; $errors .= strip_tags($sMatch)."\n";
} }
$sOutput = "$errors\n"; $sOutput = "$errors\n";
// Logging to a file does not work if the whole memory is exhausted... // Logging to a file does not work if the whole memory is exhausted...
//SetupPage::log_error("Fatal error - in $__FILE__ , $errors"); //SetupPage::log_error("Fatal error - in $__FILE__ , $errors");
} }
return $sOutput; return $sOutput;
} }
//Define some bogus, invalid HTML tags that no sane //Define some bogus, invalid HTML tags that no sane
//person would ever put in an actual document and tell //person would ever put in an actual document and tell
//PHP to delimit fatal error warnings with them. //PHP to delimit fatal error warnings with them.
ini_set('error_prepend_string', '<'.PHP_FATAL_ERROR_TAG.'>'); ini_set('error_prepend_string', '<'.PHP_FATAL_ERROR_TAG.'>');
ini_set('error_append_string', '</'.PHP_FATAL_ERROR_TAG.'>'); ini_set('error_append_string', '</'.PHP_FATAL_ERROR_TAG.'>');
// callback on errors to log // callback on errors to log
register_shutdown_function('ShutdownCallback'); register_shutdown_function('ShutdownCallback');
// Starts the capture of the ouput, and sets a filter to capture the fatal errors. // Starts the capture of the ouput, and sets a filter to capture the fatal errors.
ob_start('FatalErrorCatcher'); // Start capturing the output, and pass it through the fatal error catcher ob_start('FatalErrorCatcher'); // Start capturing the output, and pass it through the fatal error catcher
require_once(APPROOT.'/core/config.class.inc.php'); require_once(APPROOT.'/core/config.class.inc.php');
require_once(APPROOT.'/core/log.class.inc.php'); require_once(APPROOT.'/core/log.class.inc.php');
require_once(APPROOT.'/core/kpi.class.inc.php'); require_once(APPROOT.'/core/kpi.class.inc.php');
require_once(APPROOT.'/core/cmdbsource.class.inc.php'); require_once(APPROOT.'/core/cmdbsource.class.inc.php');
require_once('./xmldataloader.class.inc.php'); require_once('./xmldataloader.class.inc.php');
require_once(APPROOT.'/application/ajaxwebpage.class.inc.php'); require_once(APPROOT.'/application/ajaxwebpage.class.inc.php');
// Never cache this page // Never cache this page
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Expires: Fri, 17 Jul 1970 05:00:00 GMT"); // Date in the past header("Expires: Fri, 17 Jul 1970 05:00:00 GMT"); // Date in the past
/** /**
* Main program * Main program
*/ */
$sOperation = Utils::ReadParam('operation', ''); $sOperation = Utils::ReadParam('operation', '');
try try
{ {
switch($sOperation) switch($sOperation)
{ {
case 'async_action': case 'async_action':
ini_set('max_execution_time', max(240, ini_get('max_execution_time'))); ini_set('max_execution_time', max(240, ini_get('max_execution_time')));
// While running the setup it is desirable to see any error that may happen // While running the setup it is desirable to see any error that may happen
ini_set('display_errors', true); ini_set('display_errors', true);
ini_set('display_startup_errors', true); ini_set('display_startup_errors', true);
require_once(APPROOT.'/setup/wizardcontroller.class.inc.php'); require_once(APPROOT.'/setup/wizardcontroller.class.inc.php');
require_once(APPROOT.'/setup/wizardsteps.class.inc.php'); require_once(APPROOT.'/setup/wizardsteps.class.inc.php');
$sClass = utils::ReadParam('step_class', ''); $sClass = utils::ReadParam('step_class', '');
$sState = utils::ReadParam('step_state', ''); $sState = utils::ReadParam('step_state', '');
$sActionCode = utils::ReadParam('code', ''); $sActionCode = utils::ReadParam('code', '');
$aParams = utils::ReadParam('params', array(), false, 'raw_data'); $aParams = utils::ReadParam('params', array(), false, 'raw_data');
$oPage = new ajax_page(''); $oPage = new ajax_page('');
$oDummyController = new WizardController(''); $oDummyController = new WizardController('');
if (is_subclass_of($sClass, 'WizardStep')) if (is_subclass_of($sClass, 'WizardStep'))
{ {
/** @var WizardStep $oStep */ /** @var WizardStep $oStep */
$oStep = new $sClass($oDummyController, $sState); $oStep = new $sClass($oDummyController, $sState);
$sConfigFile = utils::GetConfigFilePath(); $sConfigFile = utils::GetConfigFilePath();
if (file_exists($sConfigFile) && !is_writable($sConfigFile) && $oStep->RequiresWritableConfig()) if (file_exists($sConfigFile) && !is_writable($sConfigFile) && $oStep->RequiresWritableConfig())
{ {
$oPage->error("<b>Error:</b> the configuration file '".$sConfigFile."' already exists and cannot be overwritten."); $oPage->error("<b>Error:</b> the configuration file '".$sConfigFile."' already exists and cannot be overwritten.");
$oPage->p("The wizard cannot modify the configuration file for you. If you want to upgrade ".ITOP_APPLICATION.", make sure that the file '<b>".realpath($sConfigFile)."</b>' can be modified by the web server."); $oPage->p("The wizard cannot modify the configuration file for you. If you want to upgrade ".ITOP_APPLICATION.", make sure that the file '<b>".realpath($sConfigFile)."</b>' can be modified by the web server.");
$oPage->output(); $oPage->output();
} }
else else
{ {
$oStep->AsyncAction($oPage, $sActionCode, $aParams); $oStep->AsyncAction($oPage, $sActionCode, $aParams);
} }
} }
$oPage->output(); $oPage->output();
break; break;
default: default:
throw(new Exception("Error unsupported operation '$sOperation'")); throw(new Exception("Error unsupported operation '$sOperation'"));
} }
} }
catch(Exception $e) catch(Exception $e)
{ {
header("HTTP/1.0 500 Internal server error."); header("HTTP/1.0 500 Internal server error.");
echo "<p>An error happened while processing the installation:</p>\n"; echo "<p>An error happened while processing the installation:</p>\n";
echo '<p>'.$e."</p>\n"; echo '<p>'.$e."</p>\n";
SetupPage::log_error("An error happened while processing the installation: ".$e); SetupPage::log_error("An error happened while processing the installation: ".$e);
} }
if (function_exists('memory_get_peak_usage')) if (function_exists('memory_get_peak_usage'))
{ {
if ($sOperation == 'file') if ($sOperation == 'file')
{ {
SetupPage::log_info("loading file '$sFileName', peak memory usage. ".memory_get_peak_usage()); SetupPage::log_info("loading file '$sFileName', peak memory usage. ".memory_get_peak_usage());
} }
else else
{ {
SetupPage::log_info("operation '$sOperation', peak memory usage. ".memory_get_peak_usage()); SetupPage::log_info("operation '$sOperation', peak memory usage. ".memory_get_peak_usage());
} }
} }

View File

@@ -1,170 +1,170 @@
<?php <?php
// Copyright (C) 2010-2012 Combodo SARL // Copyright (C) 2010-2012 Combodo SARL
// //
// This file is part of iTop. // This file is part of iTop.
// //
// iTop is free software; you can redistribute it and/or modify // iTop is free software; you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by // it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or // the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version. // (at your option) any later version.
// //
// iTop is distributed in the hope that it will be useful, // iTop is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of // but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details. // GNU Affero General Public License for more details.
// //
// You should have received a copy of the GNU Affero General Public License // You should have received a copy of the GNU Affero General Public License
// along with iTop. If not, see <http://www.gnu.org/licenses/> // along with iTop. If not, see <http://www.gnu.org/licenses/>
/** /**
* Does load data from XML files (currently used in the setup and the backoffice data loader utility) * Does load data from XML files (currently used in the setup and the backoffice data loader utility)
* *
* @copyright Copyright (C) 2010-2012 Combodo SARL * @copyright Copyright (C) 2010-2012 Combodo SARL
* @license http://opensource.org/licenses/AGPL-3.0 * @license http://opensource.org/licenses/AGPL-3.0
*/ */
/** /**
* This page is called to load an XML file into the database * This page is called to load an XML file into the database
* parameters * parameters
* 'file' string Name of the file to load * 'file' string Name of the file to load
*/ */
define('SAFE_MINIMUM_MEMORY', 256*1024*1024); define('SAFE_MINIMUM_MEMORY', 256*1024*1024);
require_once('../approot.inc.php'); require_once('../approot.inc.php');
require_once(APPROOT.'/application/application.inc.php'); require_once(APPROOT.'/application/application.inc.php');
require_once(APPROOT.'/application/startup.inc.php'); require_once(APPROOT.'/application/startup.inc.php');
require_once(APPROOT.'/application/loginwebpage.class.inc.php'); require_once(APPROOT.'/application/loginwebpage.class.inc.php');
LoginWebPage::DoLogin(true); // Check user rights and prompt if needed (must be admin) LoginWebPage::DoLogin(true); // Check user rights and prompt if needed (must be admin)
// required because the class xmldataloader is reporting errors in the setup.log file // required because the class xmldataloader is reporting errors in the setup.log file
require_once(APPROOT.'/setup/setuppage.class.inc.php'); require_once(APPROOT.'/setup/setuppage.class.inc.php');
require_once(APPROOT.'/setup/xmldataloader.class.inc.php'); require_once(APPROOT.'/setup/xmldataloader.class.inc.php');
function SetMemoryLimit($oP) function SetMemoryLimit($oP)
{ {
$sMemoryLimit = trim(ini_get('memory_limit')); $sMemoryLimit = trim(ini_get('memory_limit'));
if (empty($sMemoryLimit)) if (empty($sMemoryLimit))
{ {
// On some PHP installations, memory_limit does not exist as a PHP setting! // On some PHP installations, memory_limit does not exist as a PHP setting!
// (encountered on a 5.2.0 under Windows) // (encountered on a 5.2.0 under Windows)
// In that case, ini_set will not work, let's keep track of this and proceed with the data load // In that case, ini_set will not work, let's keep track of this and proceed with the data load
$oP->p("No memory limit has been defined in this instance of PHP"); $oP->p("No memory limit has been defined in this instance of PHP");
} }
else else
{ {
// Check that the limit will allow us to load the data // Check that the limit will allow us to load the data
// //
$iMemoryLimit = utils::ConvertToBytes($sMemoryLimit); $iMemoryLimit = utils::ConvertToBytes($sMemoryLimit);
if (!utils::IsMemoryLimitOk($iMemoryLimit, SAFE_MINIMUM_MEMORY)) if (!utils::IsMemoryLimitOk($iMemoryLimit, SAFE_MINIMUM_MEMORY))
{ {
if (ini_set('memory_limit', SAFE_MINIMUM_MEMORY) === FALSE) if (ini_set('memory_limit', SAFE_MINIMUM_MEMORY) === FALSE)
{ {
$oP->p("memory_limit is too small: $iMemoryLimit and can not be increased by the script itself."); $oP->p("memory_limit is too small: $iMemoryLimit and can not be increased by the script itself.");
} }
else else
{ {
$oP->p("memory_limit increased from $iMemoryLimit to ".SAFE_MINIMUM_MEMORY."."); $oP->p("memory_limit increased from $iMemoryLimit to ".SAFE_MINIMUM_MEMORY.".");
} }
} }
} }
} }
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// //
// Main // Main
// //
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// Never cache this page // Never cache this page
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Expires: Fri, 17 Jul 1970 05:00:00 GMT"); // Date in the past header("Expires: Fri, 17 Jul 1970 05:00:00 GMT"); // Date in the past
/** /**
* Main program * Main program
*/ */
$sFileName = Utils::ReadParam('file', '', false, 'raw_data'); $sFileName = Utils::ReadParam('file', '', false, 'raw_data');
$oP = new WebPage("iTop - Backoffice data loader"); $oP = new WebPage("iTop - Backoffice data loader");
try try
{ {
// Note: the data model must be loaded first // Note: the data model must be loaded first
$oDataLoader = new XMLDataLoader(); $oDataLoader = new XMLDataLoader();
if (empty($sFileName)) if (empty($sFileName))
{ {
throw(new Exception("Missing argument 'file'")); throw(new Exception("Missing argument 'file'"));
} }
if (!file_exists($sFileName)) if (!file_exists($sFileName))
{ {
throw(new Exception("File $sFileName does not exist")); throw(new Exception("File $sFileName does not exist"));
} }
SetMemoryLimit($oP); SetMemoryLimit($oP);
// The XMLDataLoader constructor has initialized the DB, let's start a transaction // The XMLDataLoader constructor has initialized the DB, let's start a transaction
CMDBSource::Query('START TRANSACTION'); CMDBSource::Query('START TRANSACTION');
$oChange = MetaModel::NewObject("CMDBChange"); $oChange = MetaModel::NewObject("CMDBChange");
$oChange->Set("date", time()); $oChange->Set("date", time());
$oChange->Set("userinfo", "Initialization"); $oChange->Set("userinfo", "Initialization");
$iChangeId = $oChange->DBInsert(); $iChangeId = $oChange->DBInsert();
$oP->p("Starting data load."); $oP->p("Starting data load.");
$oDataLoader->StartSession($oChange); $oDataLoader->StartSession($oChange);
$oDataLoader->LoadFile($sFileName); $oDataLoader->LoadFile($sFileName);
$oP->p("Ending data load session"); $oP->p("Ending data load session");
if ($oDataLoader->EndSession(true /* strict */)) if ($oDataLoader->EndSession(true /* strict */))
{ {
$iCountCreated = $oDataLoader->GetCountCreated(); $iCountCreated = $oDataLoader->GetCountCreated();
CMDBSource::Query('COMMIT'); CMDBSource::Query('COMMIT');
$oP->p("Data successfully written into the DB: $iCountCreated objects created"); $oP->p("Data successfully written into the DB: $iCountCreated objects created");
} }
else else
{ {
CMDBSource::Query('ROLLBACK'); CMDBSource::Query('ROLLBACK');
$oP->p("Some issues have been encountered, changes will not be recorded, please review the source data"); $oP->p("Some issues have been encountered, changes will not be recorded, please review the source data");
$aErrors = $oDataLoader->GetErrors(); $aErrors = $oDataLoader->GetErrors();
if (count($aErrors) > 0) if (count($aErrors) > 0)
{ {
$oP->p('Errors ('.count($aErrors).')'); $oP->p('Errors ('.count($aErrors).')');
foreach ($aErrors as $sMsg) foreach ($aErrors as $sMsg)
{ {
$oP->p(' * '.$sMsg); $oP->p(' * '.$sMsg);
} }
} }
$aWarnings = $oDataLoader->GetWarnings(); $aWarnings = $oDataLoader->GetWarnings();
if (count($aWarnings) > 0) if (count($aWarnings) > 0)
{ {
$oP->p('Warnings ('.count($aWarnings).')'); $oP->p('Warnings ('.count($aWarnings).')');
foreach ($aWarnings as $sMsg) foreach ($aWarnings as $sMsg)
{ {
$oP->p(' * '.$sMsg); $oP->p(' * '.$sMsg);
} }
} }
} }
} }
catch(Exception $e) catch(Exception $e)
{ {
$oP->p("An error happened while loading the data: ".$e->getMessage()); $oP->p("An error happened while loading the data: ".$e->getMessage());
$oP->p("Aborting (no data written)..."); $oP->p("Aborting (no data written)...");
CMDBSource::Query('ROLLBACK'); CMDBSource::Query('ROLLBACK');
} }
if (function_exists('memory_get_peak_usage')) if (function_exists('memory_get_peak_usage'))
{ {
$oP->p("Information: memory peak usage: ".memory_get_peak_usage()); $oP->p("Information: memory peak usage: ".memory_get_peak_usage());
} }
$oP->Output(); $oP->Output();
?> ?>