mirror of
https://github.com/Combodo/iTop.git
synced 2026-02-13 07:24:13 +01:00
Switch back files from CrLf to Lf
This commit is contained in:
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
1434
js/utils.js
1434
js/utils.js
File diff suppressed because it is too large
Load Diff
@@ -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());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -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();
|
||||||
?>
|
?>
|
||||||
|
|||||||
Reference in New Issue
Block a user