检查模板中的用户权限(不是请求用户)

时间:2017-12-11 15:28:01

标签: django django-templates django-permissions

您好有没有办法检查模板中自定义用户nit请求用户的权限。 代码示例:

{% for agency_user in users %}
    <tr>
        <td>{{ agency_user.username }}</td>
        <td>{{ agency_user.get_full_name }}</td>
        <td>{{ agency_user.groups.all.first.name }}</td>
        <td>{{ agency_user.min_price }}</td>
        <td>{{ agency_user.max_price }}</td>
        {% if agency_user|has_perm:'may_see_commerce_sell' %} #not working
            <td>some action</td>
        {% else %}
            <td>some action</td>
        {% endif %}
        <td>
            <a href="{% url 'user_edit' agency_user.id  %}" class="edit icon"></a>
            <a user-id="{{ agency_user.id }}" class="trash icon" title="some action"></a>
        </td>
    </tr>
    {% empty %}
        <td style="text-align: center" colspan="11">some action</td>
{% endfor %}

或者我必须为每个用户权限编写自定义模型方法?

类似于在Profile模型中思考:

def sell_commerce(self):
    if self.has_perm('may_see_commerce_sell'):
        return True
    else:
        return False

2 个答案:

答案 0 :(得分:4)

在你的应用程序目录中创建一个目录,将其命名为templatetags,然后在templatetags创建mytage.py文件中,然后执行此类操作

#mytage.py
from django import template
register = template.Library()

@register.filter()
def check_permission(user, permission):
    if user.user_permissions.filter(codename = permission).exists():
        return True
    return False

然后在模板

中加载您的代码
{%load mytags%}
<html lang="en">
.................
{% if user|check_permission:'delete_bills' %}
        ... do something if have permission ...
{% endif %}
...........
</html>

您可以按名称或代号字段

过滤权限

列出当前用户的所有权限

登录后你的django视图中的任何地方

for perm in request.user.permissions.all():
    print(perm.name)
    print(perm.codename)
    print(perm)

这将在控制台

中打印当前登录用户的所有权限

答案 1 :(得分:2)

你可以创建一个模板过滤器来检查这个,比如..

from django.template import Library

register = Library()

@register.filter()
def check_permission(user, permission):
    return user.has_perm(permission)

然后使用它......

{% if user|check_permission:'may_see_commerce_sell' %}
    ... do stuff ...
{% endif %}