From edf04d646534dda7594ef014999a99e830a26a77 Mon Sep 17 00:00:00 2001 From: Florian Domain Date: Fri, 12 Apr 2024 09:48:10 +0200 Subject: [PATCH 1/2] feat(CMDB-delete): add endpoint to remove all CMDB objects for a given device * this endpoint will be useful to be sure we remove all CMDB objects attached to a device --- netbox_cmdb/netbox_cmdb/api/cmdb/__init__.py | 0 netbox_cmdb/netbox_cmdb/api/cmdb/views.py | 55 ++++++++++++++++++++ netbox_cmdb/netbox_cmdb/api/urls.py | 6 +++ 3 files changed, 61 insertions(+) create mode 100644 netbox_cmdb/netbox_cmdb/api/cmdb/__init__.py create mode 100644 netbox_cmdb/netbox_cmdb/api/cmdb/views.py diff --git a/netbox_cmdb/netbox_cmdb/api/cmdb/__init__.py b/netbox_cmdb/netbox_cmdb/api/cmdb/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/netbox_cmdb/netbox_cmdb/api/cmdb/views.py b/netbox_cmdb/netbox_cmdb/api/cmdb/views.py new file mode 100644 index 0000000..ee90721 --- /dev/null +++ b/netbox_cmdb/netbox_cmdb/api/cmdb/views.py @@ -0,0 +1,55 @@ +from django.db import transaction +from django.db.models import Q +from drf_yasg import openapi +from drf_yasg.openapi import Parameter +from drf_yasg.utils import swagger_auto_schema +from rest_framework import serializers, status +from rest_framework.response import Response +from rest_framework.views import APIView + +from netbox.api.authentication import IsAuthenticatedOrLoginNotRequired +from netbox_cmdb.models.bgp import BGPPeerGroup, BGPSession, DeviceBGPSession +from netbox_cmdb.models.prefix_list import PrefixList +from netbox_cmdb.models.route_policy import RoutePolicy + + +class DeleteAllCMDBObjectsRelatedToDeviceSerializer(serializers.Serializer): + device_name = serializers.CharField() + + +class DeleteAllCMDBObjectsRelatedToDevice(APIView): + + permission_classes = [IsAuthenticatedOrLoginNotRequired] + + @swagger_auto_schema( + request_body=DeleteAllCMDBObjectsRelatedToDeviceSerializer, + responses={ + status.HTTP_200_OK: "Objects related to device have been deleted successfully", + status.HTTP_400_BAD_REQUEST: "Bad Request: Device name is required", + status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal Server Error: Something went wrong on the server", + }, + ) + def post(self, request): + device_name = request.data.get("device_name", None) + if device_name is None: + return Response( + {"error": "Device name is required"}, status=status.HTTP_400_BAD_REQUEST + ) + + with transaction.atomic(): + try: + # Delete objects in reverse order of dependencies + BGPSession.objects.filter( + Q(peer_a__device__name=device_name) | Q(peer_b__device__name=device_name) + ).delete() + DeviceBGPSession.objects.filter(device__name=device_name).delete() + BGPPeerGroup.objects.filter(device__name=device_name).delete() + RoutePolicy.objects.filter(device__name=device_name).delete() + PrefixList.objects.filter(device__name=device_name).delete() + except Exception as e: + return Response({"error": str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + return Response( + {"message": f"Objects related to device {device_name} have been deleted successfully"}, + status=status.HTTP_200_OK, + ) diff --git a/netbox_cmdb/netbox_cmdb/api/urls.py b/netbox_cmdb/netbox_cmdb/api/urls.py index 0a7edbb..1b32b8b 100644 --- a/netbox_cmdb/netbox_cmdb/api/urls.py +++ b/netbox_cmdb/netbox_cmdb/api/urls.py @@ -12,6 +12,7 @@ from netbox_cmdb.api.prefix_list.views import PrefixListViewSet from netbox_cmdb.api.route_policy.views import RoutePolicyViewSet from netbox_cmdb.api.snmp.views import SNMPCommunityViewSet, SNMPViewSet +from netbox_cmdb.api.cmdb.views import DeleteAllCMDBObjectsRelatedToDevice router = NetBoxRouter() @@ -31,5 +32,10 @@ AvailableASNsView.as_view(), name="asns-available-asn", ), + path( + "cmdb/delete-all-objects/", + DeleteAllCMDBObjectsRelatedToDevice.as_view(), + name="asns-available-asn", + ), ] urlpatterns += router.urls From 34be43add2a1ce458f216d8d36b51fe8a0e7967b Mon Sep 17 00:00:00 2001 From: Florian Domain Date: Mon, 5 Aug 2024 10:28:12 +0200 Subject: [PATCH 2/2] feat(CMDB-delete): remove SNMP objects attached to the device --- netbox_cmdb/netbox_cmdb/api/cmdb/views.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/netbox_cmdb/netbox_cmdb/api/cmdb/views.py b/netbox_cmdb/netbox_cmdb/api/cmdb/views.py index ee90721..c689412 100644 --- a/netbox_cmdb/netbox_cmdb/api/cmdb/views.py +++ b/netbox_cmdb/netbox_cmdb/api/cmdb/views.py @@ -11,6 +11,7 @@ from netbox_cmdb.models.bgp import BGPPeerGroup, BGPSession, DeviceBGPSession from netbox_cmdb.models.prefix_list import PrefixList from netbox_cmdb.models.route_policy import RoutePolicy +from netbox_cmdb.models.snmp import SNMP class DeleteAllCMDBObjectsRelatedToDeviceSerializer(serializers.Serializer): @@ -46,6 +47,7 @@ def post(self, request): BGPPeerGroup.objects.filter(device__name=device_name).delete() RoutePolicy.objects.filter(device__name=device_name).delete() PrefixList.objects.filter(device__name=device_name).delete() + SNMP.objects.filter(device__name=device_name).delete() except Exception as e: return Response({"error": str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)