Skip to main content

Check transactions that cleared the bank

Project description

Production/Stable License: AGPL-3 OCA/account-reconcile Translate me on Weblate Try me on Runboat

This module is designed to provide an easy method in which Odoo accounting users can manually reconcile/validate their financial transactions from their financial institution/transaction providers (e.g. Paypal, A financial institution, google wallet, etc) against Odoo GL Chart of Account bank accounts.

Users will be able to validate and indicate if a transaction has “Cleared the Bank” using a checkmark on a new Reconcile Financial Account Statement view on each individual financial transaction. Users will also be able to mark transactions on a bank account for future research.

The idea is that as a first step users will manually look at their paper statement and line-by-line check off which financial transactions have cleared the bank in Odoo using the new Bank Reconciliation Wizard. These changes will be displayed on the new Reconcile Financial Account Statement tree view screen. This is the process in which many companies reconcile (aka Audit) their bank account statements and accounting system today and represents good segregation of duties.

Users can save their in-process reconciliations.


Using the search view filters - users will also be able to effectively sort, filter the transactions on a particular GL Financial Account. This new screen will display the journal items associated with a particular bank account. Several of the field labels have been relabeled to a more common vernacular.

The need for this module is driven by the following:

  • Users want to easily record whether bank transactions sent to their bank have “cleared the bank”- definition of “cleared the bank”: presented to the bank for payment and paid by the bank - added/subtracted funds on a bank account.

  • Users want the ability to validate if the bank processed the transactions them correctly (e.g. properly encoded transaction - e.g. company sent a payment of $20.20 to the bank. Was it processed for $20.20?). This can be considered “Auditing the bank statement”. We don’t assume the bank correctly processed any transaction.

  • Users want to understand what payments they’ve made are still outstanding and have not been paid by the bank.

  • The financial auditing segregation standard of separating the duties of: recording customer payments and making deposits; recording supplier payments and writing checks; and monitoring bank account activity. This segregation of duties is necessary to monitor and help prevent fraud.


  1. Companies using Odoo have setup a one-to-one relationship between their bank accounts and their Odoo GL accounts. Each bank account should have a corresponding GL account that is not shared with another account. Example:

    Odoo GL Account #

    Corresponding Bank Account


    Bank (AR) Account Checking 5434 (held at Institution A)


    Master Bank Account 2343 (held at Institution A)


    Bank Payable Account Checking 5678 (held at Institution A)


    Bank Payroll Account 6656 (held at Institution B)


    Paypal Account 3343 (held at Paypal)


    Google Wallet Account 6788


    AMEX Corporate Card Account 9989

  2. Companies have included a Non-Deposited Funds Account in their GL account (typically in current assets in their bank account areas). This account is used to store payments that have been recorded in Odoo - but not yet deposited into the financial institution. (NOTE: this account is important to have if the user “batches check deposits”- which is the process of making a large single deposits of customer payment into the bank (e.g. $20,000USD), but it is made up of smaller checks (e.g. 20 checks of $1,000 each). Many banks just record the total deposit amount ($20,000) and don¬タルt provide the breakdown of the individual checks that make up the larger deposit. This setup approach enables users to drill down and see the individual checks that make up a larger deposit.


From a cash management and financial control perspective, it is recommended that users establish the following four (4) bank accounts at their financial institution at a minimum to handle financial transactions. (NOTE: we recommend users place the last 4 digits of their bank account in the GL account name of the account. It helps accountants in their management of the system):

  • Bank (AR) Account Checking 5434. This is a checking account designated as the account where payments made to the company are deposited (e.g. a customer payment made by check is deposited here, or a customer paying by electronic transaction EFT/ACH is deposited into this GL).

  • Master Bank Account 2343. This is the master account in which the company keeps the majority of their funds. Often with the most limited access.

  • Bank Payable Account Checking 5678. This is a checking account designated for the company to pay their expenses from. (e.g. Company writes a check to pay a supplier for their office supplies).

  • Bank Payroll Account 6656. This is a checking account designated for a company to pay their employees and payroll.


There has been common confusion in the Odoo community about managing bank statements in the base Odoo system. This module hopes to alleviate this gap and provide users with a sound alternative to maintain fiscal control, be easy to understand, and allow for future growth.

Why this approach?

Users in Odoo have several options in which to record financial transactions that affect the balances of a bank account (GL Bank Account entries). We believe our approach allows these to work in conjunction with each other: Import Electronic Bank Statements to enter payments (this approach follows the philosophy that you first find out that a transaction has occurred from your bank which is very common in Europe due to the electronic nature of transactions).

  • Payment Order Payments (using the direct Method) - Payments are instantly recorded and financial transactions posted into the GL

  • Voucher Payments - Payments are instantly recorded and financial transactions posted into the GL

  • Sales Receipts/Refunds

  • Transfers between accounts (a new module is being developed to help manage this)

  • Funds moved from the Undeposited Funds GL account to a Bank Account GL account.

  • Direct Journal Entries

Table of contents


To configure this module

  • Go to Settings and activate the developer mode

  • Go to Settings > Users and Companies > Users

  • Add users who will prepare the bank statements to the “Bank Statement Preparer”

  • Add users who will verify them to the “Bank Statement Manager” group


To use this module:

  • Go to Accounting > Adviser > Bank Statements

  • Create a new bank statement

  • Select the account and provide a name

  • Enter the ending balance from the bank statement

  • Check the transactions that cleared the bank

  • Check the balances

  • Save and submit for review

  • As a reviewer, check the transactions, totals and balances

  • Click on Process

Bug Tracker

Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us to smash it by providing a detailed and welcomed feedback.

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



  • NovaPoint Group LLC

  • Open Source Integrators


Other credits


This module is maintained by the OCA.

Odoo Community Association

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.

Current maintainer:


This module is part of the OCA/account-reconcile project on GitHub.

You are welcome to contribute. To learn how please visit

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page