model.itop-tickets.php 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661
  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. * Persistent classes for a CMDB
  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. abstract class Ticket extends cmdbAbstractObject
  25. {
  26. public static function Init()
  27. {
  28. $aParams = array
  29. (
  30. "category" => "bizmodel,searchable,ticketing",
  31. "key_type" => "autoincrement",
  32. "name_attcode" => "ref",
  33. "state_attcode" => "",
  34. "reconc_keys" => array("name"),
  35. "db_table" => "ticket",
  36. "db_key_field" => "id",
  37. "db_finalclass_field" => "",
  38. "display_template" => "",
  39. );
  40. MetaModel::Init_Params($aParams);
  41. MetaModel::Init_InheritAttributes();
  42. MetaModel::Init_AddAttribute(new AttributeString("ref", array("allowed_values"=>null, "sql"=>"ref", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  43. MetaModel::Init_AddAttribute(new AttributeString("title", array("allowed_values"=>null, "sql"=>"title", "default_value"=>"", "is_null_allowed"=>false, "depends_on"=>array())));
  44. MetaModel::Init_AddAttribute(new AttributeText("ticket_log", array("allowed_values"=>null, "sql"=>"ticket_log", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  45. MetaModel::Init_AddAttribute(new AttributeDateTime("start_date", array("allowed_values"=>null, "sql"=>"start_date", "default_value"=>"", "is_null_allowed"=>false, "depends_on"=>array())));
  46. MetaModel::Init_AddAttribute(new AttributeLinkedSetIndirect("document_list", array("linked_class"=>"lnkTicketToDoc", "ext_key_to_me"=>"ticket_id", "ext_key_to_remote"=>"document_id", "allowed_values"=>null, "count_min"=>0, "count_max"=>0, "depends_on"=>array())));
  47. MetaModel::Init_AddAttribute(new AttributeLinkedSetIndirect("ci_list", array("linked_class"=>"lnkTicketToCI", "ext_key_to_me"=>"ticket_id", "ext_key_to_remote"=>"ci_id", "allowed_values"=>null, "count_min"=>0, "count_max"=>0, "depends_on"=>array())));
  48. MetaModel::Init_AddAttribute(new AttributeLinkedSetIndirect("contact_list", array("linked_class"=>"lnkTicketToContact", "ext_key_to_me"=>"ticket_id", "ext_key_to_remote"=>"contact_id", "allowed_values"=>null, "count_min"=>0, "count_max"=>0, "depends_on"=>array())));
  49. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'document_list', 'ci_list', 'contact_list'));
  50. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date'));
  51. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date'));
  52. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date'));
  53. }
  54. }
  55. class lnkTicketToDoc extends cmdbAbstractObject
  56. {
  57. public static function Init()
  58. {
  59. $aParams = array
  60. (
  61. "category" => "bizmodel,searchable,ticketing",
  62. "key_type" => "autoincrement",
  63. "name_attcode" => "ticket_id",
  64. "state_attcode" => "",
  65. "reconc_keys" => array("name"),
  66. "db_table" => "lnktickettodoc",
  67. "db_key_field" => "id",
  68. "db_finalclass_field" => "",
  69. "display_template" => "",
  70. );
  71. MetaModel::Init_Params($aParams);
  72. MetaModel::Init_InheritAttributes();
  73. MetaModel::Init_AddAttribute(new AttributeExternalKey("ticket_id", array("targetclass"=>"Ticket", "jointype"=>null, "allowed_values"=>null, "sql"=>"ticket_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  74. MetaModel::Init_AddAttribute(new AttributeExternalField("ticket_ref", array("allowed_values"=>null, "extkey_attcode"=>"ticket_id", "target_attcode"=>"ref", "is_null_allowed"=>true, "depends_on"=>array())));
  75. MetaModel::Init_AddAttribute(new AttributeExternalKey("document_id", array("targetclass"=>"Document", "jointype"=>null, "allowed_values"=>null, "sql"=>"document_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  76. MetaModel::Init_AddAttribute(new AttributeExternalField("document_name", array("allowed_values"=>null, "extkey_attcode"=>"document_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  77. MetaModel::Init_SetZListItems('details', array('ticket_id', 'document_id'));
  78. MetaModel::Init_SetZListItems('advanced_search', array('ticket_id', 'document_id'));
  79. MetaModel::Init_SetZListItems('standard_search', array('ticket_id', 'document_id'));
  80. MetaModel::Init_SetZListItems('list', array('ticket_id', 'document_id'));
  81. }
  82. }
  83. class lnkTicketToContact extends cmdbAbstractObject
  84. {
  85. public static function Init()
  86. {
  87. $aParams = array
  88. (
  89. "category" => "bizmodel,searchable,ticketing",
  90. "key_type" => "autoincrement",
  91. "name_attcode" => "ticket_id",
  92. "state_attcode" => "",
  93. "reconc_keys" => array("name"),
  94. "db_table" => "lnktickettocontact",
  95. "db_key_field" => "id",
  96. "db_finalclass_field" => "",
  97. "display_template" => "",
  98. );
  99. MetaModel::Init_Params($aParams);
  100. MetaModel::Init_InheritAttributes();
  101. MetaModel::Init_AddAttribute(new AttributeExternalKey("ticket_id", array("targetclass"=>"Ticket", "jointype"=>null, "allowed_values"=>null, "sql"=>"ticket_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  102. MetaModel::Init_AddAttribute(new AttributeExternalField("ticket_ref", array("allowed_values"=>null, "extkey_attcode"=>"ticket_id", "target_attcode"=>"ref", "is_null_allowed"=>true, "depends_on"=>array())));
  103. MetaModel::Init_AddAttribute(new AttributeExternalKey("contact_id", array("targetclass"=>"Contact", "jointype"=>null, "allowed_values"=>null, "sql"=>"contact_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  104. MetaModel::Init_AddAttribute(new AttributeExternalField("contact_name", array("allowed_values"=>null, "extkey_attcode"=>"contact_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  105. MetaModel::Init_AddAttribute(new AttributeExternalField("contact_email", array("allowed_values"=>null, "extkey_attcode"=>"contact_id", "target_attcode"=>"email", "is_null_allowed"=>true, "depends_on"=>array())));
  106. MetaModel::Init_SetZListItems('details', array('ticket_id', 'contact_id', 'contact_email'));
  107. MetaModel::Init_SetZListItems('advanced_search', array('ticket_id', 'contact_id', 'contact_email'));
  108. MetaModel::Init_SetZListItems('standard_search', array('ticket_id', 'contact_id', 'contact_email'));
  109. MetaModel::Init_SetZListItems('list', array('ticket_id', 'contact_id', 'contact_email'));
  110. }
  111. }
  112. class lnkTicketToCI extends cmdbAbstractObject
  113. {
  114. public static function Init()
  115. {
  116. $aParams = array
  117. (
  118. "category" => "bizmodel,searchable,ticketing",
  119. "key_type" => "autoincrement",
  120. "name_attcode" => "ticket_id",
  121. "state_attcode" => "",
  122. "reconc_keys" => array("name"),
  123. "db_table" => "lnktickettoci",
  124. "db_key_field" => "id",
  125. "db_finalclass_field" => "",
  126. "display_template" => "",
  127. );
  128. MetaModel::Init_Params($aParams);
  129. MetaModel::Init_InheritAttributes();
  130. MetaModel::Init_AddAttribute(new AttributeExternalKey("ticket_id", array("targetclass"=>"Ticket", "jointype"=>null, "allowed_values"=>null, "sql"=>"ticket_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  131. MetaModel::Init_AddAttribute(new AttributeExternalField("ticket_ref", array("allowed_values"=>null, "extkey_attcode"=>"ticket_id", "target_attcode"=>"ref", "is_null_allowed"=>true, "depends_on"=>array())));
  132. MetaModel::Init_AddAttribute(new AttributeExternalKey("ci_id", array("targetclass"=>"FunctionalCI", "jointype"=>null, "allowed_values"=>null, "sql"=>"ci_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  133. MetaModel::Init_AddAttribute(new AttributeExternalField("ci_name", array("allowed_values"=>null, "extkey_attcode"=>"ci_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  134. MetaModel::Init_AddAttribute(new AttributeExternalField("ci_status", array("allowed_values"=>null, "extkey_attcode"=>"ci_id", "target_attcode"=>"status", "is_null_allowed"=>true, "depends_on"=>array())));
  135. MetaModel::Init_SetZListItems('details', array('ticket_id', 'ci_id', 'ci_status'));
  136. MetaModel::Init_SetZListItems('advanced_search', array('ticket_id', 'ci_id', 'ci_status'));
  137. MetaModel::Init_SetZListItems('standard_search', array('ticket_id', 'ci_id', 'ci_status'));
  138. MetaModel::Init_SetZListItems('list', array('ticket_id', 'ci_id', 'ci_status'));
  139. }
  140. }
  141. class Incident extends Ticket
  142. {
  143. public static function Init()
  144. {
  145. $aParams = array
  146. (
  147. "category" => "bizmodel,searchable,incidentmgmt",
  148. "key_type" => "autoincrement",
  149. "name_attcode" => "ref",
  150. "state_attcode" => "status",
  151. "reconc_keys" => array("name"),
  152. "db_table" => "incident",
  153. "db_key_field" => "id",
  154. "db_finalclass_field" => "",
  155. "display_template" => "",
  156. );
  157. MetaModel::Init_Params($aParams);
  158. MetaModel::Init_InheritAttributes();
  159. MetaModel::Init_AddAttribute(new AttributeEnum("status", array("allowed_values"=>new ValueSetEnum('new,assigned,escalated_tto,escalated_ttr,resolved,closed'), "sql"=>"status", "default_value"=>"new", "is_null_allowed"=>false, "depends_on"=>array())));
  160. MetaModel::Init_AddAttribute(new AttributeExternalKey("caller_id", array("targetclass"=>"Person", "jointype"=>null, "allowed_values"=>null, "sql"=>"caller_id", "is_null_allowed"=>true, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  161. MetaModel::Init_AddAttribute(new AttributeExternalField("workgroup_name", array("allowed_values"=>null, "extkey_attcode"=>"caller_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  162. MetaModel::Init_AddAttribute(new AttributeExternalKey("customer_id", array("targetclass"=>"Organization", "jointype"=>null, "allowed_values"=>null, "sql"=>"customer_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_AUTO, "depends_on"=>array())));
  163. MetaModel::Init_AddAttribute(new AttributeExternalField("customer_name", array("allowed_values"=>null, "extkey_attcode"=>"customer_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  164. MetaModel::Init_AddAttribute(new AttributeExternalKey("service_id", array("targetclass"=>"Service", "jointype"=>null, "allowed_values"=>null, "sql"=>"service_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  165. MetaModel::Init_AddAttribute(new AttributeExternalField("service_name", array("allowed_values"=>null, "extkey_attcode"=>"service_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  166. MetaModel::Init_AddAttribute(new AttributeExternalKey("servicesubcategory_id", array("targetclass"=>"ServiceSubcategory", "jointype"=>null, "allowed_values"=>null, "sql"=>"servicesubcategory_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  167. MetaModel::Init_AddAttribute(new AttributeExternalField("servicesubcategory_name", array("allowed_values"=>null, "extkey_attcode"=>"servicesubcategory_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  168. MetaModel::Init_AddAttribute(new AttributeString("product", array("allowed_values"=>null, "sql"=>"product", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  169. MetaModel::Init_AddAttribute(new AttributeEnum("impact", array("allowed_values"=>new ValueSetEnum('1,2,3'), "sql"=>"impact", "default_value"=>"1", "is_null_allowed"=>false, "depends_on"=>array())));
  170. MetaModel::Init_AddAttribute(new AttributeEnum("urgency", array("allowed_values"=>new ValueSetEnum('1,2,3'), "sql"=>"urgency", "default_value"=>"1", "is_null_allowed"=>false, "depends_on"=>array())));
  171. MetaModel::Init_AddAttribute(new AttributeEnum("priority", array("allowed_values"=>new ValueSetEnum('1,2,3'), "sql"=>"priority", "default_value"=>"low", "is_null_allowed"=>false, "depends_on"=>array())));
  172. MetaModel::Init_AddAttribute(new AttributeExternalKey("workgroup_id", array("targetclass"=>"Team", "jointype"=>null, "allowed_values"=>null, "sql"=>"workgroup_id", "is_null_allowed"=>false, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  173. MetaModel::Init_AddAttribute(new AttributeExternalField("workgroup_name", array("allowed_values"=>null, "extkey_attcode"=>"workgroup_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  174. MetaModel::Init_AddAttribute(new AttributeExternalKey("agent_id", array("targetclass"=>"Person", "jointype"=>null, "allowed_values"=>null, "sql"=>"agent_id", "is_null_allowed"=>true, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  175. MetaModel::Init_AddAttribute(new AttributeExternalField("agent_name", array("allowed_values"=>null, "extkey_attcode"=>"agent_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  176. MetaModel::Init_AddAttribute(new AttributeExternalField("agent_email", array("allowed_values"=>null, "extkey_attcode"=>"agent_id", "target_attcode"=>"email", "is_null_allowed"=>true, "depends_on"=>array())));
  177. MetaModel::Init_AddAttribute(new AttributeExternalKey("related_problem_id", array("targetclass"=>"Problem", "jointype"=>null, "allowed_values"=>null, "sql"=>"related_problem_id", "is_null_allowed"=>true, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  178. MetaModel::Init_AddAttribute(new AttributeExternalField("related_problem_ref", array("allowed_values"=>null, "extkey_attcode"=>"related_problem_id", "target_attcode"=>"ref", "is_null_allowed"=>true, "depends_on"=>array())));
  179. MetaModel::Init_AddAttribute(new AttributeExternalKey("related_change_id", array("targetclass"=>"Change", "jointype"=>null, "allowed_values"=>null, "sql"=>"related_change_id", "is_null_allowed"=>true, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  180. MetaModel::Init_AddAttribute(new AttributeExternalField("related_change_ref", array("allowed_values"=>null, "extkey_attcode"=>"related_change_id", "target_attcode"=>"ref", "is_null_allowed"=>true, "depends_on"=>array())));
  181. MetaModel::Init_AddAttribute(new AttributeDateTime("closure_date", array("allowed_values"=>null, "sql"=>"closure_date", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  182. MetaModel::Init_AddAttribute(new AttributeDateTime("last_update", array("allowed_values"=>null, "sql"=>"last_update", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  183. MetaModel::Init_AddAttribute(new AttributeDateTime("assignment_date", array("allowed_values"=>null, "sql"=>"assignment_date", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  184. MetaModel::Init_AddAttribute(new AttributeDeadline("escalation_deadline", array("allowed_values"=>null, "sql"=>"escalation_deadline", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  185. MetaModel::Init_AddAttribute(new AttributeDeadline("closure_deadline", array("allowed_values"=>null, "sql"=>"closure_deadline", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  186. MetaModel::Init_AddAttribute(new AttributeEnum("resolution_code", array("allowed_values"=>new ValueSetEnum('fixed,duplicate,couldnotreproduce,irrelevant'), "sql"=>"resolution_code", "default_value"=>null, "is_null_allowed"=>true, "depends_on"=>array())));
  187. MetaModel::Init_AddAttribute(new AttributeText("solution", array("allowed_values"=>null, "sql"=>"solution", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  188. MetaModel::Init_AddAttribute(new AttributeEnum("user_satisfaction", array("allowed_values"=>new ValueSetEnum('1,2,3,4'), "sql"=>"user_satisfaction", "default_value"=>null, "is_null_allowed"=>true, "depends_on"=>array())));
  189. MetaModel::Init_AddAttribute(new AttributeText("user_commment", array("allowed_values"=>null, "sql"=>"user_commment", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  190. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'escalation_deadline', 'closure_deadline', 'document_list', 'ci_list', 'contact_list', 'status', 'caller_id', 'customer_id', 'service_id', 'servicesubcategory_id', 'product', 'impact', 'urgency', 'priority', 'workgroup_id', 'agent_id', 'agent_email', 'related_problem_id', 'related_change_id', 'closure_date', 'last_update', 'assignment_date', 'escalation_deadline', 'closure_deadline', 'resolution_code', 'solution', 'user_satisfaction', 'user_commment'));
  191. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date', 'status', 'caller_id', 'customer_id', 'service_id', 'servicesubcategory_id', 'product', 'impact', 'urgency', 'priority', 'workgroup_id', 'agent_id', 'agent_email', 'related_problem_id', 'related_change_id', 'closure_date', 'last_update', 'assignment_date', 'escalation_deadline', 'closure_deadline', 'resolution_code', 'solution', 'user_satisfaction', 'user_commment'));
  192. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date', 'status', 'caller_id', 'customer_id', 'service_id', 'servicesubcategory_id', 'product', 'impact', 'urgency', 'priority', 'workgroup_id', 'agent_id', 'agent_email', 'related_problem_id', 'related_change_id', 'closure_date', 'last_update', 'assignment_date', 'escalation_deadline', 'closure_deadline', 'resolution_code', 'solution', 'user_satisfaction', 'user_commment'));
  193. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date', 'status', 'caller_id', 'customer_id', 'service_id', 'servicesubcategory_id', 'product', 'impact', 'urgency', 'priority', 'workgroup_id', 'agent_id', 'agent_email', 'related_problem_id', 'related_change_id', 'closure_date', 'last_update', 'assignment_date', 'escalation_deadline', 'closure_deadline', 'resolution_code', 'solution', 'user_satisfaction', 'user_commment'));
  194. // Lifecycle
  195. MetaModel::Init_DefineState(
  196. "new",
  197. array(
  198. "attribute_inherit" => null,
  199. "attribute_list" => array(
  200. 'ref' => OPT_ATT_READONLY,
  201. 'contact_list' => OPT_ATT_READONLY,
  202. 'start_date' => OPT_ATT_READONLY,
  203. 'last_update' => OPT_ATT_READONLY,
  204. 'assignment_date' => OPT_ATT_HIDDEN,
  205. 'escalation_deadline' => OPT_ATT_READONLY,
  206. 'closure_deadline' => OPT_ATT_HIDDEN,
  207. 'closure_date' => OPT_ATT_HIDDEN,
  208. 'customer_id' => OPT_ATT_MUSTCHANGE,
  209. 'service_id' => OPT_ATT_MUSTCHANGE,
  210. 'servicesubcategory_id' => OPT_ATT_MUSTCHANGE,
  211. 'product' => OPT_ATT_MUSTPROMPT,
  212. 'impact' => OPT_ATT_MUSTCHANGE,
  213. 'urgency' => OPT_ATT_MUSTCHANGE,
  214. 'priority' => OPT_ATT_READONLY,
  215. 'workgroup_id' => OPT_ATT_MUSTCHANGE,
  216. 'agent_id' => OPT_ATT_HIDDEN,
  217. 'related_problem_id' => OPT_ATT_HIDDEN,
  218. 'related_change_id' => OPT_ATT_HIDDEN,
  219. 'resolution_code' => OPT_ATT_HIDDEN,
  220. 'solution' => OPT_ATT_HIDDEN,
  221. 'user_satisfaction' => OPT_ATT_HIDDEN,
  222. 'user_commment' => OPT_ATT_HIDDEN,
  223. ),
  224. )
  225. );
  226. MetaModel::Init_DefineState(
  227. "escalated_tto",
  228. array(
  229. "attribute_inherit" => 'new',
  230. "attribute_list" => array(
  231. ),
  232. )
  233. );
  234. MetaModel::Init_DefineState(
  235. "assigned",
  236. array(
  237. "attribute_inherit" => 'new',
  238. "attribute_list" => array(
  239. 'agent_id' => OPT_ATT_MANDATORY,
  240. 'related_problem_id' => OPT_ATT_NORMAL,
  241. 'related_change_id' => OPT_ATT_NORMAL,
  242. 'closure_deadline' => OPT_ATT_READONLY,
  243. 'escalation_deadline' => OPT_ATT_HIDDEN,
  244. ),
  245. )
  246. );
  247. MetaModel::Init_DefineState(
  248. "escalated_ttr",
  249. array(
  250. "attribute_inherit" => 'assigned',
  251. "attribute_list" => array(
  252. ),
  253. )
  254. );
  255. MetaModel::Init_DefineState(
  256. "resolved",
  257. array(
  258. "attribute_inherit" => 'assigned',
  259. "attribute_list" => array(
  260. 'resolution_code' => OPT_ATT_MUSTCHANGE,
  261. 'solution' => OPT_ATT_MUSTPROMPT,
  262. ),
  263. )
  264. );
  265. MetaModel::Init_DefineState(
  266. "closed",
  267. array(
  268. "attribute_inherit" => 'resolved',
  269. "attribute_list" => array(
  270. 'user_satisfaction' => OPT_ATT_MUSTCHANGE,
  271. 'user_commment' => OPT_ATT_MUSTPROMPT,
  272. ),
  273. )
  274. );
  275. MetaModel::Init_DefineStimulus(new StimulusUserAction("ev_assign", array()));
  276. MetaModel::Init_DefineStimulus(new StimulusUserAction("ev_reassign", array()));
  277. MetaModel::Init_DefineStimulus(new StimulusInternal("ev_timeout", array()));
  278. MetaModel::Init_DefineStimulus(new StimulusUserAction("ev_resolve", array()));
  279. MetaModel::Init_DefineStimulus(new StimulusUserAction("ev_close", array()));
  280. MetaModel::Init_DefineTransition("new", "ev_assign", array("target_state"=>"assigned", "actions"=>array(), "user_restriction"=>null));
  281. MetaModel::Init_DefineTransition("new", "ev_timeout", array("target_state"=>"escalated_tto", "actions"=>array(), "user_restriction"=>null));
  282. MetaModel::Init_DefineTransition("escalated_tto", "ev_assign", array("target_state"=>"assigned", "actions"=>array(), "user_restriction"=>null));
  283. MetaModel::Init_DefineTransition("assigned", "ev_reassign", array("target_state"=>"assigned", "actions"=>array(), "user_restriction"=>null));
  284. MetaModel::Init_DefineTransition("assigned", "ev_timeout", array("target_state"=>"escalated_ttr", "actions"=>array(), "user_restriction"=>null));
  285. MetaModel::Init_DefineTransition("assigned", "ev_resolve", array("target_state"=>"resolved", "actions"=>array(), "user_restriction"=>null));
  286. MetaModel::Init_DefineTransition("escalated_ttr", "ev_reassign", array("target_state"=>"escalated_ttr", "actions"=>array(), "user_restriction"=>null));
  287. MetaModel::Init_DefineTransition("escalated_ttr", "ev_resolve", array("target_state"=>"resolved", "actions"=>array(), "user_restriction"=>null));
  288. MetaModel::Init_DefineTransition("resolved", "ev_reassign", array("target_state"=>"assigned", "actions"=>array(), "user_restriction"=>null));
  289. MetaModel::Init_DefineTransition("resolved", "ev_close", array("target_state"=>"closed", "actions"=>array(), "user_restriction"=>null));
  290. }
  291. /**
  292. * Determines the shortest SLT, for this ticket, for the given metric. Returns null is no SLT was found
  293. * @param string $sMetric Type of metric 'TTO', 'TTR', etc as defined in the SLT class
  294. * @return hash Array with 'SLT' => name of the SLT selected, 'value' => duration in seconds of the SLT metric, null if no SLT applies to this ticket
  295. */
  296. public function ComputeSLT($sMetric = 'TTO')
  297. {
  298. $aResult = null;
  299. if (MetaModel::IsValidClass('SLT'))
  300. {
  301. $sOQL = "SELECT SLT JOIN lnkSLTToSLA AS L1 ON L1.slt_id=SLT.id JOIN SLA ON L1.sla_id = SLA.id JOIN lnkContractToSLA AS L2 ON L2.sla_id = SLA.id JOIN CustomerContract ON L2.contract_id = CustomerContract.id
  302. WHERE SLT.ticket_priority = :priority AND SLA.service_id = :service_id AND SLT.metric = :metric AND CustomerContract.customer_id = :customer_id";
  303. $oSLTSet = new DBObjectSet(DBObjectSearch::FromOQL($sOQL),
  304. array(),
  305. array(
  306. 'priority' => $this->Get('priority'),
  307. 'service_id' => $this->Get('service_id'),
  308. 'metric' => $sMetric,
  309. 'customer_id' => $this->Get('customer_id'),
  310. )
  311. );
  312. $iMinDuration = PHP_INT_MAX;
  313. $sSLTName = '';
  314. while($oSLT = $oSLTSet->Fetch())
  315. {
  316. $iDuration = $oSLT->Get('value');
  317. $sUnit = $oSLT->Get('value_unit');
  318. switch($sUnit)
  319. {
  320. case 'days':
  321. $iDuration = $iDuration * 24; // 24 hours in 1 days
  322. // Fall though
  323. case 'hours':
  324. $iDuration = $iDuration * 60; // 60 minutes in 1 hour
  325. // Fall though
  326. case 'minutes':
  327. $iDuration = $iDuration * 60;
  328. }
  329. if ($iDuration < $iMinDuration)
  330. {
  331. $iMinDuration = $iDuration;
  332. $sSLTName = $oSLT->GetName();
  333. }
  334. }
  335. if ($iMinDuration == PHP_INT_MAX)
  336. {
  337. $aResult = null;
  338. }
  339. else
  340. {
  341. array('SLT' => $sSLTName, 'value' => $iMinDuration);
  342. }
  343. }
  344. return $aResult;
  345. }
  346. /**
  347. * Compute the priority of the ticket based on its impact and urgency
  348. * @return integer The priority of the ticket 1(high) .. 3(low)
  349. */
  350. public function ComputePriority()
  351. {
  352. // priority[impact][urgency]
  353. $aPriorities = array(
  354. // single person
  355. 1 => array(
  356. 1 => 1,
  357. 2 => 1,
  358. 3 => 2,
  359. ),
  360. // a group
  361. 2 => array(
  362. 1 => 1,
  363. 2 => 2,
  364. 3 => 3,
  365. ),
  366. // a departement!
  367. 3 => array(
  368. 1 => 2,
  369. 2 => 3,
  370. 3 => 3,
  371. ),
  372. );
  373. $iPriority = $aPriorities[(int)$this->Get('impact')][(int)$this->Get('urgency')];
  374. return $iPriority;
  375. }
  376. public function ComputeValues()
  377. {
  378. $iKey = $this->GetKey();
  379. if ($iKey < 0)
  380. {
  381. // Object not yet in the Database
  382. $iKey = MetaModel::GetNextKey(get_class($this));
  383. }
  384. $sName = sprintf('I-%06d', $iKey);
  385. $this->Set('ref', $sName);
  386. // Compute the priority of the ticket
  387. $this->Set('priority', $this->ComputePriority());
  388. // Compute the SLA deadlines, if any is applicable to this ticket
  389. $aSLT = $this->ComputeSLT('TTO');
  390. if ($aSLT != null)
  391. {
  392. //echo "<p>TTO: SLT found: {$aSLT['SLT']}, value: {$aSLT['value']}</p>\n";
  393. $iStartDate = AttributeDateTime::GetAsUnixSeconds($this->Get('start_date'));
  394. $this->Set('escalation_deadline', $iStartDate + $aSLT['value']);
  395. }
  396. else
  397. {
  398. $this->Set('escalation_deadline', null);
  399. }
  400. $aSLT = $this->ComputeSLT('TTR');
  401. if ($aSLT != null)
  402. {
  403. //echo "<p>TTR: SLT found: {$aSLT['SLT']}, value: {$aSLT['value']}</p>\n";
  404. $iStartDate = AttributeDateTime::GetAsUnixSeconds($this->Get('start_date'));
  405. $this->Set('closure_deadline', $iStartDate + $aSLT['value']);
  406. }
  407. else
  408. {
  409. $this->Set('closure_deadline', null);
  410. }
  411. }
  412. }
  413. class Change extends Ticket
  414. {
  415. public static function Init()
  416. {
  417. $aParams = array
  418. (
  419. "category" => "bizmodel,searchable,changemgmt",
  420. "key_type" => "autoincrement",
  421. "name_attcode" => "ref",
  422. "state_attcode" => "",
  423. "reconc_keys" => array("name"),
  424. "db_table" => "change",
  425. "db_key_field" => "id",
  426. "db_finalclass_field" => "",
  427. "display_template" => "",
  428. );
  429. MetaModel::Init_Params($aParams);
  430. MetaModel::Init_InheritAttributes();
  431. MetaModel::Init_AddAttribute(new AttributeString("reason", array("allowed_values"=>null, "sql"=>"reason", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  432. MetaModel::Init_AddAttribute(new AttributeEnum("status", array("allowed_values"=>new ValueSetEnum('Approved,Assigned,Closed,Implemented,Monitored,New,NotApproved,PlannedScheduled,Rejected,Validated'), "sql"=>"status", "default_value"=>"New", "is_null_allowed"=>true, "depends_on"=>array())));
  433. MetaModel::Init_AddAttribute(new AttributeExternalKey("caller_id", array("targetclass"=>"Person", "jointype"=>null, "allowed_values"=>null, "sql"=>"caller_id", "is_null_allowed"=>true, "on_target_delete"=>DEL_MANUAL, "depends_on"=>array())));
  434. MetaModel::Init_AddAttribute(new AttributeExternalField("workgroup_name", array("allowed_values"=>null, "extkey_attcode"=>"caller_id", "target_attcode"=>"name", "is_null_allowed"=>true, "depends_on"=>array())));
  435. MetaModel::Init_AddAttribute(new AttributeDate("start", array("allowed_values"=>null, "sql"=>"start", "default_value"=>"", "is_null_allowed"=>false, "depends_on"=>array())));
  436. MetaModel::Init_AddAttribute(new AttributeDate("end", array("allowed_values"=>null, "sql"=>"end", "default_value"=>"", "is_null_allowed"=>false, "depends_on"=>array())));
  437. MetaModel::Init_AddAttribute(new AttributeDate("last_update", array("allowed_values"=>null, "sql"=>"last_update", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  438. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'document_list', 'ci_list', 'contact_list', 'reason', 'status', 'caller_id', 'start', 'end', 'last_update'));
  439. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date', 'reason', 'status', 'caller_id', 'start', 'end', 'last_update'));
  440. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date', 'reason', 'status', 'caller_id', 'start', 'end', 'last_update'));
  441. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date', 'reason', 'status', 'caller_id', 'start', 'end', 'last_update'));
  442. MetaModel::Init_DefineState(
  443. "new",
  444. array(
  445. "attribute_inherit"=>null,
  446. "attribute_list"=>array(
  447. 'xxx' => OPT_ATT_READONLY,
  448. 'xxx' => OPT_ATT_HIDDEN,
  449. 'xxx' => OPT_ATT_MUSTCHANGE,
  450. 'xxx' => OPT_ATT_MUSTPROMPT,
  451. 'xxx' => OPT_ATT_MANDATORY,
  452. ),
  453. )
  454. );
  455. }
  456. }
  457. class UserRequest extends Ticket
  458. {
  459. public static function Init()
  460. {
  461. $aParams = array
  462. (
  463. "category" => "bizmodel,searchable,callmgmt",
  464. "key_type" => "autoincrement",
  465. "name_attcode" => "ref",
  466. "state_attcode" => "",
  467. "reconc_keys" => array("name"),
  468. "db_table" => "userrequest",
  469. "db_key_field" => "id",
  470. "db_finalclass_field" => "",
  471. "display_template" => "",
  472. );
  473. MetaModel::Init_Params($aParams);
  474. MetaModel::Init_InheritAttributes();
  475. MetaModel::Init_AddAttribute(new AttributeString("foo", array("allowed_values"=>null, "sql"=>"foo", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  476. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'document_list', 'ci_list', 'contact_list', 'foo'));
  477. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  478. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  479. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  480. }
  481. }
  482. class Problem extends Ticket
  483. {
  484. public static function Init()
  485. {
  486. $aParams = array
  487. (
  488. "category" => "bizmodel,searchable,problemmgmt",
  489. "key_type" => "autoincrement",
  490. "name_attcode" => "ref",
  491. "state_attcode" => "",
  492. "reconc_keys" => array("name"),
  493. "db_table" => "problem",
  494. "db_key_field" => "id",
  495. "db_finalclass_field" => "",
  496. "display_template" => "",
  497. );
  498. MetaModel::Init_Params($aParams);
  499. MetaModel::Init_InheritAttributes();
  500. MetaModel::Init_AddAttribute(new AttributeString("foo", array("allowed_values"=>null, "sql"=>"foo", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  501. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'document_list', 'ci_list', 'contact_list', 'foo'));
  502. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  503. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  504. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  505. MetaModel::Init_DefineState(
  506. "new",
  507. array(
  508. "attribute_inherit"=>null,
  509. "attribute_list"=>array(
  510. 'xxx' => OPT_ATT_READONLY,
  511. 'xxx' => OPT_ATT_HIDDEN,
  512. 'xxx' => OPT_ATT_MUSTCHANGE,
  513. 'xxx' => OPT_ATT_MUSTPROMPT,
  514. 'xxx' => OPT_ATT_MANDATORY,
  515. ),
  516. )
  517. );
  518. }
  519. }
  520. class KnownError extends Ticket
  521. {
  522. public static function Init()
  523. {
  524. $aParams = array
  525. (
  526. "category" => "bizmodel,searchable,knownerrormgmt",
  527. "key_type" => "autoincrement",
  528. "name_attcode" => "ref",
  529. "state_attcode" => "",
  530. "reconc_keys" => array("name"),
  531. "db_table" => "knownerror",
  532. "db_key_field" => "id",
  533. "db_finalclass_field" => "",
  534. "display_template" => "",
  535. );
  536. MetaModel::Init_Params($aParams);
  537. MetaModel::Init_InheritAttributes();
  538. MetaModel::Init_AddAttribute(new AttributeString("foo", array("allowed_values"=>null, "sql"=>"foo", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  539. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'document_list', 'ci_list', 'contact_list', 'foo'));
  540. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  541. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  542. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  543. MetaModel::Init_DefineState(
  544. "new",
  545. array(
  546. "attribute_inherit"=>null,
  547. "attribute_list"=>array(
  548. 'xxx' => OPT_ATT_READONLY,
  549. 'xxx' => OPT_ATT_HIDDEN,
  550. 'xxx' => OPT_ATT_MUSTCHANGE,
  551. 'xxx' => OPT_ATT_MUSTPROMPT,
  552. 'xxx' => OPT_ATT_MANDATORY,
  553. ),
  554. )
  555. );
  556. }
  557. }
  558. class lnkKnownErrorToProblem extends Ticket
  559. {
  560. public static function Init()
  561. {
  562. $aParams = array
  563. (
  564. "category" => "bizmodel,searchable,knownerrormgmt",
  565. "key_type" => "autoincrement",
  566. "name_attcode" => "ref",
  567. "state_attcode" => "",
  568. "reconc_keys" => array("name"),
  569. "db_table" => "lnkknownerrortoproblem",
  570. "db_key_field" => "id",
  571. "db_finalclass_field" => "",
  572. "display_template" => "",
  573. );
  574. MetaModel::Init_Params($aParams);
  575. MetaModel::Init_InheritAttributes();
  576. MetaModel::Init_AddAttribute(new AttributeString("foo", array("allowed_values"=>null, "sql"=>"foo", "default_value"=>"", "is_null_allowed"=>true, "depends_on"=>array())));
  577. MetaModel::Init_SetZListItems('details', array('ref', 'title', 'ticket_log', 'start_date', 'document_list', 'ci_list', 'contact_list', 'foo'));
  578. MetaModel::Init_SetZListItems('advanced_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  579. MetaModel::Init_SetZListItems('standard_search', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  580. MetaModel::Init_SetZListItems('list', array('ref', 'title', 'ticket_log', 'start_date', 'foo'));
  581. }
  582. }
  583. //////////////////////////////////////////////////////////////////////////////
  584. // Menu:
  585. // +----------------------------------------+
  586. // | My Module |
  587. // +----------------------------------------+
  588. // + All items
  589. // + ...
  590. // + ...
  591. ////////////////////////////////////////////////////////////////////////////////////
  592. // Create the top-level group. fRank = 1, means it will be inserted after the group '0', which is usually 'Welcome'
  593. $oMyMenuGroup = new MenuGroup('IncidentManagement', 1 /* fRank */);
  594. // By default, one entry per class
  595. new OQLMenuNode('Incidents', 'SELECT Incident', $oMyMenuGroup->GetIndex(), 0 /* fRank */);
  596. new OQLMenuNode('OpenedIncidents', 'SELECT Incident WHERE status IN ("new", "assigned", "escalation")', $oMyMenuGroup->GetIndex(), 0 /* fRank */);
  597. new OQLMenuNode('ClosedIncidents', 'SELECT Incident WHERE status IN ("resolved", "closed")', $oMyMenuGroup->GetIndex(), 0 /* fRank */);
  598. //new TemplateMenuNode('WelcomeMenuPage', '../business/templates/welcome_menu.html', $oWelcomeMenu->GetIndex() /* oParent */, 1 /* fRank */);
  599. ?>