[14.0]account_ebics - fix stack trace when using Odoo OE statement import

This commit is contained in:
Luc De Meyer 2022-08-05 12:29:47 +02:00
parent c752d1c7a3
commit de5c03c77f
2 changed files with 51 additions and 36 deletions

View File

@ -3,7 +3,7 @@
{ {
"name": "EBICS banking protocol", "name": "EBICS banking protocol",
"version": "14.0.1.0.3", "version": "14.0.1.0.4",
"license": "LGPL-3", "license": "LGPL-3",
"author": "Noviat", "author": "Noviat",
"website": "www.noviat.com", "website": "www.noviat.com",

View File

@ -168,10 +168,12 @@ class EbicsFile(models.Model):
return False return False
return True return True
def _process_result_action(self, res): def _process_result_action(self, res, parser="oca"):
notifications = [] notifications = []
st_line_ids = [] st_line_ids = []
statement_ids = [] statement_ids = []
sts_data = []
if parser == "oca":
if res.get("context"): if res.get("context"):
notifications = res["context"].get("notifications", []) notifications = res["context"].get("notifications", [])
st_line_ids = res["context"].get("statement_line_ids", []) st_line_ids = res["context"].get("statement_line_ids", [])
@ -204,8 +206,21 @@ class EbicsFile(models.Model):
(tuple(st_line_ids),), (tuple(st_line_ids),),
) )
sts_data = self.env.cr.dictfetchall() sts_data = self.env.cr.dictfetchall()
elif parser == "oe":
if res.get("res_id"):
st_ids = res["res_id"]
else: else:
sts_data = [] st_ids = res["domain"][2]
statements = self.env["account.bank.statement"].browse(st_ids)
for statement in statements:
sts_data.append(
{
"statement_id": statement.id,
"date": statement.date,
"name": statement.name,
"company_name": statement.company_id.name,
}
)
st_cnt = len(sts_data) st_cnt = len(sts_data)
if st_cnt: if st_cnt:
self.note_process += _("%s bank statements have been imported: ") % st_cnt self.note_process += _("%s bank statements have been imported: ") % st_cnt
@ -414,7 +429,7 @@ class EbicsFile(models.Model):
_("No financial journal found for Company Bank Account %s") _("No financial journal found for Company Bank Account %s")
% bank_account % bank_account
) )
return self._process_result_action(res) return self._process_result_action(res, parser="oe")
@staticmethod @staticmethod
def _unlink_camt053(self): def _unlink_camt053(self):