mirror of
https://github.com/encode/django-rest-framework.git
synced 2024-11-22 17:47:04 +03:00
Allow custom CSRF_HEADER_NAME setting. (#4415)
This commit is contained in:
parent
966330a85a
commit
b76984d222
|
@ -645,6 +645,12 @@ class BrowsableAPIRenderer(BaseRenderer):
|
|||
else:
|
||||
paginator = None
|
||||
|
||||
csrf_cookie_name = settings.CSRF_COOKIE_NAME
|
||||
csrf_header_name = getattr(settings, 'CSRF_HEADER_NAME', 'HTTP_X_CSRFToken') # Fallback for Django 1.8
|
||||
if csrf_header_name.startswith('HTTP_'):
|
||||
csrf_header_name = csrf_header_name[5:]
|
||||
csrf_header_name = csrf_header_name.replace('_', '-')
|
||||
|
||||
context = {
|
||||
'content': self.get_content(renderer, data, accepted_media_type, renderer_context),
|
||||
'view': view,
|
||||
|
@ -675,7 +681,8 @@ class BrowsableAPIRenderer(BaseRenderer):
|
|||
'display_edit_forms': bool(response.status_code != 403),
|
||||
|
||||
'api_settings': api_settings,
|
||||
'csrf_cookie_name': settings.CSRF_COOKIE_NAME,
|
||||
'csrf_cookie_name': csrf_cookie_name,
|
||||
'csrf_header_name': csrf_header_name
|
||||
}
|
||||
return context
|
||||
|
||||
|
|
|
@ -46,7 +46,7 @@ $.ajaxSetup({
|
|||
// Send the token to same-origin, relative URLs only.
|
||||
// Send the token only if the method warrants CSRF protection
|
||||
// Using the CSRFToken value acquired earlier
|
||||
xhr.setRequestHeader("X-CSRFToken", csrftoken);
|
||||
xhr.setRequestHeader(window.drf.csrfHeaderName, csrftoken);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
|
|
@ -232,6 +232,7 @@
|
|||
{% block script %}
|
||||
<script>
|
||||
window.drf = {
|
||||
csrfHeaderName: "{{ csrf_header_name|default:'X-CSRFToken' }}"
|
||||
csrfCookieName: "{{ csrf_cookie_name|default:'csrftoken' }}"
|
||||
};
|
||||
</script>
|
||||
|
|
|
@ -263,6 +263,7 @@
|
|||
{% block script %}
|
||||
<script>
|
||||
window.drf = {
|
||||
csrfHeaderName: "{{ csrf_header_name|default:'X-CSRFToken' }}"
|
||||
csrfCookieName: "{{ csrf_cookie_name|default:'csrftoken' }}"
|
||||
};
|
||||
</script>
|
||||
|
|
Loading…
Reference in New Issue
Block a user