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

[16.0][MIG] account_move_name_sequence: Migration to 16.0 #1510

Merged
merged 34 commits into from
Dec 8, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
42def7f
Add module account_move_name_sequence
alexis-via Sep 6, 2021
4aeaa9c
sequence is now required on journals
alexis-via Sep 8, 2021
d1d6874
[REF] account_move_name_sequence: Add number_next_actual and date ran…
moylop260 May 5, 2022
87f2818
[FIX] ir_sequence: Fix creating date_range_seq with range_month and r…
moylop260 May 10, 2022
52cbe64
[REF] account_move_name_sequence: Discard journals already configured
moylop260 May 11, 2022
9ac1af9
[UPD] Update account_move_name_sequence.pot
May 12, 2022
7e0350a
[UPD] README.rst
OCA-git-bot May 12, 2022
d45cda0
[ADD] icon.png
OCA-git-bot May 12, 2022
1a2b072
[FIX] account_move_name_sequence: Fix sequence domain to assign only …
moylop260 May 13, 2022
5add0a4
account_move_name_sequence 14.0.1.0.1
OCA-git-bot May 13, 2022
85cb94d
[REF] account_move_name_sequence: Moves with name '/' can not be posted
moylop260 May 13, 2022
6caddd3
[UPD] Update account_move_name_sequence.pot
May 13, 2022
caf256d
account_move_name_sequence 14.0.1.1.0
OCA-git-bot May 13, 2022
476532f
[FIX] account_move_name_sequence: Fix required journal fields in view
moylop260 May 13, 2022
d9df97e
account_move_name_sequence 14.0.1.2.0
OCA-git-bot May 13, 2022
3cd3182
[REF] account_move_name_sequence: Add maintainers to myself
moylop260 May 13, 2022
3a698a9
[UPD] README.rst
OCA-git-bot May 13, 2022
f90d1bf
[REF] account_move_name_sequence: Adding concurrency cases in README
moylop260 May 19, 2022
4a0c64d
[UPD] README.rst
OCA-git-bot May 20, 2022
cdc7934
account_move_name_sequence 14.0.1.2.1
OCA-git-bot May 20, 2022
1653cc4
[REF] account_move_name_sequence: Use Odoo native methods + Typos
frahikLV May 26, 2022
7f1c4ba
[UPD] README.rst
OCA-git-bot May 26, 2022
3a1b342
account_move_name_sequence 14.0.1.2.2
OCA-git-bot May 26, 2022
a800db0
[MIG] account_move_name_sequence: Migration to 15.0
frahikLV May 26, 2022
1987242
[FIX] account_move_name_sequence: Exclude no_gap sequences from _is_e…
frahikLV May 25, 2022
ad207c5
[UPD] Update account_move_name_sequence.pot
May 26, 2022
b70341d
[UPD] README.rst
OCA-git-bot May 26, 2022
6599bfd
[FIX] account_move_name_sequence: Use account move date to compute pr…
petrus-v Jul 7, 2022
d07e939
account_move_name_sequence 15.0.1.1.0
OCA-git-bot Jul 9, 2022
a07eeda
[IMP] : pre-commit stuff
RodrigoBM Nov 22, 2022
86eed6c
[MIG] account_move_name_sequence: Migration to 16.0
RodrigoBM Nov 24, 2022
2d5f794
[FIX] account_move_name_sequence: return sequence names do not add a …
RodrigoBM Nov 24, 2022
346eb9d
[FIX] account_move_name_sequence: issue #1465 vals get refund_sequenc…
RodrigoBM Nov 28, 2022
ab8e59d
[FIX] account_move_name_sequence: call flush before _fetch_duplicate_…
RodrigoBM Dec 2, 2022
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
160 changes: 160 additions & 0 deletions account_move_name_sequence/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,160 @@
============================
Account Move Number Sequence
============================

.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Faccount--financial--tools-lightgray.png?logo=github
:target: https://github.com/OCA/account-financial-tools/tree/15.0/account_move_name_sequence
:alt: OCA/account-financial-tools
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/account-financial-tools-15-0/account-financial-tools-15-0-account_move_name_sequence
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png
:target: https://runbot.odoo-community.org/runbot/92/15.0
:alt: Try me on Runbot

|badge1| |badge2| |badge3| |badge4| |badge5|

In Odoo version 13.0 and previous versions, the number of journal entries was generated from a sequence configured on the journal.

In Odoo version 14.0, the number of journal entries can be manually set by the user. Then, the number attributed for the next journal entries in the same journal is computed by a complex piece of code that guesses the format of the journal entry number from the number of the journal entry which was manually entered by the user. It has several drawbacks:

