You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

174 lines
7.5 KiB

# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Abhijith PG (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from ast import literal_eval
from odoo import api, models
from odoo.http import request
class Base(models.AbstractModel):
"""
Inherited Abstract Model to monitor and log user session activities like
record creation, modification, deletion, and read.
"""
_inherit = 'base'
@api.model
def create(self, vals_list):
"""
Overrides the default create method to create a user session activity
log when a record is created.
"""
res = super().create(vals_list)
models_to_track = self.env['ir.config_parameter'].sudo().get_param(
'user_session_management.model_ids')
if models_to_track:
try:
model_ids = self.env['ir.model'].sudo().browse(
literal_eval(models_to_track))
if model_ids and self._name in model_ids.mapped('model'):
name = ''
if self._context.get('params') and self._context[
'params'].get(
'action'):
name = self.env['ir.actions.act_window'].sudo().browse(
self._context['params']['action']).name or ''
if 'name' in vals_list.keys():
name = vals_list['name']
log_vals = {'name': name,
'model': self._name,
'record': res.id,
'action': 'create',
'login_id': request.session.usm_session_id,
}
self.env['user.session.activity'].create(log_vals)
except:
pass
return res
def read(self, fields=None, load='_classic_read', log=True):
"""
Overrides the default read method to create a user session activity
log when a record is read
"""
res = super().read(fields, load)
if log:
models_to_track = self.env['ir.config_parameter'].sudo().get_param(
'user_session_management.model_ids')
if models_to_track:
try:
model_ids = self.env['ir.model'].sudo().browse(
literal_eval(models_to_track))
if model_ids and self._name in model_ids.mapped('model'):
name = ''
if self._context.get('params'):
if self._context['params'].get('action'):
name = self.env['ir.actions.act_window'].sudo()\
.browse(
self._context['params'][
'action']).name or ''
record = False
records = ''
if len(self) == 1:
name = self.name if self._fields.get(
'name') else name
record = self.id
else:
records = self.ids
log_vals = {'name': name,
'model': self._name,
'record': record,
'records': records,
'action': 'read',
'login_id': request.session.usm_session_id,
}
self.env['user.session.activity'].create(log_vals)
except:
pass
return res
def write(self, vals):
"""
Overrides the default write method to create a user session activity
log when a record is modified.
"""
models_to_track = self.env['ir.config_parameter'].sudo().get_param(
'user_session_management.model_ids')
if models_to_track:
try:
model_ids = self.env['ir.model'].browse(
literal_eval(models_to_track))
if model_ids and self._name in model_ids.mapped('model'):
res = super().write(vals)
name = ''
if self._context.get('params') and self._context[
'params'].get('action'):
name = self.env['ir.actions.act_window'].browse(
self._context['params']['action']).name or ''
if 'name' in self._fields.keys():
name = self.name
log_vals = {'name': name,
'model': self._name,
'record': self.id,
'action': 'modify',
'login_id': request.session.usm_session_id,
}
self.env['user.session.activity'].create(log_vals)
return res
except:
pass
return super().write(vals)
def unlink(self):
"""
Overrides the default unlink method to create a user session activity
log when a record is deleted.
"""
models_to_track = self.env['ir.config_parameter'].sudo().get_param(
'user_session_management.model_ids')
if models_to_track:
try:
model_ids = self.env['ir.model'].browse(
literal_eval(models_to_track))
if model_ids and self._name in model_ids.mapped('model'):
name = ''
if self._context.get('params') and self._context[
'params'].get('action'):
name = self.env['ir.actions.act_window'].browse(
self._context['params']['action']).name
record = False
records = ''
if len(self) == 1:
name = self.name if self._fields.get('name') else name
record = self.id
else:
records = self.ids
log_vals = {'name': name,
'model': self._name,
'record': record,
'records': records,
'action': 'delete',
'login_id': request.session.usm_session_id,
}
self.env['user.session.activity'].create(log_vals)
except:
pass
return super().unlink()