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/ir_attachment.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/mail/models/ir_attachment.py')
| -rw-r--r-- | addons/mail/models/ir_attachment.py | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/addons/mail/models/ir_attachment.py b/addons/mail/models/ir_attachment.py new file mode 100644 index 00000000..d1279c26 --- /dev/null +++ b/addons/mail/models/ir_attachment.py @@ -0,0 +1,36 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import api, models +from odoo.exceptions import AccessError + +class IrAttachment(models.Model): + _inherit = 'ir.attachment' + + def _post_add_create(self): + """ Overrides behaviour when the attachment is created through the controller + """ + super(IrAttachment, self)._post_add_create() + for record in self: + record.register_as_main_attachment(force=False) + + def register_as_main_attachment(self, force=True): + """ Registers this attachment as the main one of the model it is + attached to. + """ + self.ensure_one() + if not self.res_model: + return + related_record = self.env[self.res_model].browse(self.res_id) + if not related_record.check_access_rights('write', raise_exception=False): + return + # message_main_attachment_id field can be empty, that's why we compare to False; + # we are just checking that it exists on the model before writing it + if related_record and hasattr(related_record, 'message_main_attachment_id'): + if force or not related_record.message_main_attachment_id: + #Ignore AccessError, if you don't have access to modify the document + #Just don't set the value + try: + related_record.message_main_attachment_id = self + except AccessError: + pass |
