美文网首页odoo
odoo13 权限仅查看自己

odoo13 权限仅查看自己

作者: 隔壁小红馆 | 来源:发表于2021-01-26 17:21 被阅读0次

有两种方式可以实现:客户仅查看自己创建的数据

  • 直接用权限组

用记录规则(ir.rule)来筛选(domain_force)

        <record id="wg_sale_partner_data_query_self" model="res.groups">
            <field name="name">客户资料查询(仅自己)</field>
            <field name="category_id" ref="module_category_wg_production_function"/>
        </record>

        <record id="wg_sale_partner_my" model="ir.rule">
            <field name="name">客户资料查询规则(仅自己)</field>
            <field ref="base.model_res_partner" name="model_id"/>
            <field name="domain_force">[('create_uid','in',[user.id,False])]</field>
            <field name="groups" eval="[(4, ref('wg_sale_partner_data_query_self'))]"/>
        </record>

注意:如果记录规则无权限组,它会作用于全局,也就是不针对某一个权限组。

  • 用python代码来
    用 _search()函数
    不用写规则,直接来判断是否选择权限组,如果有,进行筛选。
from odoo.osv import expression


    @api.model
    def _search(self, args, offset=0, limit=None, order=None, count=False, access_rights_uid=None):
        if self.user_has_groups('production_management.wg_sale_partner_data_query_self'):
            args = expression.AND([[('create_uid', 'in', [self.env.user.id,False])], list(args)])

        return super(SupplierManager, self)._search(args, offset=offset, limit=limit, order=order,
                                                count=count, access_rights_uid=access_rights_uid)

此两种方法都可实现。本人亲测。

相关文章

网友评论

    本文标题:odoo13 权限仅查看自己

    本文链接:https://www.haomeiwen.com/subject/fmtnzktx.html