check_sla_for_tickets.php 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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('../application/startup.inc.php');
  25. require_once('../application/loginwebpage.class.inc.php');
  26. LoginWebPage::DoLogin(); // Check user rights and prompt if needed
  27. $oMyChange = new CMDBChange();
  28. $oMyChange->Set("date", time());
  29. $oMyChange->Set("userinfo", "Automatic updates");
  30. $iChangeId = $oMyChange->DBInsertNoReload();
  31. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT ResponseTicket WHERE status = \'new\' AND tto_escalation_deadline <= NOW()'));
  32. while ($oToEscalate = $oSet->Fetch())
  33. {
  34. $oToEscalate->ApplyStimulus('ev_timeout');
  35. //$oToEscalate->Set('tto_escalation_deadline', null);
  36. $oToEscalate->DBUpdateTracked($oMyChange);
  37. echo "<p>ticket ".$oToEscalate->Get('ref')." reached TTO ESCALATION deadline</p>\n";
  38. }
  39. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT ResponseTicket WHERE status = \'assigned\' AND ttr_escalation_deadline <= NOW()'));
  40. while ($oToEscalate = $oSet->Fetch())
  41. {
  42. $oToEscalate->ApplyStimulus('ev_timeout');
  43. //$oToEscalate->Set('ttr_escalation_deadline', null);
  44. $oToEscalate->DBUpdateTracked($oMyChange);
  45. echo "<p>ticket ".$oToEscalate->Get('ref')." reached TTR ESCALATION deadline</p>\n";
  46. }
  47. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT ResponseTicket WHERE status = \'resolved\' AND closure_deadline <= NOW()'));
  48. while ($oToEscalate = $oSet->Fetch())
  49. {
  50. $oToEscalate->ApplyStimulus('ev_close');
  51. //$oToEscalate->Set('closure_deadline', null);
  52. $oToEscalate->DBUpdateTracked($oMyChange);
  53. echo "<p>ticket ".$oToEscalate->Get('ref')." reached closure deadline</p>\n";
  54. }
  55. ?>