Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
1484599
Add endpoint_route_handler
simahawk Oct 25, 2021
c949e3f
endpoint_route_handler: reduce log noise
simahawk Nov 18, 2021
8552694
endpoint_route_handler 14.0.1.0.1
OCA-git-bot Nov 18, 2021
b2f7d95
endpoint_route_handler: fix archive/unarchive
simahawk Dec 28, 2021
72e7949
endpoint_route_handler: fix multi env handling
simahawk Dec 29, 2021
78dbd6a
endpoint_route_handler 14.0.1.0.2
OCA-git-bot Jan 12, 2022
2ed66f0
Misc fix of authorship name
simahawk Jan 14, 2022
5b9bd25
endpoint_route_handler 14.0.1.0.3
OCA-git-bot Jan 14, 2022
7f693c0
endpoint_route_handler: fix rules by group
simahawk Jan 19, 2022
e6dec9a
endpoint_route_handler 14.0.1.0.4
OCA-git-bot Jan 19, 2022
658270c
endpoint_route_handler: dev status = Beta
simahawk Apr 4, 2022
55f16a2
endpoint_route_handler 14.0.1.1.0
OCA-git-bot Apr 4, 2022
21941fe
endpoint_route_handler: move to OCA/web-api
simahawk Jun 15, 2022
12ddc80
[UPD] README.rst
OCA-git-bot Jul 15, 2022
99e0177
[UPD] Update endpoint_route_handler.pot
Jul 15, 2022
ba0986c
[UPD] Update endpoint_route_handler.pot
Jul 15, 2022
4d1beaa
endpoint_route_handler: fix cross worker lookup
simahawk Jun 15, 2022
919cb88
endpoint_route_handler: add flag to control sync
simahawk Jul 25, 2022
9e46c6e
endpoint_route_handler: add constraints
simahawk Jul 27, 2022
41159c5
endpoint_route_handler: add auto timestamp to routes
simahawk Nov 1, 2022
49e8353
endpoint_route_handler: fix typo in validator
simahawk Jul 25, 2022
2e37783
endpoint_route_handler: add new tool model
simahawk Feb 16, 2023
99368fd
endpoint_route_handler: use sequence as version
simahawk Mar 1, 2023
eba5b34
endpoint_route_handler: log table setup and wipe
simahawk Mar 8, 2023
b8653a8
endpoint_route_handler: fail gracefully when sync field not ready
simahawk Mar 8, 2023
2bd7601
endpoint_route_handler: get rid of register_hook
simahawk Mar 27, 2023
f915c73
endpoint_route_handler: fix auto_not_found param
simahawk Apr 21, 2023
7cc7015
endpoint_route_handler: 14.0.2.0.0
simahawk May 11, 2023
76ad714
[UPD] Update endpoint_route_handler.pot
May 11, 2023
e3e3ec0
[UPD] README.rst
OCA-git-bot May 11, 2023
759945f
endpoint_route_handler: update ROADMAP
simahawk May 12, 2023
6363d09
[UPD] README.rst
OCA-git-bot May 12, 2023
9401bfb
endpoint_route_handler 14.0.2.0.1
OCA-git-bot May 12, 2023
4dd745c
endpoint_route_handler: migrate to v16
simahawk Feb 16, 2023
994231a
endpoint_route_handler: adapt to new dispatch
simahawk Feb 16, 2023
1c86e50
[UPD] Update endpoint_route_handler.pot
Jun 6, 2023
b7c10e9
[UPD] README.rst
OCA-git-bot Jun 6, 2023
9f8cbd8
[IMP] endpoint_route_handler: add request_content_type application_js…
OriolMForgeFlow Jul 17, 2023
9b2e639
endpoint_route_handler 16.0.1.1.0
OCA-git-bot Jul 20, 2023
395a263
[UPD] Update endpoint_route_handler.pot
Jul 25, 2023
d5a668f
[UPD] README.rst
OCA-git-bot Sep 3, 2023
575a692
Added translation using Weblate (Italian)
mymage Nov 27, 2023
336db37
Translated using Weblate (Italian)
mymage Nov 27, 2023
0b73a05
[IMP] endpoint_route_handler: pre-commit auto fixes
nguyenminhchien Dec 27, 2023
3564651
[MIG] endpoint_route_handler: Migration to 17.0
nguyenminhchien Dec 28, 2023
0a7012d
[UPD] Update endpoint_route_handler.pot
Jan 8, 2024
66cabdb
[BOT] post-merge updates
OCA-git-bot Jan 8, 2024
d77238f
Update translation files
weblate Feb 3, 2024
021af3e
[FIX] endpoint_route_handler: Line too long
pedrobaeza May 2, 2024
f86701c
[BOT] post-merge updates
OCA-git-bot May 2, 2024
bf457e9
[FIX] endpoint_route_handler: acl warning
qgroulard Aug 21, 2024
7066d3c
[BOT] post-merge updates
OCA-git-bot Oct 25, 2024
fc79276
[18.0][MIG] endpoint_route_handler: Migration to 18.0
cormaza Nov 8, 2024
9b1ba91
[UPD] Update endpoint_route_handler.pot
Jan 30, 2025
43980e9
[BOT] post-merge updates
OCA-git-bot Jan 30, 2025
2d91159
Update translation files
weblate Jan 30, 2025
b84fc92
[UPD] Update endpoint_route_handler.pot
Jan 31, 2025
4c5782c
Update translation files
weblate Jan 31, 2025
78addef
Translated using Weblate (Italian)
mymage Jan 31, 2025
6dcda36
Added translation using Weblate (Chinese (Simplified) (zh_CN))
xtanuiha Apr 13, 2025
b9004c5
Translated using Weblate (Chinese (Simplified) (zh_CN))
xtanuiha Apr 13, 2025
03842e3
endpoint_route_handler: wipe cache only once on sync
simahawk Jul 15, 2025
129e64d
[BOT] post-merge updates
OCA-git-bot Jul 29, 2025
481eaf7
[IMP] endpoint_route_handler: pre-commit stuff
rven Oct 6, 2025
a1015b3
[MIG] endpoint_route_handler: Migration to 19.0
rven Oct 7, 2025
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
200 changes: 200 additions & 0 deletions endpoint_route_handler/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,200 @@
.. image:: https://odoo-community.org/readme-banner-image
:target: https://odoo-community.org/get-involved?utm_source=readme
:alt: Odoo Community Association

======================
Endpoint route handler
======================

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

.. |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/license-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/19.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-19-0/web-api-19-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=19.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:%2019.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>
- Nguyen Minh Chien <chien@trobz.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/19.0/endpoint_route_handler>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
3 changes: 3 additions & 0 deletions endpoint_route_handler/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
from . import models
from . import wizard
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": "19.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