Implement impersonation
This commit is contained in:
parent
472e272305
commit
d499b781d4
7 changed files with 135 additions and 37 deletions
|
@ -71,6 +71,7 @@
|
|||
<li class="dropdown{% if active_item == 'account' %} active{% endif %}">
|
||||
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"><i class="fa fa-user"></i> {% trans "My Account" %} <span class="caret"></span></a>
|
||||
<ul class="dropdown-menu" role="menu">
|
||||
{% if user.is_superuser %}<li><a href="{% url 'impersonate-search' %}"><i class="fa fa-angellist"></i> {% trans "Impersonate user" %}</a></li>{% endif %}
|
||||
{% if user.is_staff %}<li><a href="{% url 'admin:index' %}"><i class="fa fa-wrench"></i> {% trans "Admin site" %}</a></li>{% endif %}
|
||||
<li><a href="{% url 'account_email' %}"><i class="fa fa-at"></i> {% trans "Change Email" %}</a></li>
|
||||
<li><a href="{% url 'socialaccount_connections' %}"><i class="fa fa-users"></i> {% trans "Social Accounts" %}</a></li>
|
||||
|
@ -85,7 +86,13 @@
|
|||
{% if user.is_authenticated %}
|
||||
{% user_display user as user_display %}
|
||||
{% url 'user_profile' slug=user.username as profile_url %}
|
||||
<p class="navbar-text navbar-right">{% blocktrans %}Signed in as <a href="{{ profile_url }}" class="navbar-link" title="My Profile">{{ user_display }}</a>{% endblocktrans %}</p>
|
||||
{% if user.is_impersonate %}
|
||||
{% user_display user.impersonator as impersonator_display %}
|
||||
{% url 'impersonate-stop' as stop_impersonation_url %}
|
||||
<p class="navbar-text navbar-right">{% blocktrans %}Signed in as <a href="{{ profile_url }}" class="navbar-link" title="My Profile">{{ user_display }}</a> (impersonated by {{ impersonator_display }}, <a href="{{ stop_impersonation_url }}" class="navbar-link">stop impersonation</a>){% endblocktrans %}</p>
|
||||
{% else %}
|
||||
<p class="navbar-text navbar-right">{% blocktrans %}Signed in as <a href="{{ profile_url }}" class="navbar-link" title="My Profile">{{ user_display }}</a>{% endblocktrans %}</p>
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
</div><!--/.nav-collapse -->
|
||||
</div>
|
||||
|
|
31
gnuviechadmin/templates/impersonate/list_users.html
Normal file
31
gnuviechadmin/templates/impersonate/list_users.html
Normal file
|
@ -0,0 +1,31 @@
|
|||
{% extends "base.html" %}
|
||||
{% load i18n %}
|
||||
|
||||
{% block title %}{{ block.super }} - {% trans "Django Impersonate - User List" %}{% endblock title %}
|
||||
{% block page_title %}{% blocktrans %}User List - Page {{ page_number }}{% endblocktrans %}{% endblock page_title %}
|
||||
|
||||
{% block content %}
|
||||
{% if page.object_list %}
|
||||
<ul class="list-group">
|
||||
{% for user in page.object_list %}
|
||||
<li class="list-group-item"><a href="{% url 'impersonate-start' user.pk %}{{ redirect }}">{{ user }}</a>
|
||||
- Impersonate
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
{% endif %}
|
||||
|
||||
<p>
|
||||
<a href="{% url 'impersonate-search' %}">{% trans "Search users" %}</a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
{% if page.has_previous %}
|
||||
<a href="{% url 'impersonate-list' %}?page={{ page.previous_page_number }}">Previous Page</a>
|
||||
{% endif %}
|
||||
|
||||
{% if page.has_next %}
|
||||
<a href="{% url 'impersonate-list' %}?page={{ page.next_page_number }}">Next Page</a>
|
||||
{% endif %}
|
||||
</p>
|
||||
{% endblock %}
|
45
gnuviechadmin/templates/impersonate/search_users.html
Normal file
45
gnuviechadmin/templates/impersonate/search_users.html
Normal file
|
@ -0,0 +1,45 @@
|
|||
{% extends "base.html" %}
|
||||
{% load i18n %}
|
||||
|
||||
{% block title %}{{ block.super }} - {% trans "Django Impersonate - Search Users" %}{% endblock title %}
|
||||
{% block page_title %}Search Users {% if query %}- Page {{ page_number }}{% endif %}{% endblock page_title %}
|
||||
|
||||
{% block content %}
|
||||
<form action="{% url 'impersonate-search' %}" method="GET">
|
||||
{{ redirect_field }}
|
||||
<div class="form-group">
|
||||
<label for="user-query">{% trans "Enter Search Query:" %}</label>
|
||||
<input type="text" name="q" id="user-query" class="form-control"
|
||||
value="{% if query %}{{ query }}{% endif %}">
|
||||
</div>
|
||||
<button type="submit" class="btn btn-primary">{% trans "Search" %}</button>
|
||||
</form>
|
||||
|
||||
<p>
|
||||
<a href="{% url 'impersonate-list' %}">{% trans "List all users" %}</a>
|
||||
</p>
|
||||
|
||||
<p>
|
||||
{% if query and page.object_list %}
|
||||
<ul class="list-group">
|
||||
{% for user in page.object_list %}
|
||||
<li class="list-group-item"><a
|
||||
href="{% url 'impersonate-start' user.pk %}{{ redirect }}">{{ user }}</a> - Impersonate
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
{% endif %}
|
||||
</p>
|
||||
|
||||
<p>
|
||||
{% if query and page.has_previous %}
|
||||
<a href="{% url 'impersonate-search' %}?page={{ page.previous_page_number }}&q={{ query|urlencode }}">Previous
|
||||
Page</a>
|
||||
{% endif %}
|
||||
|
||||
{% if query and page.has_next %}
|
||||
<a href="{% url 'impersonate-search' %}?page={{ page.next_page_number }}&q={{ query|urlencode }}">Next
|
||||
Page</a>
|
||||
{% endif %}
|
||||
</p>
|
||||
{% endblock %}
|
Loading…
Add table
Add a link
Reference in a new issue