Files
tomolino-processmaker/scripts/caseDump.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

120 lines
4.2 KiB
PHP

<?php
// to dump case records, to be able 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");
/**
* Summary of exportRows
* @param mixed $locDB mysql db ressource
* @param mixed $table mysql table
* @param mixed $where mysql where clause
* @param mixed $fd file descriptor used to write
* @return array found rows in the table
*/
function exportRows($locDB, $table, $where, $fd) {
$content = '';
$ret = [];
$table = "`".$locDB->dbdefault."`.`".$table."`";
$results = $locDB->query('SELECT * FROM '.$table.' WHERE '.$where);
foreach ($results as $row) {
$line = '';
foreach (array_values($row) as $val) {
if (strlen($line) > 0) {
$line .= ",";
}
if (is_string($val)) {
$line .= "'".$locDB->escape($val)."'";
} else {
$line .= $val ?? 'NULL';
}
}
$line = "INSERT INTO ".$table." VALUES ($line);";
$content .= $line. "\n";
$ret[] = $row;
}
fputs($fd, $content);
return $ret;
}
if ($argc == 3) {
// $argv[1] must be the plugin_processmaker_cases_id
// $argv[2] must be the filename to dump
/////////////////////////////
// GLPI
/////////////////////////////
$fd = fopen($argv[2], 'w');
// first get the case info
$case = exportRows($DB, 'glpi_plugin_processmaker_cases', 'id = '. $argv[1], $fd);
if (count($case) > 0) {
// then get crontaskactions
$crontasks = exportRows($DB, 'glpi_plugin_processmaker_crontaskactions', 'plugin_processmaker_cases_id = '. $argv[1], $fd);
// then get the tasks todo and done
$pmtasks = exportRows($DB, 'glpi_plugin_processmaker_tasks', 'plugin_processmaker_cases_id = '. $argv[1], $fd);
$tasktable = getTableForItemType($pmtasks[0]['itemtype']); // there should be at least one task
$tasksid = [];
foreach ($pmtasks as $pmtask) {
exportRows($DB, $tasktable, 'id = '.$pmtask['items_id'], $fd);
$tasksid[] = $pmtask['items_id'];
}
// then get the tasks of type information
$re = "<input name=\'caseid\' type=\'hidden\' value=\'".$argv[1]."\'><input name=\'taskid\' type=\'hidden\' value=\'[1-9][0-9]*\'>";
exportRows($DB, $tasktable, "content REGEXP '".$re."' AND id NOT IN (".implode(',', $tasksid).")", $fd);
// then export documents
$docs_id = exportRows($DB, 'glpi_plugin_processmaker_documents', "plugin_processmaker_cases_id = ".$argv[1], $fd);
$docs_id = array_column($docs_id, 'documentsid');
if (count($docs_id)) {
exportRows($DB, 'glpi_documents_items', "documents_id IN (".implode(',', $docs_id).")", $fd);
exportRows($DB, 'glpi_documents', "id IN (".implode(',', $docs_id).")", $fd);
}
/////////////////////////////
// PM
/////////////////////////////
// next get $PM_DB dump
$pmcases = exportRows($PM_DB, 'application', 'APP_NUMBER = '.$argv[1], $fd);
$APP_UID = $pmcases[0]['APP_UID'];
//exportRows($PM_DB, 'app_cache_view', "APP_UID = '$APP_UID'", $fd); DO NOT EXPORT
exportRows($PM_DB, 'app_delay', "APP_UID = '$APP_UID'", $fd);
exportRows($PM_DB, 'app_delegation', "APP_UID = '$APP_UID'", $fd);
// add a delete, otherwise the app_document table may contain "DELETED" documents during restore
fputs($fd, "DELETE FROM `".$PM_DB->dbdefault."`.`app_document` WHERE APP_UID = '$APP_UID';\n");
exportRows($PM_DB, 'app_document', "APP_UID = '$APP_UID'", $fd);
exportRows($PM_DB, 'app_history', "APP_UID = '$APP_UID'", $fd);
exportRows($PM_DB, 'app_message', "APP_UID = '$APP_UID'", $fd);
exportRows($PM_DB, 'app_notes', "APP_UID = '$APP_UID'", $fd);
exportRows($PM_DB, 'app_thread', "APP_UID = '$APP_UID'", $fd);
echo "Case has been dumped\n";
} else {
echo "Can't find case: " . $argv[1] . "\n";
}
fclose($fd);
} else {
echo "Can't dump case, syntax error: php.exe -f caseDump.php caseid filename\n";
}