Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
D
django-rest-framework
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
django-rest-framework
Commits
65858428
Commit
65858428
authored
Jan 13, 2014
by
S.Prymak
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make HyperlinkedModelSerializer `url` field name customizable
parent
2ecd9841
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
4 additions
and
3 deletions
+4
-3
rest_framework/serializers.py
+4
-3
No files found.
rest_framework/serializers.py
View file @
65858428
...
@@ -990,6 +990,7 @@ class HyperlinkedModelSerializerOptions(ModelSerializerOptions):
...
@@ -990,6 +990,7 @@ class HyperlinkedModelSerializerOptions(ModelSerializerOptions):
super
(
HyperlinkedModelSerializerOptions
,
self
)
.
__init__
(
meta
)
super
(
HyperlinkedModelSerializerOptions
,
self
)
.
__init__
(
meta
)
self
.
view_name
=
getattr
(
meta
,
'view_name'
,
None
)
self
.
view_name
=
getattr
(
meta
,
'view_name'
,
None
)
self
.
lookup_field
=
getattr
(
meta
,
'lookup_field'
,
None
)
self
.
lookup_field
=
getattr
(
meta
,
'lookup_field'
,
None
)
self
.
url_field_name
=
getattr
(
meta
,
'url_field_name'
,
'url'
)
class
HyperlinkedModelSerializer
(
ModelSerializer
):
class
HyperlinkedModelSerializer
(
ModelSerializer
):
...
@@ -1008,13 +1009,13 @@ class HyperlinkedModelSerializer(ModelSerializer):
...
@@ -1008,13 +1009,13 @@ class HyperlinkedModelSerializer(ModelSerializer):
if
self
.
opts
.
view_name
is
None
:
if
self
.
opts
.
view_name
is
None
:
self
.
opts
.
view_name
=
self
.
_get_default_view_name
(
self
.
opts
.
model
)
self
.
opts
.
view_name
=
self
.
_get_default_view_name
(
self
.
opts
.
model
)
if
'url'
not
in
fields
:
if
self
.
opts
.
url_field_name
not
in
fields
:
url_field
=
self
.
_hyperlink_identify_field_class
(
url_field
=
self
.
_hyperlink_identify_field_class
(
view_name
=
self
.
opts
.
view_name
,
view_name
=
self
.
opts
.
view_name
,
lookup_field
=
self
.
opts
.
lookup_field
lookup_field
=
self
.
opts
.
lookup_field
)
)
ret
=
self
.
_dict_class
()
ret
=
self
.
_dict_class
()
ret
[
'url'
]
=
url_field
ret
[
self
.
opts
.
url_field_name
]
=
url_field
ret
.
update
(
fields
)
ret
.
update
(
fields
)
fields
=
ret
fields
=
ret
...
@@ -1050,7 +1051,7 @@ class HyperlinkedModelSerializer(ModelSerializer):
...
@@ -1050,7 +1051,7 @@ class HyperlinkedModelSerializer(ModelSerializer):
We need to override the default, to use the url as the identity.
We need to override the default, to use the url as the identity.
"""
"""
try
:
try
:
return
data
.
get
(
'url'
,
None
)
return
data
.
get
(
self
.
opts
.
url_field_name
,
None
)
except
AttributeError
:
except
AttributeError
:
return
None
return
None
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment