Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[17.0][MIG] graphql_base, graphql_demo #461

Merged
merged 4 commits into from
Oct 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 0 additions & 2 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,6 @@ exclude: |
^extendable_fastapi/|
^fastapi_auth_jwt/|
^fastapi_auth_jwt_demo/|
^graphql_base/|
^graphql_demo/|
^model_serializer/|
^rest_log/|
# END NOT INSTALLABLE ADDONS
Expand Down
108 changes: 54 additions & 54 deletions graphql_base/README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -17,23 +17,22 @@ Graphql Base
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Frest--framework-lightgray.png?logo=github
:target: https://github.com/OCA/rest-framework/tree/16.0/graphql_base
:target: https://github.com/OCA/rest-framework/tree/17.0/graphql_base
:alt: OCA/rest-framework
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/rest-framework-16-0/rest-framework-16-0-graphql_base
:target: https://translation.odoo-community.org/projects/rest-framework-17-0/rest-framework-17-0-graphql_base
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/rest-framework&target_branch=16.0
:target: https://runboat.odoo-community.org/builds?repo=OCA/rest-framework&target_branch=17.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This modules enables the creation of `GraphQL <https://graphql.org/>`__ endpoints.
In itself, it does nothing and must be used by a developer to
This modules enables the creation of `GraphQL <https://graphql.org/>`__
endpoints. In itself, it does nothing and must be used by a developer to
create the GraphQL schema and resolvers using
`graphene <https://graphene-python.org/>`__,
and expose them through a controller.
An example is available in the ``graphql_demo`` module.
`graphene <https://graphene-python.org/>`__, and expose them through a
controller. An example is available in the ``graphql_demo`` module.

**Table of contents**

Expand All @@ -45,87 +44,88 @@ Usage

To use this module, you need to

- create your graphene schema
- create your controller to expose your GraphQL endpoint,
and optionally a GraphiQL IDE.
- create your graphene schema
- create your controller to expose your GraphQL endpoint, and
optionally a GraphiQL IDE.

This module does not attempt to expose the whole Odoo object model.
This could be the purpose of another module based on this one.
We believe however that it is preferable to expose a specific well tested
endpoint for each customer, so as to reduce coupling by knowing precisely
what is exposed and needs to be tested when upgrading Odoo.
This module does not attempt to expose the whole Odoo object model. This
could be the purpose of another module based on this one. We believe
however that it is preferable to expose a specific well tested endpoint
for each customer, so as to reduce coupling by knowing precisely what is
exposed and needs to be tested when upgrading Odoo.

To start working with this module, we recommend the following approach:

- Learn `GraphQL basics <https://graphql.org/learn/>`__
- Learn `graphene <https://graphene-python.org/>`__, the python library
used to create GraphQL schemas and resolvers.
- Examine the ``graphql_demo`` module in this repo, copy it,
adapt the controller to suit your needs (routes, authentication methods).
- Start building your own schema and resolver.
- Learn `GraphQL basics <https://graphql.org/learn/>`__
- Learn `graphene <https://graphene-python.org/>`__, the python library
used to create GraphQL schemas and resolvers.
- Examine the ``graphql_demo`` module in this repo, copy it, adapt the
controller to suit your needs (routes, authentication methods).
- Start building your own schema and resolver.

Building your schema
~~~~~~~~~~~~~~~~~~~~
--------------------

The schema can be built using native graphene types.
An ``odoo.addons.graphql_base.types.OdooObjectType``
is provided as a convenience. It is a graphene ``ObjectType`` with a
default attribute resolver which:
The schema can be built using native graphene types. An
``odoo.addons.graphql_base.types.OdooObjectType`` is provided as a
convenience. It is a graphene ``ObjectType`` with a default attribute
resolver which:

- converts False to None (except for Boolean types), to avoid Odoo's weird
``False`` strings being rendered as json ``"false"``;
- adds the user timezone to Datetime fields;
- raises an error if an attribute is absent to avoid field name typing errors.
- converts False to None (except for Boolean types), to avoid Odoo's
weird ``False`` strings being rendered as json ``"false"``;
- adds the user timezone to Datetime fields;
- raises an error if an attribute is absent to avoid field name typing
errors.

Creating GraphQL controllers
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
----------------------------

The module provides an ``odoo.addons.graphql_base.GraphQLControllerMixin``
class to help you build GraphQL controllers providing GraphiQL and/or GraphQL
endpoints.
The module provides an
``odoo.addons.graphql_base.GraphQLControllerMixin`` class to help you
build GraphQL controllers providing GraphiQL and/or GraphQL endpoints.

.. code-block:: python
.. code:: python

from odoo import http
from odoo.addons.graphql_base import GraphQLControllerMixin
from odoo import http
from odoo.addons.graphql_base import GraphQLControllerMixin

from ..schema import schema
from ..schema import schema


class GraphQLController(http.Controller, GraphQLControllerMixin):
class GraphQLController(http.Controller, GraphQLControllerMixin):

# The GraphiQL route, providing an IDE for developers
@http.route("/graphiql/demo", auth="user")
def graphiql(self, **kwargs):
return self._handle_graphiql_request(schema)
# The GraphiQL route, providing an IDE for developers
@http.route("/graphiql/demo", auth="user")
def graphiql(self, **kwargs):
return self._handle_graphiql_request(schema)

