Standard helper for shopinvader routers
Project description
Shopinvader Router Helper
Base helper for all shopinvader routers.
Simple Usage
The helper can be used as-is for a simple inheritable router logic:
@router.get("/name-type/{name}/{type}")
async def name_type(
name: str, type: str, env: Annotated[Environment, Depends(odoo_env)]
):
helper = env["shopinvader.router.name_type.helper"].new(dict(
name=name, type=type
))
return helper.fetch_data()
class RouterHelperNameType(VirtualModel):
_inherit = "shopinvader.router.helper"
_name = "shopinvader.router.name_type.helper"
name = fields.Char()
type = fields.Selection(
selection=[("type_1", "Type 1"), ("type_2", "Type 2")],
default="type_1",
)
def fetch_data(self):
return requests.get("https://my.api/{}/{}".format(self.name, self.type))
CRUD Usage
The helper can also be used to implement a full CRUD logic. For that, you need to define the model to use and the domain to restrict the records operations on.
@router.post("/items/")
async def create_item(
item: ItemCreate, env: Annotated[Environment, Depends(odoo_env)]
):
helper = env["shopinvader.router.item.helper"].new()
return helper.create(item.dict())
@router.get("/items/")
async def read_items(
env: Annotated[Environment, Depends(odoo_env)]
):
helper = env["shopinvader.router.item.helper"].new()
return helper.search()
@router.get("/items/{item_id}")
async def read_item(
item_id: int, env: Annotated[Environment, Depends(odoo_env)]
):
helper = env["shopinvader.router.item.helper"].new()
return helper.get(item_id)
@router.put("/items/{item_id}")
async def update_item(
item_id: int, item: ItemUpdate, env: Annotated[Environment, Depends(odoo_env)]
):
helper = env["shopinvader.router.item.helper"].new()
return helper.write(item_id, item.dict())
@router.delete("/items/{item_id}")
async def delete_item(
item_id: int, env: Annotated[Environment, Depends(odoo_env)]
):
helper = env["shopinvader.router.item.helper"].new()
return helper.unlink(item_id)
class RouterHelperItem(VirtualModel):
_inherit = "shopinvader.router.helper"
_name = "shopinvader.router.item.helper"
_model = "my.item.model"
def _domain(self):
domain = [('api_available', '=', True)]
domain.append(('partner_id', '=', self.partner_id.id))
return domain
TODO
Check helper usage with fastapi dependency injection system for cleaner code.
More utils (pdf export, file handling, …).
Table of contents
Bug Tracker
Bugs are tracked on GitHub 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.
Do not contact contributors directly about support or help with technical issues.
Credits
Contributors
Florian Mounier florian.mounier@akretion.com
Sébastien BEAU sebastien.beau@akretion.com
Maintainers
This module is part of the shopinvader/odoo-shopinvader project on GitHub.
You are welcome to contribute.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file odoo_addon_shopinvader_router_helper-18.0.1.0.0.2-py3-none-any.whl.
File metadata
- Download URL: odoo_addon_shopinvader_router_helper-18.0.1.0.0.2-py3-none-any.whl
- Upload date:
- Size: 21.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2c1385c276d3407e691df78ee1ed02205295640edf95cfc7196428fc8b9e0e55
|
|
| MD5 |
f019d7d9ce7f2718c9502e16520310f6
|
|
| BLAKE2b-256 |
9f2caba6aaef2d2baef81f42d2a2abfaa5b866e13208d7f077aae5b53c0042db
|