* Bugfix Uncaught ReferenceError: $ is not defined on ITIL Object creation * Delete error message after case cancellation successfully * change minimum version of processmaker server * delete TODO comment * Add possibility to cancel case with multiple tasks * bugfix delete reminder on case's cancel or delete * Add behavior on a claimed task or reasign to the current user for show task in timeline * Fixed issue with default dates settings in reminders for tasks * Added shortcut to select "Me as sender" * Added a test to prevent post-only user to set reminder settings * Updated XML * Fix issue with screen view * Adjusted wordings * Reviewed $new_date computation in cron * Bugfix creating a case in processcase tab doesn't redirect to the case * Adjusted visualization for Reminder * Added an <hr> * Adjusted values in dropdowns when settings are NULL * Added a test to prevent sending of remminders to "ProcessMaker" user * Added view of default and actual reminder settings for a PM task * cronPMReminder reflects changes and send reminders * Re-engineered table fields and search options * Fixed issue with FUP that were no longuer added to timeline. * Added automatic reminders * bugfix on filter * Changed copyrights * added .gitignore * add process category search option + input in process form * Added process categories * bugfixes on helpdesk process * bugfixes html_tags and actiontime * Changed the way the userId of the first task was computed, to be able to have a tobeclaimed task * Added get/set APP_DATA scripts to be able to read/write the APP_DATA in json files * Added a followup when a reminder is sent to task user (or group) Set version 5.2.3
147 lines
5.2 KiB
PHP
147 lines
5.2 KiB
PHP
<?php
|
|
/*
|
|
-------------------------------------------------------------------------
|
|
ProcessMaker plugin for GLPI
|
|
Copyright (C) 2014-2024 by Raynet SAS a company of A.Raymond Network.
|
|
|
|
https://www.araymond.com/
|
|
-------------------------------------------------------------------------
|
|
|
|
LICENSE
|
|
|
|
This file is part of ProcessMaker plugin for GLPI.
|
|
|
|
This file is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This plugin is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this plugin. If not, see <http://www.gnu.org/licenses/>.
|
|
--------------------------------------------------------------------------
|
|
*/
|
|
|
|
// 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";
|
|
}
|
|
|