Browse Source

[FIX] mass_mailing_partner: compute fields performance (#271)

- In DB which use large amounts of records and intesive use of
mass_mailings, not optimized compute records lead to a drastical
decrease of performance
pull/238/merge
David Vidal 6 years ago
committed by Pedro M. Baeza
parent
commit
3a75bbde4a
  1. 2
      mass_mailing_partner/__openerp__.py
  2. 21
      mass_mailing_partner/models/res_partner.py

2
mass_mailing_partner/__openerp__.py

@ -7,7 +7,7 @@
{
"name": "Link partners with mass-mailing",
"version": "9.0.1.0.0",
"version": "9.0.1.0.1",
"author": "Antiun Ingeniería S.L., "
"Tecnativa, "
"Odoo Community Association (OCA)",

21
mass_mailing_partner/models/res_partner.py

@ -35,16 +35,29 @@ class ResPartner(models.Model):
_("This partner '%s' is subscribed to one or more "
"mailing lists. Email must be assigned." % self.name))
@api.one
@api.multi
@api.depends('mass_mailing_contact_ids',
'mass_mailing_contact_ids.opt_out')
def _compute_mass_mailing_contacts_count(self):
self.mass_mailing_contacts_count = len(self.mass_mailing_contact_ids)
contact_data = self.env['mail.mass_mailing.contact'].read_group(
[('partner_id', 'in', self.ids)], ['partner_id'], ['partner_id'])
mapped_data = dict(
[(contact['partner_id'][0], contact['partner_id_count'])
for contact in contact_data])
for partner in self:
partner.mass_mailing_contacts_count = mapped_data.get(partner.id,
0)
@api.one
@api.multi
@api.depends('mass_mailing_stats')
def _compute_mass_mailing_stats_count(self):
self.mass_mailing_stats_count = len(self.mass_mailing_stats)
contact_data = self.env['mail.mail.statistics'].read_group(
[('partner_id', 'in', self.ids)], ['partner_id'], ['partner_id'])
mapped_data = dict(
[(contact['partner_id'][0], contact['partner_id_count'])
for contact in contact_data])
for partner in self:
partner.mass_mailing_stats_count = mapped_data.get(partner.id, 0)
@api.multi
def write(self, vals):

Loading…
Cancel
Save