mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Avoided importing models from django.contrib.admin.
Fixed #21923. Refs #21719.
This commit is contained in:
		| @@ -2,8 +2,8 @@ | |||||||
| # has been referenced in documentation. | # has been referenced in documentation. | ||||||
| from django.contrib.admin.decorators import register | from django.contrib.admin.decorators import register | ||||||
| from django.contrib.admin.helpers import ACTION_CHECKBOX_NAME | from django.contrib.admin.helpers import ACTION_CHECKBOX_NAME | ||||||
| from django.contrib.admin.options import ModelAdmin, HORIZONTAL, VERTICAL | from django.contrib.admin.options import (HORIZONTAL, VERTICAL, | ||||||
| from django.contrib.admin.options import StackedInline, TabularInline |     ModelAdmin, StackedInline, TabularInline) | ||||||
| from django.contrib.admin.filters import (ListFilter, SimpleListFilter, | from django.contrib.admin.filters import (ListFilter, SimpleListFilter, | ||||||
|     FieldListFilter, BooleanFieldListFilter, RelatedFieldListFilter, |     FieldListFilter, BooleanFieldListFilter, RelatedFieldListFilter, | ||||||
|     ChoicesFieldListFilter, DateFieldListFilter, AllValuesFieldListFilter) |     ChoicesFieldListFilter, DateFieldListFilter, AllValuesFieldListFilter) | ||||||
|   | |||||||
| @@ -4,7 +4,6 @@ from django import forms | |||||||
| from django.contrib.admin.utils import (flatten_fieldsets, lookup_field, | from django.contrib.admin.utils import (flatten_fieldsets, lookup_field, | ||||||
|     display_for_field, label_for_field, help_text_for_field) |     display_for_field, label_for_field, help_text_for_field) | ||||||
| from django.contrib.admin.templatetags.admin_static import static | from django.contrib.admin.templatetags.admin_static import static | ||||||
| from django.contrib.contenttypes.models import ContentType |  | ||||||
| from django.core.exceptions import ObjectDoesNotExist | from django.core.exceptions import ObjectDoesNotExist | ||||||
| from django.db.models.fields.related import ManyToManyRel | from django.db.models.fields.related import ManyToManyRel | ||||||
| from django.forms.utils import flatatt | from django.forms.utils import flatatt | ||||||
| @@ -257,6 +256,9 @@ class InlineAdminForm(AdminForm): | |||||||
|         self.model_admin = model_admin |         self.model_admin = model_admin | ||||||
|         self.original = original |         self.original = original | ||||||
|         if original is not None: |         if original is not None: | ||||||
|  |             # Since this module gets imported in the application's root package, | ||||||
|  |             # it cannot import models from other applications at the module level. | ||||||
|  |             from django.contrib.contenttypes.models import ContentType | ||||||
|             self.original_content_type_id = ContentType.objects.get_for_model(original).pk |             self.original_content_type_id = ContentType.objects.get_for_model(original).pk | ||||||
|         self.show_url = original and view_on_site_url is not None |         self.show_url = original and view_on_site_url is not None | ||||||
|         self.absolute_url = view_on_site_url |         self.absolute_url = view_on_site_url | ||||||
|   | |||||||
| @@ -17,7 +17,6 @@ from django.contrib.admin.utils import (unquote, flatten_fieldsets, | |||||||
| from django.contrib.admin.templatetags.admin_static import static | from django.contrib.admin.templatetags.admin_static import static | ||||||
| from django.contrib.admin.templatetags.admin_urls import add_preserved_filters | from django.contrib.admin.templatetags.admin_urls import add_preserved_filters | ||||||
| from django.contrib.auth import get_permission_codename | from django.contrib.auth import get_permission_codename | ||||||
| from django.contrib.contenttypes.models import ContentType |  | ||||||
| from django.core import checks | from django.core import checks | ||||||
| from django.core.exceptions import PermissionDenied, ValidationError, FieldError, ImproperlyConfigured | from django.core.exceptions import PermissionDenied, ValidationError, FieldError, ImproperlyConfigured | ||||||
| from django.core.paginator import Paginator | from django.core.paginator import Paginator | ||||||
| @@ -55,6 +54,13 @@ TO_FIELD_VAR = '_to_field' | |||||||
| HORIZONTAL, VERTICAL = 1, 2 | HORIZONTAL, VERTICAL = 1, 2 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def get_content_type_for_model(obj): | ||||||
|  |     # Since this module gets imported in the application's root package, | ||||||
|  |     # it cannot import models from other applications at the module level. | ||||||
|  |     from django.contrib.contenttypes.models import ContentType | ||||||
|  |     return ContentType.objects.get_for_model(obj) | ||||||
|  |  | ||||||
|  |  | ||||||
| def get_ul_class(radio_style): | def get_ul_class(radio_style): | ||||||
|     return 'radiolist' if radio_style == VERTICAL else 'radiolist inline' |     return 'radiolist' if radio_style == VERTICAL else 'radiolist inline' | ||||||
|  |  | ||||||
| @@ -291,7 +297,7 @@ class BaseModelAdmin(six.with_metaclass(RenameBaseModelAdminMethods)): | |||||||
|         elif self.view_on_site and hasattr(obj, 'get_absolute_url'): |         elif self.view_on_site and hasattr(obj, 'get_absolute_url'): | ||||||
|             # use the ContentType lookup if view_on_site is True |             # use the ContentType lookup if view_on_site is True | ||||||
|             return reverse('admin:view_on_site', kwargs={ |             return reverse('admin:view_on_site', kwargs={ | ||||||
|                 'content_type_id': ContentType.objects.get_for_model(obj).pk, |                 'content_type_id': get_content_type_for_model(obj).pk, | ||||||
|                 'object_id': obj.pk |                 'object_id': obj.pk | ||||||
|             }) |             }) | ||||||
|  |  | ||||||
| @@ -728,7 +734,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         from django.contrib.admin.models import LogEntry, ADDITION |         from django.contrib.admin.models import LogEntry, ADDITION | ||||||
|         LogEntry.objects.log_action( |         LogEntry.objects.log_action( | ||||||
|             user_id=request.user.pk, |             user_id=request.user.pk, | ||||||
|             content_type_id=ContentType.objects.get_for_model(object).pk, |             content_type_id=get_content_type_for_model(object).pk, | ||||||
|             object_id=object.pk, |             object_id=object.pk, | ||||||
|             object_repr=force_text(object), |             object_repr=force_text(object), | ||||||
|             action_flag=ADDITION |             action_flag=ADDITION | ||||||
| @@ -743,7 +749,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         from django.contrib.admin.models import LogEntry, CHANGE |         from django.contrib.admin.models import LogEntry, CHANGE | ||||||
|         LogEntry.objects.log_action( |         LogEntry.objects.log_action( | ||||||
|             user_id=request.user.pk, |             user_id=request.user.pk, | ||||||
|             content_type_id=ContentType.objects.get_for_model(object).pk, |             content_type_id=get_content_type_for_model(object).pk, | ||||||
|             object_id=object.pk, |             object_id=object.pk, | ||||||
|             object_repr=force_text(object), |             object_repr=force_text(object), | ||||||
|             action_flag=CHANGE, |             action_flag=CHANGE, | ||||||
| @@ -760,7 +766,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         from django.contrib.admin.models import LogEntry, DELETION |         from django.contrib.admin.models import LogEntry, DELETION | ||||||
|         LogEntry.objects.log_action( |         LogEntry.objects.log_action( | ||||||
|             user_id=request.user.pk, |             user_id=request.user.pk, | ||||||
|             content_type_id=ContentType.objects.get_for_model(self.model).pk, |             content_type_id=get_content_type_for_model(self.model).pk, | ||||||
|             object_id=object.pk, |             object_id=object.pk, | ||||||
|             object_repr=object_repr, |             object_repr=object_repr, | ||||||
|             action_flag=DELETION |             action_flag=DELETION | ||||||
| @@ -1042,7 +1048,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|             'absolute_url': view_on_site_url, |             'absolute_url': view_on_site_url, | ||||||
|             'form_url': form_url, |             'form_url': form_url, | ||||||
|             'opts': opts, |             'opts': opts, | ||||||
|             'content_type_id': ContentType.objects.get_for_model(self.model).id, |             'content_type_id': get_content_type_for_model(self.model).pk, | ||||||
|             'save_as': self.save_as, |             'save_as': self.save_as, | ||||||
|             'save_on_top': self.save_on_top, |             'save_on_top': self.save_on_top, | ||||||
|             'to_field_var': TO_FIELD_VAR, |             'to_field_var': TO_FIELD_VAR, | ||||||
| @@ -1660,7 +1666,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         app_label = opts.app_label |         app_label = opts.app_label | ||||||
|         action_list = LogEntry.objects.filter( |         action_list = LogEntry.objects.filter( | ||||||
|             object_id=unquote(object_id), |             object_id=unquote(object_id), | ||||||
|             content_type=ContentType.objects.get_for_model(model) |             content_type=get_content_type_for_model(model) | ||||||
|         ).select_related().order_by('action_time') |         ).select_related().order_by('action_time') | ||||||
|  |  | ||||||
|         context = dict(self.admin_site.each_context(), |         context = dict(self.admin_site.each_context(), | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| from functools import update_wrapper | from functools import update_wrapper | ||||||
| from django.http import Http404, HttpResponseRedirect | from django.http import Http404, HttpResponseRedirect | ||||||
| from django.contrib.admin import ModelAdmin, actions | from django.contrib.admin import ModelAdmin, actions | ||||||
| from django.contrib.admin.forms import AdminAuthenticationForm |  | ||||||
| from django.contrib.auth import logout as auth_logout, REDIRECT_FIELD_NAME | from django.contrib.auth import logout as auth_logout, REDIRECT_FIELD_NAME | ||||||
| from django.contrib.contenttypes import views as contenttype_views |  | ||||||
| from django.views.decorators.csrf import csrf_protect | from django.views.decorators.csrf import csrf_protect | ||||||
| from django.db.models.base import ModelBase | from django.db.models.base import ModelBase | ||||||
| from django.apps import apps | from django.apps import apps | ||||||
| @@ -212,6 +210,10 @@ class AdminSite(object): | |||||||
|  |  | ||||||
|     def get_urls(self): |     def get_urls(self): | ||||||
|         from django.conf.urls import patterns, url, include |         from django.conf.urls import patterns, url, include | ||||||
|  |         # Since this module gets imported in the application's root package, | ||||||
|  |         # it cannot import models from other applications at the module level, | ||||||
|  |         # and django.contrib.contenttypes.views imports ContentType. | ||||||
|  |         from django.contrib.contenttypes import views as contenttype_views | ||||||
|  |  | ||||||
|         if settings.DEBUG: |         if settings.DEBUG: | ||||||
|             self.check_dependencies() |             self.check_dependencies() | ||||||
| @@ -327,6 +329,10 @@ class AdminSite(object): | |||||||
|         Displays the login form for the given HttpRequest. |         Displays the login form for the given HttpRequest. | ||||||
|         """ |         """ | ||||||
|         from django.contrib.auth.views import login |         from django.contrib.auth.views import login | ||||||
|  |         # Since this module gets imported in the application's root package, | ||||||
|  |         # it cannot import models from other applications at the module level, | ||||||
|  |         # and django.contrib.admin.forms eventually imports User. | ||||||
|  |         from django.contrib.admin.forms import AdminAuthenticationForm | ||||||
|         context = dict(self.each_context(), |         context = dict(self.each_context(), | ||||||
|             title=_('Log in'), |             title=_('Log in'), | ||||||
|             app_path=request.get_full_path(), |             app_path=request.get_full_path(), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user