Skip to content
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

[13.0][MIG] account_invoice_import: Migration to 13.0 #1092

Open
wants to merge 176 commits into
base: 13.0
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
176 commits
Select commit Hold shift + click to select a range
960fd4c
Rename module from account_invoice_pdf_import to account_invoice_import
alexis-via Dec 30, 2015
798c5f4
Update FR translation
alexis-via Jan 7, 2016
c22282c
Add instructions to use my PPA for poppler-utils on Ubuntu 14.04 LTS …
alexis-via Jan 9, 2016
e858f30
Add support for direct import of XML files (YAML test provided)
alexis-via Jan 19, 2016
fdc401d
Sometimes, it's easier to extract the total tax amount instead of the…
Jan 20, 2016
8585839
Add an explaination about date parsing in invoice2data
alexis-via Jan 22, 2016
6ddd301
Add optional support for start/end dates
Jan 22, 2016
c6c6d65
Adapt to latest changes in invoice2data
alexis-via Jan 27, 2016
f5baeca
Only change name_get of invoice for our use-case, not everywhere
alexis-via Jan 28, 2016
8b86b2c
Update README with latest changes in invoice2data lib
alexis-via Jan 28, 2016
ab51b7d
Add support for partner_email to match partners
Feb 2, 2016
148efec
Update installation procedure.
alexis-via Feb 11, 2016
0cf20d2
Add modules base_zugferd, account_invoice_import_zugferd and account_…
alexis-via Feb 22, 2016
fadc305
Log raw result of invoice2data (before we make modifications)
alexis-via Mar 2, 2016
79ed33e
Fix error in README spotted by Roel Adriaans
alexis-via Mar 15, 2016
6de8555
Add module account_invoice_import_ubl
alexis-via Mar 15, 2016
cc95525
Use base_vat_sanitized
alexis-via May 13, 2016
ef7efab
Add support for import of e-fff invoices (Belgian standard)
alexis-via May 21, 2016
9a31bf1
Add support for local invoice template for invoice2data, see README
alexis-via May 25, 2016
853292e
Small usability improvement
alexis-via Jun 21, 2016
144236b
Checks that the directory really exists
alexis-via Jul 3, 2016
208f07d
Extract regular PDF invoice import from account_invoice_import to a d…
alexis-via Aug 5, 2016
2580794
Adapt code to plug the module 'ovh_supplier_invoice'
alexis-via Aug 12, 2016
04658ec
Fix product matching
alexis-via Aug 12, 2016
cea0ac0
FIX PEP8 and account_invoice_import_invoice2data unittests
alexis-via Aug 15, 2016
8bbb73b
Add module base_business_document_import and start to move some code …
alexis-via Aug 17, 2016
2fa542a
Better/cleaner pivot invoice dict format (no more IDs in the pivot in…
alexis-via Aug 18, 2016
c3eac34
Add module base_ubl (common methods to generate and parse UBL files)
alexis-via Aug 21, 2016
123e932
Add module base_phone_business_document_import
alexis-via Aug 24, 2016
b932c43
Add a unittest on _match_uom
alexis-via Aug 25, 2016
92095cf
Add module base_business_document_import_stock
alexis-via Aug 26, 2016
fd4f360
Update invoice lines on "Update Existing" invoice import
alexis-via Aug 27, 2016
ff951e7
Fix crash
alexis-via Aug 27, 2016
fd8416d
Add multi-company ir.rule on account.invoice.import.config
alexis-via Sep 14, 2016
e6eb2be
FIX Don't use _inherit = ['business.document.import']
alexis-via Sep 28, 2016
ebeeac3
Fix method call
alexis-via Oct 2, 2016
a46817d
[IMP] handle the case where the xml file is generated with mime type
adrienpeiffer Oct 4, 2016
07a1bc4
Add support for extraction + matching on website
alexis-via Oct 4, 2016
1877cc9
FIX two stupid bugs
alexis-via Oct 4, 2016
1dc3e6e
8.0 Add support for partner bank matching on invoice update (#6)
Oct 18, 2016
eac5b77
8.0 Use try/except when importing external libs (#8)
Oct 19, 2016
f8c2996
[MIG] Make modules uninstallable
hbrunn Nov 12, 2016
7bd1e6d
OCA Transbot updated translations from Transifex
oca-transbot Nov 29, 2016
1484d87
[ADD] migration of account_invoice_import_invoice2data and dependencies
hbrunn Dec 29, 2016
769cffe
Add support for 'origin' field in invoice import
alexis-via Jan 6, 2017
d8b3e32
[FIX] product.product#ean13 was renamed to barcode
hbrunn Jan 9, 2017
bf54282
[FIX] tests
hbrunn Jan 9, 2017
9d7ffb4
Port base_business_document_import* to v10
alexis-via Feb 15, 2017
31eeb3b
Allow importing invoice without invoice_import_config on partner (use…
alexis-via Mar 27, 2017
2faa2d9
Several fixes in account_invoice_import
alexis-via Apr 11, 2017
4fa2c21
Improve XML for Factur-X
alexis-via Jul 28, 2017
8faa844
Add first support for the import of Factur-X invoices
alexis-via Aug 10, 2017
c0ad0cd
Add support for allowance and charges on Factur-X invoice import
alexis-via Aug 11, 2017
8de48cb
Fix bug #16 : add support for adjustment lines (per line and global)
alexis-via Aug 13, 2017
b2e8c83
account_invoice_factur-x: now generate refunds with document type = 3…
alexis-via Aug 15, 2017
5bf80e5
Pre-process parsed_inv even when calling directly _create_invoice()
alexis-via Aug 15, 2017
ab79b90
Add support for importing customer invoices (bug #24)
alexis-via Aug 15, 2017
86bc772
Improve + modularize generation of UBL (up-port from v8 PR)
alexis-via Aug 23, 2017
6256b46
Finalise the use of the FacturX lib
alexis-via Sep 6, 2017
ebb21e2
account_invoice_import: workaround a framework bug
alexis-via Oct 4, 2017
c45f485
account_invoice_import: Add partner_type to _match_partner method for…
alexis-via Oct 14, 2017
1eb3866
OCA Transbot updated translations from Transifex
oca-transbot Feb 10, 2018
6892df2
[10.0] Update to work with latest version of invoice2data (#51)
Mar 11, 2018
7a62fae
OCA Transbot updated translations from Transifex
oca-transbot Mar 31, 2018
69f7898
[10.0] Several fixes + import invoices with VAT in a company that can…
Jul 31, 2018
787c9ae
[UPD] Update account_invoice_import.pot
oca-travis Jul 31, 2018
532c0ff
Fix import of sale order with price_source='pricelist' when pricelist…
alexis-via Aug 14, 2018
5f38dc7
Partner <-> Invoice import config : switch M2O <-> O2M
alexis-via Jan 18, 2018
3db1425
Add migration script
alexis-via Jan 19, 2018
694bdca
Add support for multiple invoice import configs in invoice import wizard
alexis-via Aug 14, 2018
1a1fb28
Add O2M field from import config to download config
alexis-via Aug 14, 2018
c389ab7
Finalize the development account_invoice_download
alexis-via Aug 18, 2018
0016ce9
Add support for additional module-specific weboob config parameters
alexis-via Aug 19, 2018
fbeff28
account_invoice_import: add a mail gateway
alexis-via Aug 22, 2018
f2c2909
Add ability to run cron invoice download from admin for all companies…
alexis-via Aug 23, 2018
fd62be3
Add multi-company support in the invoice import mail gateway
alexis-via Aug 24, 2018
00f24cd
Check the VAT number of the destination partner, to make sure the bus…
alexis-via Aug 25, 2018
ac7def2
[UPD] Update account_invoice_import.pot
oca-travis Sep 16, 2018
e37acd8
[FIX] include some of the fixes proposed in #64
Aug 15, 2018
85527a9
[11.0][MIG] account_invoice_import
Oct 2, 2018
f346822
[FIX] clean rebase from V10 that where wrong ...
Oct 2, 2018
bb49801
[FIX] utf8 comment in python3
Oct 2, 2018
630e820
Fix base64 encode/decode + remove supplier_invoice_number + code review
astirpe Oct 12, 2018
68e442c
[UPD] Update account_invoice_import.pot
oca-travis Oct 17, 2018
2c6fd82
Update translation files
oca-transbot Dec 29, 2018
c1dbe4b
[ADD] icon.png
OCA-git-bot Apr 3, 2019
f265ea1
[UPD] Update account_invoice_import.pot
oca-travis Apr 3, 2019
c255246
Update translation files
oca-transbot May 20, 2019
2ebc694
[UPD] README.rst
OCA-git-bot Jul 29, 2019
cf816f7
[12.0][MIG] account_invoice_import
astirpe Jan 3, 2020
3f2f750
[UPD] README.rst
OCA-git-bot Jan 22, 2020
e1c56e7
[UPD] Update account_invoice_import.pot
oca-travis Jan 22, 2020
015a86d
Update translation files
oca-transbot Feb 10, 2020
dec38a0
account_invoice_download: start OCA import bill wizard when using the…
alexis-via Feb 13, 2020
5dc28a4
Added translation using Weblate (German)
tv-openbig Mar 16, 2020
b8e3fb8
Translated using Weblate (German)
tv-openbig Mar 16, 2020
d87bf06
[MIG] account_invoice_import_facturx to v12
alexis-via Apr 14, 2020
49307f4
[UPD] Update account_invoice_import.pot
oca-travis Apr 29, 2020
39c4730
Update translation files
oca-transbot Apr 29, 2020
5c42ac0
Translated using Weblate (German)
marylla May 27, 2020
7b421b7
[IMP] account_invoice_import: black, isort, prettier
yvaucher Jun 23, 2020
e3b6b8e
[MIG] account_invoice_import: Migration to 13.0
yvaucher Jun 23, 2020
935ddb1
[IMP] account_invoice_import: parsed invoice hook
yvaucher Jun 23, 2020
00a4047
[IMP] account_invoice_import: Missing partner hook
yvaucher Jun 24, 2020
c65ce87
Add a quick import invoice button
yvaucher Jun 25, 2020
13d6d26
Restore dashboard button overwrite
yvaucher Jun 27, 2020
e485bb4
[RM] invoice line doesn't exist on V13
vrenaville Jan 21, 2021
7c4ad94
[FIX] account_invoice_import: fix headers
NL66278 Dec 2, 2020
9624edb
[FIX] account_invoice_import: Reduce method complexity.
NL66278 Dec 2, 2020
5be78fe
[FIX] account_invoice_import. Do not shadow config module with variable.
NL66278 Dec 3, 2020
f5d845a
[MIG] account_invoice_import to v14
alexis-via May 25, 2021
2a73e20
[FIX] account_invoice_import: mail gateway exception
StefanRijnhart May 26, 2021
ff87e09
account_invoice_import: Add USAGE.rst
alexis-via May 31, 2021
7cbb00d
[UPD] Update account_invoice_import.pot
oca-travis Jun 2, 2021
f093e44
[UPD] README.rst
OCA-git-bot Jun 2, 2021
7dbee53
account_invoice_import: fix analytic account field name
alexis-via Jun 7, 2021
6b9c7a7
account_invoice_import: FIX import config creation from partner
alexis-via Jun 7, 2021
0cef4e2
invoice_import: add button box div in account.invoice.import.config f…
alexis-via Jun 9, 2021
92a4fca
account_invoice_import 14.0.1.1.0
OCA-git-bot Jun 11, 2021
6671581
Translated using Weblate (French)
Yvesldff Jun 17, 2021
52ab8ad
Added translation using Weblate (Dutch)
bosd Jan 27, 2022
7a7e238
Translated using Weblate (Dutch)
bosd Jan 27, 2022
0c61b32
[FIX] Fix access right issues when using actions
sebalix Jan 31, 2022
f60dbc9
account_invoice_import 14.0.1.1.1
OCA-git-bot Jan 31, 2022
87b15f7
[FIX] access to form view of partners for users who are not accountants
alexis-via Feb 13, 2022
1394517
account_invoice_import 14.0.2.0.0
OCA-git-bot Feb 14, 2022
ac23c9d
Translated using Weblate (Dutch)
bosd May 15, 2022
516f86f
account_invoice_import: tests use setUpClass
simahawk May 26, 2022
6974f23
account_invoice_import: fix error logging
simahawk May 26, 2022
62d1d5f
account_invoice_import: more tests for mail gateway
simahawk May 26, 2022
fab6098
[UPD] README.rst
OCA-git-bot May 27, 2022
aeee52d
account_invoice_import 14.0.2.0.1
OCA-git-bot May 27, 2022
a19ce1a
account_invoice_import: Set a specific journal
alexis-via May 20, 2022
92f1c20
[FIX] account_invoice_import: force tax amount on supplier refunds
alexis-via Jun 2, 2022
e48c2ac
[UPD] Update account_invoice_import.pot
Jul 13, 2022
680a224
[UPD] README.rst
OCA-git-bot Jul 13, 2022
9021cf4
account_invoice_import 14.0.2.1.0
OCA-git-bot Jul 13, 2022
b40ba41
account_invoice_import: improve handling of simple PDF invoices
alexis-via Jul 14, 2022
75a514e
Update translation files
oca-transbot Jul 16, 2022
8b8ca76
account_invoice_import: skip mail attachments that are not PDF nor XML
alexis-via Aug 3, 2022
087cfe1
Translated using Weblate (French)
klodr Aug 7, 2022
262bfe4
[UPD] Update account_invoice_import.pot
Sep 27, 2022
9faa4e3
account_invoice_import 14.0.3.0.0
OCA-git-bot Sep 27, 2022
af6c12d
Update translation files
oca-transbot Sep 27, 2022
b0e1d7b
account_invoice_import: add support for additional fields
bosd May 14, 2022
173d2cd
Translated using Weblate (Dutch)
bosd Feb 7, 2023
3319ca3
[UPD] README.rst
OCA-git-bot Feb 9, 2023
80fea89
account_invoice_import 14.0.3.0.1
OCA-git-bot Feb 9, 2023
aad41ae
[REM] states on group is malicious as shadowing states on fields
i-vyshnevska Jun 15, 2022
9603b36
[IMP] set proper state with message instead of error raising
i-vyshnevska Feb 26, 2023
af98b11
account_invoice_import: Improve comments
bosd Mar 9, 2023
1fa5412
Update account_invoice_import.py
bosd Mar 13, 2023
7e594ce
Update account_invoice_import.py
bosd Mar 14, 2023
ccc40cf
account_invoice_import 14.0.3.1.0
OCA-git-bot Mar 23, 2023
f4441ca
[FIX] account_invoice_import: crash due to missing method
alexis-via Mar 23, 2023
5a285b5
account_invoice_import 14.0.3.2.0
OCA-git-bot Mar 24, 2023
5ab3def
Translated using Weblate (French)
klodr May 29, 2023
2ced64a
[UPD] README.rst
OCA-git-bot Sep 3, 2023
7fe1bb0
Translated using Weblate (French)
Sep 1, 2023
25b4ef6
account_invoice_import: use OCA wiz from in invoice tree view
alexis-via Oct 9, 2023
a7b75ad
[UPD] Update account_invoice_import.pot
Oct 16, 2023
909311a
[BOT] post-merge updates
OCA-git-bot Oct 16, 2023
7d1612c
Update translation files
weblate Oct 16, 2023
4095200
[UPD] Update account_invoice_import.pot
Oct 27, 2023
a5bdd8d
*: Fix pylint
etobella Oct 29, 2023
662cd72
[UPD] Update account_invoice_import.pot
Oct 29, 2023
777dedc
[BOT] post-merge updates
OCA-git-bot Oct 29, 2023
af99bca
Update translation files
weblate Oct 29, 2023
a3134a7
[IMP] account_invoice_import: Add a unit test with tax included
yvaucher Feb 8, 2021
dadb741
[FIX] account_invoice_import: fix unit test with tax included
i-vyshnevska Feb 12, 2021
6549297
[BOT] post-merge updates
OCA-git-bot Nov 1, 2023
fcf1ee2
Translated using Weblate (Spanish)
Ivorra78 Nov 22, 2023
cf2017c
[IMP] account_invoice_import: add support for discount
alexis-via Jul 25, 2024
6162dd3
[BOT] post-merge updates
OCA-git-bot Sep 16, 2024
141632e
[IMP] account_invoice_import: black, isort, prettier
HeliconiaSolutions Dec 3, 2024
35776c4
[MIG] account_invoice_import: Backported to 13.0
HeliconiaSolutions Dec 9, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Better/cleaner pivot invoice dict format (no more IDs in the pivot in…
…voice dict, cleaner organisation)

Code refactoring: move code in base_business_document_import, factorise code for tax matching (it was duplicated in UBL and ZUGFeRD)
Now support PDF with embedded UBL XML file
Enable unittests on account_invoice_import_ubl
More absolute xpath in account_invoice_import_ubl instead of relative xpath

WARNING: these are big changes, I may have broken a few details
alexis-via authored and HeliconiaSolutions committed Dec 3, 2024
commit 2fa542a1c4ead5d9c429cb8608572ab11a97e41b
80 changes: 50 additions & 30 deletions account_invoice_import/wizard/account_invoice_import.py
Original file line number Diff line number Diff line change
@@ -53,12 +53,20 @@ def parse_pdf_invoice(self, file_data):
'''This method must be inherited by additionnal modules with
the same kind of logic as the account_bank_statement_import_*
modules'''
res = self.fallback_parse_pdf_invoice(file_data)
if not res:
xml_files_dict = self.get_xml_files_from_pdf(file_data)
for xml_filename, xml_root in xml_files_dict.iteritems():
logger.info('Trying to parse XML file %s', xml_filename)
try:
parsed_inv = self.parse_xml_invoice(xml_root)
return parsed_inv
except:
continue
parsed_inv = self.fallback_parse_pdf_invoice(file_data)
if not parsed_inv:
raise UserError(_(
"This type of PDF invoice is not supported. Did you install "
"the module to support this type of file?"))
return res
return parsed_inv

def fallback_parse_pdf_invoice(self, file_data):
'''Designed to be inherited by the module
@@ -70,35 +78,37 @@ def fallback_parse_pdf_invoice(self, file_data):

# Dict to return:
# {
# 'currency_iso': 'EUR',
# 'currency_symbol': u'€', # The one or the other
# 'currency': res.currency recordset,
# 'currency': {
# 'iso': 'EUR',
# 'currency_symbol': u'€', # The one or the other
# },
# 'date': '2015-10-08', # Must be a string
# 'date_due': '2015-11-07',
# 'date_start': '2015-10-01', # for services over a period of time
# 'date_end': '2015-10-31',
# 'amount_untaxed': 10.0, # < 0 for refunds
# 'amount_tax': 2.0, # provide amount_untaxed OR amount_tax
# 'amount_total': 12.0, # Total with taxes, must always be provided
# 'partner_vat': 'FR25499247138',
# 'partner_email': '[email protected]'
# partner_email is not needed if we have VAT
# 'partner_name': 'Capitaine Train'
# partner_name is not needed if we have VAT or partner_email
# 'partner': {
# 'vat': 'FR25499247138',
# 'email': '[email protected]',
# 'name': 'Capitaine Train',
# },
# 'partner': res.partner recordset,
# 'invoice_number': 'I1501243',
# 'description': 'TGV Paris-Lyon',
# 'attachments': {'file1.pdf': base64data1, 'file2.pdf': base64data2},
# 'chatter_msg': 'Note added in chatter of the invoice',
# 'lines': [{
# 'product_ean13': '4123456000021',
# 'product_code': 'GZ250',
# 'product': Odoo product.product recordset,
# 'product': {
# 'ean13': '4123456000021',
# 'code': 'GZ250',
# },
# 'name': 'Gelierzucker Extra 250g',
# 'price_unit': 1.45, # price_unit always positive
# 'quantity': -2.0, # < 0 when it's a refund
# 'uos_id': ID product.uom,
# 'tax_ids': [ID account.tax],
# 'uom': {'unece_code': 'C62'},
# 'taxes': [list of tax_dict],
# }],
# }

@@ -108,8 +118,10 @@ def _prepare_create_invoice_vals(self, parsed_inv):
ailo = self.env['account.invoice.line']
company = self.env.user.company_id
assert parsed_inv.get('amount_total'), 'Missing amount_total'
partner = self._match_partner(parsed_inv)
currency = self._match_currency(parsed_inv)
partner = self._match_partner(
parsed_inv['partner'], parsed_inv['chatter_msg'])
currency = self._match_currency(
parsed_inv.get('currency'), parsed_inv['chatter_msg'])
vals = {
'partner_id': partner.id,
'currency_id': currency.id,
@@ -148,10 +160,10 @@ def _prepare_create_invoice_vals(self, parsed_inv):
'bank_bic': parsed_inv.get('bic'),
})
vals['partner_bank_id'] = partner_bank.id
parsed_inv['chatter_msg'] = _(
parsed_inv['chatter_msg'].append(_(
"The bank account <b>IBAN %s</b> has been automatically "
"added on the supplier <b>%s</b>") % (
parsed_inv['iban'], partner.name)
parsed_inv['iban'], partner.name))
config = partner.invoice_import_id
if config.invoice_line_method.startswith('1line'):
if config.invoice_line_method == '1line_no_product':
@@ -203,7 +215,8 @@ def _prepare_create_invoice_vals(self, parsed_inv):
for line in parsed_inv['lines']:
il_vals = static_vals.copy()
if config.invoice_line_method == 'nline_auto_product':
product = self._match_product(line, partner)
product = self._match_product(
line['product'], parsed_inv['chatter_msg'], partner)
fposition_id = partner.property_account_position.id
il_vals.update(
ailo.product_id_change(
@@ -213,13 +226,16 @@ def _prepare_create_invoice_vals(self, parsed_inv):
company_id=company.id)['value'])
il_vals['product_id'] = product.id
elif config.invoice_line_method == 'nline_no_product':
il_vals['invoice_line_tax_id'] = line['tax_ids']
taxes = self._match_taxes(
line.get('taxes'), parsed_inv['chatter_msg'])
il_vals['invoice_line_tax_id'] = taxes.ids
if line.get('name'):
il_vals['name'] = line['name']
elif not il_vals.get('name'):
il_vals['name'] = _('MISSING DESCRIPTION')
if line.get('uos_id'):
il_vals['uos_id'] = line['uos_id']
uom = self._match_uom(
line.get('uom'), parsed_inv['chatter_msg'])
il_vals['uos_id'] = uom.id
il_vals.update({
'quantity': line['quantity'],
'price_unit': line['price_unit'],
@@ -323,6 +339,8 @@ def update_clean_parsed_inv(self, parsed_inv):
line['price_unit'], precision_digits=prec_pp)
if parsed_inv['type'] == 'in_refund':
line['quantity'] *= -1
if 'chatter_msg' not in parsed_inv:
parsed_inv['chatter_msg'] = []
logger.debug('Resulf of invoice parsing parsed_inv=%s', parsed_inv)
return parsed_inv

@@ -333,10 +351,12 @@ def import_invoice(self):
aio = self.env['account.invoice']
iaao = self.env['ir.actions.act_window']
parsed_inv = self.parse_invoice()
partner = self._match_partner(parsed_inv)
currency = self._match_currency(parsed_inv)
parsed_inv['partner'] = partner
parsed_inv['currency'] = currency
partner = self._match_partner(
parsed_inv['partner'], parsed_inv['chatter_msg'])
currency = self._match_currency(
parsed_inv.get('currency'), parsed_inv['chatter_msg'])
parsed_inv['partner']['recordset'] = partner
parsed_inv['currency']['recordset'] = currency
self.write({
'partner_id': partner.id,
'invoice_type': parsed_inv['type'],
@@ -440,8 +460,8 @@ def _create_invoice(self, parsed_inv):
'datas': data_base64,
'datas_fname': filename,
})
if parsed_inv.get('chatter_msg'):
invoice.message_post(parsed_inv['chatter_msg'])
for chatter_msg in parsed_inv['chatter_msg']:
invoice.message_post(chatter_msg)
return invoice

@api.model