check_sla_for_tickets.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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. // Bug: only TTO is being handled for the beta version
  32. //
  33. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT Incident WHERE status = \'new\' AND escalation_deadline < NOW()'));
  34. while ($oToEscalate = $oSet->Fetch())
  35. {
  36. $oToEscalate->ApplyStimulus('ev_timeout');
  37. $oToEscalate->Set('escalation_deadline', null);
  38. $oToEscalate->DBUpdateTracked($oMyChange);
  39. echo "<p>ticket ".$oToEscalate->Get('ref')." reached TTO ESCALATION deadline</p>\n";
  40. }
  41. $oSet = new DBObjectSet(DBObjectSearch::FromOQL('SELECT Incident WHERE status = \'assigned\' AND closure_deadline < NOW()'));
  42. while ($oToEscalate = $oSet->Fetch())
  43. {
  44. $oToEscalate->ApplyStimulus('ev_timeout');
  45. $oToEscalate->Set('closure_deadline', null);
  46. $oToEscalate->DBUpdateTracked($oMyChange);
  47. echo "<p>ticket ".$oToEscalate->Get('ref')." reached TTR ESCALATION deadline</p>\n";
  48. }
  49. ?>