33require_once DOL_DOCUMENT_ROOT.
"/core/class/commonobject.class.php";
34require_once DOL_DOCUMENT_ROOT.
'/fichinter/class/fichinter.class.php';
35require_once DOL_DOCUMENT_ROOT.
'/core/lib/ticket.lib.php';
51 public $element =
'ticket';
56 public $table_element =
'ticket';
61 public $fk_element =
'fk_ticket';
66 public $picto =
'ticket';
96 public $fk_user_create;
101 public $fk_user_assign;
153 public $category_code;
158 public $severity_code;
168 public $category_label;
173 public $severity_label;
183 public $origin_replyto;
188 public $origin_references;
203 public $date_last_msg_sent;
213 public $cache_types_tickets;
218 public $cache_msgs_ticket;
223 public $notify_tiers_at_create;
248 public $regeximgext =
'\.gif|\.jpg|\.jpeg|\.png|\.bmp|\.webp|\.xpm|\.xbm';
254 const STATUS_READ = 1;
255 const STATUS_ASSIGNED = 2;
256 const STATUS_IN_PROGRESS = 3;
257 const STATUS_NEED_MORE_INFO = 5;
258 const STATUS_WAITING = 7;
259 const STATUS_CLOSED = 8;
260 const STATUS_CANCELED = 9;
291 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'visible' => -2,
'enabled' => 1,
'position' => 1,
'notnull' => 1,
'index' => 1,
'comment' =>
"Id"),
292 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'visible' => 0,
'enabled' => 1,
'position' => 5,
'notnull' => 1,
'index' => 1),
293 'ref' => array(
'type' =>
'varchar(128)',
'label' =>
'Ref',
'visible' => 1,
'enabled' => 1,
'position' => 10,
'notnull' => 1,
'index' => 1,
'searchall' => 1,
'comment' =>
"Reference of object",
'css' =>
'',
'showoncombobox' => 1),
294 'track_id' => array(
'type' =>
'varchar(255)',
'label' =>
'TicketTrackId',
'visible' => -2,
'enabled' => 1,
'position' => 11,
'notnull' => -1,
'searchall' => 1,
'help' =>
"Help text"),
295 'fk_user_create' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'Author',
'visible' => 1,
'enabled' => 1,
'position' => 15,
'notnull' => 1,
'csslist' =>
'tdoverflowmax100 maxwidth150onsmartphone'),
296 'origin_email' => array(
'type' =>
'mail',
'label' =>
'OriginEmail',
'visible' => -2,
'enabled' => 1,
'position' => 16,
'notnull' => 1,
'index' => 1,
'searchall' => 1,
'comment' =>
"Reference of object",
'csslist' =>
'tdoverflowmax150'),
297 'origin_replyto' => array(
'type' =>
'mail',
'label' =>
'EmailReplyto',
'visible' => -2,
'enabled' => 1,
'position' => 17,
'notnull' => 1,
'index' => 1,
'searchall' => 1,
'comment' =>
"Email to reply to",
'csslist' =>
'tdoverflowmax150'),
298 'origin_references' => array(
'type' =>
'text',
'label' =>
'EmailReferences',
'visible' => -2,
'enabled' => 1,
'position' => 18,
'notnull' => 1,
'index' => 1,
'searchall' => 1,
'comment' =>
"References from origin email",
'csslist' =>
'tdoverflowmax150'),
299 'subject' => array(
'type' =>
'varchar(255)',
'label' =>
'Subject',
'visible' => 1,
'enabled' => 1,
'position' => 19,
'notnull' => -1,
'searchall' => 1,
'help' =>
"",
'css' =>
'maxwidth200 tdoverflowmax200',
'csslist' =>
'tdoverflowmax250',
'autofocusoncreate' => 1),
300 'type_code' => array(
'type' =>
'varchar(32)',
'label' =>
'Type',
'visible' => 1,
'enabled' => 1,
'position' => 20,
'notnull' => -1,
'help' =>
"",
'csslist' =>
'tdoverflowmax100'),
301 'category_code' => array(
'type' =>
'varchar(32)',
'label' =>
'TicketCategory',
'visible' => -1,
'enabled' => 1,
'position' => 21,
'notnull' => -1,
'help' =>
"",
'css' =>
'maxwidth100 tdoverflowmax200'),
302 'severity_code' => array(
'type' =>
'varchar(32)',
'label' =>
'Severity',
'visible' => 1,
'enabled' => 1,
'position' => 22,
'notnull' => -1,
'help' =>
"",
'css' =>
'maxwidth100 tdoverflowmax100'),
303 'fk_soc' => array(
'type' =>
'integer:Societe:societe/class/societe.class.php',
'label' =>
'ThirdParty',
'visible' => 1,
'enabled' =>
'isModEnabled("societe")',
'position' => 50,
'notnull' => -1,
'index' => 1,
'searchall' => 1,
'help' =>
"OrganizationEventLinkToThirdParty",
'css' =>
'tdoverflowmax150 maxwidth150onsmartphone'),
304 'notify_tiers_at_create' => array(
'type' =>
'integer',
'label' =>
'NotifyThirdparty',
'visible' => -1,
'enabled' => 0,
'position' => 51,
'notnull' => 1,
'index' => 1),
305 'fk_project' => array(
'type' =>
'integer:Project:projet/class/project.class.php',
'label' =>
'Project',
'visible' => -1,
'enabled' =>
'isModEnabled("project")',
'position' => 52,
'notnull' => -1,
'index' => 1,
'help' =>
"LinkToProject"),
306 'fk_contract' => array(
'type' =>
'integer:Contrat:contrat/class/contrat.class.php',
'label' =>
'Contract',
'visible' => -1,
'enabled' =>
'isModEnabled("contract")',
'position' => 53,
'notnull' => -1,
'index' => 1,
'help' =>
"LinkToContract"),
308 'datec' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'visible' => 1,
'enabled' => 1,
'position' => 500,
'notnull' => 1,
'csslist' =>
'nowraponall'),
309 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'visible' => -1,
'enabled' => 1,
'position' => 501,
'notnull' => 1),
310 'date_read' => array(
'type' =>
'datetime',
'label' =>
'DateReading',
'visible' => -1,
'enabled' => 1,
'position' => 505,
'notnull' => 1,
'csslist' =>
'nowraponall'),
311 'date_last_msg_sent' => array(
'type' =>
'datetime',
'label' =>
'TicketLastMessageDate',
'visible' => 0,
'enabled' => 1,
'position' => 506,
'notnull' => -1),
312 'fk_user_assign' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'AssignedTo',
'visible' => 1,
'enabled' => 1,
'position' => 507,
'notnull' => 1,
'csslist' =>
'tdoverflowmax100 maxwidth150onsmartphone'),
313 'date_close' => array(
'type' =>
'datetime',
'label' =>
'TicketCloseOn',
'visible' => -1,
'enabled' => 1,
'position' => 510,
'notnull' => 1),
314 'message' => array(
'type' =>
'html',
'label' =>
'Message',
'visible' => -2,
'enabled' => 1,
'position' => 540,
'notnull' => -1,),
315 'note_private' => array(
'type' =>
'html',
'label' =>
'NotePrivate',
'enabled' => 1,
'visible' => 0,
'position' => 110),
316 'note_public' => array(
'type' =>
'html',
'label' =>
'NotePublic',
'enabled' => 1,
'visible' => 0,
'position' => 115),
317 'email_msgid' => array(
'type' =>
'varchar(255)',
'label' =>
'EmailMsgID',
'visible' => -2,
'enabled' => 1,
'position' => 540,
'notnull' => -1,
'help' =>
'EmailMsgIDDesc',
'csslist' =>
'tdoverflowmax100'),
318 'email_date' => array(
'type' =>
'datetime',
'label' =>
'EmailDate',
'visible' => -2,
'enabled' => 1,
'position' => 541),
319 'progress' => array(
'type' =>
'integer',
'label' =>
'Progression',
'visible' => -1,
'enabled' => 1,
'position' => 540,
'notnull' => -1,
'css' =>
'right',
'help' =>
"",
'isameasure' => 1,
'csslist' =>
'width50'),
320 'resolution' => array(
'type' =>
'integer',
'label' =>
'Resolution',
'visible' => -1,
'enabled' =>
'getDolGlobalString("TICKET_ENABLE_RESOLUTION")',
'position' => 550,
'notnull' => 1),
321 'model_pdf' => array(
'type' =>
'varchar(255)',
'label' =>
'PDFTemplate',
'enabled' => 1,
'visible' => 0,
'position' => 560),
322 'extraparams' => array(
'type' =>
'varchar(255)',
'label' =>
'Extraparams',
'enabled' => 1,
'visible' => 0,
'position' => 570),
323 'fk_statut' => array(
'type' =>
'integer',
'label' =>
'Status',
'visible' => 1,
'enabled' => 1,
'position' => 600,
'notnull' => 1,
'index' => 1,
'arrayofkeyval' => array(0 =>
'Unread', 1 =>
'Read', 2 =>
'Assigned', 3 =>
'InProgress', 5 =>
'NeedMoreInformation', 7 =>
'OnHold', 8 =>
'SolvedClosed', 9 =>
'Deleted')),
324 'import_key' => array(
'type' =>
'varchar(14)',
'label' =>
'ImportId',
'enabled' => 1,
'visible' => -2,
'position' => 900),
338 $this->ismultientitymanaged = 1;
339 $this->isextrafieldmanaged = 1;
341 $this->labelStatusShort = array(
342 self::STATUS_NOT_READ =>
'Unread',
343 self::STATUS_READ =>
'Read',
344 self::STATUS_ASSIGNED =>
'Assigned',
345 self::STATUS_IN_PROGRESS =>
'InProgress',
346 self::STATUS_NEED_MORE_INFO =>
'NeedMoreInformationShort',
347 self::STATUS_WAITING =>
'OnHold',
348 self::STATUS_CLOSED =>
'SolvedClosed',
349 self::STATUS_CANCELED =>
'Canceled'
351 $this->labelStatus = array(
352 self::STATUS_NOT_READ =>
'Unread',
353 self::STATUS_READ =>
'Read',
354 self::STATUS_ASSIGNED =>
'Assigned',
355 self::STATUS_IN_PROGRESS =>
'InProgress',
356 self::STATUS_NEED_MORE_INFO =>
'NeedMoreInformation',
357 self::STATUS_WAITING =>
'OnHold',
358 self::STATUS_CLOSED =>
'SolvedClosed',
359 self::STATUS_CANCELED =>
'Canceled'
363 unset($this->fields[
'fk_statut'][
'arrayofkeyval'][self::STATUS_WAITING]);
364 unset($this->labelStatusShort[self::STATUS_WAITING]);
365 unset($this->labelStatus[self::STATUS_WAITING]);
377 $this->errors = array();
382 if (isset($this->
ref)) {
383 $this->
ref = trim($this->
ref);
386 if (isset($this->track_id)) {
387 $this->track_id = trim($this->track_id);
390 if (isset($this->fk_soc)) {
391 $this->fk_soc = (int) $this->fk_soc;
394 if (isset($this->fk_project)) {
395 $this->fk_project = (int) $this->fk_project;
398 if (isset($this->origin_email)) {
399 $this->origin_email = trim($this->origin_email);
402 if (isset($this->fk_user_create)) {
403 $this->fk_user_create = (int) $this->fk_user_create;
406 if (isset($this->fk_user_assign)) {
407 $this->fk_user_assign = (int) $this->fk_user_assign;
410 if (isset($this->subject)) {
411 $this->subject = trim($this->subject);
414 if (isset($this->message)) {
415 $this->message = trim($this->message);
418 $langs->loadLangs(array(
'errors',
'ticket'));
419 $this->errors[] = $langs->trans(
'ErrorFieldTooLong', $langs->transnoentitiesnoconv(
'InitialMessage'));
420 dol_syslog(get_class($this).
'::create error -1 message too long', LOG_ERR);
425 if (isset($this->
status)) {
429 if (isset($this->resolution)) {
430 $this->resolution = (int) $this->resolution;
433 if (isset($this->progress)) {
434 $this->progress = (int) $this->progress;
437 if (isset($this->timing)) {
438 $this->timing = trim($this->timing);
441 if (isset($this->type_code)) {
442 $this->type_code = trim($this->type_code);
445 if (isset($this->category_code)) {
446 $this->category_code = trim($this->category_code);
449 if (isset($this->severity_code)) {
450 $this->severity_code = trim($this->severity_code);
453 if (empty($this->
ref)) {
454 $this->errors[] =
'ErrorTicketRefRequired';
455 dol_syslog(get_class($this).
"::create error -1 ref null", LOG_ERR);
473 if ($test->fetch(0, $getRef) > 0) {
474 if (($action ==
'add') || ($action ==
'update' && $this->
ref != $getRef)) {
479 $this->
ref = $getRef;
490 public function create($user, $notrigger = 0)
497 if (empty($this->datec)) {
500 if (empty($this->track_id)) {
506 $result = $this->
verify();
513 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"ticket(";
517 $sql .=
"fk_project,";
518 $sql .=
"fk_contract,";
519 $sql .=
"origin_email,";
520 $sql .=
"origin_replyto,";
521 $sql .=
"origin_references,";
522 $sql .=
"fk_user_create,";
523 $sql .=
"fk_user_assign,";
524 $sql .=
"email_msgid,";
525 $sql .=
"email_date,";
528 $sql .=
"note_private,";
529 $sql .=
"note_public,";
530 $sql .=
"fk_statut,";
531 $sql .=
"resolution,";
534 $sql .=
"type_code,";
535 $sql .=
"category_code,";
536 $sql .=
"severity_code,";
538 $sql .=
"date_read,";
539 $sql .=
"date_close,";
541 $sql .=
"notify_tiers_at_create,";
542 $sql .=
"model_pdf,";
544 $sql .=
") VALUES (";
545 $sql .=
" ".(!isset($this->
ref) ?
'' :
"'".$this->db->escape($this->
ref).
"'").
",";
546 $sql .=
" ".(!isset($this->track_id) ?
'NULL' :
"'".$this->db->escape($this->track_id).
"'").
",";
547 $sql .=
" ".($this->fk_soc > 0 ? ((int) $this->fk_soc) :
"null").
",";
548 $sql .=
" ".($this->fk_project > 0 ? ((int) $this->fk_project) :
"null").
",";
549 $sql .=
" ".($this->fk_contract > 0 ? ((int) $this->fk_contract) :
"null").
",";
550 $sql .=
" ".(!isset($this->origin_email) ?
'NULL' :
"'".$this->db->escape($this->origin_email).
"'").
",";
551 $sql .=
" ".(!isset($this->origin_replyto) ?
'NULL' :
"'".$this->db->escape($this->origin_replyto).
"'").
",";
552 $sql .=
" ".(!isset($this->origin_references) ?
'NULL' :
"'".$this->db->escape($this->origin_references).
"'").
",";
553 $sql .=
" ".(!isset($this->fk_user_create) ? ($user->id > 0 ? ((int) $user->id) :
'NULL') : ($this->fk_user_create > 0 ? ((int) $this->fk_user_create) :
'NULL')).
",";
554 $sql .=
" ".($this->fk_user_assign > 0 ? ((int) $this->fk_user_assign) :
'NULL').
",";
555 $sql .=
" ".(empty($this->email_msgid) ?
'NULL' :
"'".$this->db->escape($this->email_msgid).
"'").
",";
556 $sql .=
" ".(!
isDolTms($this->email_date) ?
'NULL' :
"'".$this->db->idate($this->email_date).
"'").
",";
557 $sql .=
" ".(!isset($this->subject) ?
'NULL' :
"'".$this->db->escape($this->subject).
"'").
",";
558 $sql .=
" ".(!isset($this->message) ?
'NULL' :
"'".$this->db->escape($this->message).
"'").
",";
559 $sql .=
" ".(!isset($this->note_private) ?
'NULL' :
"'".$this->db->escape($this->note_private).
"'").
",";
560 $sql .=
" ".(!isset($this->note_public) ?
'NULL' :
"'".$this->db->escape($this->note_public).
"'").
",";
561 $sql .=
" ".(!isset($this->
status) ?
'0' : ((int) $this->
status)).
",";
562 $sql .=
" ".(!isset($this->resolution) ?
'NULL' : ((int) $this->resolution)).
",";
563 $sql .=
" ".(!isset($this->progress) ?
'0' : ((int) $this->progress)).
",";
564 $sql .=
" ".(!isset($this->timing) ?
'NULL' :
"'".$this->db->escape($this->timing).
"'").
",";
565 $sql .=
" ".(!isset($this->type_code) ?
'NULL' :
"'".$this->db->escape($this->type_code).
"'").
",";
566 $sql .=
" ".(empty($this->category_code) || $this->category_code ==
'-1' ?
'NULL' :
"'".$this->db->escape($this->category_code).
"'").
",";
567 $sql .=
" ".(!isset($this->severity_code) ?
'NULL' :
"'".$this->db->escape($this->severity_code).
"'").
",";
568 $sql .=
" ".(!
isDolTms($this->datec) ?
'NULL' :
"'".$this->db->idate($this->datec).
"'").
",";
569 $sql .=
" ".(!isset($this->date_read) ||
dol_strlen((
string) $this->date_read) == 0 ?
'NULL' :
"'".$this->db->idate($this->date_read).
"'").
",";
570 $sql .=
" ".(!isset($this->date_close) ||
dol_strlen((
string) $this->date_close) == 0 ?
'NULL' :
"'".$this->db->idate($this->date_close).
"'");
571 $sql .=
", ".((int) $this->entity);
572 $sql .=
", ".(!isset($this->notify_tiers_at_create) ? 1 : ((int) $this->notify_tiers_at_create));
573 $sql .=
", '".$this->db->escape($this->model_pdf).
"'";
574 $sql .=
", ".(!isset($this->ip) ?
'NULL' :
"'".$this->db->escape($this->ip).
"'");
579 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
580 $resql = $this->db->query($sql);
583 $this->errors[] =
"Error ".$this->db->lasterror();
587 $this->
id = $this->db->last_insert_id(MAIN_DB_PREFIX.
"ticket");
590 if (!$error &&
getDolGlobalString(
'TICKET_ADD_AUTHOR_AS_CONTACT') && empty($this->context[
"createdfrompublicinterface"])) {
594 if (!empty($user->socid) && !empty($user->contact_id) &&
getDolGlobalInt(
'TICKET_ADD_AUTHOR_AS_CONTACT') == 2) {
595 $contact_type =
'external';
596 $contributor_id = $user->contact_id;
598 $contact_type =
'internal';
599 $contributor_id = $user->id;
603 if ($this->
add_contact($contributor_id,
'CONTRIBUTOR', $contact_type) < 0) {
608 if (!$error && $this->fk_user_assign > 0) {
609 if ($this->
add_contact($this->fk_user_assign,
'SUPPORTTEC',
'internal') < 0) {
623 if (!$error && !$notrigger) {
625 $result = $this->call_trigger(
'TICKET_CREATE', $user);
634 foreach ($this->errors as $errmsg) {
635 dol_syslog(get_class($this).
"::create ".$errmsg, LOG_ERR);
636 $this->error .= ($this->error ?
', '.$errmsg : $errmsg);
638 $this->db->rollback();
645 $this->db->rollback();
646 dol_syslog(get_class($this).
"::Create fails verify ".implode(
',', $this->errors), LOG_WARNING);
660 public function fetch(
$id = 0, $ref =
'', $track_id =
'', $email_msgid =
'')
665 if (empty(
$id) && empty($ref) && empty($track_id) && empty($email_msgid)) {
666 $this->error =
'ErrorWrongParameters';
673 $sql .=
" t.entity,";
675 $sql .=
" t.track_id,";
676 $sql .=
" t.fk_soc,";
677 $sql .=
" t.fk_project,";
678 $sql .=
" t.fk_contract,";
679 $sql .=
" t.origin_email,";
680 $sql .=
" t.origin_replyto,";
681 $sql .=
" t.origin_references,";
682 $sql .=
" t.fk_user_create,";
683 $sql .=
" t.fk_user_assign,";
684 $sql .=
" t.email_msgid,";
685 $sql .=
" t.email_date,";
686 $sql .=
" t.subject,";
687 $sql .=
" t.message,";
688 $sql .=
" t.note_private,";
689 $sql .=
" t.note_public,";
690 $sql .=
" t.fk_statut as status,";
691 $sql .=
" t.resolution,";
692 $sql .=
" t.progress,";
693 $sql .=
" t.timing,";
694 $sql .=
" t.type_code,";
695 $sql .=
" t.category_code,";
696 $sql .=
" t.severity_code,";
698 $sql .=
" t.date_read,";
699 $sql .=
" t.date_last_msg_sent,";
700 $sql .=
" t.date_close,";
702 $sql .=
" t.model_pdf,";
703 $sql .=
" t.extraparams,";
705 $sql .=
" type.label as type_label, category.label as category_label, severity.label as severity_label";
706 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
707 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_type as type ON type.code=t.type_code";
708 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_category as category ON category.code=t.category_code";
709 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_severity as severity ON severity.code=t.severity_code";
712 $sql .=
" WHERE t.rowid = ".((int)
$id);
714 $sql .=
" WHERE t.entity IN (".getEntity($this->element, 1).
")";
716 $sql .=
" AND t.ref = '".$this->db->escape($ref).
"'";
717 } elseif ($track_id) {
718 $sql .=
" AND t.track_id = '".$this->db->escape($track_id).
"'";
720 $sql .=
" AND t.email_msgid = '".$this->db->escape($email_msgid).
"'";
724 dol_syslog(get_class($this).
"::fetch", LOG_DEBUG);
725 $resql = $this->db->query($sql);
727 if ($this->db->num_rows($resql)) {
728 $obj = $this->db->fetch_object($resql);
730 $this->
id = $obj->rowid;
731 $this->entity = $obj->entity;
732 $this->
ref = $obj->ref;
733 $this->track_id = $obj->track_id;
734 $this->fk_soc = $obj->fk_soc;
735 $this->socid = $obj->fk_soc;
736 $this->fk_project = $obj->fk_project;
737 $this->fk_contract = $obj->fk_contract;
738 $this->origin_email = $obj->origin_email;
739 $this->origin_replyto = $obj->origin_replyto;
740 $this->origin_references = $obj->origin_references;
741 $this->fk_user_create = $obj->fk_user_create;
742 $this->fk_user_assign = $obj->fk_user_assign;
743 $this->email_msgid = $obj->email_msgid;
744 $this->email_date = $this->db->jdate($obj->email_date);
745 $this->subject = $obj->subject;
746 $this->message = $obj->message;
747 $this->note_private = $obj->note_private;
748 $this->note_public = $obj->note_public;
749 $this->model_pdf = $obj->model_pdf;
750 $this->extraparams = !empty($obj->extraparams) ? (array) json_decode($obj->extraparams,
true) : array();
751 $this->ip = $obj->ip;
753 $this->
status = $obj->status;
754 $this->fk_statut = $this->status;
756 $this->resolution = $obj->resolution;
757 $this->progress = $obj->progress;
758 $this->timing = $obj->timing;
760 $this->type_code = $obj->type_code;
761 $label_type = ($langs->trans(
"TicketTypeShort".$obj->type_code) !=
"TicketTypeShort".$obj->type_code ? $langs->trans(
"TicketTypeShort".$obj->type_code) : ($obj->type_label !=
'-' ? $obj->type_label :
''));
762 $this->type_label = $label_type;
764 $this->category_code = $obj->category_code;
765 $label_category = ($langs->trans(
"TicketCategoryShort".$obj->category_code) !=
"TicketCategoryShort".$obj->category_code ? $langs->trans(
"TicketCategoryShort".$obj->category_code) : ($obj->category_label !=
'-' ? $obj->category_label :
''));
766 $this->category_label = $label_category;
768 $this->severity_code = $obj->severity_code;
769 $label_severity = ($langs->trans(
"TicketSeverityShort".$obj->severity_code) !=
"TicketSeverityShort".$obj->severity_code ? $langs->trans(
"TicketSeverityShort".$obj->severity_code) : ($obj->severity_label !=
'-' ? $obj->severity_label :
''));
770 $this->severity_label = $label_severity;
772 $this->datec = $this->db->jdate($obj->datec);
773 $this->date_creation = $this->db->jdate($obj->datec);
774 $this->date_read = $this->db->jdate($obj->date_read);
775 $this->date_validation = $this->db->jdate($obj->date_read);
776 $this->date_last_msg_sent = $this->db->jdate($obj->date_last_msg_sent);
777 $this->date_close = $this->db->jdate($obj->date_close);
778 $this->tms = $this->db->jdate($obj->tms);
779 $this->date_modification = $this->db->jdate($obj->tms);
783 $this->db->free($resql);
789 $this->error =
"Error ".$this->db->lasterror();
790 dol_syslog(get_class($this).
"::fetch ".$this->error, LOG_ERR);
807 public function fetchAll($user, $sortorder =
'ASC', $sortfield =
't.datec', $limit = 0, $offset = 0, $arch = 0, $filter =
'')
809 global $langs, $extrafields;
812 $extrafields->fetch_name_optionals_label($this->table_element);
817 $sql .=
" t.track_id,";
818 $sql .=
" t.fk_soc,";
819 $sql .=
" t.fk_project,";
820 $sql .=
" t.fk_contract,";
821 $sql .=
" t.origin_email,";
822 $sql .=
" t.origin_replyto,";
823 $sql .=
" t.origin_references,";
824 $sql .=
" t.fk_user_create, uc.lastname as user_create_lastname, uc.firstname as user_create_firstname,";
825 $sql .=
" t.fk_user_assign, ua.lastname as user_assign_lastname, ua.firstname as user_assign_firstname,";
826 $sql .=
" t.subject,";
827 $sql .=
" t.message,";
828 $sql .=
" t.note_private,";
829 $sql .=
" t.note_public,";
830 $sql .=
" t.fk_statut as status,";
831 $sql .=
" t.resolution,";
832 $sql .=
" t.progress,";
833 $sql .=
" t.timing,";
834 $sql .=
" t.type_code,";
835 $sql .=
" t.category_code,";
836 $sql .=
" t.severity_code,";
838 $sql .=
" t.date_read,";
839 $sql .=
" t.date_last_msg_sent,";
840 $sql .=
" t.date_close,";
842 $sql .=
" type.label as type_label, category.label as category_label, severity.label as severity_label";
844 if ($extrafields->attributes[$this->table_element][
'count'] > 0) {
845 foreach ($extrafields->attributes[$this->table_element][
'label'] as $key => $val) {
846 $sql .= ($extrafields->attributes[$this->table_element][
'type'][$key] !=
'separate' ?
",ef.".$key.
" as options_".$key :
'');
849 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as t";
850 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_type as type ON type.code = t.type_code";
851 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_category as category ON category.code = t.category_code";
852 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_ticket_severity as severity ON severity.code = t.severity_code";
853 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe as s ON s.rowid = t.fk_soc";
854 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"user as uc ON uc.rowid = t.fk_user_create";
855 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"user as ua ON ua.rowid = t.fk_user_assign";
856 if ($extrafields->attributes[$this->table_element][
'count'] > 0) {
857 if (is_array($extrafields->attributes[$this->table_element][
'label']) && count($extrafields->attributes[$this->table_element][
'label'])) {
858 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"ticket_extrafields as ef on (t.rowid = ef.fk_object)";
861 $sql .=
" WHERE t.entity IN (".getEntity(
'ticket').
")";
864 if (is_array($filter)) {
865 foreach ($filter as $key => $value) {
866 if (strpos($key,
'date')) {
867 $sql .=
" AND ".$this->db->sanitize($key).
" = '".$this->db->escape((
string) $value).
"'";
868 } elseif (($key ==
't.fk_user_assign') || ($key ==
't.type_code') || ($key ==
't.category_code') || ($key ==
't.severity_code') || ($key ==
't.fk_soc')) {
869 $sql .=
" AND ".$this->db->sanitize($key).
" = '".$this->db->escape((
string) $value).
"'";
870 } elseif ($key ==
't.fk_statut') {
871 if (is_array($value) && count($value) > 0) {
872 $sql .=
" AND ".$this->db->sanitize($key).
" IN (".$this->db->sanitize(implode(
',', $value)).
")";
874 $sql .=
" AND ".$this->db->sanitize($key).
' = '.((int) $value);
876 } elseif ($key ==
't.fk_contract') {
877 $sql .=
" AND ".$this->db->sanitize($key).
' = '.((int) $value);
879 $sql .=
" AND ".$this->db->sanitize($key).
" LIKE '%".$this->db->escape($this->db->escapeforlike((
string) $value)).
"%'";
888 $sql .= forgeSQLFromUniversalSearchCriteria($filter, $errormessage);
890 $this->errors[] = $errormessage;
891 dol_syslog(__METHOD__.
' '.implode(
',', $this->errors), LOG_ERR);
896 $socid = $user->socid ?: 0;
899 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
900 $search_sale = $user->id;
903 if ($search_sale && $search_sale !=
'-1') {
904 if ($search_sale == -2) {
905 $sql .=
" AND NOT EXISTS (SELECT sc.fk_soc FROM ".MAIN_DB_PREFIX.
"societe_commerciaux as sc WHERE sc.fk_soc = t.fk_soc)";
906 } elseif ($search_sale > 0) {
907 $sql .=
" AND EXISTS (SELECT sc.fk_soc FROM ".MAIN_DB_PREFIX.
"societe_commerciaux as sc WHERE sc.fk_soc = t.fk_soc AND sc.fk_user = ".((int) $search_sale).
")";
912 $sql .=
" AND t.fk_soc = ".((int) $socid);
915 $sql .= $this->db->order($sortfield, $sortorder);
916 if (!empty($limit)) {
917 $sql .= $this->db->plimit($limit + 1, $offset);
920 dol_syslog(get_class($this).
"::fetchAll", LOG_DEBUG);
921 $resql = $this->db->query($sql);
924 $this->lines = array();
926 $num = $this->db->num_rows($resql);
931 $obj = $this->db->fetch_object($resql);
935 $line->id = $obj->rowid;
937 $line->ref = $obj->ref;
938 $line->track_id = $obj->track_id;
939 $line->fk_soc = $obj->fk_soc;
940 $line->fk_project = $obj->fk_project;
941 $line->fk_contract = $obj->fk_contract;
942 $line->origin_email = $obj->origin_email;
943 $line->origin_replyto = $obj->origin_replyto;
944 $line->origin_references = $obj->origin_references;
946 $line->fk_user_create = $obj->fk_user_create;
947 $line->fk_user_assign = $obj->fk_user_assign;
949 $line->subject = $obj->subject;
950 $line->message = $obj->message;
951 $line->note_private = $obj->note_private;
952 $line->note_public = $obj->note_public;
953 $line->fk_statut = $obj->status;
954 $line->status = $obj->status;
955 $line->resolution = $obj->resolution;
956 $line->progress = $obj->progress;
957 $line->timing = $obj->timing;
959 $label_type = ($langs->trans(
"TicketTypeShort".$obj->type_code) !=
"TicketTypeShort".$obj->type_code ? $langs->trans(
"TicketTypeShort".$obj->type_code) : ($obj->type_label !=
'-' ? $obj->type_label :
''));
960 $line->type_label = $label_type;
962 $this->category_code = $obj->category_code;
963 $label_category = ($langs->trans(
"TicketCategoryShort".$obj->category_code) !=
"TicketCategoryShort".$obj->category_code ? $langs->trans(
"TicketCategoryShort".$obj->category_code) : ($obj->category_label !=
'-' ? $obj->category_label :
''));
964 $line->category_label = $label_category;
966 $this->severity_code = $obj->severity_code;
967 $label_severity = ($langs->trans(
"TicketSeverityShort".$obj->severity_code) !=
"TicketSeverityShort".$obj->severity_code ? $langs->trans(
"TicketSeverityShort".$obj->severity_code) : ($obj->severity_label !=
'-' ? $obj->severity_label :
''));
968 $line->severity_label = $label_severity;
970 $line->datec = $this->db->jdate($obj->datec);
971 $line->date_read = $this->db->jdate($obj->date_read);
972 $line->date_last_msg_sent = $this->db->jdate($obj->date_last_msg_sent);
973 $line->date_close = $this->db->jdate($obj->date_close);
976 if ($extrafields->attributes[$this->table_element][
'count'] > 0) {
977 if (is_array($extrafields->attributes[$this->table_element][
'label']) && count($extrafields->attributes[$this->table_element][
'label'])) {
978 foreach ($extrafields->attributes[$this->table_element][
'label'] as $key => $val) {
979 $tmpkey =
'options_'.$key;
980 $line->{$tmpkey} = $obj->$tmpkey;
984 $this->lines[$i] = $line;
988 $this->db->free($resql);
991 $this->error =
"Error ".$this->db->lasterror();
992 dol_syslog(get_class($this).
"::fetchAll ".$this->error, LOG_ERR);
1004 public function update($user, $notrigger = 0)
1015 if (isset($this->
ref)) {
1016 $this->
ref = trim($this->
ref);
1019 if (isset($this->track_id)) {
1020 $this->track_id = trim($this->track_id);
1023 if (isset($this->fk_soc)) {
1024 $this->fk_soc = (int) $this->fk_soc;
1027 if (isset($this->fk_project)) {
1028 $this->fk_project = (int) $this->fk_project;
1031 if (isset($this->fk_contract)) {
1032 $this->fk_contract = (int) $this->fk_contract;
1035 if (isset($this->origin_email)) {
1036 $this->origin_email = trim($this->origin_email);
1039 if (isset($this->fk_user_create)) {
1040 $this->fk_user_create = (int) $this->fk_user_create;
1043 if (isset($this->fk_user_assign)) {
1044 $this->fk_user_assign = (int) $this->fk_user_assign;
1047 if (isset($this->subject)) {
1048 $this->subject = trim($this->subject);
1051 if (isset($this->message)) {
1052 $this->message = trim($this->message);
1055 $langs->loadLangs(array(
'errors',
'ticket'));
1056 $this->errors[] = $langs->trans(
'ErrorFieldTooLong', $langs->transnoentitiesnoconv(
'InitialMessage'));
1057 dol_syslog(get_class($this).
'::update error -1 message too long', LOG_ERR);
1062 if (isset($this->
status)) {
1066 if (isset($this->resolution)) {
1067 $this->resolution = (int) $this->resolution;
1070 if (isset($this->progress)) {
1071 $this->progress = (int) $this->progress;
1074 if (isset($this->timing)) {
1075 $this->timing = trim($this->timing);
1078 if (isset($this->type_code)) {
1079 $this->timing = trim($this->type_code);
1082 if (isset($this->category_code)) {
1083 $this->timing = trim($this->category_code);
1086 if (isset($this->severity_code)) {
1087 $this->timing = trim($this->severity_code);
1089 if (isset($this->model_pdf)) {
1090 $this->model_pdf = trim($this->model_pdf);
1095 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket SET";
1096 $sql .=
" ref=".(isset($this->
ref) ?
"'".$this->db->escape($this->
ref).
"'" :
"").
",";
1097 $sql .=
" track_id=".(isset($this->track_id) ?
"'".$this->db->escape($this->track_id).
"'" :
"null").
",";
1098 $sql .=
" fk_soc=".(isset($this->fk_soc) ? (int) $this->fk_soc :
"null").
",";
1099 $sql .=
" fk_project=".(isset($this->fk_project) ? (int) $this->fk_project :
"null").
",";
1100 $sql .=
" fk_contract=".(isset($this->fk_contract) ? (int) $this->fk_contract :
"null").
",";
1101 $sql .=
" origin_email=".(isset($this->origin_email) ?
"'".$this->db->escape($this->origin_email).
"'" :
"null").
",";
1102 $sql .=
" origin_replyto=".(isset($this->origin_replyto) ?
"'".$this->db->escape($this->origin_replyto).
"'" :
"null").
",";
1103 $sql .=
" origin_references=".(isset($this->origin_references) ?
"'".$this->db->escape($this->origin_references).
"'" :
"null").
",";
1104 $sql .=
" fk_user_create=".(isset($this->fk_user_create) ? (int) $this->fk_user_create :
"null").
",";
1105 $sql .=
" fk_user_assign=".(isset($this->fk_user_assign) ? (int) $this->fk_user_assign :
"null").
",";
1106 $sql .=
" subject=".(isset($this->subject) ?
"'".$this->db->escape($this->subject).
"'" :
"null").
",";
1107 $sql .=
" message=".(isset($this->message) ?
"'".$this->db->escape($this->message).
"'" :
"null").
",";
1108 $sql .=
" note_private=".(isset($this->note_private) ?
"'".$this->db->escape($this->note_private).
"'" :
"null").
",";
1109 $sql .=
" note_public=".(isset($this->note_public) ?
"'".$this->db->escape($this->note_public).
"'" :
"null").
",";
1110 $sql .=
" fk_statut=".(isset($this->
status) ? (int) $this->
status :
"0").
",";
1111 $sql .=
" resolution=".(isset($this->resolution) ? (int) $this->resolution :
"null").
",";
1112 $sql .=
" progress=".(isset($this->progress) ?
"'".$this->db->escape((
string) $this->progress).
"'" :
"null").
",";
1113 $sql .=
" timing=".(isset($this->timing) ?
"'".$this->db->escape($this->timing).
"'" :
"null").
",";
1114 $sql .=
" type_code=".(isset($this->type_code) ?
"'".$this->db->escape($this->type_code).
"'" :
"null").
",";
1115 $sql .=
" category_code=".(isset($this->category_code) ?
"'".$this->db->escape($this->category_code).
"'" :
"null").
",";
1116 $sql .=
" severity_code=".(isset($this->severity_code) ?
"'".$this->db->escape($this->severity_code).
"'" :
"null").
",";
1117 $sql .=
" datec=".(isDolTms($this->datec) ?
"'".$this->db->idate($this->datec).
"'" :
'null').
",";
1118 $sql .=
" date_read=".(dol_strlen((
string) $this->date_read) != 0 ?
"'".$this->db->idate($this->date_read).
"'" :
'null').
",";
1119 $sql .=
" date_last_msg_sent=".(dol_strlen((
string) $this->date_last_msg_sent) != 0 ?
"'".$this->db->idate($this->date_last_msg_sent).
"'" :
'null').
",";
1120 $sql .=
" model_pdf=".(isset($this->model_pdf) ?
"'".$this->db->escape($this->model_pdf).
"'" :
"null").
",";
1121 $sql .=
" date_close=".(dol_strlen((
string) $this->date_close) != 0 ?
"'".$this->db->idate($this->date_close).
"'" :
'null');
1122 $sql .=
" WHERE rowid=".((int) $this->
id);
1126 $resql = $this->db->query($sql);
1129 $this->errors[] =
"Error ".$this->db->lasterror();
1134 $result = $this->insertExtraFields();
1140 if (!$error && !$notrigger) {
1142 $result = $this->call_trigger(
'TICKET_MODIFY', $user);
1151 foreach ($this->errors as $errmsg) {
1152 dol_syslog(get_class($this).
"::update ".$errmsg, LOG_ERR);
1153 $this->error .= ($this->error ?
', '.$errmsg : $errmsg);
1155 $this->db->rollback();
1158 $this->db->commit();
1170 public function delete($user, $notrigger = 0)
1178 $result = $this->call_trigger(
'TICKET_DELETE', $user);
1187 $res = $this->delete_linked_contact();
1189 dol_syslog(get_class($this).
"::delete error", LOG_ERR);
1196 $res = $this->deleteObjectLinked();
1204 $result = $this->deleteExtraFields();
1207 dol_syslog(get_class($this).
"::delete error -3 ".$this->error, LOG_ERR);
1214 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"categorie_ticket";
1215 $sql .=
" WHERE fk_ticket = ".(int) $this->
id;
1217 $result = $this->db->query($sql);
1220 $this->errors[] = $this->db->lasterror();
1225 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"ticket";
1226 $sql .=
" WHERE rowid=".((int) $this->
id);
1228 dol_syslog(get_class($this).
"::delete sql=".$sql);
1229 $resql = $this->db->query($sql);
1232 $this->errors[] =
"Error ".$this->db->lasterror();
1235 $this->deleteEcmFiles(1);
1237 $dir = DOL_DATA_ROOT.
'/'.$this->element.
'/'.$this->ref;
1241 $this->errors[] = $this->error;
1249 foreach ($this->errors as $errmsg) {
1250 dol_syslog(get_class($this).
"::delete ".$errmsg, LOG_ERR);
1251 $this->error .= ($this->error ?
', '.$errmsg : $errmsg);
1253 $this->db->rollback();
1256 $this->db->commit();
1301 $object->context[
'createfromclone'] =
'createfromclone';
1302 $result =
$object->create($user);
1306 $this->error =
$object->error;
1310 unset(
$object->context[
'createfromclone']);
1314 $this->db->commit();
1317 $this->db->rollback();
1332 $this->
ref =
'TI0501-001';
1333 $this->track_id =
'XXXXaaaa';
1334 $this->origin_email =
'email@email.com';
1335 $this->fk_project = 1;
1336 $this->fk_user_create = 1;
1337 $this->fk_user_assign = 1;
1338 $this->subject =
'Subject of ticket';
1339 $this->message =
'Message of ticket';
1341 $this->resolution = 1;
1342 $this->progress = 10;
1344 $this->type_code =
'TYPECODE';
1345 $this->category_code =
'CATEGORYCODE';
1346 $this->severity_code =
'SEVERITYCODE';
1349 $this->date_last_msg_sent =
dol_now();
1350 $this->date_close =
dol_now();
1364 print
Form::selectarray(
'search_fk_statut', $this->labelStatusShort, $selected, $show_empty = 1, $key_in_label = 0, $value_as_key = 0, $option =
'', $translate = 1, $maxlen = 0, $disabled = 0, $sort =
'', $morecss =
'');
1377 if (!empty($this->cache_types_tickets) && count($this->cache_types_tickets)) {
1382 $sql =
"SELECT rowid, code, label, use_default, pos, description";
1383 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_ticket_type";
1384 $sql .=
" WHERE entity IN (".getEntity(
'c_ticket_type').
")";
1385 $sql .=
" AND active > 0";
1386 $sql .=
" ORDER BY pos";
1387 dol_syslog(get_class($this).
"::load_cache_type_tickets", LOG_DEBUG);
1388 $resql = $this->db->query($sql);
1390 $num = $this->db->num_rows($resql);
1393 $obj = $this->db->fetch_object($resql);
1394 $label = ($langs->trans(
"TicketTypeShort".$obj->code) !=
"TicketTypeShort".$obj->code ? $langs->trans(
"TicketTypeShort".$obj->code) : ($obj->label !=
'-' ? $obj->label :
''));
1395 $this->cache_types_tickets[$obj->rowid][
'code'] = $obj->code;
1396 $this->cache_types_tickets[$obj->rowid][
'label'] = $label;
1397 $this->cache_types_tickets[$obj->rowid][
'use_default'] = $obj->use_default;
1398 $this->cache_types_tickets[$obj->rowid][
'pos'] = $obj->pos;
1416 global
$conf, $langs;
1418 if ($publicgroup == -1 && !empty(
$conf->cache[
'category_tickets']) && count(
$conf->cache[
'category_tickets'])) {
1423 $sql =
"SELECT rowid, code, label, use_default, pos, description, public, active, force_severity, fk_parent";
1424 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_ticket_category";
1425 $sql .=
" WHERE entity IN (".getEntity(
'c_ticket_category').
")";
1426 $sql .=
" AND active > 0";
1427 if ($publicgroup > -1) {
1428 $sql .=
" AND public = ".((int) $publicgroup);
1430 $sql .=
" ORDER BY pos";
1432 dol_syslog(get_class($this).
"::load_cache_categories_tickets", LOG_DEBUG);
1434 $resql = $this->db->query($sql);
1436 $num = $this->db->num_rows($resql);
1439 $obj = $this->db->fetch_object($resql);
1440 $conf->cache[
'category_tickets'][$obj->rowid][
'code'] = $obj->code;
1441 $conf->cache[
'category_tickets'][$obj->rowid][
'use_default'] = $obj->use_default;
1442 $conf->cache[
'category_tickets'][$obj->rowid][
'pos'] = $obj->pos;
1443 $conf->cache[
'category_tickets'][$obj->rowid][
'public'] = $obj->public;
1444 $conf->cache[
'category_tickets'][$obj->rowid][
'active'] = $obj->active;
1445 $conf->cache[
'category_tickets'][$obj->rowid][
'force_severity'] = $obj->force_severity;
1446 $conf->cache[
'category_tickets'][$obj->rowid][
'fk_parent'] = $obj->fk_parent;
1450 $label = ($langs->trans(
"TicketCategoryShort".$obj->code) !=
"TicketCategoryShort".$obj->code ? $langs->trans(
"TicketCategoryShort".$obj->code) : ($obj->label !=
'-' ? $obj->label :
''));
1451 $conf->cache[
'category_tickets'][$obj->rowid][
'label'] = $label;
1469 global
$conf, $langs;
1471 if (!empty(
$conf->cache[
'severity_tickets']) && count(
$conf->cache[
'severity_tickets'])) {
1476 $sql =
"SELECT rowid, code, label, use_default, pos, description";
1477 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_ticket_severity";
1478 $sql .=
" WHERE entity IN (".getEntity(
'c_ticket_severity').
")";
1479 $sql .=
" AND active > 0";
1480 $sql .=
" ORDER BY pos";
1481 dol_syslog(get_class($this).
"::loadCacheSeveritiesTickets", LOG_DEBUG);
1482 $resql = $this->db->query($sql);
1484 $num = $this->db->num_rows($resql);
1487 $obj = $this->db->fetch_object($resql);
1489 $conf->cache[
'severity_tickets'][$obj->rowid][
'code'] = $obj->code;
1490 $label = ($langs->trans(
"TicketSeverityShort".$obj->code) !=
"TicketSeverityShort".$obj->code ? $langs->trans(
"TicketSeverityShort".$obj->code) : ($obj->label !=
'-' ? $obj->label :
''));
1491 $conf->cache[
'severity_tickets'][$obj->rowid][
'label'] = $label;
1492 $conf->cache[
'severity_tickets'][$obj->rowid][
'use_default'] = $obj->use_default;
1493 $conf->cache[
'severity_tickets'][$obj->rowid][
'pos'] = $obj->pos;
1512 return $this->LibStatut($this->
status, $mode, 0, $this->progress);
1526 public function LibStatut($status, $mode = 0, $notooltip = 0, $progress = 0)
1529 global $langs, $hookmanager;
1531 $labelStatus = (isset($status) && !empty($this->labelStatus[$status])) ? $this->labelStatus[$status] :
'';
1532 $labelStatusShort = (isset($status) && !empty($this->labelStatusShort[$status])) ? $this->labelStatusShort[$status] :
'';
1537 case self::STATUS_NOT_READ:
1538 $statusType =
'status0';
1540 case self::STATUS_READ:
1541 $statusType =
'status1';
1543 case self::STATUS_ASSIGNED:
1544 $statusType =
'status2';
1546 case self::STATUS_IN_PROGRESS:
1547 $statusType =
'status4';
1549 case self::STATUS_WAITING:
1550 $statusType =
'status7';
1552 case self::STATUS_NEED_MORE_INFO:
1553 $statusType =
'status3';
1555 case self::STATUS_CANCELED:
1556 $statusType =
'status9';
1558 case self::STATUS_CLOSED:
1559 $statusType =
'status6';
1566 $parameters = array(
1567 'status' => $status,
1572 $reshook = $hookmanager->executeHooks(
'LibStatut', $parameters, $this);
1575 return $hookmanager->resPrint;
1579 $labelStatus =
'Unknown';
1580 $labelStatusShort =
'Unknown';
1581 $statusType =
'status0';
1587 $params = array(
'tooltip' =>
'no');
1590 $labelStatus = $langs->transnoentitiesnoconv($labelStatus);
1591 $labelStatusShort = $langs->transnoentitiesnoconv($labelStatusShort);
1593 if ($status == self::STATUS_IN_PROGRESS && $progress > 0) {
1594 $labelStatus .=
' ('.round($progress).
'%)';
1595 $labelStatusShort .=
' ('.round($progress).
'%)';
1598 return dolGetStatus($labelStatus, $labelStatusShort,
'', $statusType, $mode,
'', $params);
1611 $langs->load(
'ticket');
1612 $nofetch = !empty($params[
'nofetch']);
1615 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"Ticket").
'</u>';
1616 $datas[
'picto'] .=
' '.$this->getLibStatut(4);
1617 $datas[
'ref'] =
'<br><b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
1618 $datas[
'track_id'] =
'<br><b>'.$langs->trans(
'TicketTrackId').
':</b> '.$this->track_id;
1619 $datas[
'subject'] =
'<br><b>'.$langs->trans(
'Subject').
':</b> '.$this->subject;
1620 if ($this->date_creation) {
1621 $datas[
'date_creation'] =
'<br><b>'.$langs->trans(
'DateCreation').
':</b> '.
dol_print_date($this->date_creation,
'dayhour');
1623 if ($this->date_modification) {
1624 $datas[
'date_modification'] =
'<br><b>'.$langs->trans(
'DateModification').
':</b> '.
dol_print_date($this->date_modification,
'dayhour');
1628 require_once DOL_DOCUMENT_ROOT .
'/categories/class/categorie.class.php';
1629 $form =
new Form($this->db);
1630 $datas[
'categories'] =
'<br>' . $form->showCategories($this->
id, Categorie::TYPE_TICKET, 1);
1646 public function getNomUrl($withpicto = 0, $option =
'', $notooltip = 0, $morecss =
'', $save_lastsearch_value = -1)
1648 global $action,
$conf, $hookmanager, $langs;
1650 if (!empty(
$conf->dol_no_mouse_hover)) {
1658 'objecttype' => $this->element,
1659 'option' => $option,
1662 $classfortooltip =
'classfortooltip';
1665 $classfortooltip =
'classforajaxtooltip';
1666 $dataparams =
' data-params="'.dol_escape_htmltag(json_encode($params)).
'"';
1669 $label = implode($this->getTooltipContentArray($params));
1672 $url = DOL_URL_ROOT.
'/ticket/card.php?id='.
$this->id;
1674 if ($option !=
'nolink') {
1676 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
1677 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
1678 $add_save_lastsearch_values = 1;
1680 if ($add_save_lastsearch_values) {
1681 $url .=
'&save_lastsearch_values=1';
1686 if (empty($notooltip)) {
1688 $label = $langs->trans(
"ShowTicket");
1689 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
1691 $linkclose .= ($label ?
' title="'.dolPrintHTMLForAttribute($label).
'"' :
' title="tocomplete"');
1692 $linkclose .= $dataparams.
' class="'.$classfortooltip.($morecss ?
' '.$morecss :
'').
'"';
1694 $linkclose = ($morecss ?
' class="'.$morecss.
'"' :
'');
1697 $linkstart =
'<a href="'.$url.
'"';
1698 $linkstart .= $linkclose.
'>';
1701 $result .= $linkstart;
1703 $result .=
img_object(($notooltip ?
'' : $label), ($this->picto ?:
'generic'), (($withpicto != 2) ?
'class="paddingright"' :
''), 0, 0, $notooltip ? 0 : 1);
1705 if ($withpicto != 2) {
1706 $result .= $this->ref;
1708 $result .= $linkend;
1711 $hookmanager->initHooks(array(
'ticketdao'));
1712 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
1713 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
1715 $result = $hookmanager->resPrint;
1717 $result .= $hookmanager->resPrint;
1737 if ($this->
status != self::STATUS_CANCELED) {
1742 $this->
status = Ticket::STATUS_READ;
1744 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
1745 $sql .=
" SET fk_statut = ".((int) $this->
status) .
", date_read = '".$this->db->idate(
dol_now()).
"'";
1746 $sql .=
" WHERE rowid = ".((int) $this->
id);
1749 $resql = $this->db->query($sql);
1751 $this->context[
'actionmsg'] = $langs->trans(
'TicketLogMesgReadBy', $this->
ref, $user->getFullName($langs));
1752 $this->context[
'actionmsg2'] = $langs->trans(
'TicketLogMesgReadBy', $this->
ref, $user->getFullName($langs));
1756 $result = $this->call_trigger(
'TICKET_MODIFY', $user);
1764 $this->db->commit();
1767 $this->
status = $this->oldcopy->status;
1769 $this->db->rollback();
1771 $this->error = implode(
',', $this->errors);
1773 dol_syslog(get_class($this).
"::markAsRead ".$this->error, LOG_ERR);
1777 $this->
status = $this->oldcopy->status;
1779 $this->db->rollback();
1780 $this->error = $this->db->lasterror();
1781 dol_syslog(get_class($this).
"::markAsRead ".$this->error, LOG_ERR);
1800 if (!empty($this->date_read)) {
1808 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
1809 $sql .=
" SET date_read = '".$this->db->idate(
dol_now()).
"'";
1810 $sql .=
", fk_user_modif = ".((int) $user->id);
1811 $sql .=
" WHERE rowid = ".((int) $this->
id);
1813 dol_syslog(get_class($this).
"::setReadDate");
1815 $resql = $this->db->query($sql);
1818 $this->db->rollback();
1819 $this->date_read = $this->oldcopy->date_read;
1820 $this->error = $this->db->lasterror();
1822 dol_syslog(get_class($this).
"::setReadDate ".$this->error, LOG_ERR);
1827 $result = $this->call_trigger(
'TICKET_MODIFY', $user);
1829 $this->db->rollback();
1830 $this->date_read = $this->oldcopy->date_read;
1831 $this->error = implode(
',', $this->errors);
1833 dol_syslog(get_class($this).
"::setReadDate ".$this->error, LOG_ERR);
1838 $this->db->commit();
1841 $this->fk_user_modif = $user->id;
1842 $this->user_modification_id = $user->id;
1855 public function assignUser($user, $id_assign_user, $notrigger = 0)
1863 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
1864 if ($id_assign_user > 0) {
1865 $newstatus = Ticket::STATUS_ASSIGNED;
1867 $newstatus = Ticket::STATUS_READ;
1869 $sql .=
" SET fk_user_assign=".((int) $id_assign_user).
", fk_statut = ".$newstatus;
1871 $sql .=
" SET fk_user_assign=null, fk_statut = ".Ticket::STATUS_READ;
1873 $sql .=
" WHERE rowid = ".((int) $this->
id);
1875 dol_syslog(get_class($this).
"::assignUser sql=".$sql);
1876 $resql = $this->db->query($sql);
1878 $this->fk_user_assign = $id_assign_user;
1882 $result = $this->call_trigger(
'TICKET_ASSIGNED', $user);
1890 $this->db->commit();
1893 $this->db->rollback();
1894 $this->error = implode(
',', $this->errors);
1895 dol_syslog(get_class($this).
"::assignUser ".$this->error, LOG_ERR);
1899 $this->db->rollback();
1900 $this->error = $this->db->lasterror();
1901 dol_syslog(get_class($this).
"::assignUser ".$this->error, LOG_ERR);
1920 public function createTicketMessage($user, $notrigger = 0, $filename_list = array(), $mimetype_list = array(), $mimefilename_list = array(), $send_email =
false, $public_area = 0, $summary =
'', $external_contacts = [])
1922 global
$conf, $langs, $hookmanager;
1928 if (isset($this->track_id)) {
1929 $this->track_id = trim($this->track_id);
1932 if (isset($this->message)) {
1933 $this->message = trim($this->message);
1939 include_once DOL_DOCUMENT_ROOT.
'/comm/action/class/actioncomm.class.php';
1941 $actioncomm->type_code =
'AC_OTH_AUTO';
1942 $actioncomm->code =
'TICKET_MSG';
1943 if ($this->
private) {
1944 $actioncomm->code =
'TICKET_MSG_PRIVATE';
1947 $actioncomm->code .=
'_SENTBYMAIL';
1949 if ((empty($user->id) || $user->id == 0) && isset($_SESSION[
'email_customer'])) {
1950 $actioncomm->email_from = $_SESSION[
'email_customer'];
1952 $actioncomm->socid = $this->socid;
1953 $actioncomm->label = $this->subject;
1955 $actioncomm->label = preg_replace(
'/(\[[^\]]*\]).*$/',
'\1', $actioncomm->label);
1956 if ($actioncomm->label) {
1957 $actioncomm->label .=
' ';
1959 $actioncomm->label .= (
string) $summary;
1962 $actioncomm->note_private = $this->message;
1963 $actioncomm->userassigned = array($user->id => array(
'id' => $user->id,
'transparency' => 0));
1965 $parameters = array();
1966 $reshook = $hookmanager->executeHooks(
'createTicketMessageExternalContacts', $parameters, $actioncomm);
1968 $actioncomm->socpeopleassigned = $external_contacts;
1969 } elseif ($reshook == 0) {
1970 $actioncomm->socpeopleassigned += $external_contacts;
1973 $actioncomm->userownerid = $user->id;
1974 $actioncomm->datep = $now;
1975 $actioncomm->percentage = -1;
1976 $actioncomm->elementtype =
'ticket';
1979 $actioncomm->elementtype =
'ticket';
1980 $actioncomm->fk_project = $this->fk_project;
1986 if ($public_area && !empty($this->origin_email) &&
getDolGlobalString(
'TICKET_ASSIGN_CONTACT_TO_MESSAGE')) {
1987 $contacts = $this->searchContactByEmail($this->origin_email);
1988 if (!empty($contacts)) {
1990 foreach ($contacts as $contact) {
1991 if ((
int) $contact->status == 1) {
1992 $actioncomm->contact_id = $contact->id;
1999 $attachedfiles = array();
2000 $attachedfiles[
'paths'] = $filename_list;
2001 $attachedfiles[
'names'] = $mimefilename_list;
2002 $attachedfiles[
'mimes'] = $mimetype_list;
2003 if (is_array($attachedfiles) && count($attachedfiles) > 0) {
2004 $actioncomm->attachedfiles = $attachedfiles;
2010 $actionid = $actioncomm->create($user);
2011 if ($actionid <= 0) {
2013 $this->error = $actioncomm->error;
2014 $this->errors = $actioncomm->errors;
2017 if ($actionid > 0) {
2018 if (is_array($attachedfiles) && array_key_exists(
'paths', $attachedfiles) && count($attachedfiles[
'paths']) > 0) {
2020 foreach ($attachedfiles[
'paths'] as $key => $filespath) {
2022 $destdir =
$conf->ticket->dir_output.
'/'.$this->ref;
2027 if (in_array($actioncomm->code, array(
'TICKET_MSG',
'TICKET_MSG_SENTBYMAIL',
'TICKET_MSG_PRIVATE'))) {
2028 $ecmfile =
new EcmFiles($this->db);
2029 $destdir = preg_replace(
'/^'.preg_quote(DOL_DATA_ROOT,
'/').
'/',
'', $destdir);
2030 $destdir = preg_replace(
'/[\\/]$/',
'', $destdir);
2031 $destdir = preg_replace(
'/^[\\/]/',
'', $destdir);
2033 $result = $ecmfile->fetch(0,
'', $destdir.
'/'.$attachedfiles[
'names'][$key]);
2036 $ecmfile->agenda_id = $actionid;
2039 $result = $ecmfile->update($user);
2052 $this->db->rollback();
2055 $this->db->commit();
2067 if (!empty($this->cache_msgs_ticket) && is_array($this->cache_msgs_ticket) && count($this->cache_msgs_ticket)) {
2073 $sql =
"SELECT id as rowid, fk_user_author, fk_user_action, email_from, datec, datep, label, note as message, code";
2074 $sql .=
" FROM ".MAIN_DB_PREFIX.
"actioncomm";
2075 $sql .=
" WHERE fk_element = ".(int) $this->
id;
2076 $sql .=
" AND elementtype = 'ticket'";
2077 $sql .=
" ORDER BY datep DESC";
2079 dol_syslog(get_class($this).
"::load_cache_actions_ticket", LOG_DEBUG);
2080 $resql = $this->db->query($sql);
2082 $num = $this->db->num_rows($resql);
2085 $obj = $this->db->fetch_object($resql);
2086 $this->cache_msgs_ticket[$i][
'id'] = $obj->rowid;
2087 $this->cache_msgs_ticket[$i][
'fk_user_author'] = $obj->fk_user_author;
2088 $this->cache_msgs_ticket[$i][
'fk_user_action'] = $obj->fk_user_action;
2089 if (in_array($obj->code, array(
'TICKET_MSG',
'AC_TICKET_CREATE')) && empty($obj->fk_user_author)) {
2090 $this->cache_msgs_ticket[$i][
'fk_contact_author'] = $obj->email_from;
2092 $this->cache_msgs_ticket[$i][
'datec'] = $this->db->jdate($obj->datec);
2093 $this->cache_msgs_ticket[$i][
'datep'] = $this->db->jdate($obj->datep);
2094 $this->cache_msgs_ticket[$i][
'subject'] = $obj->label;
2095 $this->cache_msgs_ticket[$i][
'message'] = $obj->message;
2096 $this->cache_msgs_ticket[$i][
'private'] = (preg_match(
'/^TICKET_MSG_PRIVATE/', $obj->code) ? 1 : 0);
2101 $this->error =
"Error ".$this->db->lasterror();
2102 dol_syslog(get_class($this).
"::load_cache_actions_ticket ".$this->error, LOG_ERR);
2117 if ($this->
status != Ticket::STATUS_CLOSED && $this->
status != Ticket::STATUS_CANCELED) {
2121 $this->
status = ($mode ? Ticket::STATUS_CANCELED : Ticket::STATUS_CLOSED);
2123 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
2124 $sql .=
" SET fk_statut = ".((int) $this->
status).
", progress=100, date_close='".$this->db->idate(
dol_now()).
"'";
2125 $sql .=
" WHERE rowid = ".((int) $this->
id);
2127 dol_syslog(get_class($this).
"::close mode=".$mode);
2128 $resql = $this->db->query($sql);
2134 dol_syslog(
"We have closed the ticket, so we close all linked interventions");
2135 $this->fetchObjectLinked($this->
id, $this->element,
null,
'fichinter');
2136 if ($this->linkedObjectsIds) {
2137 foreach ($this->linkedObjectsIds[
'fichinter'] as $fichinter_id) {
2139 $fichinter->fetch($fichinter_id);
2140 if ($fichinter->statut == 0) {
2141 $result = $fichinter->setValid($user);
2143 $this->errors[] = $fichinter->error;
2147 if ($fichinter->statut < 3) {
2148 $result = $fichinter->setStatut(3);
2150 $this->errors[] = $fichinter->error;
2159 $result = $this->call_trigger(
'TICKET_CLOSE', $user);
2166 $this->db->commit();
2169 $this->db->rollback();
2170 $this->error = implode(
',', $this->errors);
2171 dol_syslog(get_class($this).
"::close ".$this->error, LOG_ERR);
2175 $this->db->rollback();
2176 $this->error = $this->db->lasterror();
2177 dol_syslog(get_class($this).
"::close ".$this->error, LOG_ERR);
2196 $thirdparties = array();
2200 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"societe";
2201 $sql .=
" WHERE entity IN (".getEntity(
'ticket', 1).
")";
2202 if (!empty($type)) {
2203 if ($type == 1 || $type == 2) {
2204 $sql .=
" AND client = ".((int) $type);
2205 } elseif ($type == 3) {
2206 $sql .=
" AND fournisseur = 1";
2209 if (!empty($email)) {
2210 if (empty($exact)) {
2212 if (preg_match(
'/^([\*])?[^*]+([\*])?$/', $email, $regs) && count($regs) > 1) {
2213 $email = str_replace(
'*',
'%', $email);
2215 $email =
'%'.$email.
'%';
2219 if (is_array($filters) && !empty($filters)) {
2223 $sql .=
"email LIKE '".$this->db->escape($email).
"'";
2225 if (is_array($filters) && !empty($filters)) {
2226 foreach ($filters as $field => $value) {
2227 $sql .=
" ".$clause.
" ".$this->db->sanitize($field).
" LIKE '".$this->db->escape($value).
"'";
2229 if (!empty($email)) {
2234 $res = $this->db->query($sql);
2236 while ($rec = $this->db->fetch_array($res)) {
2237 $soc =
new Societe($this->db);
2238 $soc->fetch($rec[
'rowid']);
2239 $thirdparties[] = $soc;
2242 return $thirdparties;
2244 $this->error = $this->db->error().
' sql='.$sql;
2245 dol_syslog(get_class($this).
"::searchSocidByEmail ".$this->error, LOG_ERR);
2260 $contacts = array();
2263 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"socpeople";
2264 $sql .=
" WHERE entity IN (".getEntity(
'contact').
")";
2265 if (!empty($socid)) {
2266 $sql .=
" AND fk_soc = ".((int) $socid);
2268 if (!empty($email)) {
2271 $sql .=
"email = '".$this->db->escape($email).
"'";
2273 $sql .=
"email LIKE BINARY '".$this->db->escape($this->db->escapeforlike($email)).
"'";
2277 $res = $this->db->query($sql);
2279 while ($rec = $this->db->fetch_object($res)) {
2280 include_once DOL_DOCUMENT_ROOT.
'/contact/class/contact.class.php';
2281 $contactstatic =
new Contact($this->db);
2282 $contactstatic->fetch($rec->rowid);
2283 $contacts[] = $contactstatic;
2288 $this->error = $this->db->error().
' sql='.$sql;
2289 dol_syslog(get_class($this).
"::searchContactByEmail ".$this->error, LOG_ERR);
2303 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
2304 $sql .=
" SET fk_soc = ".($id > 0 ? (int)
$id :
"null");
2305 $sql .=
" WHERE rowid = ".((int) $this->
id);
2306 dol_syslog(get_class($this).
'::setCustomer sql='.$sql);
2307 $resql = $this->db->query($sql);
2327 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
2328 $sql .=
" SET progress = ".($percent > 0 ? (float) $percent :
"null");
2329 $sql .=
" WHERE rowid = ".((int) $this->
id);
2330 dol_syslog(get_class($this).
'::set_progression sql='.$sql);
2331 $resql = $this->db->query($sql);
2351 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"ticket";
2352 $sql .=
" SET fk_contract = ".($contractid > 0 ? (int) $contractid :
"null");
2353 $sql .=
" WHERE rowid = ".((int) $this->
id);
2354 dol_syslog(get_class($this).
'::setContract sql='.$sql);
2355 $resql = $this->db->query($sql);
2375 return $this->getIdContact(
'internal',
'SUPPORTTEC');
2386 return $this->listeContact(-1,
'internal', 0,
'', $status);
2396 return $this->getIdContact(
'external',
'SUPPORTCLI');
2407 return $this->listeContact(-1,
'external', 0,
'', $status);
2417 return $this->getIdContact(
'internal',
'CONTRIBUTOR');
2427 return $this->getIdContact(
'external',
'CONTRIBUTOR');
2437 $array_contact = $this->getIdTicketInternalContact();
2439 $array_contact = array_merge($array_contact, $this->getIdTicketCustomerContact());
2441 $array_contact = array_merge($array_contact, $this->getIdTicketInternalInvolvedContact());
2443 $array_contact = array_merge($array_contact, $this->getIdTicketCustomerInvolvedContact());
2445 return $array_contact;
2455 $array_contact = array();
2457 $array_contact = array_merge($array_contact, $this->getIdTicketCustomerContact());
2459 $array_contact = array_merge($array_contact, $this->getIdTicketCustomerInvolvedContact());
2461 return $array_contact;
2476 public function listeContact($statusoflink = -1, $source =
'external', $list = 0, $code =
'', $status = -1)
2482 $sql =
"SELECT ec.rowid, ec.statut as statuslink, ec.fk_socpeople as id, ec.fk_c_type_contact";
2483 if ($source ==
'internal') {
2484 $sql .=
", '-1' as socid, t.statut as statuscontact";
2487 if ($source ==
'external' || $source ==
'thirdparty') {
2488 $sql .=
", t.fk_soc as socid, t.statut as statuscontact";
2491 $sql .=
", t.civility, t.lastname as lastname, t.firstname, t.email";
2492 if ($source ==
'internal') {
2493 $sql .=
", t.office_phone as phone, t.user_mobile as phone_mobile";
2496 if ($source ==
'external') {
2497 $sql .=
", t.phone as phone, t.phone_mobile as phone_mobile, t.phone_perso as phone_perso";
2500 $sql .=
", tc.source, tc.element, tc.code, tc.libelle as type_contact_label";
2501 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_type_contact tc";
2502 $sql .=
", ".MAIN_DB_PREFIX.
"element_contact ec";
2503 if ($source ==
'internal') {
2504 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"user t on ec.fk_socpeople = t.rowid";
2507 if ($source ==
'external' || $source ==
'thirdparty') {
2508 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"socpeople t on ec.fk_socpeople = t.rowid";
2511 $sql .=
" WHERE ec.element_id = ".((int) $this->
id);
2512 $sql .=
" AND ec.fk_c_type_contact=tc.rowid";
2513 $sql .=
" AND tc.element='".$this->db->escape($this->element).
"'";
2514 if ($source ==
'internal') {
2515 $sql .=
" AND tc.source = 'internal'";
2517 $sql .=
" AND t.statut = ".((int) $status);
2521 if ($source ==
'external' || $source ==
'thirdparty') {
2522 $sql .=
" AND tc.source = 'external'";
2524 $sql .=
" AND t.statut = ".((int) $status);
2528 if (!empty($code)) {
2529 $sql .=
" AND tc.code = '".$this->db->escape($code).
"'";
2532 $sql .=
" AND tc.active=1";
2533 if ($statusoflink >= 0) {
2534 $sql .=
" AND ec.statut = ".((int) $statusoflink);
2537 $sql .=
" ORDER BY t.lastname ASC";
2539 $resql = $this->db->query($sql);
2541 $num = $this->db->num_rows($resql);
2544 $obj = $this->db->fetch_object($resql);
2547 $transkey =
"TypeContact_".$obj->element.
"_".$obj->source.
"_".$obj->code;
2548 $labelType = ($langs->trans($transkey) != $transkey ? $langs->trans($transkey) : $obj->type_contact_label);
2550 'source' => $obj->source,
2551 'socid' => (
int) $obj->socid,
2552 'id' => (
int) $obj->id,
2553 'nom' => $obj->lastname,
2554 'civility' => $obj->civility,
2555 'lastname' => $obj->lastname,
2556 'firstname' => $obj->firstname,
2557 'email' => $obj->email,
2558 'rowid' => (
int) $obj->rowid,
2559 'code' => $obj->code,
2560 'libelle' => $labelType,
2561 'labeltype' => $labelType,
2562 'status' => $obj->statuslink,
2563 'statuscontact' => (
int) $obj->statuscontact,
2564 'fk_c_type_contact' => (
int) $obj->fk_c_type_contact,
2565 'phone' => $obj->phone,
2566 'phone_mobile' => $obj->phone_mobile);
2567 if ($source ==
'external') {
2568 $tab[$i][
'phone_perso'] = $obj->phone_perso;
2571 $tab[$i] = $obj->id;
2579 $this->error = $this->db->error();
2602 $dirmodels = array_merge(array(
'/'), (array)
$conf->modules_parts[
'models']);
2603 foreach ($dirmodels as $reldir) {
2604 $file =
dol_buildpath($reldir.
"core/modules/ticket/".$modele.
'.php', 0);
2605 if (file_exists($file)) {
2606 $classname = $modele;
2611 if ($classname !==
'') {
2613 $modTicket =
new $classname();
2614 '@phan-var-force ModeleNumRefTicket $modTicket';
2616 $defaultref = $modTicket->getNextValue($thirdparty, $this);
2619 if (is_numeric($defaultref) && $defaultref <= 0) {
2637 include_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2642 if (file_exists($dir_osencoded)) {
2643 $handle = opendir($dir_osencoded);
2644 if (is_resource($handle)) {
2645 while (($file = readdir($handle)) !==
false) {
2647 $file = mb_convert_encoding($file,
'UTF-8',
'ISO-8859-1');
2672 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmail.class.php';
2673 include_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2674 include_once DOL_DOCUMENT_ROOT.
'/core/lib/images.lib.php';
2676 $maxwidthsmall = 270;
2677 $maxheightsmall = 150;
2678 $maxwidthmini = 128;
2679 $maxheightmini = 72;
2681 $formmail =
new FormMail($this->db);
2682 $formmail->trackid = (is_null($forcetrackid) ?
'tic'.$this->id :
'');
2683 $attachedfiles = $formmail->get_attached_files();
2685 $filepath = $attachedfiles[
'paths'];
2686 $filename = $attachedfiles[
'names'];
2687 $mimetype = $attachedfiles[
'mimes'];
2690 $destdir =
$conf->ticket->dir_output.
'/'.$this->ref;
2696 $listofpaths = array();
2697 $listofnames = array();
2698 foreach ($filename as $i => $val) {
2699 $destfile = $destdir.
'/'.$filename[$i];
2701 if (is_file($destfile)) {
2702 $pathinfo = pathinfo($filename[$i]);
2704 $destfile = $destdir.
'/'.$pathinfo[
'filename'].
' - '.
dol_print_date($now,
'dayhourlog').
'.'.$pathinfo[
'extension'];
2708 'description' =>
'File saved by copyFilesForTicket',
2709 'src_object_type' => $this->element,
2710 'src_object_id' => $this->
id,
2711 'gen_or_uploaded' =>
'uploaded'
2714 $res =
dol_move($filepath[$i], $destfile,
'0', 1, 0, 1, $moreinfo);
2718 $this->error =
"Failed to move file ".dirbasename($filepath[$i]).
" into ".
dirbasename($destfile);
2725 $imgThumbSmall =
vignette($destfile, $maxwidthsmall, $maxheightsmall,
'_small', 50,
"thumbs");
2728 $imgThumbMini =
vignette($destfile, $maxwidthmini, $maxheightmini,
'_mini', 50,
"thumbs");
2733 $formmail->remove_attached_files($i);
2736 $listofpaths[$i] = $destfile;
2737 $listofnames[$i] = basename($destfile);
2740 return array(
'listofpaths' => $listofpaths,
'listofnames' => $listofnames,
'listofmimes' => $mimetype);
2756 if (!is_array($categories)) {
2757 $categories = array($categories);
2761 include_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
2763 $existing =
$c->containing($this->
id, Categorie::TYPE_TICKET,
'id');
2766 if (is_array($existing)) {
2767 $to_del = array_diff($existing, $categories);
2768 $to_add = array_diff($categories, $existing);
2771 $to_add = $categories;
2775 foreach ($to_del as $del) {
2776 if (
$c->fetch($del) > 0) {
2777 $c->del_type($this, Categorie::TYPE_TICKET);
2780 foreach ($to_add as $add) {
2781 if (
$c->fetch($add) > 0) {
2782 $c->add_type($this, Categorie::TYPE_TICKET);
2801 public function newMessage($user, &$action, $private = 1, $public_area = 0)
2803 global
$mysoc, $langs, $hookmanager;
2817 array_push($this->errors, $langs->trans(
"ErrorTicketIsNotValid"));
2823 array_push($this->errors, $langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Message")));
2824 $action =
'add_message';
2828 $summary = mb_strcut(
GETPOST(
'summary',
'alphanohtml'), 0, 42,
'UTF-8');
2833 $send_email = (bool)
GETPOSTINT(
'send_email');
2836 $resarray =
$object->copyFilesForTicket();
2837 if (is_numeric($resarray) && $resarray == -1) {
2842 $listofpaths = $resarray[
'listofpaths'];
2843 $listofnames = $resarray[
'listofnames'];
2844 $listofmimes = $resarray[
'listofmimes'];
2847 $external_contacts =
$object->getInfosTicketExternalContact(1);
2848 $external_resources = [];
2849 if (!empty($external_contacts)) {
2850 foreach ($external_contacts as $eContact) {
2851 $external_resources[$eContact[
'id']] = $eContact;
2858 $id =
$object->createTicketMessage($user, 0, $listofpaths, $listofmimes, $listofnames, $send_email, $public_area, $summary, $external_resources);
2862 $this->error =
$object->error;
2863 $this->errors =
$object->errors;
2864 $action =
'add_message';
2867 if (!$error &&
$id > 0) {
2868 setEventMessages($langs->trans(
'TicketMessageSuccessfullyAdded'),
null,
'mesgs');
2871 if (!empty($public_area)) {
2879 $internal_contacts =
$object->getInfosTicketInternalContact(1);
2881 $assigned_user_dont_have_email =
'';
2885 if ($this->fk_user_assign > 0) {
2886 $assigned_user =
new User($this->db);
2887 $assigned_user->fetch($this->fk_user_assign);
2888 if (!empty($assigned_user->email)) {
2889 $sendto[$assigned_user->email] = $assigned_user->getFullName($langs).
" <".$assigned_user->email.
">";
2891 $assigned_user_dont_have_email = $assigned_user->getFullName($langs);
2894 $assigned_user =
null;
2898 foreach ($internal_contacts as $key => $info_sendto) {
2900 if ($info_sendto[
'id'] == $user->id) {
2905 if (!empty($info_sendto[
'email']) && ($assigned_user ===
null || $assigned_user->email != $info_sendto[
'email'])) {
2906 $sendto[] =
dolGetFirstLastname($info_sendto[
'firstname'], $info_sendto[
'lastname']).
" <".$info_sendto[
'email'].
">";
2910 if (empty($sendto)) {
2925 $parameters = array(
'sendto' => $sendto);
2926 $reshook = $hookmanager->executeHooks(
'updateSendtoTicketMessage', $parameters,
$object, $action);
2927 if (empty($reshook)) {
2928 $sendto = array_merge($sendto, $hookmanager->resArray);
2929 } elseif ($reshook > 0) {
2930 $sendto = $hookmanager->resArray;
2933 if (!empty($sendto)) {
2936 $subject =
'['.$appli.
'- ticket #'.
$object->track_id.
'] '.$this->subject;
2939 $message =
getDolGlobalString(
'TICKET_MESSAGE_MAIL_INTRO', $langs->trans(
'TicketMessageMailIntroText'));
2940 $message .=
'<br><br>';
2941 $messagePost =
GETPOST(
'message',
'restricthtml');
2945 $message .= $messagePost;
2948 $message .=
'<br><br>';
2949 $message .=
"==============================================";
2950 $message .= !empty(
$object->thirdparty->name) ?
'<br>'.$langs->trans(
'ThirdParty').
" : ".
$object->thirdparty->name :
'';
2951 $message .= !empty(
$object->thirdparty->town) ?
'<br>'.$langs->trans(
'Town').
" : ".
$object->thirdparty->town :
'';
2952 $message .= !empty(
$object->thirdparty->phone) ?
'<br>'.$langs->trans(
'Phone').
" : ".
$object->thirdparty->phone :
'';
2955 $message .=
'<br><br>';
2956 if (!empty($assigned_user_dont_have_email)) {
2957 $message .=
'<br>'.$langs->trans(
'NoEMail').
' : '.$assigned_user_dont_have_email;
2959 foreach ($sendto as $val) {
2960 $message .=
'<br>'.$langs->trans(
'TicketNotificationRecipient').
' : '.$val;
2965 $message .=
'<br><br>';
2966 $message .= $langs->trans(
'TicketNotificationEmailBodyInfosTrackUrlinternal').
' : <a href="'.$url_internal_ticket.
'">'.
$object->track_id.
'</a>';
2973 $this->sendTicketMessageByEmail($subject, $message, 0, $sendto, $listofpaths, $listofmimes, $listofnames, array(), $from, $replyto);
2982 if ((
int) $send_email > 0) {
2984 $internal_contacts =
$object->getInfosTicketInternalContact(1);
2987 if (is_array($internal_contacts) && count($internal_contacts) > 0) {
2991 $subject =
GETPOST(
'subject',
'alphanohtml') ?
GETPOST(
'subject',
'alphanohtml') :
'['.$appli.
' - '.$langs->trans(
"Ticket").
' #'.
$object->track_id.
'] '.$langs->trans(
'TicketNewMessage');
2993 $message_intro = $langs->trans(
'TicketNotificationEmailBody',
"#".
$object->id);
2996 $message =
getDolGlobalString(
'TICKET_MESSAGE_MAIL_INTRO', $langs->trans(
'TicketMessageMailIntroText'));
2997 $message .=
'<br><br>';
2998 $messagePost =
GETPOST(
'message',
'restricthtml');
3002 $message .= $messagePost;
3005 $message .=
'<br><br>';
3006 $message .=
"==============================================<br>";
3007 $message .= !empty(
$object->thirdparty->name) ? $langs->trans(
'ThirdParty').
" : ".
$object->thirdparty->name :
'';
3008 $message .= !empty(
$object->thirdparty->town) ?
'<br>'.$langs->trans(
'Town').
" : ".
$object->thirdparty->town :
'';
3009 $message .= !empty(
$object->thirdparty->phone) ?
'<br>'.$langs->trans(
'Phone').
" : ".
$object->thirdparty->phone :
'';
3012 foreach ($internal_contacts as $key => $info_sendto) {
3014 if ($info_sendto[
'id'] == $user->id) {
3015 dol_syslog(
"We cancel sending email to internal user ".$info_sendto[
'email'].
" because it is current user", LOG_DEBUG);
3019 if ($info_sendto[
'email'] !=
'') {
3020 $email = $info_sendto[
'email'];
3021 if ($email !=
null) {
3022 $sendto[$email] =
dolGetFirstLastname($info_sendto[
'firstname'], $info_sendto[
'lastname']).
" <".$info_sendto[
'email'].
">";
3026 $recipient =
dolGetFirstLastname($info_sendto[
'firstname'], $info_sendto[
'lastname'], -1).
' ('.strtolower((
string) $info_sendto[
'libelle']).
')';
3027 $message .= (!empty($recipient) ?
'<br>'.$langs->trans(
'TicketNotificationRecipient').
' : '.$recipient.
'<br>' :
'');
3035 $message .=
'<br>'.$langs->trans(
'TicketNotificationEmailBodyInfosTrackUrlinternal').
' : <a href="'.$url_internal_ticket.
'">'.
$object->track_id.
'</a><br>';
3044 $parameters = array(
'sendto' => $sendto);
3045 $reshook = $hookmanager->executeHooks(
'updateSendtoTicketMessage', $parameters,
$object, $action);
3046 if (empty($reshook)) {
3047 $sendto = array_merge($sendto, $hookmanager->resArray);
3048 } elseif ($reshook > 0) {
3049 $sendto = $hookmanager->resArray;
3052 $sendtocc = array();
3062 if (!empty($sendto)) {
3063 $this->sendTicketMessageByEmail($subject, $message, 0, $sendto, $listofpaths, $listofmimes, $listofnames, $sendtocc, $from, $replyto);
3070 if (empty(
$object->private)) {
3072 if (is_array($external_contacts) && count($external_contacts) === 0) {
3073 if (!empty(
$object->fk_soc)) {
3075 $array_company = array(array(
'firstname' =>
'',
'lastname' =>
$object->thirdparty->name,
'email' =>
$object->thirdparty->email,
'libelle' => $langs->transnoentities(
'Customer'),
'socid' =>
$object->thirdparty->id));
3076 $external_contacts = array_merge($external_contacts, $array_company);
3077 } elseif (empty(
$object->fk_soc) && !empty(
$object->origin_replyto)) {
3078 $array_external = array(array(
'firstname' =>
'',
'lastname' =>
$object->origin_replyto,
'email' =>
$object->origin_replyto,
'libelle' => $langs->transnoentities(
'Customer'),
'socid' => 0));
3079 $external_contacts = array_merge($external_contacts, $array_external);
3080 } elseif (empty(
$object->fk_soc) && !empty(
$object->origin_email)) {
3081 $array_external = array(array(
'firstname' =>
'',
'lastname' =>
$object->origin_email,
'email' =>
$object->thirdparty->email,
'libelle' => $langs->transnoentities(
'Customer'),
'socid' =>
$object->thirdparty->id));
3082 $external_contacts = array_merge($external_contacts, $array_external);
3087 if (is_array($external_contacts) && count($external_contacts) > 0) {
3091 $subject =
GETPOST(
'subject') ?
GETPOST(
'subject') :
'['.$appli.
' - '.$langs->trans(
"Ticket").
' #'.
$object->track_id.
'] '.$langs->trans(
'TicketNewMessage');
3096 $message_intro =
dol_nl2br($message_intro);
3099 $message_signature =
dol_nl2br($message_signature);
3103 $messagePost =
GETPOST(
'message',
'restricthtml');
3107 $message = $messagePost;
3108 $message .=
'<br><br>';
3110 foreach ($external_contacts as $key => $info_sendto) {
3112 if ($info_sendto[
'id'] == $user->contact_id) {
3116 if ($info_sendto[
'email'] !=
'' && $info_sendto[
'email'] !=
$object->origin_email) {
3117 $email = $info_sendto[
'email'];
3118 if ($email !=
null) {
3119 $sendto[$email] = trim($info_sendto[
'firstname'].
" ".$info_sendto[
'lastname']).
" <".$info_sendto[
'email'].
">";
3122 $recipient =
dolGetFirstLastname($info_sendto[
'firstname'], $info_sendto[
'lastname'], -1).
' ('.strtolower((
string) $info_sendto[
'libelle']).
')';
3123 $message .= (!empty($recipient) ?
'<br>'.$langs->trans(
'TicketNotificationRecipient').
' : '.$recipient.
'<br>' :
'');
3128 $url_public_ticket = (
getDolGlobalInt(
'TICKET_ENABLE_PUBLIC_INTERFACE') ?
3131 if (
getDolGlobalInt(
'TICKET_INCLUDE_LINK_TO_PUBLIC_INTERFACE_IN_MESSAGE')) {
3132 $message .=
'<br>' . $langs->trans(
'TicketNewEmailBodyInfosTrackUrlCustomer') .
' : <a href="' . $url_public_ticket .
'">' .
$object->track_id .
'</a><br>';
3136 $message = $message_intro.
'<br><br>'.$message;
3139 $message .=
'<br>'.$message_signature;
3141 if (!empty(
$object->origin_replyto)) {
3143 } elseif (!empty(
$object->origin_email)) {
3147 if (
$object->fk_soc > 0 && !array_key_exists(
$object->origin_replyto, $sendto) && !array_key_exists(
$object->origin_email, $sendto)) {
3150 if (!empty(
$object->thirdparty->email)) {
3151 $sendto[
$object->thirdparty->email] =
$object->thirdparty->email;
3162 $parameters = array(
'sendto' => $sendto);
3163 $reshook = $hookmanager->executeHooks(
'updateSendtoTicketMessage', $parameters,
$object, $action);
3164 if (empty($reshook)) {
3165 $sendto = array_merge($sendto, $hookmanager->resArray);
3166 } elseif ($reshook > 0) {
3167 $sendto = $hookmanager->resArray;
3170 $sendtocc = array();
3176 if (!empty($sendto)) {
3181 $result = $this->sendTicketMessageByEmail($subject, $message, 0, $sendto, $listofpaths, $listofmimes, $listofnames, $sendtocc, $from, $replyto);
3184 $this->date_last_msg_sent =
dol_now();
3185 $this->update($user, 1);
3189 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"actioncomm";
3190 $sql .=
" SET email_msgid = '".$this->db->escape($this->email_msgid).
"',";
3191 $sql .=
" email_subject = '".$this->db->escape($subject).
"',";
3192 $sql .=
" email_from = '".$this->db->escape($from).
"',";
3193 $sql .=
" email_to = '".$this->db->escape(implode(
',', $sendto)).
"',";
3194 $sql .=
" email_tocc = '".$this->db->escape(implode(
',', $sendtocc)).
"',";
3195 $sql .=
" reply_to = '".$this->db->escape($replyto).
"'";
3196 $sql .=
" WHERE id = ".((int)
$id);
3198 $resql = $this->db->query($sql);
3211 && (
$object->status < self::STATUS_IN_PROGRESS && !$user->socid && !$private))
3212 || (
$object->status > self::STATUS_IN_PROGRESS && $public_area)) {
3214 $object->setStatut($object::STATUS_IN_PROGRESS,
null,
'',
'TICKET_MODIFY');
3215 } elseif (
getDolGlobalInt(
'TICKET_SET_STATUS_ON_ANSWER', -1) >= 0 && empty($user->socid) && empty($private)) {
3247 public function sendTicketMessageByEmail($subject, $message, $send_internal_cc = 0, $array_receiver = array(), $filename_list = array(), $mimetype_list = array(), $mimefilename_list = array(), $array_receiver_cc = array(), $from =
'', $replyto =
'')
3249 global
$conf, $langs, $user, $hookmanager;
3252 dol_syslog(get_class($this).
'::sendTicketMessageByEmail: Emails are disable into ticket setup by option TICKET_DISABLE_ALL_MAILS', LOG_WARNING);
3256 $langs->load(
"mails");
3258 include_once DOL_DOCUMENT_ROOT.
'/contact/class/contact.class.php';
3262 if (!is_array($array_receiver) || !count($array_receiver) > 0) {
3263 $array_receiver = $this->getInfosTicketInternalContact(1);
3264 $array_receiver = array_merge($array_receiver, $this->getInfosTicketExternalContact(1));
3267 dol_syslog(
"sendTicketMessageByEmail array_receiver=".json_encode($array_receiver), LOG_DEBUG);
3268 dol_syslog(
"sendTicketMessageByEmail array_receiver_cc=".json_encode($array_receiver_cc), LOG_DEBUG);
3271 if ($send_internal_cc) {
3274 if (!empty($array_receiver_cc) && is_array($array_receiver_cc)) {
3275 $sendtocc .= ($sendtocc ?
',' :
'').implode(
',', $array_receiver_cc);
3282 $parameters = array(
'from' => $from);
3284 $reshook = $hookmanager->executeHooks(
'getTicketMessageEmailFrom', $parameters, $this, $action);
3285 if ($reshook && !empty($hookmanager->resArray[
'from'])) {
3286 $from = $hookmanager->resArray[
'from'];
3290 $this->email_msgids = array();
3292 if (is_array($array_receiver) && count($array_receiver) > 0) {
3294 $deliveryreceipt = 0;
3295 $filepath = $filename_list;
3296 $filename = $mimefilename_list;
3297 $mimetype = $mimetype_list;
3303 $conf->global->MAIN_MAIL_AUTOCOPY_TO =
'';
3306 $upload_dir_tmp =
$conf->user->dir_output.
"/".$user->id.
'/temp';
3308 include_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
3309 $trackid =
"tic".$this->id;
3311 $moreinheader =
'X-Dolibarr-Info: sendTicketMessageByEmail'.
"\r\n";
3312 if (!empty($this->email_msgid)) {
3314 $moreinheader .=
'In-Reply-To: <'.$this->email_msgid.
'>'.
"\r\n";
3322 if (!empty($this->origin_references)) {
3323 $references .= (empty($references) ?
'' :
' ').$this->origin_references;
3325 if (!empty($this->email_msgid) && !preg_match(
'/'.preg_quote($this->email_msgid,
'/').
'/', $references)) {
3326 $references .= (empty($references) ?
'' :
' ').
'<'.$this->email_msgid.
'>';
3329 $moreinheader .=
'References: '.$references.
"\r\n";
3333 $receiverstring =
'';
3334 foreach ($array_receiver as $key => $receiver) {
3335 $receiverstring .= ($receiverstring ?
',' :
'').$receiver;
3338 $sendcontext =
'ticket';
3341 $mailfile =
new CMailFile($subject, $receiverstring, $from, $message, $filepath, $mimetype, $filename, $sendtocc,
'', $deliveryreceipt, -1,
'',
'', $trackid, $moreinheader, $sendcontext, $replyto, $upload_dir_tmp);
3344 if ($mailfile->error) {
3347 $result = $mailfile->sendfile();
3350 setEventMessages($langs->trans(
'MailSuccessfulySent', $mailfile->getValidAddress($from, 2), $mailfile->getValidAddress($receiverstring, 2)),
null,
'mesgs');
3353 $this->email_msgid = $mailfile->msgid;
3355 $langs->load(
"other");
3356 if ($mailfile->error) {
3357 setEventMessages($langs->trans(
'ErrorFailedToSendMail', $from, $receiverstring),
null,
'errors');
3358 dol_syslog(
'ErrorFailedToSendMail from='.$from.
' to='.$receiverstring.
' : '.$mailfile->error);
3360 setEventMessages(
'No mail sent. Feature is disabled by option MAIN_DISABLE_ALL_MAILS',
null,
'errors');
3362 setEventMessages($langs->trans(
'ErrorFailedToSendMail', $from, $receiverstring),
null,
'errors');
3363 dol_syslog(
'ErrorFailedToSendMail from='.$from.
' to='.$receiverstring.
' : (no error details)', LOG_WARNING);
3369 $conf->global->MAIN_MAIL_AUTOCOPY_TO = $old_MAIN_MAIL_AUTOCOPY_TO;
3373 $langs->load(
"other");
3374 setEventMessages($langs->trans(
'ErrorMailRecipientIsEmptyForSendTicketMessage'),
null,
'warnings');
3391 global $user, $langs;
3398 $sql =
"SELECT p.rowid, p.ref, p.datec as datec";
3399 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as p";
3400 if (empty($user->socid) &&
isModEnabled(
'societe') && !$user->hasRight(
'societe',
'client',
'voir') && !$user->socid) {
3401 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON p.fk_soc = sc.fk_soc";
3402 $sql .=
" WHERE sc.fk_user = ".((int) $user->id);
3405 $sql .= $clause.
" p.entity IN (".
getEntity(
'ticket').
")";
3406 if ($mode ==
'opened') {
3407 $sql .=
" AND p.fk_statut NOT IN (".Ticket::STATUS_CLOSED.
", ".Ticket::STATUS_CANCELED.
")";
3410 $sql .=
" AND p.fk_soc = ".((int) $user->socid);
3413 $resql = $this->db->query($sql);
3415 $label = $labelShort =
'';
3417 if ($mode ==
'opened') {
3418 $status =
'openall';
3421 $label = $langs->trans(
"MenuListNonClosed");
3422 $labelShort = $langs->trans(
"MenuListNonClosed");
3427 $response->label = $label;
3428 $response->labelShort = $labelShort;
3429 $response->url = DOL_URL_ROOT.
'/ticket/list.php?search_fk_statut[]='.$status;
3433 while ($obj = $this->db->fetch_object($resql)) {
3434 $response->nbtodo++;
3435 if ($mode ==
'opened') {
3436 $datelimit = (int) $this->db->jdate($obj->datec) + (int) $delay_warning;
3437 if ($datelimit < $now) {
3444 $this->error = $this->db->lasterror();
3458 $this->nb = array();
3461 $sql =
"SELECT count(p.rowid) as nb";
3462 $sql .=
" FROM ".MAIN_DB_PREFIX.
"ticket as p";
3463 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe as s ON p.fk_soc = s.rowid";
3464 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
3465 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON s.rowid = sc.fk_soc";
3466 $sql .=
" WHERE sc.fk_user = ".((int) $user->id);
3469 $sql .=
" ".$clause.
" p.entity IN (".
getEntity(
'ticket').
")";
3471 $resql = $this->db->query($sql);
3474 while ($obj = $this->db->fetch_object($resql)) {
3475 $this->nb[
"ticket"] = $obj->nb;
3477 $this->db->free($resql);
3481 $this->error = $this->db->lasterror();
3496 $tables = array(
'ticket');
3512 $selected = (empty($arraydata[
'selected']) ? 0 : $arraydata[
'selected']);
3514 $return =
'<div class="box-flex-item box-flex-grow-zero">';
3515 $return .=
'<div class="info-box info-box-sm">';
3516 $return .=
'<span class="info-box-icon bg-infobox-action">';
3518 $return .=
'</span>';
3519 $return .=
'<div class="info-box-content">';
3520 $return .=
'<span class="info-box-ref inline-block tdoverflowmax150 valignmiddle">'.(method_exists($this,
'getNomUrl') ? $this->getNomUrl(1) : $this->ref).
'</span>';
3521 if ($selected >= 0) {
3522 $return .=
'<input id="cb'.$this->id.
'" class="flat checkforselect fright" type="checkbox" name="toselect[]" value="'.$this->
id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
3524 if (!empty($arraydata[
'user_assignment'])) {
3525 $return .=
'<br><span class="info-box-label" title="'.dol_escape_htmltag($langs->trans(
"AssignedTo")).
'">'.$arraydata[
'user_assignment'].
'</span>';
3527 if (property_exists($this,
'type_code') && !empty($this->type_code)) {
3529 $return .=
'<div class="tdoverflowmax125 inline-block">'.$langs->getLabelFromKey($this->db,
'TicketTypeShort'.$this->type_code,
'c_ticket_type',
'code',
'label', $this->type_code).
'</div>';
3531 if (method_exists($this,
'getLibStatut')) {
3532 $return .=
'<br><div class="info-box-status">'.$this->getLibStatut(3).
'</div>';
3534 $return .=
'</div>';
3535 $return .=
'</div>';
3536 $return .=
'</div>';
3552 public function generateDocument($modele, $outputlangs, $hidedetails = 0, $hidedesc = 0, $hideref = 0, $moreparams =
null)
3556 $langs->load(
"ticket");
3557 $outputlangs->load(
"ticket");
3560 $modele =
'generic_ticket_odt';
3562 if (!empty($this->model_pdf)) {
3563 $modele = $this->model_pdf;
3569 $modelpath =
"core/modules/ticket/doc/";
3571 return $this->commonGenerateDocument($modelpath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams);
$id
Support class for third parties, contacts, members, users or resources.
if(! $sortfield) if(! $sortorder) $object
Class to manage agenda events (actions)
Class to send emails (with attachments or not) Usage: $mailfile = new CMailFile($subject,...
Class to manage categories.
Parent class of all other business classes (invoices, contracts, proposals, orders,...
fetch_optionals($rowid=null, $optionsArray=null)
Function to get extra fields of an object into $this->array_options This method is in most cases call...
static commonReplaceThirdparty(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a thirdparty id with another one.
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
add_contact($fk_socpeople, $type_contact, $source='external', $notrigger=0)
Add a link between element $this->element and a contact.
Class to manage Dolibarr database access.
Class to manage ECM files.
Class to manage third parties objects (customers, suppliers, prospects...)
fetch($id=0, $ref='', $track_id='', $email_msgid='')
Load object in memory from the database.
fetchAll($user, $sortorder='ASC', $sortfield='t.datec', $limit=0, $offset=0, $arch=0, $filter='')
Load all objects in memory from database.
static replaceThirdparty($db, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
createTicketMessage($user, $notrigger=0, $filename_list=array(), $mimetype_list=array(), $mimefilename_list=array(), $send_email=false, $public_area=0, $summary='', $external_contacts=[])
Add message into database.
listeContact($statusoflink=-1, $source='external', $list=0, $code='', $status=-1)
Get array of all contacts for a ticket Override method of file commonobject.class....
loadCacheMsgsTicket()
Load the list of event on ticket into ->cache_msgs_ticket.
sendTicketMessageByEmail($subject, $message, $send_internal_cc=0, $array_receiver=array(), $filename_list=array(), $mimetype_list=array(), $mimefilename_list=array(), $array_receiver_cc=array(), $from='', $replyto='')
Send ticket by email to linked contacts.
setProgression($percent)
Define progression of current ticket.
searchSocidByEmail($email, $type=0, $filters=array(), $clause='AND')
Search and fetch thirparties by email.
loadCacheSeveritiesTickets()
Charge dans cache la liste des sévérité de tickets (paramétrable dans dictionnaire)
$fields
'type' field format ('integer', 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter]]',...
getInfosTicketExternalContact($status=-1)
Retrieve information about external contacts.
searchContactByEmail($email, $socid=0, $case='')
Search and fetch contacts by email.
getIdTicketCustomerInvolvedContact()
Return id des contacts clients des intervenants.
LibStatut($status, $mode=0, $notooltip=0, $progress=0)
Return status label of object.
setContract($contractid)
Link element with a contract.
setReadDate($user, $notrigger=0)
Set read date if not already set.
getTicketAllContacts()
Return id of all contacts for ticket.
createFromClone(User $user, $fromid)
Load an object from its id and create a new one in database.
assignUser($user, $id_assign_user, $notrigger=0)
Set an assigned user to a ticket.
loadStateBoard()
Load indicator this->nb of global stats widget.
getTooltipContentArray($params)
getTooltipContentArray
getKanbanView($option='', $arraydata=null)
Return clickable link of object (with eventually picto)
printSelectStatus($selected="")
Print selected status.
is_photo_available($sdir)
Return if at least one photo is available.
getIdTicketInternalContact()
Return id des contacts interne de suivi.
update($user, $notrigger=0)
Update object into database.
loadCacheCategoriesTickets($publicgroup=-1)
Load into a cache array, the list of ticket categories (setup done into dictionary)
setCustomer($id)
Define parent commany of current ticket.
markAsRead($user, $notrigger=0)
Mark a message as read.
getDefaultRef($thirdparty=null)
Get a default reference.
const STATUS_NOT_READ
Status.
getTicketAllCustomerContacts()
Return id of all contacts for ticket.
verify()
Check properties of ticket are ok (like ref, track_id, ...).
setCategories($categories)
Sets object to supplied categories.
initAsSpecimen()
Initialise object with example values Id must be 0 if object instance is a specimen.
newMessage($user, &$action, $private=1, $public_area=0)
Add new message on a ticket (private/public area).
getIdTicketCustomerContact()
Return id des contacts clients pour le suivi ticket.
checkExistingRef(string $action, string $getRef)
Check if ref exists or not.
__construct(DoliDB $db)
Constructor.
loadCacheTypesTickets()
Load into a cache the types of tickets (setup done into dictionaries)
getLibStatut($mode=0)
Return status label of object.
close(User $user, $mode=0)
Close a ticket.
getIdTicketInternalInvolvedContact()
Return id des contacts clients des intervenants.
copyFilesForTicket($forcetrackid=null)
Copy files defined into $_SESSION array into the ticket directory of attached files.
generateDocument($modele, $outputlangs, $hidedetails=0, $hidedesc=0, $hideref=0, $moreparams=null)
Create a document onto disk according to template module.
getNomUrl($withpicto=0, $option='', $notooltip=0, $morecss='', $save_lastsearch_value=-1)
Return a link to the object card (with optionally the picto)
load_board($user, $mode)
Load indicators for dashboard (this->nbtodo and this->nbtodolate)
getInfosTicketInternalContact($status=-1)
Retrieve information about internal contacts.
create($user, $notrigger=0)
Create object into database.
Class to manage Dolibarr users.
print $langs trans("Ref").' m titre as m m statut as status
Or an array listing all the potential status of the object: array: int of the status => translated la...
dirbasename($pathfile)
Return the relative dirname (relative to DOL_DATA_ROOT) of a full path string.
dol_move($srcfile, $destfile, $newmask='0', $overwriteifexists=1, $testvirus=0, $indexdatabase=1, $moreinfo=array(), $entity=null)
Move a file into another name.
dol_delete_dir_recursive($dir, $count=0, $nophperrors=0, $onlysub=0, &$countdeleted=0, $indexdatabase=1, $nolog=0, $level=0)
Remove a directory $dir and its subdirectories (or only files and subdirectories)
dol_is_file($pathoffile)
Return if path is a file.
dol_is_dir($folder)
Test if filename is a directory.
dol_now($mode='gmt')
Return date for now.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
setEntity($currentobject)
Set entity id to use when to create an object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_osencode($str)
Return a string encoded into OS filesystem encoding.
isDolTms($timestamp)
isDolTms check if a timestamp is valid.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
dol_nl2br($stringtoencode, $nl2brmode=0, $forxml=false)
Replace CRLF in string with a HTML BR tag.
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
if(!function_exists( 'dol_getprefix')) dol_include_once($relpath, $classname='')
Make an include_once using default root and alternate root if it fails.
dolGetFirstLastname($firstname, $lastname, $nameorder=-1)
Return firstname and lastname in correct order.
dol_textishtml($msg, $option=0)
Return if a text is a html content.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_clone($srcobject, $native=2)
Create a clone of instance of object (new instance with same value for each properties) With native =...
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
utf8_check($str)
Check if a string is in UTF8.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
getEntity($element, $shared=1, $currentobject=null)
Get list of entity id to use.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
vignette($file, $maxWidth=160, $maxHeight=120, $extName='_small', $quality=50, $outdir='thumbs', $targetformat=0)
Create a thumbnail from an image file (Supported extensions are gif, jpg, png and bmp).
image_format_supported($file, $acceptsvg=0)
Return if a filename is file name of a supported image format.
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
Class to generate the form for creating a new ticket.
generate_random_id($car=16)
Generate a random id.