mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-10-24 12:41:13 +03:00
Fix "Converter is already registered" deprecation warning. (#9512)
This commit is contained in:
parent
f6ea019bd9
commit
5cc1028c2f
|
@ -1,10 +1,11 @@
|
||||||
from django.urls import URLResolver, include, path, re_path, register_converter
|
from django.urls import URLResolver, include, path, re_path, register_converter
|
||||||
|
from django.urls.converters import get_converters
|
||||||
from django.urls.resolvers import RoutePattern
|
from django.urls.resolvers import RoutePattern
|
||||||
|
|
||||||
from rest_framework.settings import api_settings
|
from rest_framework.settings import api_settings
|
||||||
|
|
||||||
|
|
||||||
def _get_format_path_converter(suffix_kwarg, allowed):
|
def _get_format_path_converter(allowed):
|
||||||
if allowed:
|
if allowed:
|
||||||
if len(allowed) == 1:
|
if len(allowed) == 1:
|
||||||
allowed_pattern = allowed[0]
|
allowed_pattern = allowed[0]
|
||||||
|
@ -23,11 +24,14 @@ def _get_format_path_converter(suffix_kwarg, allowed):
|
||||||
def to_url(self, value):
|
def to_url(self, value):
|
||||||
return '.' + value + '/'
|
return '.' + value + '/'
|
||||||
|
|
||||||
|
return FormatSuffixConverter
|
||||||
|
|
||||||
|
|
||||||
|
def _generate_converter_name(allowed):
|
||||||
converter_name = 'drf_format_suffix'
|
converter_name = 'drf_format_suffix'
|
||||||
if allowed:
|
if allowed:
|
||||||
converter_name += '_' + '_'.join(allowed)
|
converter_name += '_' + '_'.join(allowed)
|
||||||
|
return converter_name
|
||||||
return converter_name, FormatSuffixConverter
|
|
||||||
|
|
||||||
|
|
||||||
def apply_suffix_patterns(urlpatterns, suffix_pattern, suffix_required, suffix_route=None):
|
def apply_suffix_patterns(urlpatterns, suffix_pattern, suffix_required, suffix_route=None):
|
||||||
|
@ -104,7 +108,9 @@ def format_suffix_patterns(urlpatterns, suffix_required=False, allowed=None):
|
||||||
else:
|
else:
|
||||||
suffix_pattern = r'\.(?P<%s>[a-z0-9]+)/?$' % suffix_kwarg
|
suffix_pattern = r'\.(?P<%s>[a-z0-9]+)/?$' % suffix_kwarg
|
||||||
|
|
||||||
converter_name, suffix_converter = _get_format_path_converter(suffix_kwarg, allowed)
|
converter_name = _generate_converter_name(allowed)
|
||||||
|
if converter_name not in get_converters():
|
||||||
|
suffix_converter = _get_format_path_converter(allowed)
|
||||||
register_converter(suffix_converter, converter_name)
|
register_converter(suffix_converter, converter_name)
|
||||||
|
|
||||||
suffix_route = '<%s:%s>' % (converter_name, suffix_kwarg)
|
suffix_route = '<%s:%s>' % (converter_name, suffix_kwarg)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user