testes/docs/zentulo_system_deep_dive.md

209 lines
10 KiB
Markdown

# Relatório Zentulo System Deep Dive: Análise Técnica e Funcional
Este documento apresenta uma análise detalhada da arquitetura, lógica de negócios e fluxos operacionais do Sistema Zentulo, um ambiente de análise e simulação para a plataforma Zentulo.
## 1. Visão Geral da Arquitetura
O sistema Zentulo utiliza uma arquitetura **Híbrida Web/Electron**, projetada para operar tanto em navegadores quanto em ambiente desktop com permissões estendidas de sistema de arquivos.
* **Frontend:** React com Tailwind CSS.
* **Comunicação:** REST API e WebSockets (Socket.io) para atualizações em tempo real.
* **Persistência Local:** `localStorage` com lógica de sincronização offline personalizada.
* **Integração Nativa:** Electron Bridge (`window.electronAPI`) para processamento de arquivos XML locais e automação do Outlook.
---
## 2. Fluxos Visuais (Mermaid.js)
### Fluxo 1: Ciclo de Vida da Solicitação de Liberação
O coração do sistema é o fluxo de solicitações feitas por motoristas e aprovadas pela central de monitoramento.
```mermaid
sequenceDiagram
participant M as Motorista (Portal)
participant S as Socket.io / API
participant C as Central (Painel Monitoramento)
M->>S: Envia Solicitação (Placa, Operação, CTe/NF)
S-->>C: Notificação Real-time (monitoring-update)
C->>C: Supervisor clica em "Atender"
Note right of C: Status muda para "ANÁLISE"
C-->>M: Notificação: "Solicitação Atendida"
C->>C: Validação de Perímetro/SST/Fiscal
C->>S: Clica em "Aprovar" (Envia Rota/Mensagem)
S-->>M: Notificação: "LIBERADO" (Verde)
M->>M: Clica em "Saí em Rota"
Note left of M: Status muda para "EM ROTA"
```
### Fluxo 2: Processamento Fiscal e Automação de E-mail
Este fluxo descreve como o sistema extrai dados de documentos fiscais sem intervenção manual pesada.
```mermaid
graph TD
A[Outlook Automation] -->|Electron Select Folder| B[Download XMLs]
B --> C{Tipo de Documento?}
C -->|NF-e| D[FiscalAnalysis Component]
C -->|CT-e / MDF-e| E[CTE Component]
D -->|window.electronAPI.processFiscal| F[Validação contra Regras de Negócio]
E -->|window.electronAPI.processCTEs| G[Validação de CTE / MDF-e]
F --> H[Relatório de Divergências]
G --> I[Log de Processamento e Auditoria]
```
### Fluxo 3: Sincronização Offline de Documentos
O sistema garante que motoristas possam salvar comprovantes mesmo em áreas de sombra de sinal.
```mermaid
graph LR
A[Upload do Arquivo] --> B{Conexão Online?}
B -- Não --> C[Salva em localStorage 'pending_sync']
B -- Sim --> D[Envia para /api/documents]
C --> E[Monitora Evento 'online']
E --> F[syncPending Utility]
F --> D
D --> G[Cria Registro na Gestão de Documentos]
```
### Fluxo 4: Importação de Planilhas (Excel)
O sistema permite popular cadastros em massa via processamento local de arquivos `.xlsx`.
```mermaid
graph TD
A[Selecionar Arquivo .xlsx] --> B[FileReader.readAsBinaryString]
B --> C[XLSX.read Parser]
C --> D[Mapeamento de Colunas Dinâmico]
D --> E{Motorista Válido?}
E -->|Sim| F[Lista de Prévia para Conferência]
E -->|Não| G[Alerta de Erro de Formato]
F --> H[Loop: POST /api/drivers]
H --> I[Atualização Local da UI]
```
### Fluxo 5: Sistema de Telemetria e Rastreamento
Monitoramento em tempo real de veículos com integração a provedores externos.
```mermaid
sequenceDiagram
participant W as Worker (30s polling)
participant T as T4S API
participant S as Sascar API
participant DB as TelemetryDB (Memória)
participant IO as Socket.io
participant C as Cliente (Dashboard)
loop A cada 30 segundos
W->>T: Bulk Fetch (PRALOG + PETY)
T-->>W: Array de Posições
W->>S: Bulk Fetch (Se credenciais configuradas)
S-->>W: Array de Posições
W->>W: Normalização de Dados
W->>W: Validação Geofence (lat > -21.0?)
W->>W: Validação Velocidade (> 90 km/h?)
W->>DB: Atualiza Posições + Histórico
W->>IO: Emit 'positions-update'
IO-->>C: Atualização Real-time
end
Note over W,C: Alertas: FORA_DA_ROTA, EXCESS_SPEED, SIGNAL_LOST
```
---
## 3. Análise Detalhada dos Módulos
### 3.1 Painel de Monitoramento
* **Lógica de Status:** Transições coordenadas entre *Pending* -> *Analysis* -> *Approved* -> *In Progress* -> *Arrived*.
* **Validação de Rota:** Contém lógica específica para impedir rotas pela "Avenida Brasil" dependendo do valor da carga e destino, a menos que o destino seja na própria avenida.
* **Integração Real-time:** Uso intensivo de WebSockets para sincronizar os estados entre o supervisor e o motorista instantaneamente.
### 3.2 Gestão de Checklists e Manutenção
* **Auto-Renovação:** Implementa uma regra de +30 dias de validade ao renovar um checklist básico.
* **Cálculo de Status:** Status dinâmico (Válido, Alerta, Expirado) calculado em tempo real com base na data atual e datas de expiração.
* **Ordens de Serviço (OS):** Suporta criação de OS manuais ou automáticas (baseadas em sequencial interno).
### 3.3 Cadastro e Gestão de Documentos
* **Importação (Planilhas):** Utiliza a biblioteca `xlsx` para parsing de arquivos Excel. Possui lógica de mapeamento inteligente que busca por variações de nomes de colunas (ex: "Motoristas", "Nome", "CPF").
* **Hierarquia de Documentos:** Documentos são vinculados a Entidades (MOTORISTA ou CAVALO/VEÍCULO). Salvar um novo documento do mesmo tipo (ex: CRLV) substitui logicamente o anterior.
* **Módulo de Planilhas:** Existe uma rota dedicada (`/spreadsheets`) que se integra ao sistema de sincronização offline, permitindo a gestão de documentos de planilha associados à operação.
### 3.4 Administração e Segurança (RBAC)
* **Níveis de Acesso:** DEV, SUPERVISOR, GR, MONITORAMENTO.
* **Restrições de Hierarquia:** O código impede que usuários com nível SUPERVISOR editem ou excluam usuários com nível DEV.
* **Configuração de E-mail:** O e-mail de cadastro do usuário é a "chave" para as integrações de Outlook, servindo como credencial para a automação Electron.
---
## 4. Backend e Infraestrutura
### 4.1 Arquitetura do Backend
* **Stack:** Node.js + Express.js
* **Banco de Dados:** MongoDB Atlas (`mongodb+srv://pralog:pralog123@cluster0.aobkjaq.mongodb.net/pralog`)
* **Comunicação Real-time:** Socket.io v4.8.1
* **Autenticação:** JWT (jsonwebtoken) + bcrypt para hash de senhas
* **Segurança:** Helmet.js, express-rate-limit, CORS configurado
### 4.2 Sistema de Telemetria e Rastreamento
O sistema possui integração nativa com dois provedores de rastreamento veicular:
#### Integração T4S
* **Contas Configuradas:** PRALOG e PETY
* **Endpoint:** `https://integracaov2.t4stecnologia.com.br/api`
* **Autenticação:** Bearer Token com cache de 50 minutos
* **Polling:** A cada 30 segundos (configurável)
* **Dados Capturados:** Placa, lat/lng, velocidade, ignição, endereço, timestamp
#### Integração Sascar
* **Status:** Estrutura pronta, aguardando credenciais
* **Normalização:** Converte dados brutos para formato unificado
* **Fallback:** Retorna array vazio se credenciais não configuradas
#### Geofencing e Alertas Automáticos
* **Cerca Eletrônica:** Validação de latitude (alerta se `lat > -21.0`)
* **Alerta de Velocidade:** Dispara se velocidade > 90 km/h
* **Níveis de Risco:**
* `NORMAL` - Operação dentro dos parâmetros
* `HIGH` - Excesso de velocidade
* `CRITICAL` - Fora da rota autorizada
* **Perda de Sinal:** Monitora veículos sem atualização por > 5 minutos
* **Histórico:** Mantém últimas 50 posições em memória por veículo
### 4.3 Gestão de Planilhas (SpreadsheetData)
* **Clientes Suportados:** IMPERIO, ORTOBOM_RJ, ORTOBOM_SP, LIBFARMA
* **Funcionalidades:**
* Importação de dados via biblioteca `xlsx`
* Arquivamento de registros antigos
* Queries por `clientId` e status de arquivamento
* **Script de Verificação:** `check-spreadsheet.js` para auditoria de dados
### 4.4 Sistema de Auto-Update
* **Provedor:** GitHub Releases
* **Repositório:** `itguys/pralog-server`
* **Diretório de Cache:** `zentulo-systems-updater`
* **Componente Frontend:** `VersionChecker` + `ElectronUpdater`
* **Fluxo:** Verifica → Baixa → Notifica Usuário → Instala ao Reiniciar
### 4.5 Processamento de Arquivos
* **Upload:** Multer v2.0.2 para multipart/form-data
* **PDF:** Parsing com `pdf-parse` e geração com `pdfkit`
* **Excel:** Leitura e escrita com `xlsx` v0.18.5
* **Compressão:** Middleware `compression` para otimizar tráfego
---
## 5. Gaps e Pontos de Atenção
1. **Dependência do Electron:** Módulos de Fiscal, CTe e Outlook não funcionam nativamente na web devido às restrições de sandbox do navegador (necessitam do bridge native).
2. **Performance de Filtro:** A filtragem de solicitações no painel de monitoramento ocorre majoritariamente no lado do cliente (`client-side filtering`), o que pode degradar a performance com milhares de registros.
3. **Endpoint do Outlook:** O endpoint `/api/outlook-filter` é simulado/mockado, exigindo um serviço backend Azure AD robusto para operação real.
4. **Sincronização:** A lógica offline depende inteiramente do `localStorage`. Limpar os dados do navegador sem sincronização resultará em perda de dados "pendentes".
5. **Credenciais de Rastreamento:**
* **T4S:** Senhas pendentes para contas PRALOG e PETY (marcadas como `[AGUARDANDO_WHATSAPP_*]`)
* **Sascar:** Credenciais completamente ausentes (estrutura pronta, mas inativa)
6. **Segurança do Banco de Dados:** Credenciais do MongoDB expostas em arquivo `.env` sem criptografia adicional.
7. **Geofencing Simplificado:** Lógica de cerca eletrônica usa apenas validação de latitude (`lat > -21.0`), sem polígonos complexos ou múltiplas zonas.
8. **Telemetria em Memória:** Histórico de posições armazenado apenas em memória (não persistido), limitado a 50 posições por veículo.
---
*Relatório atualizado em 06 de Fevereiro de 2026.*