oca-ocb-report/odoo-bringout-oca-ocb-spreadsheet/spreadsheet/controllers/main.py
Ernad Husremovic 184bb0e321 19.0 vanilla
2026-03-09 09:32:02 +01:00

45 lines
1.4 KiB
Python

import logging
from odoo import http
from odoo.http import request, Controller
logger = logging.getLogger(__name__)
class SpreadsheetController(Controller):
@http.route("/spreadsheet/log", type="jsonrpc", auth="user", methods=["POST"])
def log_action(self, action_type, datasources, **kw):
if datasources:
self._log_spreadsheet_export(action_type, request.env.uid, datasources)
def _log_spreadsheet_export(self, action_type, user_id, datasources):
if action_type not in ["download", "copy", "freeze", "print"]:
return
data = [src for datasource in datasources if (src := self._stringify_source(datasource))]
if not data:
return
logger.info(
"User %d exported (%s) spreadsheet data (%s) from %s",
user_id, action_type, "), (".join(data), request.httprequest.environ["REMOTE_ADDR"]
)
@staticmethod
def _stringify_source(source):
res_model = source.get("resModel")
if not res_model or res_model not in request.env:
return
if not (fields := source.get("fields", [])):
return
string = f"model: {res_model} with fields: [{','.join(fields)}]"
if groupby := source.get("groupby"):
string += f" grouped by [{','.join(groupby)}]"
if domain := source.get("domain"):
string += f" with domain {domain}"
return string