跳至內容
選單
此問題已被標幟
1 回覆
4833 瀏覽次數

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
5130
3
11月 24
30075
1
12月 21
2797
0
12月 21
2346
3
12月 15
1367