Make signals configurable

This commit is contained in:
2022-11-29 07:20:21 +00:00
parent f7242f4dd8
commit 851d021af2
14 changed files with 397 additions and 28 deletions

View File

@@ -5,14 +5,15 @@ from django.http import HttpResponseBadRequest
from django.shortcuts import render
from django.views import View
from core.models import Callback, Hook
from core.models import Callback, Hook, Signal
def get_callbacks(user, hook=None):
def get_callbacks(user, hook=None, signal=None):
if hook:
callbacks = Callback.objects.filter(hook=hook, hook__user=user)
else:
callbacks = Callback.objects.filter(hook__user=user)
cast = {"hook": hook, "hook__user": user}
elif signal:
cast = {"signal": signal, "signal__user": user}
callbacks = Callback.objects.filter(**cast)
return callbacks
@@ -22,15 +23,15 @@ class Callbacks(LoginRequiredMixin, View):
list_template = "partials/callback-list.html"
page_title = "List of received callbacks"
async def get(self, request, type, pk=None):
async def get(self, request, type, object_type, object_id):
if type not in self.allowed_types:
return HttpResponseBadRequest
template_name = f"wm/{type}.html"
unique = str(uuid.uuid4())[:8]
if pk:
if object_type == "hook":
try:
hook = Hook.objects.get(id=pk, user=request.user)
hook = Hook.objects.get(id=object_id, user=request.user)
except Hook.DoesNotExist:
message = "Hook does not exist."
message_class = "danger"
@@ -41,6 +42,19 @@ class Callbacks(LoginRequiredMixin, View):
}
return render(request, template_name, context)
callbacks = get_callbacks(request.user, hook)
elif object_type == "signal":
try:
signal = Signal.objects.get(id=object_id, user=request.user)
except Signal.DoesNotExist:
message = "Signal does not exist."
message_class = "danger"
context = {
"message": message,
"class": message_class,
"type": type,
}
return render(request, template_name, context)
callbacks = get_callbacks(request.user, signal=signal)
else:
callbacks = get_callbacks(request.user)
if type == "page":