http_routing/models/ir_qweb.py

53 lines
1.8 KiB
Python
Raw Normal View History

2024-05-21 15:09:17 +03:00
# Part of Talisman . See LICENSE file for full copyright and licensing details.
2024-05-03 12:59:22 +03:00
import logging
from odoo import models
from odoo.http import request
from odoo.addons.http_routing.models.ir_http import slug, unslug_url, url_for
_logger = logging.getLogger(__name__)
BAD_REQUEST = """Missing request.is_frontend attribute.
The request.is_frontend attribute is missing, this means that although
http_routing is installed and that all incoming requests SHOULD be
going through ir.http._match (which sets that attribute),
there are some rogue requests which do not. This is likely due to a
@route(auth='none') controller which creates its own registry and attempts
to render a template (e.g. odoo/odoo#99667).
The following expectations MUST hold:
When:
* there is an incoming http request (request is truthy)
* there is a registry loaded (models are in use)
* http_routing is installed (dependency of both portal and website)
Then:
* request.is_frontend is set
Failure to meet this expectation can lead to downstream problems, e.g.
here inside of http_routing's ir.qweb. Solutions vary, the one used
inside of #99667 is to use the request.borrow_request context manager to
temporary hide the incoming http request.
"""
class IrQweb(models.AbstractModel):
_inherit = "ir.qweb"
def _prepare_environment(self, values):
irQweb = super()._prepare_environment(values)
values['slug'] = slug
values['unslug_url'] = unslug_url
if not irQweb.env.context.get('minimal_qcontext') and request:
if not hasattr(request, 'is_frontend'):
_logger.warning(BAD_REQUEST, stack_info=True)
elif request.is_frontend:
return irQweb._prepare_frontend_environment(values)
return irQweb
def _prepare_frontend_environment(self, values):
values['url_for'] = url_for
return self