Django Admin Search field reverse lookup

У меня есть следующие модели:

class Policy(models.Model):
    name = models.CharField(max_length=40)

    def __str__(self) -> str:
        return self.name

    class Meta:
        verbose_name_plural = 'Policies'

class Statement(models.Model):
    name = models.CharField(max_length=40)
    policy = models.ForeignKey(
        to=Policy,
        on_delete=models.CASCADE,
        related_name='statements'
    )
    action = models.CharField(max_length=64)
    resource = models.CharField(max_length=128)

и следующая простая модель администратора:

class PolicyAdmin(admin.ModelAdmin):
    inlines = [StatementInline]
    search_fields = [name,]
    class Meta:
        model = Policy

Я хочу добиться того, чтобы включить функцию поиска в списке изменений политики, с помощью которой я смогу искать политику по полю имени модели заявления в дополнение к имени политики.

@admin.register(Policy)
class ExapmleAdmin(admin.ModelAdmin):
    search_fields = ("statements__name",)
    class Meta:
        model = Policy

admin.site.register(Statement)

В вашем файле admin.py. Вы можете искать политику с помощью поля name модели Statement следующим образом.

Вернуться на верх