Adds detail page for federated servers
This commit is contained in:
@ -1,5 +1,6 @@
|
||||
""" manage federated servers """
|
||||
from django.contrib.auth.decorators import login_required, permission_required
|
||||
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
|
||||
@ -21,3 +22,28 @@ class Federation(View):
|
||||
servers = models.FederatedServer.objects.all()
|
||||
data = {"servers": servers}
|
||||
return TemplateResponse(request, "settings/federation.html", data)
|
||||
|
||||
|
||||
@method_decorator(login_required, name="dispatch")
|
||||
@method_decorator(
|
||||
permission_required("bookwyrm.control_federation", raise_exception=True),
|
||||
name="dispatch",
|
||||
)
|
||||
class FederatedServer(View):
|
||||
""" views for handling a specific federated server """
|
||||
|
||||
def get(self, request, server):
|
||||
""" load a server """
|
||||
server = get_object_or_404(models.FederatedServer, id=server)
|
||||
users = server.user_set
|
||||
data = {
|
||||
"server": server,
|
||||
"users": users,
|
||||
"reports": models.Report.objects.filter(user__in=users.all()),
|
||||
"followed_by_us": users.filter(followers__local=True),
|
||||
"followed_by_them": users.filter(following__local=True),
|
||||
"blocked_by_us": models.UserBlocks.objects.filter(
|
||||
user_subject__in=users.all()
|
||||
),
|
||||
}
|
||||
return TemplateResponse(request, "settings/federated_server.html", data)
|
||||
|
Reference in New Issue
Block a user