summaryrefslogtreecommitdiff
path: root/addons/website/models/ir_attachment.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/website/models/ir_attachment.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/website/models/ir_attachment.py')
-rw-r--r--addons/website/models/ir_attachment.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/addons/website/models/ir_attachment.py b/addons/website/models/ir_attachment.py
new file mode 100644
index 00000000..dec1a662
--- /dev/null
+++ b/addons/website/models/ir_attachment.py
@@ -0,0 +1,36 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+import logging
+from odoo import fields, models, api
+from odoo.exceptions import UserError
+from odoo.tools.translate import _
+_logger = logging.getLogger(__name__)
+
+
+class Attachment(models.Model):
+
+ _inherit = "ir.attachment"
+
+ # related for backward compatibility with saas-6
+ website_url = fields.Char(string="Website URL", related='local_url', deprecated=True, readonly=False)
+ key = fields.Char(help='Technical field used to resolve multiple attachments in a multi-website environment.')
+ website_id = fields.Many2one('website')
+
+ @api.model
+ def create(self, vals):
+ website = self.env['website'].get_current_website(fallback=False)
+ if website and 'website_id' not in vals and 'not_force_website_id' not in self.env.context:
+ vals['website_id'] = website.id
+ return super(Attachment, self).create(vals)
+
+ @api.model
+ def get_serving_groups(self):
+ return super(Attachment, self).get_serving_groups() + ['website.group_website_designer']
+
+ @api.model
+ def get_serve_attachment(self, url, extra_domain=None, extra_fields=None, order=None):
+ website = self.env['website'].get_current_website()
+ extra_domain = (extra_domain or []) + website.website_domain()
+ order = ('website_id, %s' % order) if order else 'website_id'
+ return super(Attachment, self).get_serve_attachment(url, extra_domain, extra_fields, order)