mirror of
https://github.com/netbox-community/netbox.git
synced 2026-04-21 16:31:38 +02:00
#21364 update swagger endpoint for /api/extras/scripts/
This commit is contained in:
@@ -27,6 +27,11 @@ router.register('config-context-profiles', views.ConfigContextProfileViewSet)
|
|||||||
router.register('config-templates', views.ConfigTemplateViewSet)
|
router.register('config-templates', views.ConfigTemplateViewSet)
|
||||||
router.register('scripts', views.ScriptViewSet, basename='script')
|
router.register('scripts', views.ScriptViewSet, basename='script')
|
||||||
|
|
||||||
|
# Map POST to the script detail route for running scripts (without affecting the list route)
|
||||||
|
for route in router.routes:
|
||||||
|
if route.name == '{basename}-detail':
|
||||||
|
route.mapping['post'] = 'post'
|
||||||
|
|
||||||
app_name = 'extras-api'
|
app_name = 'extras-api'
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('dashboard/', views.DashboardView.as_view(), name='dashboard'),
|
path('dashboard/', views.DashboardView.as_view(), name='dashboard'),
|
||||||
|
|||||||
@@ -1,16 +1,16 @@
|
|||||||
from django.http import Http404
|
from django.http import Http404
|
||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
from django_rq.queues import get_connection
|
from django_rq.queues import get_connection
|
||||||
from drf_spectacular.utils import extend_schema, extend_schema_view
|
from drf_spectacular.utils import extend_schema, extend_schema_view, OpenApiExample
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
from rest_framework.decorators import action
|
from rest_framework.decorators import action
|
||||||
from rest_framework.exceptions import PermissionDenied
|
from rest_framework.exceptions import PermissionDenied
|
||||||
from rest_framework.generics import RetrieveUpdateDestroyAPIView
|
from rest_framework.generics import RetrieveUpdateDestroyAPIView
|
||||||
from rest_framework.mixins import ListModelMixin, RetrieveModelMixin
|
from rest_framework.mixins import DestroyModelMixin, ListModelMixin, RetrieveModelMixin, UpdateModelMixin
|
||||||
from rest_framework.renderers import JSONRenderer
|
from rest_framework.renderers import JSONRenderer
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
from rest_framework.routers import APIRootView
|
from rest_framework.routers import APIRootView
|
||||||
from rest_framework.viewsets import ModelViewSet
|
from rest_framework.viewsets import GenericViewSet
|
||||||
from rq import Worker
|
from rq import Worker
|
||||||
|
|
||||||
from extras import filtersets
|
from extras import filtersets
|
||||||
@@ -267,7 +267,13 @@ class ConfigTemplateViewSet(SyncedDataMixin, ConfigTemplateRenderMixin, NetBoxMo
|
|||||||
update=extend_schema(request=serializers.ScriptInputSerializer),
|
update=extend_schema(request=serializers.ScriptInputSerializer),
|
||||||
partial_update=extend_schema(request=serializers.ScriptInputSerializer),
|
partial_update=extend_schema(request=serializers.ScriptInputSerializer),
|
||||||
)
|
)
|
||||||
class ScriptViewSet(ModelViewSet):
|
class ScriptViewSet(
|
||||||
|
ListModelMixin,
|
||||||
|
RetrieveModelMixin,
|
||||||
|
UpdateModelMixin,
|
||||||
|
DestroyModelMixin,
|
||||||
|
GenericViewSet
|
||||||
|
):
|
||||||
permission_classes = [IsAuthenticatedOrLoginNotRequired]
|
permission_classes = [IsAuthenticatedOrLoginNotRequired]
|
||||||
queryset = Script.objects.all()
|
queryset = Script.objects.all()
|
||||||
serializer_class = serializers.ScriptSerializer
|
serializer_class = serializers.ScriptSerializer
|
||||||
@@ -303,11 +309,32 @@ class ScriptViewSet(ModelViewSet):
|
|||||||
|
|
||||||
return Response(serializer.data)
|
return Response(serializer.data)
|
||||||
|
|
||||||
|
@extend_schema(
|
||||||
|
request=serializers.ScriptInputSerializer,
|
||||||
|
responses={200: serializers.ScriptDetailSerializer},
|
||||||
|
examples=[
|
||||||
|
OpenApiExample(
|
||||||
|
'Script with no variables',
|
||||||
|
value={'data': {}, 'commit': True},
|
||||||
|
request_only=True,
|
||||||
|
),
|
||||||
|
OpenApiExample(
|
||||||
|
'Script with variables',
|
||||||
|
value={
|
||||||
|
'data': {
|
||||||
|
'variable_name': 'example_value',
|
||||||
|
'another_variable': 123
|
||||||
|
},
|
||||||
|
'commit': True
|
||||||
|
},
|
||||||
|
request_only=True,
|
||||||
|
),
|
||||||
|
]
|
||||||
|
)
|
||||||
def post(self, request, pk):
|
def post(self, request, pk):
|
||||||
"""
|
"""
|
||||||
Run a Script identified by its numeric PK or module & name and return the pending Job as the result
|
Run a Script (via POST) identified by its numeric PK or module & name and return the pending Job as the result
|
||||||
"""
|
"""
|
||||||
|
|
||||||
script = self._get_script(pk)
|
script = self._get_script(pk)
|
||||||
|
|
||||||
if not request.user.has_perm('extras.run_script', obj=script):
|
if not request.user.has_perm('extras.run_script', obj=script):
|
||||||
|
|||||||
Reference in New Issue
Block a user