mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Adds basic API endpoint for requesting plugin panels
This commit is contained in:
parent
f36534d558
commit
70e5c7b142
@ -480,7 +480,7 @@ if settings.ENABLE_PLATFORM_FRONTEND:
|
|||||||
|
|
||||||
urlpatterns += frontendpatterns
|
urlpatterns += frontendpatterns
|
||||||
|
|
||||||
# Append custom plugin URLs (if plugin support is enabled)
|
# Append custom plugin URLs (if custom plugin support is enabled)
|
||||||
if settings.PLUGINS_ENABLED:
|
if settings.PLUGINS_ENABLED:
|
||||||
urlpatterns.append(get_plugin_urls())
|
urlpatterns.append(get_plugin_urls())
|
||||||
|
|
||||||
|
@ -9,6 +9,7 @@ from django_filters.rest_framework import DjangoFilterBackend
|
|||||||
from drf_spectacular.utils import extend_schema
|
from drf_spectacular.utils import extend_schema
|
||||||
from rest_framework import permissions, status
|
from rest_framework import permissions, status
|
||||||
from rest_framework.exceptions import NotFound
|
from rest_framework.exceptions import NotFound
|
||||||
|
from rest_framework.permissions import IsAuthenticated
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
from rest_framework.views import APIView
|
from rest_framework.views import APIView
|
||||||
|
|
||||||
@ -410,6 +411,24 @@ class RegistryStatusView(APIView):
|
|||||||
return Response(result)
|
return Response(result)
|
||||||
|
|
||||||
|
|
||||||
|
class PluginPanelList(APIView):
|
||||||
|
"""API endpoint for listing all available plugin panels."""
|
||||||
|
|
||||||
|
permission_classes = [IsAuthenticated]
|
||||||
|
serializer_class = PluginSerializers.PluginPanelSerializer
|
||||||
|
|
||||||
|
@extend_schema(responses={200: PluginSerializers.PluginPanelSerializer(many=True)})
|
||||||
|
def get(self, request):
|
||||||
|
"""Show available plugin panels."""
|
||||||
|
panels = []
|
||||||
|
|
||||||
|
# Extract all plugins from the registry which provide custom panels
|
||||||
|
for _plugin in registry.with_mixin('panel', active=True):
|
||||||
|
...
|
||||||
|
|
||||||
|
return Response(PluginSerializers.PluginPanelSerializer(panels, many=True).data)
|
||||||
|
|
||||||
|
|
||||||
plugin_api_urls = [
|
plugin_api_urls = [
|
||||||
path('action/', ActionPluginView.as_view(), name='api-action-plugin'),
|
path('action/', ActionPluginView.as_view(), name='api-action-plugin'),
|
||||||
path('barcode/', include(barcode_api_urls)),
|
path('barcode/', include(barcode_api_urls)),
|
||||||
@ -417,6 +436,12 @@ plugin_api_urls = [
|
|||||||
path(
|
path(
|
||||||
'plugins/',
|
'plugins/',
|
||||||
include([
|
include([
|
||||||
|
path(
|
||||||
|
'panel/',
|
||||||
|
include([
|
||||||
|
path('', PluginPanelList.as_view(), name='api-plugin-panel-list')
|
||||||
|
]),
|
||||||
|
),
|
||||||
# Plugin management
|
# Plugin management
|
||||||
path('reload/', PluginReload.as_view(), name='api-plugin-reload'),
|
path('reload/', PluginReload.as_view(), name='api-plugin-reload'),
|
||||||
path('install/', PluginInstall.as_view(), name='api-plugin-install'),
|
path('install/', PluginInstall.as_view(), name='api-plugin-install'),
|
||||||
|
@ -303,3 +303,17 @@ class PluginRelationSerializer(serializers.PrimaryKeyRelatedField):
|
|||||||
def to_representation(self, value):
|
def to_representation(self, value):
|
||||||
"""Return the 'key' of the PluginConfig object."""
|
"""Return the 'key' of the PluginConfig object."""
|
||||||
return value.key
|
return value.key
|
||||||
|
|
||||||
|
|
||||||
|
class PluginPanelSerializer(serializers.Serializer):
|
||||||
|
"""Serializer for a plugin panel."""
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
"""Meta for serializer."""
|
||||||
|
|
||||||
|
fields = ['plugin', 'title', 'description', 'icon']
|
||||||
|
|
||||||
|
plugin = serializers.CharField(label=_('Plugin Key'))
|
||||||
|
title = serializers.CharField(label=_('Panel Title'))
|
||||||
|
description = serializers.CharField(label=_('Panel Description'))
|
||||||
|
icon = serializers.CharField(label=_('Panel Icon'))
|
||||||
|
Loading…
Reference in New Issue
Block a user