# -*- coding: utf-8 -*- # © 2016 Antonio Espinosa - <antonio.espinosa@tecnativa.com> # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). import logging from psycopg2.extensions import AsIs _logger = logging.getLogger(__name__) def column_exists(cr, table, column): cr.execute(""" SELECT column_name FROM information_schema.columns WHERE table_name = %s AND column_name = %s""", (table, column)) return bool(cr.fetchall()) def column_add_with_value(cr, table, column, field_type, value): if not column_exists(cr, table, column): cr.execute(""" ALTER TABLE %s ADD COLUMN %s %s""", (AsIs(table), AsIs(column), AsIs(field_type))) cr.execute(""" UPDATE %s SET %s = %s""", (AsIs(table), AsIs(column), value)) def pre_init_hook(cr): _logger.info("Creating res.partner.tracking_emails_count column " "with value 0") column_add_with_value( cr, "res_partner", "tracking_emails_count", "integer", 0) _logger.info("Creating res.partner.email_score column " "with value 50.0") column_add_with_value( cr, "res_partner", "email_score", "double precision", 50.0)