fix
This commit is contained in:
@@ -14,6 +14,7 @@ from .models import ProblemPermission
|
|||||||
class BasePermissionDecorator(object):
|
class BasePermissionDecorator(object):
|
||||||
def __init__(self, func):
|
def __init__(self, func):
|
||||||
self.func = func
|
self.func = func
|
||||||
|
functools.update_wrapper(self, func)
|
||||||
|
|
||||||
def __get__(self, obj, obj_type):
|
def __get__(self, obj, obj_type):
|
||||||
if inspect.iscoroutinefunction(self.func):
|
if inspect.iscoroutinefunction(self.func):
|
||||||
|
|||||||
@@ -252,10 +252,13 @@ def validate_serializer(serializer):
|
|||||||
self = args[0]
|
self = args[0]
|
||||||
request = args[1]
|
request = args[1]
|
||||||
s = serializer(data=request.data)
|
s = serializer(data=request.data)
|
||||||
if s.is_valid():
|
if await sync_to_async(s.is_valid)():
|
||||||
request.data = s.data
|
request.data = s.data
|
||||||
request.serializer = s
|
request.serializer = s
|
||||||
return await view_method(*args, **kwargs)
|
response = view_method(*args, **kwargs)
|
||||||
|
if asyncio.iscoroutine(response):
|
||||||
|
return await response
|
||||||
|
return response
|
||||||
else:
|
else:
|
||||||
return self.invalid_serializer(s)
|
return self.invalid_serializer(s)
|
||||||
return async_handle
|
return async_handle
|
||||||
|
|||||||
Reference in New Issue
Block a user