diff --git a/pms_integration/admin.py b/pms_integration/admin.py index ff70a6b5..35660069 100644 --- a/pms_integration/admin.py +++ b/pms_integration/admin.py @@ -1,13 +1,13 @@ from django.contrib import admin -# Register your models here. -from .manager import PluginLoader -from django.http import HttpResponseRedirect from django.urls import path -from django.utils.html import format_html from django.shortcuts import render -from django import forms +from django.utils.html import format_html +from django.http import HttpResponseRedirect +from .manager import PluginLoader from pms_integration.models import PMSConfiguration, PMSIntegrationLog - +from django import forms +from pms_integration.utils import get_all_plugins +from django.urls import reverse class PMSConfigurationForm(forms.ModelForm): class Meta: @@ -16,7 +16,6 @@ class PMSConfigurationForm(forms.ModelForm): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) - # Загружаем доступные плагины plugins = PluginLoader.load_plugins() plugin_choices = [(plugin_name, plugin_name) for plugin_name in plugins.keys()] self.fields['plugin_name'] = forms.ChoiceField(choices=plugin_choices, required=False) @@ -24,21 +23,40 @@ class PMSConfigurationForm(forms.ModelForm): @admin.register(PMSConfiguration) class PMSConfigurationAdmin(admin.ModelAdmin): form = PMSConfigurationForm - list_display = ('name', 'plugin_name', 'created_at') + list_display = ('name', 'plugin_name', 'created_at', 'check_plugins_button') search_fields = ('name', 'plugin_name') ordering = ('-created_at',) - def save_model(self, request, obj, form, change): - # Проверка на наличие плагина - plugins = PluginLoader.load_plugins() - if obj.plugin_name and obj.plugin_name not in plugins.keys(): - raise ValueError(f"Выберите корректный плагин. '{obj.plugin_name}' нет среди допустимых значений.") - super().save_model(request, obj, form, change) - - + def check_plugins_button(self, obj=None): + """ + Возвращает кнопку для проверки плагинов. + """ + url = reverse('admin:check-plugins') # Генерируем URL с помощью reverse + return format_html( + 'Проверить плагины', + url + ) + check_plugins_button.short_description = "Действия" + + def check_plugins_view(self, request, *args, **kwargs): + """ + Custom admin view to check and display available plugins. + """ + plugins = get_all_plugins() + return render(request, "pms_integration/admin/check_plugins.html", {"plugins": plugins}) + + def get_urls(self): + """ + Add custom URLs to the admin panel. + """ + urls = super().get_urls() + custom_urls = [ + path("check-plugins/", self.admin_site.admin_view(self.check_plugins_view), name="check-plugins"), + ] + return custom_urls + urls @admin.register(PMSIntegrationLog) class PMSIntegrationLogAdmin(admin.ModelAdmin): list_display = ('hotel', 'checked_at', 'status', 'message') search_fields = ('hotel__name', 'status', 'message') list_filter = ('status', 'checked_at') - ordering = ('-checked_at',) + ordering = ('-checked_at',) \ No newline at end of file diff --git a/pms_integration/templates/admin/check_plugins.html b/pms_integration/templates/admin/check_plugins.html deleted file mode 100644 index 6d757f8c..00000000 --- a/pms_integration/templates/admin/check_plugins.html +++ /dev/null @@ -1,16 +0,0 @@ -{% extends "admin/base_site.html" %} - -{% block content %} -
Ниже перечислены плагины, доступные в системе:
-| Plugin Name | +Description | +|
|---|---|---|
| {{ plugin_name }} | +{{ plugin_info.description|default:"No description available" }} | + +|
| Нет доступных плагинов. | +||