check_sla_for_tickets.php 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. // Copyright (C) 2010 Combodo SARL
  3. //
  4. // This program is free software; you can redistribute it and/or modify
  5. // it under the terms of the GNU General Public License as published by
  6. // the Free Software Foundation; version 3 of the License.
  7. //
  8. // This program is distributed in the hope that it will be useful,
  9. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. // GNU General Public License for more details.
  12. //
  13. // You should have received a copy of the GNU General Public License
  14. // along with this program; if not, write to the Free Software
  15. // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  16. /**
  17. * Export data specified by an OQL
  18. *
  19. * @author Erwan Taloc <erwan.taloc@combodo.com>
  20. * @author Romain Quetiez <romain.quetiez@combodo.com>
  21. * @author Denis Flaven <denis.flaven@combodo.com>
  22. * @license http://www.opensource.org/licenses/gpl-3.0.html LGPL
  23. */
  24. require_once('../approot.inc.php');
  25. require_once(APPROOT.'/application/startup.inc.php');
  26. require_once(APPROOT.'/application/loginwebpage.class.inc.php');
  27. LoginWebPage::DoLogin(); // Check user rights and prompt if needed
  28. $oMyChange = new CMDBChange();
  29. $oMyChange->Set("date", time());
  30. $oMyChange->Set("userinfo", "Automatic updates");
  31. $iChangeId = $oMyChange->DBInsertNoReload();
  32. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT ResponseTicket WHERE status = \'new\' AND tto_escalation_deadline <= NOW()'));
  33. while ($oToEscalate = $oSet->Fetch())
  34. {
  35. $oToEscalate->ApplyStimulus('ev_timeout');
  36. //$oToEscalate->Set('tto_escalation_deadline', null);
  37. $oToEscalate->DBUpdateTracked($oMyChange, true);
  38. echo "<p>ticket ".$oToEscalate->Get('ref')." reached TTO ESCALATION deadline</p>\n";
  39. }
  40. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT ResponseTicket WHERE status = \'assigned\' AND ttr_escalation_deadline <= NOW()'));
  41. while ($oToEscalate = $oSet->Fetch())
  42. {
  43. $oToEscalate->ApplyStimulus('ev_timeout');
  44. //$oToEscalate->Set('ttr_escalation_deadline', null);
  45. $oToEscalate->DBUpdateTracked($oMyChange, true);
  46. echo "<p>ticket ".$oToEscalate->Get('ref')." reached TTR ESCALATION deadline</p>\n";
  47. }
  48. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT ResponseTicket WHERE status = \'resolved\' AND closure_deadline <= NOW()'));
  49. while ($oToEscalate = $oSet->Fetch())
  50. {
  51. $oToEscalate->ApplyStimulus('ev_close');
  52. //$oToEscalate->Set('closure_deadline', null);
  53. $oToEscalate->DBUpdateTracked($oMyChange, true);
  54. echo "<p>ticket ".$oToEscalate->Get('ref')." reached closure deadline</p>\n";
  55. }
  56. ?>