-
-
Notifications
You must be signed in to change notification settings - Fork 426
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[16.0][MIG] account_statement_import_online_ponto: Migration to 16.0 #554
[16.0][MIG] account_statement_import_online_ponto: Migration to 16.0 #554
Conversation
ca1412a
to
3db5d62
Compare
1474034
to
49a3590
Compare
5ce26cf
to
6ac2db2
Compare
8c59283
to
6c86e3a
Compare
6c86e3a
to
5a9b71c
Compare
/ocabot migration account_statement_import_online_ponto |
2cbefb1
to
178a565
Compare
def reset_transactions(date_since): | ||
"""Reset values for new statement.""" | ||
statement_date_since = self._get_statement_date_since(date_since) | ||
statement_date_until = ( | ||
statement_date_since + self._get_statement_date_step() | ||
) | ||
statement_lines = [] | ||
return statement_date_since, statement_date_until, statement_lines | ||
|
||
lines = sorted(lines, key=itemgetter("transaction_datetime")) | ||
( | ||
statement_date_since, | ||
statement_date_until, | ||
statement_lines, | ||
) = reset_transactions(lines[0]["transaction_datetime"]) | ||
for line in lines: | ||
line.pop("transaction_datetime") | ||
vals_line = self._ponto_get_transaction_vals(line) | ||
if vals_line["date"] >= statement_date_until: | ||
self._create_or_update_statement( | ||
(statement_lines, {}), statement_date_since, statement_date_until | ||
) | ||
( | ||
statement_date_since, | ||
statement_date_until, | ||
statement_lines, | ||
) = reset_transactions(statement_date_until) | ||
statement_lines.append(vals_line) | ||
# Handle lines in last statement. | ||
self._create_or_update_statement( | ||
(statement_lines, {}), statement_date_since, statement_date_until | ||
) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After testing this module with real data, we noticed that a few lines were retrieved from ponto but were not imported in odoo. The reason seems to be that the date of the lines not always falls back into the date range (date_since - date_until) and so they are filtered out. I had difficulties to fix this method so I ended up with rewriting this method and simplifying the code this way:
def _ponto_store_lines(self, lines):
"""Store transactions retrieved from Ponto in statements.
"""
lines = sorted(lines, key=itemgetter("transaction_datetime"))
# Group statement lines by date per period (date range)
grouped_periods = {}
for line in lines:
date_since = line["transaction_datetime"]
statement_date_since = self._get_statement_date_since(date_since)
statement_date_until = statement_date_since + self._get_statement_date_step()
if (statement_date_since, statement_date_until) not in grouped_periods:
grouped_periods[(statement_date_since, statement_date_until)] = []
line.pop("transaction_datetime")
vals_line = self._ponto_get_transaction_vals(line)
grouped_periods[(statement_date_since, statement_date_until)].append(vals_line)
# For each period, create or update statement lines
for period, statement_lines in grouped_periods.items():
(statement_date_since, statement_date_until) = period
self._create_or_update_statement(
(statement_lines, {}), statement_date_since, statement_date_until
)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@astirpe Hi, could you make a PR along these lines to my branch? Just to be sure I updated things like intended. Anyway, thank you for your contribution!
17bd08f
to
3d49a70
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Suggestions:
- There is already
account_statement_import_online_migration
PR ([16.0][MIG] account_statement_import_online: Migration to 16.0 #548), we should leave this one only withaccount_statement_import_online_ponto
changes. - Unify all changes in the migration commit.
- Update the translations .pot
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have tested the Module:
- created MyPonto account
- added Odoo integration
- in Odoo Added online bank sync. Important notice: use Clientid from Myponto in field Login in Odoo
- Tested with Daily, weekly and Monthly statement, all lines were retreived complete (this was an issue before the lastest changes)
- Field Partner is now also filled in in odoo, this makes the reconcile process better.
d00405d
to
bc9cada
Compare
1. Find partner if ther already is a bank account with the right IBAN; 2. Store (and display) raw import data to help in problem determination; 3. Make it easy to extend the parsing of import data; 4. Apply some clean coding principles.
Currently translated at 100.0% (16 of 16 strings) Translation: bank-statement-import-14.0/bank-statement-import-14.0-account_statement_import_online_ponto Translate-URL: https://translation.odoo-community.org/projects/bank-statement-import-14-0/bank-statement-import-14-0-account_statement_import_online_ponto/ca/
The 2 modules account_statement_import_online and account_statement_import depend on account_statement_import_base (and not on each other) and share common code, in particular a hook to update the statement line. So we can now have reconciliation modules that use this hook and therefore work both on file import and online import. More details on OCA#481. Improve bank statement line form view and journal form view.
Separate retrieval of data from ponto (buffer data) and creation of statements.
Add debug messages Set raw_data in bank statement lines
With Ponto we can only retrieve data backwards in time. Therefore we override the normal _pull method to create statements in descending order of statement date.
07d0791
to
56880d1
Compare
56880d1
to
bda6315
Compare
@victoralmau I did the rebase and a check. Found one deprecated text in the help for a field. Everything in order now. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code review OK
This PR has the |
/ocabot merge nobump |
What a great day to merge this nice PR. Let's do it! |
Congratulations, your PR was merged at 63086d1. Thanks a lot for contributing to OCA. ❤️ |
This PR includes the changes from #548
If that base PR is merged, this one can be rebased. Conversely when this branch is merged PR 548 can be closed.