# The graphql route, for applications.
# Note csrf=False: you may want to apply extra security
# (such as origin restrictions) to this route.
@http.route("/graphql/demo", auth="user", csrf=False)
def graphql(self, **kwargs):
return self._handle_graphql_request(schema)
# The graphql route, for applications.
# Note csrf=False: you may want to apply extra security
# (such as origin restrictions) to this route.
@http.route("/graphql/demo", auth="user", csrf=False)
def graphql(self, **kwargs):
return self._handle_graphql_request(schema)

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/rest-framework/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/rest-framework/issues/new?body=module:%20graphql_base%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.
`feedback <https://github.com/OCA/rest-framework/issues/new?body=module:%20graphql_base%0Aversion:%2017.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
~~~~~~~
-------

* ACSONE SA/NV

Maintainers
~~~~~~~~~~~
-----------

This module is maintained by the OCA.

Expand All @@ -145,6 +145,6 @@ Current `maintainer <https://odoo-community.org/page/maintainer-role>`__:

|maintainer-sbidoul|

This module is part of the `OCA/rest-framework <https://github.com/OCA/rest-framework/tree/16.0/graphql_base>`_ project on GitHub.
This module is part of the `OCA/rest-framework <https://github.com/OCA/rest-framework/tree/17.0/graphql_base>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
2 changes: 1 addition & 1 deletion graphql_base/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).

from .controllers import GraphQLControllerMixin
from .types import OdooObjectType
from .graphene_types import OdooObjectType, odoo_attr_resolver
4 changes: 2 additions & 2 deletions graphql_base/__manifest__.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
"name": "Graphql Base",
"summary": """
Base GraphQL/GraphiQL controller""",
"version": "16.0.1.0.1",
"version": "17.0.1.0.1",
"license": "LGPL-3",
"author": "ACSONE SA/NV,Odoo Community Association (OCA)",
"website": "https://github.com/OCA/rest-framework",
Expand All @@ -14,5 +14,5 @@
"external_dependencies": {"python": ["graphene", "graphql_server"]},
"development_status": "Production/Stable",
"maintainers": ["sbidoul"],
"installable": False,
"installable": True,
}
2 changes: 1 addition & 1 deletion graphql_base/controllers/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
from odoo import http


class GraphQLControllerMixin(object):
class GraphQLControllerMixin:
def _parse_body(self):
req = http.request.httprequest
# We use mimetype here since we don't need the other
Expand Down
2 changes: 1 addition & 1 deletion graphql_base/types.py → graphql_base/graphene_types.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,6 @@ 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__(
return super().__init_subclass_with_meta__(
default_resolver=default_resolver, **options
)
22 changes: 22 additions & 0 deletions graphql_base/i18n/it.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * graphql_base
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"PO-Revision-Date: 2024-01-15 17:34+0000\n"
"Last-Translator: mymage <[email protected]>\n"
"Language-Team: none\n"
"Language: it\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 4.17\n"

#. module: graphql_base
#: model_terms:ir.ui.view,arch_db:graphql_base.graphiql
msgid "Loading..."
msgstr "Caricamento ..."
3 changes: 3 additions & 0 deletions graphql_base/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[build-system]
requires = ["whool"]
build-backend = "whool.buildapi"
5 changes: 5 additions & 0 deletions graphql_base/readme/DESCRIPTION.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
This modules enables the creation of [GraphQL](https://graphql.org/)
endpoints. In itself, it does nothing and must be used by a developer to
create the GraphQL schema and resolvers using
[graphene](https://graphene-python.org/), and expose them through a
controller. An example is available in the `graphql_demo` module.
6 changes: 0 additions & 6 deletions graphql_base/readme/DESCRIPTION.rst

This file was deleted.

61 changes: 61 additions & 0 deletions graphql_base/readme/USAGE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
To use this module, you need to

- create your graphene schema
- create your controller to expose your GraphQL endpoint, and
optionally a GraphiQL IDE.

This module does not attempt to expose the whole Odoo object model. This
could be the purpose of another module based on this one. We believe
however that it is preferable to expose a specific well tested endpoint
for each customer, so as to reduce coupling by knowing precisely what is
exposed and needs to be tested when upgrading Odoo.

To start working with this module, we recommend the following approach:

- Learn [GraphQL basics](https://graphql.org/learn/)
- Learn [graphene](https://graphene-python.org/), the python library
used to create GraphQL schemas and resolvers.
- Examine the `graphql_demo` module in this repo, copy it, adapt the
controller to suit your needs (routes, authentication methods).
- Start building your own schema and resolver.

## Building your schema

The schema can be built using native graphene types. An
`odoo.addons.graphql_base.types.OdooObjectType` is provided as a
convenience. It is a graphene `ObjectType` with a default attribute
resolver which:

- converts False to None (except for Boolean types), to avoid Odoo's
weird `False` strings being rendered as json `"false"`;
- adds the user timezone to Datetime fields;
- raises an error if an attribute is absent to avoid field name typing
errors.

## Creating GraphQL controllers

The module provides an `odoo.addons.graphql_base.GraphQLControllerMixin`
class to help you build GraphQL controllers providing GraphiQL and/or
GraphQL endpoints.

``` python
from odoo import http
from odoo.addons.graphql_base import GraphQLControllerMixin

from ..schema import schema


class GraphQLController(http.Controller, GraphQLControllerMixin):

# The GraphiQL route, providing an IDE for developers
@http.route("/graphiql/demo", auth="user")
def graphiql(self, **kwargs):
return self._handle_graphiql_request(schema)

# The graphql route, for applications.
# Note csrf=False: you may want to apply extra security
# (such as origin restrictions) to this route.
@http.route("/graphql/demo", auth="user", csrf=False)
def graphql(self, **kwargs):
return self._handle_graphql_request(schema)
```
62 changes: 0 additions & 62 deletions graphql_base/readme/USAGE.rst

This file was deleted.

Loading
Loading