diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/mail/models/res_config_settings.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/mail/models/res_config_settings.py')
| -rw-r--r-- | addons/mail/models/res_config_settings.py | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/addons/mail/models/res_config_settings.py b/addons/mail/models/res_config_settings.py new file mode 100644 index 00000000..6cae4f3b --- /dev/null +++ b/addons/mail/models/res_config_settings.py @@ -0,0 +1,36 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +import datetime + +from werkzeug import urls + +from odoo import api, fields, models, tools + + +class ResConfigSettings(models.TransientModel): + """ Inherit the base settings to add a counter of failed email + configure + the alias domain. """ + _inherit = 'res.config.settings' + + fail_counter = fields.Integer('Fail Mail', readonly=True) + alias_domain = fields.Char('Alias Domain', help="If you have setup a catch-all email domain redirected to " + "the Odoo server, enter the domain name here.", config_parameter='mail.catchall.domain') + + @api.model + def get_values(self): + res = super(ResConfigSettings, self).get_values() + + previous_date = datetime.datetime.now() - datetime.timedelta(days=30) + + res.update( + fail_counter=self.env['mail.mail'].sudo().search_count([ + ('date', '>=', previous_date.strftime(tools.DEFAULT_SERVER_DATETIME_FORMAT)), + ('state', '=', 'exception')]), + ) + + return res + + def set_values(self): + super(ResConfigSettings, self).set_values() + self.env['ir.config_parameter'].set_param("mail.catchall.domain", self.alias_domain or '') |
