Skip to content

Latest commit

 

History

History
80 lines (56 loc) · 5.27 KB

README.md

File metadata and controls

80 lines (56 loc) · 5.27 KB

cnpjrfb

Sistema web em PHP usando o usando o Adianti FrameWork para consultar os Dados públicos CNPJ fornecidos pela Receita Federal do Brasil.

A Versão 2.0.0 contem as alterações do modelo de dados de 21/03/2021 feito pela RFB.

Agradecimento para todas as pessoas que contribuíram de forma direta ou indireta para o projeto. Abaixo alguns nomes de destaque, pois o sistema de consulta foi baseado nos scripts de carga de dados das pessoas abaixo. Sem essas pessoas o trabalho seria bem mais difícil:

Visão no Celular

Visão no Tablet

Instalando e rodando

O processo de instalação é simples para a parte PHP. Porém a carga do banco de dados pode ser complicada e muito demorada, levando algumas horas até dias dependendo do seu hardware.

Requisitos

  • Apache PHP 8.1 ou superior para a versão 2.1.0 ou superior.
  • Banco de Dados Relacional, com a carga dos dados conforme modelo. Funciona nos bancos PostgreSQL, MySQL, MariaDB, SQLite !
  • Aproximadamente 50 GB de espaço livre em disco para a instalação:
    • 6,1 GB arquivos zip da Receita Federal (Agosto/2024), que pode ser liberado depois da instalação.
    • 18 GB para arquivos texto descompactados, que pode ser liberado depois da instalação
    • 18 GB para banco de dados. Considerando o PostgreSQL.

Informação sobre o Banco de dados e carga ETL

Tabela Quantidade de linhas Tamanho em MB
empresa 45.811.638
estabelecimento 48.421.619
socios 20.426.417
simples 27.893.923
Total 142.553.597

Intalação separada

Parte 1 - PHP

  1. Ter um servidor PHP 8.1 ou superior. Com o drive PDO do banco relacional desejado e para o SqLite
  2. Configura o PHP conforme orientações do Adianti FrameWork 7.3.0
  3. Crie no seu servidor a pasta cnjrfb.
  4. Copie o conteudo da pasta www/cnjrfb do projeto para a pasta cnjrfb do seu servidor PHP.
  5. Verifique se tudo dentro de <caminho servidor>/cnjrfb/ tem permissão de execução do servidor web. Se for Linux (Debian/Ubuntu) com Apache pode executar sudo chown -R www-data:www-data
  6. Abra o sistema em um navegador e verifique se os sistema está funcionando. Existe um pequeno banco em SqLite para demonstrar o funcionamento.

ATENÇÃO!! a função de gerar grafo foi removida temporarimente da versão 2.

Parte 2 - a carga dos dados, no banco relacional !

Agora vem parte demorada !

Caminho normal

  • Baixe todos os arquivos do site de receita federal. Para quem está usando Linux tem um script para essa parta www/cargabs/download/download_files.sh
  • Script PHP para carga no banco
    • na pasta projeto/modelo_banco/ vai encontrar os scripts criação do banco de dados, para os SGBD's: SqLite, MySql, MariaDB e PostgreSQL. Se precisar de um MER tem na pasta projeto/modelo_banco/mysql
    • Altere o arquivo de configuração projeto/www/cargabd/config.php
    • rode o script em modo terminal projeto/www/cargabd/index.php
    • vá descençar !! o processo todo em desktop no win10, i5, 16 ram, PHP 7.4 no wamp com config padrão levou mais de 30 horas.

Caminho alternativo

ATENÇÃO!! devido o volume de dados crie índices, nas colunas que pretender ter o maior volume de pesquisa e assim diminuir o tempo de busco. Recomendo criar na coluna cnpj_basico em todas as tabelas

Parte 3 - Configurando o PHP para o banco completo !

  • altera o arquivo <caminho servidor>/cnjrfb/app/config/maindatabase.php para apontar para o novo banco de dados. Veja como em Adianti FrameWork 7.3.0
  • PARA quem criu o banco o DATABASE_SCHEMA altere o arquivo <caminho servidor>/cnjrfb/init.php na linha 33 alterando o valor da constante define('DATABASE_SCHEMA',''); para o valor desjado usando o PONTO para separar SCHEMA.TABELA

Intalação via Docker-compose - NÃO ESTÁ COMPLETO

Existem alguns arquivos em Docker-compose para criar todo o ambiente necessários para rodar tudo que é necessário. A ideia é com um comando o usuário consiga ter tudo funcionando sem muito esforço.

  1. Instale o Docker e Docker-compose
  2. Abriu um terminal na raiz do projeto
  3. Execute o comando docker-compose build para gerar todo o ambiente.
  4. Execute o comando docker-compose -f docker-compose.yml up -d para rodar o ambiente já configurado. O Docker pretender resolver apenas Parte 1 - PHP
  5. Verificando se a instalação está correta: Abra o sistema em um navegador e verifique se os 3 menus dentre home está funcionando: Empresa, Sócios e CNEA.