跳至内容
菜单
此问题已终结
1 回复
4866 查看

I'm trying to overwrite delete method with log information into the db:

def post_write(self, cr, uid, ids, action, model, context=None):
    if isinstance(ids, (int, long)):
      ids = [ids]
    queue = self.pool.get("hr.changes.queue")
    for id in ids:
        queue.create(self, cr, uid, {
            "action": action,
            "related_model": model,
            "affected_id": id
        })

def unlink(self, cr, uid, ids, context=None):
    self.post_write(self, cr, uid, ids, "delete", "hr.employee")
    return super(hr_employee, self).unlink(cr, uid, ids)

but I have this error: "'hr.employee' object has no attribute 'execute'"

形象
丢弃

At least you don't pass context in your method unlink. Probably won't fix it, but it is better to do it. In your code, there is no execute, Can you post the complete stacktrace, it will probably tell you something more.

最佳答案

Hi,

Another way to follow users operations see module Audit Trail audittrail exists in the apps openerp.

This module lets administrator track every user operation on all the objects of the system.

The administrator can subscribe to rules for read, write and delete on objects and can check logs.

installl this module and in menu Reporting>>Audit Rules define the objects to be tracked . For example partner:

image description

形象
丢弃
编写者

No, its not all the task and installing this module is not solution.

Yes, you can track one operation 'delete' for one object 'hr.employee' and not all task for all objects.

编写者

I think installing the whole module is not the best solution if I can do it by overwriting the only method.

相关帖文 回复 查看 活动
2
3月 15
5154
3
11月 24
30161
1
12月 21
2886
0
12月 21
2387
3
12月 15
1367