summaryrefslogtreecommitdiff
path: root/addons/mass_mailing/models/mail_mail.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/mass_mailing/models/mail_mail.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/mass_mailing/models/mail_mail.py')
-rw-r--r--addons/mass_mailing/models/mail_mail.py88
1 files changed, 88 insertions, 0 deletions
diff --git a/addons/mass_mailing/models/mail_mail.py b/addons/mass_mailing/models/mail_mail.py
new file mode 100644
index 00000000..4339dfdf
--- /dev/null
+++ b/addons/mass_mailing/models/mail_mail.py
@@ -0,0 +1,88 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+import re
+import werkzeug.urls
+
+from odoo import api, fields, models, tools
+
+
+class MailMail(models.Model):
+ """Add the mass mailing campaign data to mail"""
+ _inherit = ['mail.mail']
+
+ mailing_id = fields.Many2one('mailing.mailing', string='Mass Mailing')
+ mailing_trace_ids = fields.One2many('mailing.trace', 'mail_mail_id', string='Statistics')
+
+ @api.model_create_multi
+ def create(self, values_list):
+ """ Override mail_mail creation to create an entry in mail.mail.statistics """
+ # TDE note: should be after 'all values computed', to have values (FIXME after merging other branch holding create refactoring)
+ mails = super(MailMail, self).create(values_list)
+ for mail, values in zip(mails, values_list):
+ if values.get('mailing_trace_ids'):
+ mail.mailing_trace_ids.write({'message_id': mail.message_id})
+ return mails
+
+ def _get_tracking_url(self):
+ base_url = self.env['ir.config_parameter'].sudo().get_param('web.base.url')
+ token = tools.hmac(self.env(su=True), 'mass_mailing-mail_mail-open', self.id)
+ return werkzeug.urls.url_join(base_url, 'mail/track/%s/%s/blank.gif' % (self.id, token))
+
+ def _send_prepare_body(self):
+ """ Override to add the tracking URL to the body and to add
+ trace ID in shortened urls """
+ # TDE: temporary addition (mail was parameter) due to semi-new-API
+ self.ensure_one()
+ body = super(MailMail, self)._send_prepare_body()
+
+ if self.mailing_id and body and self.mailing_trace_ids:
+ for match in re.findall(tools.URL_REGEX, self.body_html):
+ href = match[0]
+ url = match[1]
+
+ parsed = werkzeug.urls.url_parse(url, scheme='http')
+
+ if parsed.scheme.startswith('http') and parsed.path.startswith('/r/'):
+ new_href = href.replace(url, url + '/m/' + str(self.mailing_trace_ids[0].id))
+ body = body.replace(href, new_href)
+
+ # generate tracking URL
+ tracking_url = self._get_tracking_url()
+ body = tools.append_content_to_html(
+ body,
+ '<img src="%s"/>' % tracking_url,
+ plaintext=False,
+ )
+
+ body = self.env['mail.render.mixin']._replace_local_links(body)
+
+ return body
+
+ def _send_prepare_values(self, partner=None):
+ # TDE: temporary addition (mail was parameter) due to semi-new-API
+ res = super(MailMail, self)._send_prepare_values(partner)
+ base_url = self.env['ir.config_parameter'].sudo().get_param('web.base.url').rstrip('/')
+ if self.mailing_id and res.get('body') and res.get('email_to'):
+ emails = tools.email_split(res.get('email_to')[0])
+ email_to = emails and emails[0] or False
+
+ urls_to_replace = [
+ (base_url + '/unsubscribe_from_list', self.mailing_id._get_unsubscribe_url(email_to, self.res_id)),
+ (base_url + '/view', self.mailing_id._get_view_url(email_to, self.res_id))
+ ]
+
+ for url_to_replace, new_url in urls_to_replace:
+ if url_to_replace in res['body']:
+ res['body'] = res['body'].replace(url_to_replace, new_url if new_url else '#')
+ return res
+
+ def _postprocess_sent_message(self, success_pids, failure_reason=False, failure_type=None):
+ mail_sent = not failure_type # we consider that a recipient error is a failure with mass mailling and show them as failed
+ for mail in self:
+ if mail.mailing_id:
+ if mail_sent is True and mail.mailing_trace_ids:
+ mail.mailing_trace_ids.write({'sent': fields.Datetime.now(), 'exception': False})
+ elif mail_sent is False and mail.mailing_trace_ids:
+ mail.mailing_trace_ids.write({'exception': fields.Datetime.now(), 'failure_type': failure_type})
+ return super(MailMail, self)._postprocess_sent_message(success_pids, failure_reason=failure_reason, failure_type=failure_type)