Files
tomolino-processmaker/scripts/caseRestore.php
Moron, Olivier eeed2b061b * Added postmessage for communication between iframe and iframe parent for cases (CORS issue)
* Added date_creation and date_mod to case table
* Added PM document management as URL links in item host
* Added caseDump.php and caseRestore.php to be able to dump and restore cases.
* Added GLPI_TICKET_REQUESTTYPES_ID to RW requesttypes_id in tickets
* Added possibility to read/write GLPI_ITEM_GLOBAL_VALIDATION
* Added marketplace folder management
* Added a badge for the case id on tasks in Tickets, Changes and Problems
* Added group to Watcher for task to be claimed
* Changed int(11) into int unsigned
* Added some case fields to be searchable in tickets (changes or problems)
* Removed tech auto-assignment to ticket
* Removed task re-assign mandatory justification (is now optional in task, or process, or default)

* Fixed issue with processes that don't appear in dropdown when in search list
* Fixed first task not set as done when in simplified interface
* Fixed missing comma in SQL document table creation
* Fixes cancellation and deletion rights that were not independent
* Fixed add solution that was not compliant with GLPI9.5
* Fixed task cat that were active after add or updates
* Added a $DB->escape() to escape special chars before query

* Improved global response time for GLPI <-> PM server

Set version to 4.4.0 for GLPI 9.5
2023-10-16 14:48:42 +02:00

77 lines
1.6 KiB
PHP

<?php
// to restore case state
// Ensure current directory when run from crontab
chdir(dirname($_SERVER["SCRIPT_FILENAME"]));
define('GLPI_ROOT', '../../..');
include (GLPI_ROOT . "/inc/includes.php");
function runSQLFile($locdbs, $path) {
$line = 1;
$script = fopen($path, 'r');
if (!$script) {
return false;
}
$sql_query = @fread(
$script,
@filesize($path)
) . "\n";
$queries = preg_split('/;\s*$/m', $sql_query);
foreach ($queries as $query) {
$query = trim($query);
if ($query != '') {
$re = '/INSERT INTO `.*`\.`glpi_/';
$locdb = $locdbs['PM'];
if (preg_match($re, $query)) {
$locdb = $locdbs['GLPI'];
}
$locdb->queryOrDie($query, "ERROR: Can't exec line $line\n");
$line++;
}
}
return true;
}
if ($argc == 3) {
// $argv[1] must be the cases_id
// and
// argv[2] must be a SQL file to restore
/////////////////////////////
// Delete the case in GLPI and PM
/////////////////////////////
$case = new PluginProcessmakerCase();
if ($case->getFromDB($argv[1]) && $case->deleteCase()) {
echo "Case has been deleted\n";
} else {
echo "Can't delete case " . $argv[1] . "\n";
}
$DB->beginTransaction();
$PM_DB->beginTransaction();
runSQLFile(['GLPI' => $DB, 'PM' => $PM_DB], $argv[2]);
$PM_DB->commit();
$DB->commit();
echo "Case has been restored\n";
} else {
echo "Can't restore case, a cases_id is missing and/or sql file name, syntax: php.exe -f caseRestore.php cases_id SQLfilename\n";
}