2018-01-16 11:28:15 +05:30
|
|
|
# -*- coding: utf-8 -*-
|
2018-01-16 02:34:37 -08:00
|
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details
|
2018-01-16 11:28:15 +05:30
|
|
|
|
2017-12-22 17:38:41 +05:30
|
|
|
import logging
|
|
|
|
from flectra import api, fields, models, _
|
|
|
|
|
|
|
|
_logger = logging.getLogger(__name__)
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
|
|
|
|
# This is a nasty hack, targeted for V11 only
|
|
|
|
class IrModel(models.Model):
|
|
|
|
_inherit = 'ir.model'
|
|
|
|
|
|
|
|
@api.multi
|
|
|
|
def unlink(self):
|
|
|
|
self.env.cr.execute(
|
|
|
|
"DELETE FROM ir_model_fields WHERE name='website_id'")
|
|
|
|
return super(IrModel, self).unlink()
|
2017-12-22 17:38:41 +05:30
|
|
|
|
|
|
|
|
|
|
|
class IrModelData(models.Model):
|
|
|
|
_inherit = 'ir.model.data'
|
|
|
|
|
|
|
|
# Overriding Method
|
|
|
|
@api.model
|
|
|
|
def _update(self, model, module, values, xml_id=False, store=True,
|
|
|
|
noupdate=False, mode='init', res_id=False):
|
|
|
|
# records created during module install should not display the messages of OpenChatter
|
|
|
|
self = self.with_context(install_mode=True)
|
|
|
|
current_module = module
|
|
|
|
|
|
|
|
if xml_id and ('.' in xml_id):
|
|
|
|
assert len(xml_id.split('.')) == 2, _(
|
|
|
|
"'%s' contains too many dots. XML ids should not contain dots ! These are used to refer to other modules data, as in module.reference_id") % xml_id
|
|
|
|
module, xml_id = xml_id.split('.')
|
|
|
|
|
|
|
|
action = self.browse()
|
|
|
|
record = self.env[model].browse(res_id)
|
|
|
|
|
|
|
|
if xml_id:
|
|
|
|
self._cr.execute("""SELECT imd.id, imd.res_id, md.id, imd.model, imd.noupdate
|
|
|
|
FROM ir_model_data imd LEFT JOIN %s md ON (imd.res_id = md.id)
|
|
|
|
WHERE imd.module=%%s AND imd.name=%%s""" % record._table,
|
|
|
|
(module, xml_id))
|
|
|
|
results = self._cr.fetchall()
|
|
|
|
for imd_id, imd_res_id, real_id, imd_model, imd_noupdate in results:
|
|
|
|
# In update mode, do not update a record if it's ir.model.data is flagged as noupdate
|
|
|
|
if mode == 'update' and imd_noupdate:
|
|
|
|
return imd_res_id
|
|
|
|
if not real_id:
|
|
|
|
self.clear_caches()
|
|
|
|
self._cr.execute('DELETE FROM ir_model_data WHERE id=%s',
|
|
|
|
(imd_id,))
|
|
|
|
record = record.browse()
|
|
|
|
else:
|
|
|
|
assert model == imd_model, "External ID conflict, %s already refers to a `%s` record," \
|
|
|
|
" you can't define a `%s` record with this ID." % (
|
|
|
|
xml_id, imd_model, model)
|
|
|
|
action = self.browse(imd_id)
|
|
|
|
record = record.browse(imd_res_id)
|
|
|
|
|
|
|
|
if action and record:
|
|
|
|
# Set ``is_cloned`` to ``False``
|
|
|
|
if values.get('type') == 'qweb' and not values.get('is_cloned'):
|
|
|
|
values.update({'is_cloned': False})
|
|
|
|
|
|
|
|
record.write(values)
|
|
|
|
action.sudo().write({'date_update': fields.Datetime.now()})
|
|
|
|
|
|
|
|
elif record:
|
|
|
|
record.write(values)
|
|
|
|
if xml_id:
|
|
|
|
for parent_model, parent_field in record._inherits.items():
|
|
|
|
self.sudo().create({
|
|
|
|
'name': xml_id + '_' + parent_model.replace('.', '_'),
|
|
|
|
'model': parent_model,
|
|
|
|
'module': module,
|
|
|
|
'res_id': record[parent_field].id,
|
|
|
|
'noupdate': noupdate,
|
|
|
|
})
|
|
|
|
self.sudo().create({
|
|
|
|
'name': xml_id,
|
|
|
|
'model': model,
|
|
|
|
'module': module,
|
|
|
|
'res_id': record.id,
|
|
|
|
'noupdate': noupdate,
|
|
|
|
})
|
|
|
|
|
|
|
|
elif mode == 'init' or (mode == 'update' and xml_id):
|
|
|
|
existing_parents = set() # {parent_model, ...}
|
|
|
|
if xml_id:
|
|
|
|
for parent_model, parent_field in record._inherits.items():
|
|
|
|
xid = self.sudo().search([
|
|
|
|
('module', '=', module),
|
|
|
|
('name', '=',
|
|
|
|
xml_id + '_' + parent_model.replace('.', '_')),
|
|
|
|
])
|
|
|
|
# XML ID found in the database, try to recover an existing record
|
|
|
|
if xid:
|
|
|
|
parent = self.env[xid.model].browse(xid.res_id)
|
|
|
|
if parent.exists():
|
|
|
|
existing_parents.add(xid.model)
|
|
|
|
values[parent_field] = parent.id
|
|
|
|
else:
|
|
|
|
xid.unlink()
|
|
|
|
|
|
|
|
record = record.create(values)
|
|
|
|
if xml_id:
|
|
|
|
# To add an external identifiers to all inherits model
|
|
|
|
inherit_models = [record]
|
|
|
|
while inherit_models:
|
|
|
|
current_model = inherit_models.pop()
|
|
|
|
for parent_model_name, parent_field in current_model._inherits.items():
|
|
|
|
inherit_models.append(self.env[parent_model_name])
|
|
|
|
if parent_model_name in existing_parents:
|
|
|
|
continue
|
|
|
|
self.sudo().create({
|
|
|
|
'name': xml_id + '_' + parent_model_name.replace(
|
|
|
|
'.', '_'),
|
|
|
|
'model': parent_model_name,
|
|
|
|
'module': module,
|
|
|
|
'res_id': record[parent_field].id,
|
|
|
|
'noupdate': noupdate,
|
|
|
|
})
|
|
|
|
existing_parents.add(parent_model_name)
|
|
|
|
self.sudo().create({
|
|
|
|
'name': xml_id,
|
|
|
|
'model': model,
|
|
|
|
'module': module,
|
|
|
|
'res_id': record.id,
|
|
|
|
'noupdate': noupdate
|
|
|
|
})
|
|
|
|
if current_module and module != current_module:
|
|
|
|
_logger.warning(
|
|
|
|
"Creating the ir.model.data %s in module %s instead of %s.",
|
|
|
|
xml_id, module, current_module)
|
|
|
|
|
|
|
|
if xml_id and record:
|
|
|
|
self.loads[(module, xml_id)] = (model, record.id)
|
|
|
|
for parent_model, parent_field in record._inherits.items():
|
|
|
|
parent_xml_id = xml_id + '_' + parent_model.replace('.', '_')
|
|
|
|
self.loads[(module, parent_xml_id)] = (
|
|
|
|
parent_model, record[parent_field].id)
|
|
|
|
|
|
|
|
return record.id
|
|
|
|
|
|
|
|
@api.model
|
|
|
|
def _process_end(self, modules):
|
|
|
|
super(IrModelData, self)._process_end(modules)
|
|
|
|
ir_ui_view = self.env['ir.ui.view']
|
|
|
|
ir_model_data = self.env['ir.model.data']
|
|
|
|
|
|
|
|
default_website = self.env['website'].search([
|
|
|
|
('is_default_website', '=', True)])
|
|
|
|
for cus_view in ir_ui_view.search([('customize_show', '=', True),
|
|
|
|
('website_id', '=', False),
|
|
|
|
'|', ('active', '=', False),
|
|
|
|
('active', '=', True)]):
|
|
|
|
if default_website:
|
|
|
|
cus_view.write({'website_id': default_website.id})
|
|
|
|
|
|
|
|
for website in self.env['website'].search(
|
|
|
|
[('is_default_website', '=', False)]):
|
|
|
|
for view in ir_ui_view.search(
|
|
|
|
[('website_id', '=', default_website.id),
|
|
|
|
('customize_show', '=', True), ('is_cloned', '=', False),
|
|
|
|
'|', ('active', '=', False), ('active', '=', True)]):
|
|
|
|
if not ir_ui_view.search(
|
|
|
|
[('key', '=', view.key +
|
|
|
|
'_' + website.website_code),
|
|
|
|
'|', ('active', '=', False), ('active', '=', True)]):
|
|
|
|
new_cus_view = view.copy({
|
|
|
|
'is_cloned': True,
|
|
|
|
'key': view.key + '_' + website.website_code,
|
|
|
|
'website_id': website.id
|
|
|
|
})
|
2018-01-12 14:43:13 +05:30
|
|
|
new_inherit_id = ir_ui_view.search(
|
|
|
|
[('key', '=', new_cus_view.inherit_id.key +
|
|
|
|
'_' + website.website_code),
|
|
|
|
'|', ('active', '=', False), ('active', '=', True)])
|
|
|
|
if new_cus_view.inherit_id and new_inherit_id:
|
|
|
|
new_cus_view.write({
|
|
|
|
'inherit_id': new_inherit_id.id,
|
|
|
|
})
|
2017-12-22 17:38:41 +05:30
|
|
|
model_data_id = ir_model_data.create({
|
|
|
|
'model': view.model_data_id.model,
|
|
|
|
'name': view.model_data_id.name +
|
|
|
|
'_' + website.website_code,
|
|
|
|
'res_id': new_cus_view.id,
|
|
|
|
'module': view.model_data_id.module,
|
|
|
|
})
|
|
|
|
new_cus_view.write({
|
|
|
|
'model_data_id': model_data_id
|
|
|
|
})
|