В моем приложении (развернутом в Heroku fwiw) было два объекта модели, Org
и Event
с соответствующими представлениями объектов и без проблем / ошибок. когда я ввел третий объект Theme
и изменил некоторые URL-маршруты, чтобы использовать его слаг, я теперь получаю следующую ошибку, запрашивающую представление для Org
(путь URL-адреса, представление которого принимает org.slug
в качестве параметра):
AttributeError: 'NoneType' object has no attribute 'org'
и 404
orgs.models.py
class Org(models.Model):
name = models.CharField(max_length=100, unique=True)
slug = AutoSlugField(populate_from='name')
themes = models.ManyToManyField('common.Theme', related_name='orgs', blank=True)
...
def __str__(self):
return self.name
def get_absolute_url(self):
return reverse('org-detail', args=[self.slug])
class Event(models.Model):
org = models.ForeignKey('Org', on_delete=models.CASCADE, related_name='events')
name = models.CharField(max_length=120)
slug = AutoSlugField(populate_from='name', unique_with='org', sep='-')
...
def __str__(self):
return self.name
def get_absolute_url(self):
return reverse('event-detail', args=[self.org.slug, self.slug])
common.models.py
class Theme(models.Model):
name = models.CharField(max_length=50)
slug = AutoSlugField(populate_from='name')
class Meta:
ordering = ['name']
def __str__(self):
return self.name
def get_absolute_url(self):
return reverse('themes', args=[self.slug])
orgs.urls.py
urlpatterns = [
url(r'^org/(?P<org_slug>[-\w]+)/?$', views.org, name='org-detail'),
url(r'^org/(?P<org_slug>[-\w]+)/event/(?P<slug>[-\w]+)/', include([
url(r'^$', views.event, name='event-detail'),
...
])),
...
]
common.urls.py
urlpatterns = [
url(r'^(?P<slug>[-\w]+)/?$', views.theme, name='theme'),
...
]
orgs.views.py
def event(request, org_slug, slug):
event = Event.objects.filter(slug=slug).order_by('id').first()
if event.org.slug != org_slug:
raise Http404
event_url = '{}{}{}'.format(settings.DEFAULT_PROTOCOL, settings.APP_DOMAIN, event.get_absolute_url())
context = {
'event': event,
'event_url': event_url,
'event_url_encode': urlquote_plus(event_url),
}
return render(request, 'orgs/event.html', context)
def org(request, slug, role=None):
try:
org = Org.objects.get(slug=slug)
except Org.DoesNotExist:
return HttpResponseBadRequest()
context = {
'org': org,
}
return render(request, 'orgs/org.html', context)
views.event возвращает правильный ответ, как и ожидалось. views.org раньше, но теперь возвращает 404. ошибка журнала фактически показывает ошибку, генерируемую views.event, но я не понимаю, почему:
Traceback (most recent call last):
File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 41, in inner
response = get_response(request)
File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 249, in _legacy_get_response
response = self._get_response(request)
File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 187, in _get_response
response = self.process_exception_by_middleware(e, request)
File "/app/.heroku/python/lib/python3.6/site-packages/channels/handler.py", line 237, in process_exception_by_middleware
return super(AsgiHandler, self).process_exception_by_middleware(exception, request)
File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 185, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/app/.heroku/python/lib/python3.6/contextlib.py", line 52, in inner
return func(*args, **kwds)
File "/app/project/utils/helpers.py", line 28, in _decorated
return view(request, *args, **kwargs)
File "/app/.heroku/python/lib/python3.6/site-packages/htmlmin/decorators.py", line 13, in minify
response = f(*args, **kwargs)
File "/app/orgs/views.py", line 243, in event
if event.org.slug != org_slug:
AttributeError: 'NoneType' object has no attribute 'org'
в режиме отладки Джанго говорит: No Theme matches the given query.
повышается на project.utils.helpers._decorated
для GET app.com/org/valid-org-slug
. почему тема вызывается в этом запросе (или слаг темы используется как аргумент вместо org?) - она не используется и не запрашивается views.event или views.org? и как событие может быть NoneType
для views.org, если view.event возвращает правильный объект? спасибо