Files
tomolino-processmaker/scripts/caseRestore.php
Moron, Olivier cc17bd5fe4 * Bugfix Reminders on task cancelled before delete reminders update was not deleted
* 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
2025-01-14 12:17:17 +01:00

103 lines
2.7 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 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";
}