mirror of
https://github.com/bringout/oca-ocb-report.git
synced 2026-04-20 18:22:07 +02:00
45 lines
1.4 KiB
Python
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
|