0

我正在努力实现应该允许所有作为人力资源经理的用户查看记录。我创建了一个功能领域:

def list_HRM(self, cr, uid, ids, field_name, arg, context):
         attribute = {}
        hr_managers = self.pool.get('hr.employee').search(cr, uid, ['&', ('department_id.name', '=', 'Human Resources'), ('manager', '=', True)], context=context)
        hr_managers_uid = []
        for record in hr_managers:
            hr_managers_uid.append(self.pool.get('hr.employee').browse(cr, uid, record, context=context).user_id.id)
        record = self.browse(cr, uid, ids)[0]
        attribute[record.id] = str(uid in hr_managers_uid or uid==1)
        return attribute

    _columns={
    'hr_managers_func' : fields.function(list_HRM, type='char', method=True, string='List of HR Managers'),
    'always_true':fields.boolean()
     }
   _defaults={
      'always_true':True
      }

在 .xml 文件中:

<field name="always_true" invisible="1"/>
<field name="hr_managers_func" invisible="1"/>

在记录规则中:

['&','|',('state','=','hod_depart'),('state','=','hr_review'),('always_true','=',eval(hr_managers_func))]

由于记录规则条件格式即[('field_name','operator',values)],我使用了字段'always_true'。我认为该规则将使用 eval 评估功能字段,但不幸的是 eval 不适用于记录规则,我收到此错误:

NameError: name 'eval' is not defined

我想不出更多。我看到几个论坛和我的问题有些相似,他们使用相关字段来避免记录中的功能字段,但是在这里我必须检查当前用户是否属于hr manager。我已经尝试以最好的方式解释这一点,期待一些答复。

4

1 回答 1

3

要限制函数字段,您需要定义一个 fnct_search。功能场本身变成了一个虚拟的。

在您的模型中:

def _my_functional_field_search(self, cr, uid, obj, name, args, context=None):
    list_of_ids = [...]

    return [('id', 'in', list_of_ids)]

_columns = {
    'my_functional_field': fields.function(
        lambda **x: True,
        fnct_search=_my_functional_field_search,
        type='boolean',
        method=True,
    ),
}

然后在您的安全 XML 文件中:

<record id="your_rule_id" model="ir.rule">
  <field name="name">Your Rule Name</field>
  <field name="model_id" ref="model_the_model" />
  <field name="groups" eval="[(4, ref('group_affected_group'))]" />
  <field name="domain_force">[('my_functional_field', '=', True)]</field>
</record>
于 2014-01-24T15:15:04.833 回答