mirror of
https://github.com/bringout/oca-ocb-core.git
synced 2026-04-20 07:32:08 +02:00
vanilla 19.0
This commit is contained in:
parent
991d2234ca
commit
d1963a3c3a
3066 changed files with 1651266 additions and 922560 deletions
|
|
@ -1,14 +1,15 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# 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='json', auth="user")
|
||||
@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
|
||||
|
|
@ -21,14 +22,14 @@ class Domain(Controller):
|
|||
# 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)
|
||||
sql, params = query.select()
|
||||
|
||||
# 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(f"EXPLAIN {sql}", params)
|
||||
request.env.cr.execute(sql)
|
||||
return True
|
||||
except Exception: # pylint: disable=broad-except
|
||||
return False
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue