mirror of
https://github.com/graphql-python/graphene.git
synced 2024-11-26 03:23:55 +03:00
Refactored mounted types logic
This commit is contained in:
parent
da3683028e
commit
93dacda923
|
@ -1,12 +1,12 @@
|
||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
from itertools import chain
|
from itertools import chain
|
||||||
|
|
||||||
from ..utils.orderedtype import OrderedType
|
from .mountedtype import MountedType
|
||||||
from .structures import NonNull
|
from .structures import NonNull
|
||||||
from .dynamic import Dynamic
|
from .dynamic import Dynamic
|
||||||
|
|
||||||
|
|
||||||
class Argument(OrderedType):
|
class Argument(MountedType):
|
||||||
|
|
||||||
def __init__(self, type, default_value=None, description=None, name=None, required=False, _creation_counter=None):
|
def __init__(self, type, default_value=None, description=None, name=None, required=False, _creation_counter=None):
|
||||||
super(Argument, self).__init__(_creation_counter=_creation_counter)
|
super(Argument, self).__init__(_creation_counter=_creation_counter)
|
||||||
|
@ -47,7 +47,7 @@ def to_arguments(args, extra_args=None):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
if isinstance(arg, UnmountedType):
|
if isinstance(arg, UnmountedType):
|
||||||
arg = arg.Argument()
|
arg = Argument.mount(arg)
|
||||||
|
|
||||||
if isinstance(arg, (InputField, Field)):
|
if isinstance(arg, (InputField, Field)):
|
||||||
raise ValueError('Expected {} to be Argument, but received {}. Try using Argument({}).'.format(
|
raise ValueError('Expected {} to be Argument, but received {}. Try using Argument({}).'.format(
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import inspect
|
import inspect
|
||||||
|
|
||||||
from ..utils.orderedtype import OrderedType
|
from .mountedtype import MountedType
|
||||||
|
|
||||||
|
|
||||||
class Dynamic(OrderedType):
|
class Dynamic(MountedType):
|
||||||
'''
|
'''
|
||||||
A Dynamic Type let us get the type in runtime when we generate
|
A Dynamic Type let us get the type in runtime when we generate
|
||||||
the schema. So we can have lazy fields.
|
the schema. So we can have lazy fields.
|
||||||
|
|
|
@ -2,8 +2,8 @@ import inspect
|
||||||
from collections import Mapping, OrderedDict
|
from collections import Mapping, OrderedDict
|
||||||
from functools import partial
|
from functools import partial
|
||||||
|
|
||||||
from ..utils.orderedtype import OrderedType
|
|
||||||
from .argument import Argument, to_arguments
|
from .argument import Argument, to_arguments
|
||||||
|
from .mountedtype import MountedType
|
||||||
from .structures import NonNull
|
from .structures import NonNull
|
||||||
from .unmountedtype import UnmountedType
|
from .unmountedtype import UnmountedType
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ def source_resolver(source, root, args, context, info):
|
||||||
return resolved
|
return resolved
|
||||||
|
|
||||||
|
|
||||||
class Field(OrderedType):
|
class Field(MountedType):
|
||||||
|
|
||||||
def __init__(self, type, args=None, resolver=None, source=None,
|
def __init__(self, type, args=None, resolver=None, source=None,
|
||||||
deprecation_reason=None, name=None, description=None,
|
deprecation_reason=None, name=None, description=None,
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
from ..utils.orderedtype import OrderedType
|
from .mountedtype import MountedType
|
||||||
from .structures import NonNull
|
from .structures import NonNull
|
||||||
|
|
||||||
|
|
||||||
class InputField(OrderedType):
|
class InputField(MountedType):
|
||||||
|
|
||||||
def __init__(self, type, name=None, default_value=None,
|
def __init__(self, type, name=None, default_value=None,
|
||||||
deprecation_reason=None, description=None,
|
deprecation_reason=None, description=None,
|
||||||
|
|
21
graphene/types/mountedtype.py
Normal file
21
graphene/types/mountedtype.py
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
from ..utils.orderedtype import OrderedType
|
||||||
|
from .unmountedtype import UnmountedType
|
||||||
|
|
||||||
|
|
||||||
|
class MountedType(OrderedType):
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def mount(cls, unmounted): # noqa: N802
|
||||||
|
'''
|
||||||
|
Mount the UnmountedType instance
|
||||||
|
'''
|
||||||
|
assert isinstance(unmounted, UnmountedType), (
|
||||||
|
'{} can\'t mount {}'
|
||||||
|
).format(cls.__name__, repr(unmounted))
|
||||||
|
|
||||||
|
return cls(
|
||||||
|
unmounted.get_type(),
|
||||||
|
*unmounted.args,
|
||||||
|
_creation_counter=unmounted.creation_counter,
|
||||||
|
**unmounted.kwargs
|
||||||
|
)
|
|
@ -27,41 +27,29 @@ class UnmountedType(OrderedType):
|
||||||
'''
|
'''
|
||||||
raise NotImplementedError("get_type not implemented in {}".format(self))
|
raise NotImplementedError("get_type not implemented in {}".format(self))
|
||||||
|
|
||||||
|
def mount_as(self, _as):
|
||||||
|
return _as.mount(self)
|
||||||
|
|
||||||
def Field(self): # noqa: N802
|
def Field(self): # noqa: N802
|
||||||
'''
|
'''
|
||||||
Mount the UnmountedType as Field
|
Mount the UnmountedType as Field
|
||||||
'''
|
'''
|
||||||
from .field import Field
|
from .field import Field
|
||||||
return Field(
|
return self.mount_as(Field)
|
||||||
self.get_type(),
|
|
||||||
*self.args,
|
|
||||||
_creation_counter=self.creation_counter,
|
|
||||||
**self.kwargs
|
|
||||||
)
|
|
||||||
|
|
||||||
def InputField(self): # noqa: N802
|
def InputField(self): # noqa: N802
|
||||||
'''
|
'''
|
||||||
Mount the UnmountedType as InputField
|
Mount the UnmountedType as InputField
|
||||||
'''
|
'''
|
||||||
from .inputfield import InputField
|
from .inputfield import InputField
|
||||||
return InputField(
|
return self.mount_as(InputField)
|
||||||
self.get_type(),
|
|
||||||
*self.args,
|
|
||||||
_creation_counter=self.creation_counter,
|
|
||||||
**self.kwargs
|
|
||||||
)
|
|
||||||
|
|
||||||
def Argument(self): # noqa: N802
|
def Argument(self): # noqa: N802
|
||||||
'''
|
'''
|
||||||
Mount the UnmountedType as Argument
|
Mount the UnmountedType as Argument
|
||||||
'''
|
'''
|
||||||
from .argument import Argument
|
from .argument import Argument
|
||||||
return Argument(
|
return self.mount_as(Argument)
|
||||||
self.get_type(),
|
|
||||||
*self.args,
|
|
||||||
_creation_counter=self.creation_counter,
|
|
||||||
**self.kwargs
|
|
||||||
)
|
|
||||||
|
|
||||||
def __eq__(self, other):
|
def __eq__(self, other):
|
||||||
return (
|
return (
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
|
|
||||||
from .dynamic import Dynamic
|
from .mountedtype import MountedType
|
||||||
from .field import Field
|
|
||||||
from .inputfield import InputField
|
|
||||||
from .unmountedtype import UnmountedType
|
from .unmountedtype import UnmountedType
|
||||||
|
|
||||||
|
|
||||||
|
@ -35,34 +33,16 @@ def get_base_fields(bases, _as=None):
|
||||||
return fields
|
return fields
|
||||||
|
|
||||||
|
|
||||||
def mount_as(unmounted_field, _as):
|
|
||||||
'''
|
|
||||||
Mount the UnmountedType dinamically as Field or InputField
|
|
||||||
'''
|
|
||||||
if _as is None:
|
|
||||||
return unmounted_field
|
|
||||||
|
|
||||||
elif _as is Field:
|
|
||||||
return unmounted_field.Field()
|
|
||||||
|
|
||||||
elif _as is InputField:
|
|
||||||
return unmounted_field.InputField()
|
|
||||||
|
|
||||||
raise Exception(
|
|
||||||
'Unmounted field "{}" cannot be mounted in {}.'.format(
|
|
||||||
unmounted_field, _as
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def get_field_as(value, _as=None):
|
def get_field_as(value, _as=None):
|
||||||
'''
|
'''
|
||||||
Get type mounted
|
Get type mounted
|
||||||
'''
|
'''
|
||||||
if isinstance(value, (Field, InputField, Dynamic)):
|
if isinstance(value, MountedType):
|
||||||
return value
|
return value
|
||||||
elif isinstance(value, UnmountedType):
|
elif isinstance(value, UnmountedType):
|
||||||
return mount_as(value, _as)
|
if _as is None:
|
||||||
|
return value
|
||||||
|
return _as.mount(value)
|
||||||
|
|
||||||
|
|
||||||
def yank_fields_from_attrs(attrs, _as=None, delete=True, sort=True):
|
def yank_fields_from_attrs(attrs, _as=None, delete=True, sort=True):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user