oca-ocb-core/odoo-bringout-oca-ocb-web/web/controllers/domain.py
Ernad Husremovic d1963a3c3a vanilla 19.0
2025-10-08 10:49:46 +02:00

35 lines
1.5 KiB
Python

# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo import http, _
from odoo.http import Controller, request
from odoo.exceptions import ValidationError
from odoo.tools import SQL
from odoo.tools.misc import mute_logger
class Domain(Controller):
@http.route('/web/domain/validate', type='jsonrpc', auth="user")
def validate(self, model, domain):
""" Parse `domain` and verify that it can be used to search on `model`
:return: True when the domain is valid, otherwise False
:raises ValidationError: if `model` is invalid
"""
Model = request.env.get(model)
if Model is None:
raise ValidationError(_('Invalid model: %s', model))
try:
# go through the motions of preparing the final SQL for the domain,
# so that anything invalid will raise an exception.
query = Model.sudo()._search(domain)
# Execute the search in EXPLAIN mode, to have the query parser
# verify it. EXPLAIN will make sure the query is never actually executed
# An alternative to EXPLAIN would be a LIMIT 0 clause, but the semantics
# of a falsy `limit` parameter when calling _search() do not permit it.
sql = SQL("EXPLAIN %s", query.select())
with mute_logger('odoo.sql_db'):
request.env.cr.execute(sql)
return True
except Exception: # pylint: disable=broad-except
return False