Как построить get_admin_url/get app_label и имя класса?

У меня есть метод модели _get_admin_url, и я хочу создать URL-адрес динамически.

class Person(models.Model):
    ...

    def _get_admin_url(self):
        "Returns the admin url."
        # return '/admin/some_app/person/%d' %self.id
        return '/admin/%s/%s/%d/' %(..., ..., d)

    admin_url = property(_get_admin_url)

Как я могу получить значения для app_label и имени класса? Или есть лучший способ?


person allcaps    schedule 01.10.2013    source источник


Ответы (2)


Вы можете использовать функцию Reversing admin URLs.

from django.core import urlresolvers
c = Choice.objects.get(...)
change_url = urlresolvers.reverse('admin:polls_choice_change', args=(c.id,))

Если вы хотите сослаться на страницу change_list, вы должны сделать

urlresolvers.reverse('admin:%s_%s_changelist' % (app_label, model_name))
person karthikr    schedule 01.10.2013
comment
Спасибо за ваш ответ. Но чем мне еще нужно хардкодить "опросы" и "выбор"? Или я что-то упускаю? - person allcaps; 01.10.2013
comment
Да, вам нужно будет указать имя приложения и название модели. - person karthikr; 01.10.2013
comment
Я нашел способ установить имя приложения и название модели. Еще раз спасибо, что указали мне на изменение URL-адресов администратора. - person allcaps; 03.10.2013

Также можно установить app_name и model_name с ContentType, см.: https://stackoverflow.com/a/11395481/991572

Итак, я сделал это в webapp/models.py:

from django.contrib.contenttypes.models import ContentType
from django.core import urlresolvers

class Base(models.Model):
    title = models.CharField(max_length=100)

    def _get_admin_url(self):
        "Returns the admin change view url."
        content_type = ContentType.objects.get_for_model(self.__class__)
        view_name = "admin:%s_%s_change" % (content_type.app_label, content_type.model)
        url = urlresolvers.reverse(view_name, args=(self.id,)) 
        return url

    admin_url = property(_get_admin_url)            

class Book(Base):
    something = models.CharField(max_length=100)

Зарегистрируйте базу и книгу на сайте администратора, создайте несколько записей и в оболочке:

In [1]: from webapp.models import *

In [2]: Base.objects.get(pk=1).admin_url
Out[2]: '/admin/webapp/base/1/'

In [3]: Book.objects.get(pk=2).admin_url
Out[3]: '/admin/webapp/book/2/'
person allcaps    schedule 02.10.2013