[IMP] mail_tracking: Ignore catchall
This commit is contained in:
parent
9449f77510
commit
7e271bb5ca
@ -10,3 +10,4 @@ from . import res_partner
|
|||||||
from . import mail_thread
|
from . import mail_thread
|
||||||
from . import mail_resend_message
|
from . import mail_resend_message
|
||||||
from . import mail_alias
|
from . import mail_alias
|
||||||
|
from . import ir_config_parameter
|
||||||
|
24
mail_tracking/models/ir_config_parameter.py
Normal file
24
mail_tracking/models/ir_config_parameter.py
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
# Copyright 2020 Tecnativa - Alexandre Díaz
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
||||||
|
|
||||||
|
from odoo import api, models
|
||||||
|
|
||||||
|
|
||||||
|
class IrConfigParameter(models.Model):
|
||||||
|
_inherit = "ir.config_parameter"
|
||||||
|
|
||||||
|
@api.model_create_multi
|
||||||
|
def create(self, vals_list):
|
||||||
|
res = super().create(vals_list)
|
||||||
|
self.env["mail.alias"].clear_caches()
|
||||||
|
return res
|
||||||
|
|
||||||
|
def write(self, vals):
|
||||||
|
res = super().write(vals)
|
||||||
|
self.env["mail.alias"].clear_caches()
|
||||||
|
return res
|
||||||
|
|
||||||
|
def unlink(self):
|
||||||
|
res = super().unlink()
|
||||||
|
self.env["mail.alias"].clear_caches()
|
||||||
|
return res
|
@ -10,10 +10,17 @@ class MailAlias(models.Model):
|
|||||||
@api.model
|
@api.model
|
||||||
@tools.ormcache()
|
@tools.ormcache()
|
||||||
def get_aliases(self):
|
def get_aliases(self):
|
||||||
return {
|
aliases = {
|
||||||
x["display_name"]
|
x["display_name"]
|
||||||
for x in self.search_read([("alias_name", "!=", False)], ["display_name"])
|
for x in self.search_read([("alias_name", "!=", False)], ["display_name"])
|
||||||
}
|
}
|
||||||
|
IrConfigParamObj = self.env["ir.config_parameter"].sudo()
|
||||||
|
catchall = "{}@{}".format(
|
||||||
|
IrConfigParamObj.get_param("mail.catchall.alias"),
|
||||||
|
IrConfigParamObj.get_param("mail.catchall.domain"),
|
||||||
|
)
|
||||||
|
aliases.add(catchall)
|
||||||
|
return aliases
|
||||||
|
|
||||||
@api.model_create_multi
|
@api.model_create_multi
|
||||||
def create(self, vals_list):
|
def create(self, vals_list):
|
||||||
|
@ -211,7 +211,7 @@ class TestMailTracking(TransactionCase):
|
|||||||
|
|
||||||
def _check_partner_trackings_to(self, message):
|
def _check_partner_trackings_to(self, message):
|
||||||
message_dict = message.message_format()[0]
|
message_dict = message.message_format()[0]
|
||||||
self.assertEqual(len(message_dict["partner_trackings"]), 3)
|
self.assertEqual(len(message_dict["partner_trackings"]), 4)
|
||||||
# mail cc
|
# mail cc
|
||||||
foundPartner = False
|
foundPartner = False
|
||||||
foundNoPartner = False
|
foundNoPartner = False
|
||||||
@ -253,16 +253,19 @@ class TestMailTracking(TransactionCase):
|
|||||||
"res_id": self.recipient.id,
|
"res_id": self.recipient.id,
|
||||||
"partner_ids": [(4, self.recipient.id)],
|
"partner_ids": [(4, self.recipient.id)],
|
||||||
"email_to": "Dominique Pinon <support+unnamed@test.com>"
|
"email_to": "Dominique Pinon <support+unnamed@test.com>"
|
||||||
", sender@example.com, recipient@example.com",
|
", sender@example.com, recipient@example.com"
|
||||||
|
", TheCatchall@test.com",
|
||||||
"body": "<p>This is another test message</p>",
|
"body": "<p>This is another test message</p>",
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
message._moderate_accept()
|
message._moderate_accept()
|
||||||
recipients = self.recipient._message_get_suggested_recipients()
|
recipients = self.recipient._message_get_suggested_recipients()
|
||||||
self.assertEqual(len(recipients[self.recipient.id]), 3)
|
self.assertEqual(len(recipients[self.recipient.id]), 4)
|
||||||
self._check_partner_trackings_to(message)
|
self._check_partner_trackings_to(message)
|
||||||
# Catchall + Alias
|
# Catchall + Alias
|
||||||
self.env["ir.config_parameter"].set_param("mail.catchall.domain", "test.com")
|
IrConfigParamObj = self.env["ir.config_parameter"].sudo()
|
||||||
|
IrConfigParamObj.set_param("mail.catchall.alias", "TheCatchall")
|
||||||
|
IrConfigParamObj.set_param("mail.catchall.domain", "test.com")
|
||||||
self.env["mail.alias"].create(
|
self.env["mail.alias"].create(
|
||||||
{
|
{
|
||||||
"alias_model_id": self.env["ir.model"]._get("res.partner").id,
|
"alias_model_id": self.env["ir.model"]._get("res.partner").id,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user