* the available options for the sequence are limited,
* it is not possible to configure the sequence in advance before the deployment in production,
* as it is error-prone, they added a *Resequence* wizard to re-generate the journal entry numbers, which can be considered as illegal in many countries,
* the `piece of code <https://github.com/odoo/odoo/blob/14.0/addons/account/models/sequence_mixin.py>`_ that handles this is not easy to understand and quite difficult to debug.

Odoo>=v14.0 raises new concurrency issues since it locks the last journal entry of the journal to get the new number causing a bottleneck
Even if you only are creating a draft journal entry it locks the last one
It applies to all accounting Journal Entries

e.g.

- Customer Invoices
- Credit Notes
- Customer Payments
- Vendor Bills
- Vendor Refunds
- Vendor Payment
- Manual Journal Entries

Then, the following concurrency errors are being raised now frequently:

* Editing the last record used to get the new number from another process
* Creating a new draft invoice/payment (not only when posting it)
* Creating a transaction to create an invoice then payment or vice versa raises a deadlock error
* Reconciling the last record it could be a heavy process
* Creating 2 or more Invoices/Bills at the same time
* Creating 2 or more Payments at the same time (Even if your country allows to relax gaps in these kinds of documents, you are not able anymore to change the implementation to standard)
* Creating 2 or more Journal Entries at the same time


All these increases in concurrency errors bring more issues since that Odoo is not prepared:

* Using e-commerce, configured with Invoicing Policy Ordered and Automatic Invoice, the portal users will see errors in the checkout even if the payment was done, the sale order could be in state draft and request a new payment, so double charges
* Using `subscription_template.payment_mode=success_payment` you will see subscriptions with tag "payment exception"
* Using accounting creating invoice or payment, you will see errors then you will need to start the process again and again until you get the lock before another user
* The workers could be used for more time than before since that it could be waiting for release so less concurrent users supported or loading page is shown more frequently affecting the performance

The new accounting number is a significant bottleneck

.. image:: https://media.istockphoto.com/vectors/road-highways-with-many-different-vehicles-vector-id1328678690


If you do not believe all these issues are occurring, we have created the following issues and unittest to reproduce errors in v14.0 including the deadlock, but not v13.0:

- Passing unittest for `13.0 - [REF] account: Adding unittests for concurrency issues in account_move sequences <https://github.com/odoo/odoo/pull/91614>`_
- Concurrency errors for `14.0 - [REF] account: Adding unittests for concurrency issues in account_move sequences <https://github.com/odoo/odoo/pull/91525>`_
- `Stress testing and issue reported to Odoo <https://github.com/odoo/odoo/issues/90465>`_
- `[BUG] account: Concurrency errors increased considerably in account.move for Odoo>=v14.0 #91873 <https://github.com/odoo/odoo/issues/91873>`_


Using this module, you can configure what kind of documents the gap sequence may be relaxed
And even if you must use no-gap in your company or country it will reduce the concurrency issues since the module is using an extra table (ir_sequence) instead of locking the last record

For those like me who think that the implementation before Odoo v14.0 was much better, for the accountants who think it should not be possible to manually enter the sequence of a customer invoice, for the auditor who considers that resequencing journal entries is prohibited by law, this module may be a solution to get out of the nightmare.

The field names used in this module to configure the sequence on the journal are exactly the same as in Odoo version 13.0 and previous versions. That way, if you migrate to Odoo version 14.0 and you install this module immediately after the migration, you should keep the previous behavior and the same sequences will continue to be used.

The module removes access to the *Resequence* wizard on journal entries.

**Table of contents**

.. contents::
:local:

Configuration
=============

On the form view of an account journal, in the first tab, there is a many2one link to the sequence. When you create a new journal, you can keep this field empty and a new sequence will be automatically created when you save the journal.

On sale and purchase journals, you have an additional option to have another sequence dedicated to refunds.

Upon module installation, all existing journals will be updated with a journal entry sequence (and also a credit note sequence for sale and purchase journals). You should update the configuration of the sequences to fit your needs. You can uncheck the option *Dedicated Credit Note Sequence* on existing sale and purchase journals if you don't want it. For the journals which already have journal entries, you should update the sequence configuration to avoid a discontinuity in the numbering for the next journal entry.

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/account-financial-tools/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us smashing it by providing a detailed and welcomed
`feedback <https://github.com/OCA/account-financial-tools/issues/new?body=module:%20account_move_name_sequence%0Aversion:%2015.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
~~~~~~~

* Akretion
* Vauxoo

Contributors
~~~~~~~~~~~~

* Alexis de Lattre <[email protected]>
* Moisés López <[email protected]>
* Francisco Luna <[email protected]>

Maintainers
~~~~~~~~~~~

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

.. |maintainer-alexis-via| image:: https://github.com/alexis-via.png?size=40px
:target: https://github.com/alexis-via
:alt: alexis-via
.. |maintainer-moylop260| image:: https://github.com/moylop260.png?size=40px
:target: https://github.com/moylop260
:alt: moylop260
.. |maintainer-frahikLV| image:: https://github.com/frahikLV.png?size=40px
:target: https://github.com/frahikLV
:alt: frahikLV

Current `maintainers <https://odoo-community.org/page/maintainer-role>`__:

