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

[15.0][MIG] endpoint_route_handler #44

Closed
wants to merge 36 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
bd4dbe1
Add endpoint_route_handler
simahawk Oct 25, 2021
7d07c29
endpoint_route_handler: reduce log noise
simahawk Nov 18, 2021
36a369b
endpoint_route_handler 14.0.1.0.1
OCA-git-bot Nov 18, 2021
7cb3991
endpoint_route_handler: fix archive/unarchive
simahawk Dec 28, 2021
43b7666
endpoint_route_handler: fix multi env handling
simahawk Dec 29, 2021
9977cdd
endpoint_route_handler 14.0.1.0.2
OCA-git-bot Jan 12, 2022
3ad89dd
Misc fix of authorship name
simahawk Jan 14, 2022
924750f
endpoint_route_handler 14.0.1.0.3
OCA-git-bot Jan 14, 2022
65be5db
endpoint_route_handler: fix rules by group
simahawk Jan 19, 2022
74eb9a8
endpoint_route_handler 14.0.1.0.4
OCA-git-bot Jan 19, 2022
a8f0920
endpoint_route_handler: dev status = Beta
simahawk Apr 4, 2022
4c6a0eb
endpoint_route_handler 14.0.1.1.0
OCA-git-bot Apr 4, 2022
a597af6
endpoint_route_handler: move to OCA/web-api
simahawk Jun 15, 2022
36f3821
[UPD] README.rst
OCA-git-bot Jul 15, 2022
0bf00e7
[UPD] Update endpoint_route_handler.pot
Jul 15, 2022
2dce0d2
[UPD] Update endpoint_route_handler.pot
Jul 15, 2022
68e17cd
endpoint_route_handler: fix cross worker lookup
simahawk Jun 15, 2022
bdff8c8
endpoint_route_handler: add flag to control sync
simahawk Jul 25, 2022
27165a5
endpoint_route_handler: add constraints
simahawk Jul 27, 2022
00b94ed
endpoint_route_handler: add auto timestamp to routes
simahawk Nov 1, 2022
6a86b22
endpoint_route_handler: fix typo in validator
simahawk Jul 25, 2022
2853f6e
endpoint_route_handler: add new tool model
simahawk Feb 16, 2023
41a1d75
endpoint_route_handler: use sequence as version
simahawk Mar 1, 2023
634f576
endpoint_route_handler: log table setup and wipe
simahawk Mar 8, 2023
f13668b
endpoint_route_handler: fail gracefully when sync field not ready
simahawk Mar 8, 2023
ff217b2
endpoint_route_handler: get rid of register_hook
simahawk Mar 27, 2023
0f3d01f
endpoint_route_handler: fix auto_not_found param
simahawk Apr 21, 2023
00d4470
endpoint_route_handler: 14.0.2.0.0
simahawk May 11, 2023
141e888
[UPD] Update endpoint_route_handler.pot
May 11, 2023
1bbc8c0
[UPD] README.rst
OCA-git-bot May 11, 2023
4687b9a
endpoint_route_handler: update ROADMAP
simahawk May 12, 2023
b0463c5
[UPD] README.rst
OCA-git-bot May 12, 2023
120395d
endpoint_route_handler 14.0.2.0.1
OCA-git-bot May 12, 2023
a8cb2dc
[UPD] README.rst
OCA-git-bot Sep 3, 2023
6b5e9d9
Added translation using Weblate (Italian)
mymage Feb 29, 2024
5347d6d
[MIG] endpoint_route_handler: migrate to V15
astirpe May 19, 2024
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
179 changes: 179 additions & 0 deletions endpoint_route_handler/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,179 @@
======================
Endpoint route handler
======================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:b67dfaf93ba5b7b697405ae1415b6b559fc25eb02541ca224cf5bf57e635f725
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-LGPL--3-blue.png
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fweb--api-lightgray.png?logo=github
:target: https://github.com/OCA/web-api/tree/14.0/endpoint_route_handler
:alt: OCA/web-api
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/web-api-14-0/web-api-14-0-endpoint_route_handler
: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/web-api&target_branch=14.0
:alt: Try me on Runboat

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

Technical module that provides a base handler
for adding and removing controller routes on the fly.

Can be used as a mixin or as a tool.

**Table of contents**

.. contents::
:local:

Usage
=====

As a mixin
~~~~~~~~~~

Use standard Odoo inheritance::

class MyModel(models.Model):
_name = "my.model"
_inherit = "endpoint.route.handler"

Once you have this, each `my.model` record will generate a route.
You can have a look at the `endpoint` module to see a real life example.

