module_uninstall_check/wizards/wizard_module_uninstall_line.py
# -*- coding: utf-8 -*-
# Copyright (C) 2017 - Today: GRAP (http://www.grap.coop)
# @author: Sylvain LE GAL (https://twitter.com/legalsylvain)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
import logging
from openerp import api, fields, models
_logger = logging.getLogger(__name__)
class WizardModuleUninstallLine(models.TransientModel):
_name = 'wizard.module.uninstall.line'
LINE_TYPE_SELECTION = [
('model', 'Model'),
('field', 'Field'),
]
DB_TYPE_SELECTION = [
('', 'Unknown Type'),
('r', 'Ordinary Table'),
('i', 'Index'),
('S', 'Sequence'),
('v', 'view'),
('c', 'Composite Type'),
('t', 'TOAST table'),
]
wizard_id = fields.Many2one(
comodel_name='wizard.module.uninstall', required=True)
line_type = fields.Selection(
selection=LINE_TYPE_SELECTION, required=True)
model_id = fields.Many2one(comodel_name='ir.model', readonly=True)
model_name = fields.Char(
string='Model Name', related='model_id.model', readonly=True)
table_size = fields.Integer(
string='Table Size (KB)', compute='_compute_database',
multi='database', store=True)
index_size = fields.Integer(
string='Indexes Size (KB)', compute='_compute_database',
multi='database', store=True)
db_type = fields.Selection(
selection=DB_TYPE_SELECTION, compute='_compute_database',
multi='database', store=True)
db_size = fields.Integer(
string='Total DB Size (KB)', compute='_compute_database',
multi='database', store=True)
model_row_qty = fields.Integer(
string='Rows Quantity', compute='_compute_database', multi='database',
store=True,
help="The approximate value of the number of records in the database,"
" based on the PostgreSQL column 'reltuples'.\n You should reindex"
" your database, to have a more precise value\n\n"
" 'REINDEX database your_database_name;'")
field_id = fields.Many2one(comodel_name='ir.model.fields', readonly=True)
field_name = fields.Char(
string='Field Name', related='field_id.name', readonly=True)
field_ttype = fields.Selection(
string='Field Type', related='field_id.ttype', readonly=True)
field_model_name = fields.Char(
string='Field Model Name', related='field_id.model_id.model',
readonly=True)
@api.multi
@api.depends('model_id', 'line_type')
def _compute_database(self):
table_names = []
for line in self.filtered(lambda x: x.model_id):
model_obj = self.env.registry.get(line.model_id.model, False)
if model_obj:
table_names.append(model_obj._table)
else:
# Try to guess table name, replacing "." by "_"
table_names.append(line.model_id.model.replace('.', '_'))
# Get Relation Informations
req = (
"SELECT"
" table_name,"
" row_qty,"
" db_type,"
" pg_table_size(table_name::regclass::oid) AS table_size,"
" pg_indexes_size(table_name::regclass::oid) AS index_size,"
" pg_total_relation_size(table_name::regclass::oid) AS db_size"
" FROM ("
" SELECT"
" relname AS table_name,"
" reltuples AS row_qty,"
" relkind as db_type"
" FROM pg_class"
" WHERE relname IN %s) AS tmp;"
)
self.env.cr.execute(req, (tuple(table_names),))
res = self.env.cr.fetchall()
table_res = {x[0]: (x[1], x[2], x[3], x[4], x[5]) for x in res}
for line in self:
model_obj = self.env.registry.get(line.model_id.model, False)
if model_obj:
table_name = model_obj._table
else:
# Try to guess table name, replacing "." by "_"
table_name = line.model_id.model.replace('.', '_')
res = table_res.get(table_name, (0, '', 0, 0, 0))
line.model_row_qty = res[0]
line.db_type = res[1]
line.table_size = res[2] / 1024
line.index_size = res[3] / 1024
line.db_size = res[4] / 1024