|maintainer-alexis-via| |maintainer-moylop260| |maintainer-frahikLV|

This module is part of the `OCA/account-financial-tools <https://github.com/OCA/account-financial-tools/tree/15.0/account_move_name_sequence>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
2 changes: 2 additions & 0 deletions account_move_name_sequence/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
from .post_install import create_journal_sequences
from . import models
27 changes: 27 additions & 0 deletions account_move_name_sequence/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Copyright 2021 Akretion France (http://www.akretion.com/)
# Copyright 2022 Vauxoo (https://www.vauxoo.com/)
# @author: Alexis de Lattre <[email protected]>
# @author: Moisés López <[email protected]>
# @author: Francisco Luna <[email protected]>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

{
"name": "Account Move Number Sequence",
"version": "16.0.1.0.0",
"category": "Accounting",
"license": "AGPL-3",
"summary": "Generate journal entry number from sequence",
"author": "Akretion,Vauxoo,Odoo Community Association (OCA)",
"maintainers": ["alexis-via", "moylop260", "frahikLV"],
"website": "https://github.com/OCA/account-financial-tools",
"depends": [
"account",
],
"data": [
"views/account_journal.xml",
"views/account_move.xml",
"security/ir.model.access.csv",
],
"post_init_hook": "create_journal_sequences",
"installable": True,
}
129 changes: 129 additions & 0 deletions account_move_name_sequence/i18n/account_move_name_sequence.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * account_move_name_sequence
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 15.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: account_move_name_sequence
#: model:ir.model.constraint,message:account_move_name_sequence.constraint_account_move_name_state_diagonal
msgid ""
"A move can not be posted with name \"/\" or empty value\n"
"Check the journal sequence, please"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,help:account_move_name_sequence.field_account_journal__refund_sequence
msgid ""
"Check this box if you don't want to share the same sequence for invoices and"
" credit notes made from this journal"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_journal__refund_sequence_id
msgid "Credit Note Entry Sequence"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_journal__refund_sequence
msgid "Dedicated Credit Note Sequence"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_journal__sequence_id
msgid "Entry Sequence"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_bank_statement_line__highest_name
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_move__highest_name
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_payment__highest_name
msgid "Highest Name"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model,name:account_move_name_sequence.model_account_journal
msgid "Journal"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model,name:account_move_name_sequence.model_account_move
msgid "Journal Entry"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_bank_statement_line__name
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_move__name
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_payment__name
msgid "Number"
msgstr ""

#. module: account_move_name_sequence
#: code:addons/account_move_name_sequence/models/account_journal.py:0
#, python-format
msgid ""
"On journal '%s', the same sequence is used as Entry Sequence and Credit Note"
" Entry Sequence."
msgstr ""

#. module: account_move_name_sequence
#: code:addons/account_move_name_sequence/models/account_journal.py:0
#, python-format
msgid "Refund"
msgstr ""

#. module: account_move_name_sequence
#: code:addons/account_move_name_sequence/models/account_journal.py:0
#: model:ir.model,name:account_move_name_sequence.model_ir_sequence
#, python-format
msgid "Sequence"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_bank_statement_line__sequence_number
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_move__sequence_number
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_payment__sequence_number
msgid "Sequence Number"
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_bank_statement_line__sequence_prefix
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_move__sequence_prefix
#: model:ir.model.fields,field_description:account_move_name_sequence.field_account_payment__sequence_prefix
msgid "Sequence Prefix"
msgstr ""

#. module: account_move_name_sequence
#: code:addons/account_move_name_sequence/models/account_journal.py:0
#, python-format
msgid ""
"The company is not set on sequence '%(sequence)s' configured as credit note "
"sequence of journal '%(journal)s'."
msgstr ""

#. module: account_move_name_sequence
#: code:addons/account_move_name_sequence/models/account_journal.py:0
#, python-format
msgid ""
"The company is not set on sequence '%(sequence)s' configured on journal "
"'%(journal)s'."
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,help:account_move_name_sequence.field_account_journal__refund_sequence_id
msgid ""
"This sequence will be used to generate the journal entry number for refunds."
msgstr ""

#. module: account_move_name_sequence
#: model:ir.model.fields,help:account_move_name_sequence.field_account_journal__sequence_id
msgid "This sequence will be used to generate the journal entry number."
msgstr ""
3 changes: 3 additions & 0 deletions account_move_name_sequence/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
from . import account_journal
from . import account_move
from . import ir_sequence
Loading