Invoicing and accounting entries for Brazil
by Akretion https://github.com/OCA/l10n-brazil , Odoo Community Association (OCA) https://github.com/OCA/l10n-brazil| Availability |
Odoo Online
Odoo.sh
On Premise
|
| Odoo Apps Dependencies |
•
Invoicing (account)
• Discuss (mail) |
| Community Apps Dependencies | Show |
| Lines of code | 27832 |
| Technical Name |
l10n_br_account |
| License | AGPL-3 |
| Website | https://github.com/OCA/l10n-brazil |
| Versions | 8.0 10.0 12.0 14.0 15.0 16.0 |
Invoicing and accounting entries for Brazil

Visão Geral
O módulo l10n_br_account integra o motor fiscal brasileiro (l10n_br_fiscal) ao framework contábil nativo do Odoo (módulo account). Ele integra a complexa lógica da tributação e dos documentos fiscais do Brasil com as faturas e lançamentos contábeis conforme as normas de contabilidade brasileiras.
O módulo atende desde a automação na emissão de notas para empresas do Simples Nacional até os cenários contábeis mais exigentes do regime normal (Lucro Real/Presumido).
Arquitetura e Integração: Decorator Pattern (_inherits)
A arquitetura do módulo se baseia no mecanismo de herança por composição _inherits do Odoo para criar uma composição dinâmica entre os modelos fiscais e contábeis:
- account.move herda de l10n_br_fiscal.document
- account.move.line herda de l10n_br_fiscal.document.line
Esta abordagem, análoga ao Decorator Pattern, oferece as seguintes vantagens:
- Gerenciamento Unificado: Permite controlar o Documento Fiscal diretamente pela interface da Fatura do Odoo. Campos fiscais (CFOP, NCM, valores de impostos) são acessados e computados de forma transparente, como se fossem nativos do account.move.line.
- Baixíssima Redundância de Dados: A herança por composição evita a duplicação de centenas de campos fiscais nas tabelas contábeis. A “fonte da verdade” fiscal é sempre o registro em l10n_br_fiscal.document, garantindo um banco de dados normalizado e consistente.
- Modularidade e Manutenção: A lógica fiscal complexa permanece encapsulada no l10n_br_fiscal. Para assegurar a reatividade dos campos computados na interface da fatura, o módulo utiliza um mixin especializado (l10n_br_account.decorator.mixin) que gerencia a herança de métodos e campos dinâmicos.
Principais Funcionalidades e Casos de Uso
Uso Simplificado: Cálculo dos impostos e criação dos Documentos Fiscais
O módulo l10n_br_account é a peça chave para automatizar a emissão de documentos fiscais a partir de qualquer fluxo de negócio que gere uma fatura no Odoo, como:
- Ordens de Venda (sale.order)
- Ordens de Compra (purchase.order)
- Movimentações de Estoque (stock.picking)
- Contratos (contract.contract), entre outros.
A Operação Fiscal pré-configurada orquestra o preenchimento automático de todos os dados necessários, permitindo a geração de NF-e, NFS-e e outros documentos com mínima intervenção.
Uso Avançado: Lançamentos contábeis corretos para as empresas do Regime Normal
Para empresas no Lucro Real ou Presumido, o l10n_br_account habilita uma gestão contábil e fiscal precisa e aderente à legislação.
- Lançamentos Contábeis de Impostos: Conecta os impostos fiscais (l10n_br_fiscal.tax) aos contábeis (account.tax), garantindo que a validação de uma fatura gere os lançamentos corretos para ICMS, IPI, PIS, COFINS, etc., em suas respectivas contas (custo, recuperável, despesa).
- Operações Sem Impacto Financeiro: Suporta operações como “Remessa para Industrialização”, permitindo a emissão do documento fiscal obrigatório e o lançamento correto dos impostos, mas sem gerar contas a pagar ou a receber, mantendo a integridade fiscal e contábil.
- Composição de Valores Financeiros: Gerencia a correta composição do valor financeiro das faturas. Por exemplo, assegura que o valor do IPI, quando não recuperável, seja somado ao contas a pagar do fornecedor.
- Importação de Documentos (XML): Facilita a importação de documentos de fornecedores, criando simultaneamente o l10n_br_fiscal.document com os dados fiscais e a fatura de fornecedor (account.move) pronta para validação e pagamento.
Escopo e Delimitação do Módulo
O nome l10n_br_account deriva do módulo account, que ele estende. É importante notar que o módulo account do Odoo, em sua essência, é focado em faturamento, embora contenha os conceitos fundamentais de planos de contas e lançamentos contábeis.
Para uma contabilidade completa de uma empresa no regime normal, mesmo utilizando o Odoo Enterprise, é necessária a instalação de dezenas de módulos adicionais da OCA, provenientes de diversos repositórios da OCA. O l10n_br_account, apesar do nome, não substitui este ecossistema. Ele se concentra na ponte fiscal-contábil. Funções como conciliação avançada (através de módulos como account_reconcile), gestão de ordens de pagamento, integração bancária (CNAB) e importação de extratos são tratadas por dezenas de outros módulos específicos da OCA…
Por outro lado, é importante ressaltar que os autores deste módulo possuem clientes do regime normal com uma contabilidade significativamente mais completa do que a oferecida nativamente pelo Odoo Enterprise, baseando-se exclusivamente em módulos de código aberto da OCA. Alcançar tal nível de sofisticação, no entanto, exige anos de experiência em implementação e uma escolha estratégica da versão do Odoo. É importante evitar versões muito recentes, para as quais o ecossistema de módulos da OCA ainda não atingiu a maturidade e estabilidade necessárias após o processo de migração (uma versão nova do Odoo mal tem 500 módulos da OCA migrados depois de 6 meses, mas tem quase 2000 depois de um ano e quase 3000 depois de 3 anos).
Vale a pena mencionar que lançamentos de Custo da Mercadoria Vendida (CMV) e outros lançamentos de contabilidade de estoque IFRS/IAS2, são tipicamente realizados através da combinação do módulo nativo stock_account, do l10n_br_stock_account (deste mesmo repo) e da ativação do modo “anglo-saxon” no seu plano de contas.
Detalhes sobre o modelo de dados
Cardinalidade: Documentos Fiscais e Lançamentos Contábeis
A arquitetura suporta cenários onde um único lançamento financeiro (account.move) agrupa múltiplos documentos fiscais, como uma fatura única para pagar vários Conhecimentos de Transporte (CT-e). Esta flexibilidade é garantida por três campos-chave:
- account.move.fiscal_document_id: O campo Many2one que implementa o _inherits. Representa o documento fiscal “principal” ou em edição na interface da fatura.
- account.move.line.fiscal_document_line_id: O pilar da arquitetura. Permite que cada linha da fatura aponte para uma linha de um documento fiscal distinto. É isso que possibilita agregar múltiplos documentos em um único account.move.
- account.move.fiscal_document_ids: Campo One2many computado que agrega todos os documentos fiscais vinculados às linhas da fatura, oferecendo uma visão completa e consolidada quando o lançamento tem mais de um documento fiscal.
A flexibilidade do design é bidirecional. O sistema também gerencia nativamente cenários onde um lançamento contábil (``account.move``) não possui nenhum documento fiscal associado. Isso é fundamental para operações puramente contábeis ou não fiscais, como:
- Lançamentos de folha de pagamento.
- Operações financeiras ou contábeis em empresas de um grupo multinacional que não operam no Brasil.
Além disso, mesmo dentro de uma fatura fiscalizada, a associação é granular. Apenas as linhas de produto (invoice_line_ids com display_type='product') são vinculadas a uma l10n_br_fiscal.document.line. Linhas de impostos, de contas a pagar/receber, ou linhas de anotação/seção permanecem como lançamentos puramente contábeis, sem linha de documento fiscal específica.
Observação sobre a Normalização do Modelo de Dados
Idealmente, o modelo de dados teria redundância zero. Contudo, para simplificar a injeção de mixins fiscais — em especial o l10n_br_fiscal.document.line.mixin — e alavancar a lógica nativa do Odoo, foi uma decisão de design manter a nomenclatura de um pequeno e controlado conjunto de campos, como partner_id, company_id, user_id, currency_id, product_id, quantity, price_unit e name.
Como consequência, existe uma redundância mínima e gerenciada. Considerando os milhares de campos necessários para a diversidade de documentos fiscais brasileiros, apenas cerca de quatro campos do account.move e quatro do account.move.line são efetivamente duplicados. Para garantir a integridade, estes campos (apelidados de shadow fields) são cuidadosamente sincronizados em tempo real, inclusive durante a edição de novos registros em memória (fase NewId), assegurando total consistência entre a fatura e o documento fiscal.
A Separação Estratégica dos Mixins Fiscais
No caso do account.move, o objetivo era obter os campos do l10n_br_fiscal.document sem duplicá-los (o que o _inherits faz perfeitamente), mas também precisávamos de seus métodos (como _compute_fiscal_tax_ids ou _compute_tax_fields). Se usássemos _inherit no mixin principal (l10n_br_fiscal.document.mixin), teríamos os métodos, mas os campos seriam duplicados, quebrando o princípio de normalização.
Por outro lado, modelos como sale.order e purchase.order não são uma representação de um documento fiscal, mas sim precursores dele. Portanto, eles podem usar uma herança simples (_inherit) diretamente no mixin principal (l10n_br_fiscal.document.mixin), pois precisam tanto dos campos quanto dos métodos para preparar os dados que serão posteriormente utilizados na geração do documento fiscal.
Modelo UML Simplificado