The options of the routing rules are defined by the method `_default_endpoint_options`.
Here's an example from the `endpoint` module::

def _default_endpoint_options_handler(self):
return {
"klass_dotted_path": "odoo.addons.endpoint.controllers.main.EndpointController",
"method_name": "auto_endpoint",
"default_pargs": (self.route,),
}

As you can see, you have to pass the references to the controller class and the method to use
when the endpoint is called. And you can prepare some default arguments to pass.
In this case, the route of the current record.


As a tool
~~~~~~~~~

Initialize non stored route handlers and generate routes from them.
For instance::

route_handler = self.env["endpoint.route.handler.tool"]
endpoint_handler = MyController()._my_handler
vals = {
"name": "My custom route",
"route": "/my/custom/route",
"request_method": "GET",
"auth_type": "public",
}
new_route = route_handler.new(vals)
new_route._register_controller()

You can override options and define - for instance - a different controller method::

options = {
"handler": {
"klass_dotted_path": "odoo.addons.my_module.controllers.SpecialController",
"method_name": "my_special_handler",
}
}
new_route._register_controller(options=options)

Of course, what happens when the endpoint gets called
depends on the logic defined on the controller method.

In both cases (mixin and tool) when a new route is generated or an existing one is updated,
the `ir.http.routing_map` (which holds all Odoo controllers) will be updated.

You can see a real life example on `shopfloor.app` model.

Known issues / Roadmap
======================

* add api docs helpers
* allow multiple HTTP methods on the same endpoint
* multiple values for route and methods

keep the same in the ui for now, later own we can imagine a multi-value selection or just add text field w/ proper validation and cleanup

remove the route field in the table of endpoint_route

support a comma separated list of routes
maybe support comma separated list of methods
use only routing.routes for generating the rule
sort and freeze its values to update the endpoint hash

catch dup route exception on the sync to detect duplicated routes
and use the endpoint_hash to retrieve the real record
(note: we could store more info in the routing information which will stay in the map)

for customizing the rule behavior the endpoint the hook is to override the registry lookup

make EndpointRule class overridable on the registry

NOTE in v16 we won't care anymore about odoo controller
so the lookup of the controller can be simplified to a basic py obj that holds the routing info.

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

Bugs are tracked on `GitHub Issues <https://github.com/OCA/web-api/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/web-api/issues/new?body=module:%20endpoint_route_handler%0Aversion:%2014.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
~~~~~~~

* Camptocamp

Contributors
~~~~~~~~~~~~

* Simone Orsi <simone.orsi@camptocamp.com>

Maintainers
~~~~~~~~~~~

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

.. |maintainer-simahawk| image:: https://github.com/simahawk.png?size=40px
:target: https://github.com/simahawk
:alt: simahawk

Current `maintainer <https://odoo-community.org/page/maintainer-role>`__:

|maintainer-simahawk|

This module is part of the `OCA/web-api <https://github.com/OCA/web-api/tree/14.0/endpoint_route_handler>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
2 changes: 2 additions & 0 deletions endpoint_route_handler/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
from . import models
from .post_init_hook import post_init_hook
17 changes: 17 additions & 0 deletions endpoint_route_handler/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Copyright 2021 Camptocamp SA
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).

{
"name": "Endpoint route handler",
"summary": """Provide mixin and tool to generate custom endpoints on the fly.""",
"version": "15.0.1.0.0",
"license": "LGPL-3",
"development_status": "Beta",
"author": "Camptocamp,Odoo Community Association (OCA)",
"maintainers": ["simahawk"],
"website": "https://github.com/OCA/web-api",
"data": [
"security/ir.model.access.csv",
],
"post_init_hook": "post_init_hook",
}
1 change: 1 addition & 0 deletions endpoint_route_handler/controllers/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import main
18 changes: 18 additions & 0 deletions endpoint_route_handler/controllers/main.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Copyright 2021 Camptocamp SA
# @author: Simone Orsi <simone.orsi@camptocamp.com>
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).


import logging

from werkzeug.exceptions import NotFound

from odoo import http

_logger = logging.getLogger(__file__)


class EndpointNotFoundController(http.Controller):
def auto_not_found(self, endpoint_route, **params):
_logger.error("Non registered endpoint for %s", endpoint_route)
raise NotFound()
7 changes: 7 additions & 0 deletions endpoint_route_handler/exceptions.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# Copyright 2022 Camptocamp SA
# @author: Simone Orsi <simone.orsi@camptocamp.com>
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).


class EndpointHandlerNotFound(Exception):
"""Raise when an endpoint handler is not found."""
Loading
Loading