You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Readarr/src/LogentriesNLog/LogentriesTarget.cs

151 lines
4.3 KiB

using System;
using LogentriesCore;
using NLog;
using NLog.Targets;
using NzbDrone.Common.Exceptron.fastJSON;
namespace LogentriesNLog
{
[Target("Logentries")]
public sealed class LogentriesTarget : TargetWithLayout
{
private AsyncLogger logentriesAsync;
public LogentriesTarget()
{
logentriesAsync = new AsyncLogger();
logentriesAsync.setImmediateFlush(true);
}
/** Debug flag. */
public bool Debug
{
get { return logentriesAsync.getDebug(); }
set { logentriesAsync.setDebug(value); }
}
/** Is using DataHub parameter flag. - ste to true if it is needed to send messages to DataHub instance. */
public bool IsUsingDataHub
{
get { return logentriesAsync.getIsUsingDataHab(); }
set { logentriesAsync.setIsUsingDataHub(value); }
}
/** DataHub server address */
public String DataHubAddr
{
get { return logentriesAsync.getDataHubAddr(); }
set { logentriesAsync.setDataHubAddr(value); }
}
/** DataHub server port */
public int DataHubPort
{
get { return logentriesAsync.getDataHubPort(); }
set { logentriesAsync.setDataHubPort(value); }
}
/** Option to set Token programmatically or in Appender Definition */
public string Token
{
get { return logentriesAsync.getToken(); }
set { logentriesAsync.setToken(value); }
}
/** HTTP PUT Flag */
public bool HttpPut
{
get { return logentriesAsync.getUseHttpPut(); }
set { logentriesAsync.setUseHttpPut(value); }
}
/** SSL/TLS parameter flag */
public bool Ssl
{
get { return logentriesAsync.getUseSsl(); }
set { logentriesAsync.setUseSsl(value); }
}
/** ACCOUNT_KEY parameter for HTTP PUT logging */
public String Key
{
get { return logentriesAsync.getAccountKey(); }
set { logentriesAsync.setAccountKey(value); }
}
/** LOCATION parameter for HTTP PUT logging */
public String Location
{
get { return logentriesAsync.getLocation(); }
set { logentriesAsync.setLocation(value); }
}
/* LogHostname - switch that defines whether add host name to the log message */
public bool LogHostname
{
get { return logentriesAsync.getUseHostName(); }
set { logentriesAsync.setUseHostName(value); }
}
/* HostName - user-defined host name. If empty the library will try to obtain it automatically */
public String HostName
{
get { return logentriesAsync.getHostName(); }
set { logentriesAsync.setHostName(value); }
}
/* User-defined log message ID */
public String LogID
{
get { return logentriesAsync.getLogID(); }
set { logentriesAsync.setLogID(value); }
}
public bool KeepConnection { get; set; }
protected override void Write(LogEventInfo logEvent)
{
//Render message content
var log = new Log
{
Level = logEvent.Level.ToString(),
Logger = logEvent.LoggerName,
Message = logEvent.FormattedMessage,
Time = logEvent.TimeStamp,
};
//NLog can pass null references of Exception
if (logEvent.Exception != null)
{
log.Exception = logEvent.Exception.ToString();
log.ExceptionType = logEvent.Exception.GetType().ToString();
}
logentriesAsync.AddLine(JSON.Instance.ToJSON(log));
}
protected override void CloseTarget()
{
base.CloseTarget();
logentriesAsync.interruptWorker();
}
}
public class Log
{
public string Message { get; set; }
public DateTime Time { get; set; }
public string Logger { get; set; }
public string Exception { get; set; }
public string ExceptionType { get; set; }
public String Level { get; set; }
}
}