-
-
Notifications
You must be signed in to change notification settings - Fork 298
/
types.py
43 lines (32 loc) · 1.44 KB
/
types.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# Copyright 2018 ACSONE SA/NV
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
import graphene
from odoo import fields
def odoo_attr_resolver(attname, default_value, root, info, **args):
"""An attr resolver that is specialized for Odoo recordsets.
It converts False to None, except for Odoo Boolean fields.
This is necessary because Odoo null values are often represented
as False, and graphene would convert a String field with value False
to "false".
It converts datetimes to the user timezone.
It also raises an error if the attribute is not present, ignoring
any default value, so as to return if the schema declares a field
that is not present in the underlying Odoo model.
"""
value = getattr(root, attname)
field = root._fields.get(attname)
if value is False:
if not isinstance(field, fields.Boolean):
return None
elif isinstance(field, fields.Datetime):
return fields.Datetime.context_timestamp(root, value)
return value
class OdooObjectType(graphene.ObjectType):
"""A graphene ObjectType with an Odoo aware default resolver."""
@classmethod
def __init_subclass_with_meta__(cls, default_resolver=None, **options):
if default_resolver is None:
default_resolver = odoo_attr_resolver
return super(OdooObjectType, cls).__init_subclass_with_meta__(
default_resolver=default_resolver, **options
)