The comments app was unconditionally accessing various settings that didn't

exist in Django's global settings. Changed those accesses to conditional
lookups with default fallbacks.

The comment_test tests now pass without needing to add any extra settings.


git-svn-id: http://code.djangoproject.com/svn/django/trunk@8573 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Malcolm Tredinnick 2008-08-26 06:58:43 +00:00
parent 47ed499a5d
commit ccb37ce74c
2 changed files with 13 additions and 6 deletions

View File

@ -10,14 +10,14 @@ def get_comment_app():
Get the comment app (i.e. "django.contrib.comments") as defined in the settings
"""
# Make sure the app's in INSTALLED_APPS
comments_app = getattr(settings, 'COMMENTS_APP', 'django.contrib.comments')
comments_app = get_comment_app_name()
if comments_app not in settings.INSTALLED_APPS:
raise ImproperlyConfigured("The COMMENTS_APP (%r) "\
"must be in INSTALLED_APPS" % settings.COMMENTS_APP)
# Try to import the package
try:
package = __import__(settings.COMMENTS_APP, '', '', [''])
package = __import__(comments_app, '', '', [''])
except ImportError:
raise ImproperlyConfigured("The COMMENTS_APP setting refers to "\
"a non-existing package.")
@ -31,6 +31,13 @@ def get_comment_app():
return package
def get_comment_app_name():
"""
Returns the name of the comment app (either the setting value, if it
exists, or the default).
"""
return getattr(settings, 'COMMENTS_APP', 'django.contrib.comments')
def get_model():
from django.contrib.comments.models import Comment
return Comment
@ -46,7 +53,7 @@ def get_flag_url(comment):
"""
Get the URL for the "flag this comment" view.
"""
if settings.COMMENTS_APP != __name__ and hasattr(get_comment_app(), "get_flag_url"):
if get_comment_app_name() != __name__ and hasattr(get_comment_app(), "get_flag_url"):
return get_comment_app().get_flag_url(comment)
else:
return urlresolvers.reverse("django.contrib.comments.views.moderation.flag", args=(comment.id,))
@ -55,7 +62,7 @@ def get_delete_url(comment):
"""
Get the URL for the "delete this comment" view.
"""
if settings.COMMENTS_APP != __name__ and hasattr(get_comment_app(), "get_delete_url"):
if get_comment_app_name() != __name__ and hasattr(get_comment_app(), "get_delete_url"):
return get_comment_app().get_flag_url(get_delete_url)
else:
return urlresolvers.reverse("django.contrib.comments.views.moderation.delete", args=(comment.id,))
@ -64,7 +71,7 @@ def get_approve_url(comment):
"""
Get the URL for the "approve this comment from moderation" view.
"""
if settings.COMMENTS_APP != __name__ and hasattr(get_comment_app(), "get_approve_url"):
if get_comment_app_name() != __name__ and hasattr(get_comment_app(), "get_approve_url"):
return get_comment_app().get_approve_url(comment)
else:
return urlresolvers.reverse("django.contrib.comments.views.moderation.approve", args=(comment.id,))

View File

@ -81,7 +81,7 @@ class BaseCommentNode(template.Node):
site__pk = settings.SITE_ID,
is_public = True,
)
if settings.COMMENTS_HIDE_REMOVED:
if getattr(settings, 'COMMENTS_HIDE_REMOVED', True):
qs = qs.filter(is_removed=False)
return qs