From 84e7dbb41620e2bf235e5f26806c37beaf9a5548 Mon Sep 17 00:00:00 2001 From: Rom1-B Date: Fri, 15 Nov 2024 11:58:09 +0100 Subject: [PATCH] feat(mail collector): add 'TO' as observer --- .../mailcollectors.php | 1 + install/mysql/glpi-empty.sql | 1 + src/MailCollector.php | 2 +- .../setup/mailcollector/setup_form.html.twig | 1 + tests/emails-tests/44-multiple-to.eml | 32 +++++++++++++++++++ tests/imap/MailCollector.php | 12 +++++-- 6 files changed, 46 insertions(+), 3 deletions(-) create mode 100644 tests/emails-tests/44-multiple-to.eml diff --git a/install/migrations/update_10.0.x_to_11.0.0/mailcollectors.php b/install/migrations/update_10.0.x_to_11.0.0/mailcollectors.php index 26fb740288d..58594a2803a 100644 --- a/install/migrations/update_10.0.x_to_11.0.0/mailcollectors.php +++ b/install/migrations/update_10.0.x_to_11.0.0/mailcollectors.php @@ -38,3 +38,4 @@ */ $migration->addField('glpi_mailcollectors', 'create_user_from_email', 'bool', ['value' => 0]); +$migration->addField('glpi_mailcollectors', 'add_to_to_observer', 'bool', ['value' => 1]); diff --git a/install/mysql/glpi-empty.sql b/install/mysql/glpi-empty.sql index c5d725943f6..aa7771eb10f 100644 --- a/install/mysql/glpi-empty.sql +++ b/install/mysql/glpi-empty.sql @@ -4265,6 +4265,7 @@ CREATE TABLE `glpi_mailcollectors` ( `use_mail_date` tinyint NOT NULL DEFAULT '0', `date_creation` timestamp NULL DEFAULT NULL, `requester_field` int NOT NULL DEFAULT '0', + `add_to_to_observer` tinyint NOT NULL DEFAULT '1', `add_cc_to_observer` tinyint NOT NULL DEFAULT '0', `collect_only_unread` tinyint NOT NULL DEFAULT '0', `create_user_from_email` tinyint NOT NULL DEFAULT '0', diff --git a/src/MailCollector.php b/src/MailCollector.php index 3a6e0b31f54..234af344372 100644 --- a/src/MailCollector.php +++ b/src/MailCollector.php @@ -927,7 +927,7 @@ public function buildTicket($uid, \Laminas\Mail\Storage\Message $message, $optio } $tos = $headers['tos']; - if (is_array($tos) && count($tos)) { + if (is_array($tos) && count($tos) && $this->getField("add_to_to_observer")) { foreach ($tos as $to) { if ( $to != $requester diff --git a/templates/pages/setup/mailcollector/setup_form.html.twig b/templates/pages/setup/mailcollector/setup_form.html.twig index 495ee10b06f..6839f78e067 100644 --- a/templates/pages/setup/mailcollector/setup_form.html.twig +++ b/templates/pages/setup/mailcollector/setup_form.html.twig @@ -95,6 +95,7 @@ (constant('MailCollector::REQUESTER_FIELD_FROM')): __('No'), (constant('MailCollector::REQUESTER_FIELD_REPLY_TO')): __('Yes'), }, __('Use Reply-To as requester (when available)')) }} + {{ fields.dropdownYesNo('add_to_to_observer', item.fields['add_to_to_observer'], __('Add TO users as observer')) }} {{ fields.dropdownYesNo('add_cc_to_observer', item.fields['add_cc_to_observer'], __('Add CC users as observer')) }} {{ fields.dropdownYesNo('collect_only_unread', item.fields['collect_only_unread'], __('Collect only unread mail')) }} {% set create_user_helper %} diff --git a/tests/emails-tests/44-multiple-to.eml b/tests/emails-tests/44-multiple-to.eml new file mode 100644 index 00000000000..ce053f2227f --- /dev/null +++ b/tests/emails-tests/44-multiple-to.eml @@ -0,0 +1,32 @@ +Return-Path: tech@glpi-project.org +Received: from 192.168.1.3 (LHLO mail.glpi-project.org) (192.168.1.3) + by mail.glpi-project.org with LMTP; Tue, 2 Apr 2019 14:43:12 +0200 + (CEST) +Received: from mail.glpi-project.org (localhost [127.0.0.1]) + by mail.glpi-project.org (Postfix) with ESMTP id 6F3457E80D1E + for ; Tue, 2 Apr 2019 14:43:12 +0200 (CEST) +Received: from localhost (localhost [127.0.0.1]) + by mail.glpi-project.org (Postfix) with ESMTP id 645C77E80D1C + for ; Tue, 2 Apr 2019 14:43:12 +0200 (CEST) +Received: from mail.glpi-project.org ([127.0.0.1]) + by localhost (mail.glpi-project.org [127.0.0.1]) (amavisd-new, port 10026) + with ESMTP id POJTfrC8TVrL for ; + Tue, 2 Apr 2019 14:43:12 +0200 (CEST) +Received: from mail.glpi-project.org (localhost [127.0.0.1]) + by mail.glpi-project.org (Postfix) with ESMTP id 55AF37E80C20 + for ; Tue, 2 Apr 2019 14:43:12 +0200 (CEST) +Date: Tue, 2 Apr 2019 14:43:12 +0200 (CEST) +From: Tech Ni Cian +To: GLPI debug , Normal User +Message-ID: <2078889367.1658939.1554208992329.JavaMail.zimbra@glpi-project.org> +Subject: Ticket with multiple to +MIME-Version: 1.0 +Content-Type: text/plain; charset=utf-8 +Content-Transfer-Encoding: 7bit +X-Mailer: Zimbra 8.0.9_GA_6191 (ZimbraWebClient - FF66 (Linux)/8.0.9_GA_6191) +Thread-Topic: Ticket with multiple to +Thread-Index: OOKl6v3Lu6HeDTdJe0OrUl01ERm/dw== + +This ticket have multiple to + +Best regards, diff --git a/tests/imap/MailCollector.php b/tests/imap/MailCollector.php index 9d69eb417ec..b207549a710 100644 --- a/tests/imap/MailCollector.php +++ b/tests/imap/MailCollector.php @@ -76,6 +76,7 @@ public function testGetEmpty() 'use_mail_date' => '', 'date_creation' => '', 'requester_field' => '', + 'add_to_to_observer' => '', 'add_cc_to_observer' => '', 'collect_only_unread' => '', 'create_user_from_email' => '', @@ -597,6 +598,7 @@ private function doConnect() 'server_port' => 143, 'server_ssl' => '', 'server_cert' => '/novalidate-cert', + 'add_to_to_observer' => 1, 'add_cc_to_observer' => 1, 'collect_only_unread' => 1, 'requester_field' => \MailCollector::REQUESTER_FIELD_REPLY_TO, @@ -738,6 +740,7 @@ function () use (&$msg) { 'Ticket with observer', 'Re: [GLPI #0038927] Update - Issues with new Windows 10 machine', 'A message without to header', + 'Ticket with multiple to', ] ], // Mails having "normal" user as requester @@ -781,12 +784,13 @@ function () use (&$msg) { '43 - Korean encoding issue', ] ], - // Mails having "normal" user as observer (add_cc_to_observer = true) + // Mails having "normal" user as observer [ 'users_id' => $nuid, 'actor_type' => \CommonITILActor::OBSERVER, 'tickets_names' => [ - 'Ticket with observer', + 'Ticket with observer', // add_cc_to_observer = true + 'Ticket with multiple to', // add_to_to_observer = true ] ], ]; @@ -937,6 +941,8 @@ function () use (&$msg) { $names[] = $name; } + sort($names); + sort($actor_specs['tickets_names']); $this->array($names)->isIdenticalTo($actor_specs['tickets_names']); } @@ -984,6 +990,8 @@ function () use (&$msg) { foreach ($iterator as $data) { $filenames[$data['filename']] = $data['mime']; } + ksort($filenames); + ksort($expected_docs); $this->array($filenames)->isIdenticalTo($expected_docs); $this->integer(count($iterator))->isIdenticalTo(count($expected_docs));