aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework
diff options
context:
space:
mode:
Diffstat (limited to 'rest_framework')
-rw-r--r--rest_framework/routers.py5
-rw-r--r--rest_framework/serializers.py6
2 files changed, 6 insertions, 5 deletions
diff --git a/rest_framework/routers.py b/rest_framework/routers.py
index f2d06211..169e6e8b 100644
--- a/rest_framework/routers.py
+++ b/rest_framework/routers.py
@@ -20,6 +20,7 @@ from collections import namedtuple
from django.conf.urls import patterns, url
from django.core.exceptions import ImproperlyConfigured
from django.core.urlresolvers import NoReverseMatch
+from django.utils.datastructures import SortedDict
from rest_framework import views
from rest_framework.response import Response
from rest_framework.reverse import reverse
@@ -277,7 +278,7 @@ class DefaultRouter(SimpleRouter):
"""
Return a view to use as the API root.
"""
- api_root_dict = {}
+ api_root_dict = SortedDict()
list_name = self.routes[0].name
for prefix, viewset, basename in self.registry:
api_root_dict[prefix] = list_name.format(basename=basename)
@@ -286,7 +287,7 @@ class DefaultRouter(SimpleRouter):
_ignore_model_permissions = True
def get(self, request, *args, **kwargs):
- ret = {}
+ ret = SortedDict()
for key, url_name in api_root_dict.items():
try:
ret[key] = reverse(
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py
index b3db3582..d24cb99d 100644
--- a/rest_framework/serializers.py
+++ b/rest_framework/serializers.py
@@ -845,7 +845,7 @@ class ModelSerializer(Serializer):
}
if model_field:
- kwargs['required'] = not(model_field.null or model_field.blank)
+ kwargs['required'] = not(model_field.null or model_field.blank) and model_field.editable
if model_field.help_text is not None:
kwargs['help_text'] = model_field.help_text
if model_field.verbose_name is not None:
@@ -868,7 +868,7 @@ class ModelSerializer(Serializer):
"""
kwargs = {}
- if model_field.null or model_field.blank:
+ if model_field.null or model_field.blank and model_field.editable:
kwargs['required'] = False
if isinstance(model_field, models.AutoField) or not model_field.editable:
@@ -1126,7 +1126,7 @@ class HyperlinkedModelSerializer(ModelSerializer):
}
if model_field:
- kwargs['required'] = not(model_field.null or model_field.blank)
+ kwargs['required'] = not(model_field.null or model_field.blank) and model_field.editable
if model_field.help_text is not None:
kwargs['help_text'] = model_field.help_text
if model_field.verbose_name is not None: