( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
20.0246545992Connection::getInstance( $type = 'local' ).../index.php:15
30.0246546104Connection->__construct( $type = 'local' ).../Connection.php:32
40.0246546592Connection->connect( ).../Connection.php:26
50.0246549512Logger->info( $message = 'Tentando conexão com método: padrão', $context = ??? ).../Connection.php:120
60.0246549512Logger->log( $level = 'INFO', $message = 'Tentando conexão com método: padrão', $context = [] ).../Logger.php:88
70.0248551704Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:33] [INFO] Tentando conexão com método: padrão\n' ).../Logger.php:134
80.0248551704file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:33] [INFO] Tentando conexão com método: padrão\n', $flags = 10 ).../Logger.php:157

( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
20.0246545992Connection::getInstance( $type = 'local' ).../index.php:15
30.0246546104Connection->__construct( $type = 'local' ).../Connection.php:32
40.0246546592Connection->connect( ).../Connection.php:26
51.4395593824Logger->info( $message = 'Conexão estabelecida com método \'padrão\': chevaliertech02', $context = ??? ).../Connection.php:126
61.4395593824Logger->log( $level = 'INFO', $message = 'Conexão estabelecida com método \'padrão\': chevaliertech02', $context = [] ).../Logger.php:88
71.4396594288Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:34] [INFO] Conexão estabelecida com método \'padrão\': chevaliertech02\n' ).../Logger.php:134
81.4396594288file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:34] [INFO] Conexão estabelecida com método \'padrão\': chevaliertech02\n', $flags = 10 ).../Logger.php:157

( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
21.4401599552Logger->info( $message = 'Acesso à página principal', $context = ??? ).../index.php:16
31.4401599552Logger->log( $level = 'INFO', $message = 'Acesso à página principal', $context = [] ).../Logger.php:88
41.4401599984Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:34] [INFO] Acesso à página principal\n' ).../Logger.php:134
51.4401599984file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:34] [INFO] Acesso à página principal\n', $flags = 10 ).../Logger.php:157
Início - Sistema de Canhotos de Frete

Sistema de Canhotos de Frete

Bem-vindo ao sistema de processamento de canhotos

✅ Sistema Conectado

Banco de dados conectado com sucesso!

Pendentes


( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
21.4405599592Connection->fetchOne( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Pendente\'', $params = ??? ).../index.php:116
31.4405599592Connection->query( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Pendente\'', $params = [] ).../Connection.php:214
41.4583638336Logger->debug( $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Pendente\'', 'params' => [], 'execution_time' => 0.01782393455505371] ).../Connection.php:181
51.4583638336Logger->log( $level = 'DEBUG', $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Pendente\'', 'params' => [], 'execution_time' => 0.01782393455505371] ).../Logger.php:76
61.4583639088Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Pendente\'","params":[],"execution_time":0.01782393455505371}\n' ).../Logger.php:134
71.4583639088file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Pendente\'","params":[],"execution_time":0.01782393455505371}\n', $flags = 10 ).../Logger.php:157
3

Processando


( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
21.4590599968Connection->fetchOne( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processando\'', $params = ??? ).../index.php:130
31.4590599968Connection->query( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processando\'', $params = [] ).../Connection.php:214
41.4775638712Logger->debug( $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processando\'', 'params' => [], 'execution_time' => 0.018534183502197266] ).../Connection.php:181
51.4776638712Logger->log( $level = 'DEBUG', $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processando\'', 'params' => [], 'execution_time' => 0.018534183502197266] ).../Logger.php:76
61.4776639496Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processando\'","params":[],"execution_time":0.018534183502197266}\n' ).../Logger.php:134
71.4776639496file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processando\'","params":[],"execution_time":0.018534183502197266}\n', $flags = 10 ).../Logger.php:157
0

Processados


( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
21.4780599968Connection->fetchOne( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processado\'', $params = ??? ).../index.php:144
31.4780599968Connection->query( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processado\'', $params = [] ).../Connection.php:214
41.5238638712Logger->debug( $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processado\'', 'params' => [], 'execution_time' => 0.04578518867492676] ).../Connection.php:181
51.5238638712Logger->log( $level = 'DEBUG', $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processado\'', 'params' => [], 'execution_time' => 0.04578518867492676] ).../Logger.php:76
61.5239639496Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processado\'","params":[],"execution_time":0.04578518867492676}\n' ).../Logger.php:134
71.5239639496file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Processado\'","params":[],"execution_time":0.04578518867492676}\n', $flags = 10 ).../Logger.php:157
66549

Rejeitados


( ! ) Warning: file_put_contents(/var/www/html/storage/logs/app_2026-06-23.log): Failed to open stream: Permission denied in /var/www/html/src/Services/Logger.php on line 157
Call Stack
#TimeMemoryFunctionLocation
10.0239441856{main}( ).../index.php:0
21.5244599968Connection->fetchOne( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Rejeitado\'', $params = ??? ).../index.php:158
31.5244599968Connection->query( $sql = 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Rejeitado\'', $params = [] ).../Connection.php:214
41.5421638712Logger->debug( $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Rejeitado\'', 'params' => [], 'execution_time' => 0.01770496368408203] ).../Connection.php:181
51.5421638712Logger->log( $level = 'DEBUG', $message = 'Query executada', $context = ['sql' => 'SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Rejeitado\'', 'params' => [], 'execution_time' => 0.01770496368408203] ).../Logger.php:76
61.5422639464Logger->writeToFile( $file = '/var/www/html/storage/logs/app_2026-06-23.log', $content = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Rejeitado\'","params":[],"execution_time":0.01770496368408203}\n' ).../Logger.php:134
71.5422639464file_put_contents( $filename = '/var/www/html/storage/logs/app_2026-06-23.log', $data = '[2026-06-23 16:07:34] [DEBUG] Query executada {"sql":"SELECT COUNT(*) as count FROM canhotos_processamento WHERE status_processamento = \'Rejeitado\'","params":[],"execution_time":0.01770496368408203}\n', $flags = 10 ).../Logger.php:157
0

📜 Histórico de Versões

📋 Changelog - Sistema de Canhotos de Frete



Todas as mudanças notáveis neste projeto serão documentadas neste arquivo.

O formato é baseado em Keep a Changelog,
e este projeto adere ao Versionamento Semântico.

🚀 Versão 1.2 - Padronização de Layout & Componentes 2026-04-20


🚀 Adicionado

  • Arquitetura de Componentes: Extração de Topo, Menu de Navegação e Rodapé para componentes PHP reutilizáveis.

  • Identidade Visual Unificada: Padronização da interface em todas as páginas do sistema (Dashboard, Processamento, Logs e Visualização).

  • CSS Centralizado: Criação do `common.css` unificando estilos globais e reduzindo redundância de código.


🛠️ Corrigido

  • Correção de sintaxe em tags de script em páginas refatoradas.

  • Ajuste no balanço de fechamento de divs (DOM) após migração para componentes.

  • Validação de consistência visual entre as páginas 'index', 'dashboard', 'process' e 'logs'.


🚀 Versão 1.1 - Smart Crop & Correções 2026-04-20


🚀 Adicionado

  • Implementação da função de recorte inteligente (AICrop) utilizando IA para otimizar a visualização dos canhotos.

  • Integração de recorte automático no fluxo de visualização de imagens.


🛠️ Corrigido

  • Ajustes e correções na lógica de status de processamento (ex: diferenciação entre 'Processado' e 'Pendente Recorte').

  • Melhoria na exibição e filtragem de status na interface web.


🚀 Versão 1.0 - Validação Humana 2026-04-16


🚀 Adicionado

  • Liberado para produção.

  • Implementação de modal interativo de Changelog global.

  • Validação IA expandida para canhotos com preenchimento manual de 'Liberação Canhoto' (vistos locais).

  • Ajuste e correção da gravação das aprovações da IA como status 'Validado'.