Merge pull request #953 from bookwyrm-social/admin-filters

Filter reports and users by server name and username
This commit is contained in:
Mouse Reeve
2021-04-17 11:26:12 -07:00
committed by GitHub
9 changed files with 44 additions and 9 deletions

View File

@ -29,7 +29,7 @@ class Federation(View):
except ValueError:
page = 1
servers = models.FederatedServer.objects.all()
servers = models.FederatedServer.objects
sort = request.GET.get("sort")
sort_fields = ["created_date", "application_type", "server_name"]

View File

@ -29,8 +29,10 @@ class Reports(View):
resolved = request.GET.get("resolved") == "true"
server = request.GET.get("server")
if server:
server = get_object_or_404(models.FederatedServer, id=server)
filters["user__federated_server"] = server
filters["user__federated_server__server_name"] = server
username = request.GET.get("username")
if username:
filters["user__username__icontains"] = username
filters["resolved"] = resolved
data = {
"resolved": resolved,

View File

@ -1,7 +1,6 @@
""" manage user """
from django.contrib.auth.decorators import login_required, permission_required
from django.core.paginator import Paginator
from django.shortcuts import get_object_or_404
from django.template.response import TemplateResponse
from django.utils.decorators import method_decorator
from django.views import View
@ -29,10 +28,14 @@ class UserAdmin(View):
filters = {}
server = request.GET.get("server")
if server:
server = get_object_or_404(models.FederatedServer, id=server)
server = models.FederatedServer.objects.filter(server_name=server).first()
filters["federated_server"] = server
filters["federated_server__isnull"] = False
username = request.GET.get("username")
if username:
filters["username__icontains"] = username
users = models.User.objects.filter(**filters).all()
users = models.User.objects.filter(**filters)
sort = request.GET.get("sort", "-created_date")
sort_fields = [
@ -46,5 +49,9 @@ class UserAdmin(View):
users = users.order_by(sort)
paginated = Paginator(users, PAGE_LENGTH)
data = {"users": paginated.get_page(page), "sort": sort, "server": server}
data = {
"users": paginated.get_page(page),
"sort": sort,
"server": server,
}
return TemplateResponse(request, "settings/user_admin.html", data)