OCA/l10n-brazil · 18.0
Invoicing and accounting entries for Brazil
l10n_br_account
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.documentcom 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
Many2oneque 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
One2manycomputado 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 emAdicionar 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 LinhaeImpostos, 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ábeispode estar oculta por padrão. A instalação do módulo ``account_usability`` (disponível no repositórioOCA/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>.







