Horse Logger: Provider LogFile
O Horse Logger: Provider LogFile é um provedor oficial para o middleware horse-logger para imprimir os logs em suas APIs, em um arquivo físico.
⭕ Pré-requisitos
horse-logger - Horse Logger é um middleware para você registrar logs em suas APIs.
horse-utils-clientip - Horse Utils Client IP é um middleware para você capturar o IP dos Clientes em suas APIs.
Obs: Se você usa Boss (gerenciador de dependências para Delphi), o Horse Logger e o horse-utils-clientip serão instalados automaticamente ao instalar o horse-logger-provider-console.
⚙️ Instalação
Você pode instalar facilmente utilizando o comando boss install
:
boss install horse-logger-provider-logfile
Ou, se você preferir instalar manualmente, basta adicionar as pastas em seu projeto, em Project > Options > Resource Compiler > Directories and Conditionals > Include file search path:
../horse-logger-provider-logfile/src
✔️ Compatibilidade
Delphi | Lazarus |
---|---|
✔️ | ✔️ |
🔠 Formatação
Você pode formatar a saída do log:
Padrão: ${request_clientip} [${time}] ${request_user_agent} "${request_method} ${request_path_info} ${request_version}" ${response_status} ${response_content_length}
Valores possíveis: time
,time_short
,execution_time
,request_clientip
,request_method
,request_version
,request_url
,request_query
,request_path_info
,request_path_translated
,request_cookie
,request_accept
,request_from
,request_host
,request_referer
,request_user_agent
,request_connection
,request_derived_from
,request_remote_addr
,request_remote_host
,request_script_name
,request_server_port
,request_remote_ip
,request_internal_path_info
,request_raw_path_info
,request_cache_control
,request_script_name
,request_authorization
,request_content_encoding
,request_content_type
,request_content_length
,request_content_version
,request_content
,response_version
,response_reason
,response_server
,response_realm
,response_allow
,response_location
,response_log_message
,response_title
,response_content_encoding
,response_content_type
,response_content_length
,response_content_version
,response_content
,response_status
🤙 Exemplos de Uso
uses
Horse,
Horse.Logger, // Esta unit é necessária
Horse.Logger.Provider.LogFile, // Esta unit é necessária
System.SysUtils;
var
LLogFileConfig: THorseLoggerLogFileConfig;
begin
LLogFileConfig := THorseLoggerLogFileConfig.New
.SetLogFormat('${request_clientip} [${time}] ${response_status}')
.SetDir('D:\Servidores\Log');
// Você também pode especificar o formato do log e o diretório que ele vai ser salvo:
// THorseLoggerManager.RegisterProvider(THorseLoggerProviderLogFile.New(LLogFileConfig));
// Aqui você definirá o provedor que será usado.
THorseLoggerManager.RegisterProvider(THorseLoggerProviderLogFile.New());
// Necessário para adicionar o Middleware no Horse:
THorse.Use(THorseLoggerManager.HorseCallback);
THorse.Get('/ping',
procedure(Req: THorseRequest; Res: THorseResponse; Next: TProc)
begin
Res.Send('pong');
end);
THorse.Listen(9000);
end;
{$MODE DELPHI}{$H+}
uses
{$IFDEF UNIX}{$IFDEF UseCThreads}
cthreads,
{$ENDIF}{$ENDIF}
Horse,
Horse.Logger, // Esta unit é necessária
Horse.Logger.Provider.LogFile, // Esta unit é necessária
SysUtils;
var
LLogFileConfig: THorseLoggerLogFileConfig;
procedure GetPing(Req: THorseRequest; Res: THorseResponse; Next: TNextProc);
begin
Res.Send('Pong');
end;
begin
LLogFileConfig := THorseLoggerLogFileConfig.New
.SetLogFormat('${request_clientip} [${time}] ${response_status}')
.SetDir('D:\Servidores\Log');
// Você também pode especificar o formato do log e o diretório que ele vai ser salvo:
THorseLoggerManager.RegisterProvider(THorseLoggerProviderLogFile.New(LLogFileConfig));
// Aqui você definirá o provedor que será usado.
// THorseLoggerManager.RegisterProvider(THorseLoggerProviderLogFile.New());
// Necessário para adicionar o Middleware no Horse:
THorse.Use(THorseLoggerManager.HorseCallback);
THorse.Get('/ping');
THorse.Listen(9000, OnListen);
end.
📝 Exemplos de Saída
Usando a opção de formatação padrão de log, a saída será algo assim:
0:0:0:0:0:0:0:1 [06/outubro/2021 10:34:53.949] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
0:0:0:0:0:0:0:1 [06/outubro/2021 10:34:55.842] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
0:0:0:0:0:0:0:1 [06/outubro/2021 10:34:56.887] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
0:0:0:0:0:0:0:1 [06/outubro/2021 10:35:24.458] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
0:0:0:0:0:0:0:1 [06/outubro/2021 10:35:31.638] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
0:0:0:0:0:0:0:1 [06/outubro/2021 10:35:32.685] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
0:0:0:0:0:0:0:1 [06/outubro/2021 10:35:33.590] PostmanRuntime/7.28.4 "GET /ping HTTP/1.1" 200 4
⚠️ Avisos
- Link para o repositório: https://github.com/HashLoad/horse-logger-provider-logfile.
- Caso tenha alguma sugestão, envie um Pull Request.
- O
horse-logger-provider-logfile
é gratuito e Open Source, está licenciado pela MIT License.