Aviso Importante: Pré-requisitos e Complexidade
Para utilizar o l10n_br_account de forma eficaz, é necessário ter domínio aprofundado de dois ecossistemas complexos: o módulo account nativo do Odoo e o motor l10n_br_fiscal deste repositório.
O account é o maior e mais intrincado módulo do Odoo, constituindo por si só um ERP financeiro completo, e não apenas um simples software de emissão de notas para microempresas. Por sua vez, o l10n_br_fiscal é o maior módulo entre os mais de 3000 disponíveis na OCA. Este módulo, l10n_br_account, está também entre os três mais complexos da localização brasileira e exige um uso avançado do ORM do Odoo para gerenciar a dualidade documento fiscal/lançamento contábil.
A implementação bem-sucedida de um ERP estrangeiro no Brasil é uma tarefa que demanda profissionais altamente qualificados, com anos de experiência em programação backend (Python) e implantação de verdadeiros sistemas ERP. Uma implementação não se resume a baixar e instalar módulo (apenas 1% do trabalho); envolve análise de processos, configuração, migração de dados e customizações, migração de modulos OCA a partir de outras versões… Subestimar essa complexidade invariavelmente leva a projetos problemáticos e custos elevados no longo prazo.
Este aviso serve para alinhar expectativas e reforçar que o sucesso de uma implantação Odoo no Brasil depende de expertise técnica e funcional aprofundada. Infelizmente, este mercado atrai aventureiros que subestimam essa complexidade ou que vendem projetos acreditando ser possível terceirizar a execução sem grande compromisso com a entrega, explorando a falta de informação do cliente. Este cenário caracteriza um “market for lemons”, onde a assimetria de informação torna difícil distinguir entre fornecedores qualificados e despreparados, impedindo o desenvolvimento de um mercado de implementação maduro.
Agravando a situação, onde se esperaria uma garantia criteriosa de qualidade, o ecossistema corporativo “oficial” investe pesadamente em propaganda para mascarar essa realidade, promovendo uma visão onde a consultoria de implementação é tratada como uma commodity. Esse modelo, focado em comissões pela venda de licenças (muitas vezes desnecessárias ao utilizar o ecossistema da OCA), alimenta um mercado paralelo notório de “parceiros fantoches/bucha de canhão” que compram certificações oficiais de empresas estrangeiras para simular uma competência que não possuem. Cuidado com profissionais que ostentam certificações compradas para transferir a responsabilidade da implementação sem o devido suporte ou conhecimento real. Não se deixe enganar por narrativas que simplificam a complexidade do projeto para priorizar a venda de licenças!
Conclusão
O l10n_br_account possui um design robusto que unifica as complexas lógicas fiscal e contábil do Brasil dentro do Odoo. Sua arquitetura, projetada por especialistas para especialistas, oferece uma plataforma flexível e confiável, capaz de sustentar operações de alta complexidade e garantir a conformidade fiscal e contábil das empresas que utilizam a localização brasileira da OCA.
Table of contents
Installation
Este modulo depende dos módulos:
- l10n_br_coa (que depende do módulo account)
- l10n_br_fiscal
Configuration
Antes de seguir este guia, é fundamental que você:
- Tenha configurado sua empresa com o país “Brasil”. A maioria dos campos fiscais só aparecerá neste contexto.
- Tenha configurado o regime fiscal da sua empresa.
- Tenha configurado um Plano de Contas, idealmente deriavdo do plano base do módulo l10n_br_coa.
- Esteja familiarizado com o processo de faturamento padrão do Odoo através do módulo account.
- Compreenda os conceitos básicos do módulo ``l10n_br_fiscal``, especialmente o que são Operações Fiscais (l10n_br_fiscal.operation) e como o sistema seleciona e calcula os impostos com base nelas.
Usage
Passo a Passo: Criando uma Fatura Fiscal
O processo se inicia a partir da fatura padrão do Odoo, agora “decorada” com os campos fiscais necessários.
- Navegue até Faturamento Acesse o menu Faturamento > Clientes > Faturas.
- Crie uma Nova Fatura Clique no botão Criar.
- Selecione o Cliente No campo Cliente, selecione um parceiro configurado para o Brasil. O cadastro do cliente contenha as informações fiscais corretas (CNPJ/CPF, perfil fiscal, endereço, etc.). Nos dados de demonstração, a AMD do Brasil é um excelente exemplo.
- Preencha os Dados Fiscais do Cabeçalho Com a instalação do
módulo, novos campos fiscais aparecerão no cabeçalho da fatura.
- Tipo de Documento: Selecione o modelo do documento fiscal. Para uma NF-e, por exemplo, escolha ``55 - Nota Fiscal Eletrônica``.
- Operação Fiscal: Este é um campo chave. Ele define a natureza da transação. Selecione uma operação compatível, como ``Venda de Mercadoria``.
- Adicione as Linhas da Fatura Na aba Linhas da Fatura, clique
em Adicionar uma linha.
- Selecione um produto. Usando os dados de demonstração, você pode escolher o produto ``[E-COM08] Storage Box``.
- Observe que, ao selecionar o produto, os campos fiscais da linha, como Operação Fiscal da Linha e Impostos, são preenchidos automaticamente com base nas regras da Operação Fiscal principal. Os impostos são calculados e exibidos em tempo real.
Visualizando e Editando os Detalhes Fiscais da Linha
A grade de linhas da fatura oferece uma visão simplificada. Para acessar todos os detalhes fiscais de uma linha ou para editar manualmente algum campo (como um NCM ou CST específico para aquela operação), você pode usar o modo de edição em pop-up.
- Clique no ícone de “abrir registro externo” (um quadrado com uma seta), localizado à esquerda da linha do produto na grade editável.
- Uma janela pop-up se abrirá, exibindo o formulário completo da linha. Nele, você encontrará a aba ``Impostos``, que contém o detalhamento completo dos cálculos para cada tributo (ICMS, IPI, PIS, COFINS, etc.).
Verificando os Lançamentos Contábeis
Após preencher a fatura, você pode (e deve) inspecionar os lançamentos contábeis que serão gerados.
- Acesse a aba ``Lançamentos Contábeis``.
- Nesta aba, você verá todas as contas que serão movimentadas, incluindo as linhas específicas para cada imposto (débito de impostos a recuperar, crédito de impostos a recolher, etc.), refletindo o resultado dos cálculos do motor fiscal.
Nota Importante: Para usuários da versão Community do Odoo, a aba Lançamentos Contábeis pode estar oculta por padrão. A instalação do módulo ``account_usability`` (disponível no repositório OCA/account-financial-tools) é fortemente recomendada para torná-la visível e facilitar a análise contábil.
Após a conferência, você pode Confirmar a fatura para gerar os lançamentos contábeis e prosseguir com a transmissão do documento fiscal, caso seja um documento eletrônico.
Acessando a Visão Fiscal Detalhada
No canto superior direito do formulário da fatura, você encontrará um smart button chamado Detalhe Fiscal.
Clicar neste botão permite navegar diretamente para a tela do l10n_br_fiscal.document, que oferece uma visão completa e focada nos aspectos puramente fiscais. Nesta tela, é possível consultar detalhes aprofundados, gerenciar o ciclo de vida do documento (cancelamento, carta de correção) e, para documentos eletrônicos, acompanhar todo o histórico de comunicação e o status de transmissão junto à SEFAZ.
Known issues / Roadmap
Changelog
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.
Credits
Authors
- Akretion
Contributors
- Akretion:
- Renato Lima <renato.lima@akretion.com.br>
- Raphaël Valyi <raphael.valyi@akretion.com.br>
- KMEE:
- Luis Felipe Mileo <mileo@kmee.com.br>
- Escodoo:
- Marcel Savegnago <marcel.savegnago@escodoo.com.br>
- Engenere:
- Antônio S. Pereira Neto <neto@engenere.one>
- Felipe Motter Pereira <felipe@engenere.one>
Maintainers
This module is maintained by the OCA.
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 maintainers:

This module is part of the OCA/l10n-brazil project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
Please log in to comment on this module