mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
Fixes #2322: Webhooks firing on non-enabled event types
This commit is contained in:
@ -2,7 +2,6 @@ import datetime
|
|||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.db.models import Q
|
|
||||||
|
|
||||||
from extras.models import Webhook
|
from extras.models import Webhook
|
||||||
from extras.constants import OBJECTCHANGE_ACTION_CREATE, OBJECTCHANGE_ACTION_DELETE, OBJECTCHANGE_ACTION_UPDATE
|
from extras.constants import OBJECTCHANGE_ACTION_CREATE, OBJECTCHANGE_ACTION_DELETE, OBJECTCHANGE_ACTION_UPDATE
|
||||||
@ -18,23 +17,16 @@ def enqueue_webhooks(instance, action):
|
|||||||
if not settings.WEBHOOKS_ENABLED or instance._meta.model_name not in WEBHOOK_MODELS:
|
if not settings.WEBHOOKS_ENABLED or instance._meta.model_name not in WEBHOOK_MODELS:
|
||||||
return
|
return
|
||||||
|
|
||||||
type_create = action == OBJECTCHANGE_ACTION_CREATE
|
# Retrieve any applicable Webhooks
|
||||||
type_update = action == OBJECTCHANGE_ACTION_UPDATE
|
action_flag = {
|
||||||
type_delete = action == OBJECTCHANGE_ACTION_DELETE
|
OBJECTCHANGE_ACTION_CREATE: 'type_create',
|
||||||
|
OBJECTCHANGE_ACTION_UPDATE: 'type_update',
|
||||||
# Find assigned webhooks
|
OBJECTCHANGE_ACTION_DELETE: 'type_delete',
|
||||||
|
}[action]
|
||||||
obj_type = ContentType.objects.get_for_model(instance.__class__)
|
obj_type = ContentType.objects.get_for_model(instance.__class__)
|
||||||
webhooks = Webhook.objects.filter(
|
webhooks = Webhook.objects.filter(obj_type=obj_type, enabled=True, **{action_flag: True})
|
||||||
Q(enabled=True) &
|
|
||||||
(
|
|
||||||
Q(type_create=type_create) |
|
|
||||||
Q(type_update=type_update) |
|
|
||||||
Q(type_delete=type_delete)
|
|
||||||
) &
|
|
||||||
Q(obj_type=obj_type)
|
|
||||||
)
|
|
||||||
|
|
||||||
if webhooks:
|
if webhooks.exists():
|
||||||
# Get the Model's API serializer class and serialize the object
|
# Get the Model's API serializer class and serialize the object
|
||||||
serializer_class = get_serializer_for_model(instance.__class__)
|
serializer_class = get_serializer_for_model(instance.__class__)
|
||||||
serializer_context = {
|
serializer_context = {
|
||||||
|
Reference in New Issue
Block a user