Big update of base_partner_one2many_phone: new types, add email support
Migration script provided
This commit is contained in:
@@ -21,26 +21,33 @@ def create_partner_phone(cr, phone_field, phone_type):
|
||||
return to_create
|
||||
|
||||
|
||||
def create_partner_email(cr):
|
||||
cr.execute('SELECT id, email FROM res_partner WHERE email IS NOT null')
|
||||
to_create = []
|
||||
for partner in cr.fetchall():
|
||||
to_create.append({
|
||||
'partner_id': partner[0],
|
||||
'type': '1_email_primary',
|
||||
'email': partner[1],
|
||||
})
|
||||
return to_create
|
||||
|
||||
|
||||
def migrate_to_partner_phone(cr, registry):
|
||||
"""This post_install script is required because, when the module
|
||||
is installed, Odoo creates the column in the DB and compute the field
|
||||
and THEN it loads the file data/res_country_department_data.yml...
|
||||
So, when it computes the field on module installation, the
|
||||
departments are not available in the DB, so the department_id field
|
||||
on res.partner stays null. This post_install script fixes this."""
|
||||
logger.info('start data migration for one2many_phone')
|
||||
with api.Environment.manage():
|
||||
env = api.Environment(cr, SUPERUSER_ID, {})
|
||||
rppo = env['res.partner.phone']
|
||||
to_create = []
|
||||
to_create += create_partner_phone(cr, 'phone', '1_home')
|
||||
to_create += create_partner_phone(cr, 'mobile', '2_mobile')
|
||||
to_create += create_partner_phone(cr, 'fax', '5_office_fax')
|
||||
to_create += create_partner_phone(cr, 'phone', '3_phone_primary')
|
||||
to_create += create_partner_phone(cr, 'mobile', '5_mobile_primary')
|
||||
to_create += create_partner_phone(cr, 'fax', '7_fax_primary')
|
||||
to_create += create_partner_email(cr)
|
||||
# I need to create all at the end for invalidation purposes
|
||||
for vals in to_create:
|
||||
rppo.create(vals)
|
||||
logger.info(
|
||||
'partner_phone type %s phone %s created for partner ID %d',
|
||||
vals['type'], vals['phone'], vals['partner_id'])
|
||||
'partner_phone type %s phone %s email %s created for partner ID %d',
|
||||
vals['type'], vals.get('phone'), vals.get('mail'), vals['partner_id'])
|
||||
logger.info('end data migration for one2many_phone')
|
||||
return
|
||||
|
||||
Reference in New Issue
Block a user