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.
Zero/ZeroLevel/Services/Logging/Log.cs

258 lines
7.1 KiB

6 years ago
using System;
5 years ago
using ZeroLevel.Logging;
6 years ago
using ZeroLevel.Services.Logging;
using ZeroLevel.Services.Logging.Implementation;
namespace ZeroLevel
{
public static class Log
{
#region Fields
6 years ago
internal static ILogger _router;
#endregion Fields
6 years ago
#region Ctor
6 years ago
static Log()
{
_router = new LogRouter();
}
#endregion Ctor
6 years ago
private static string FormatMessage(string line, params object[] args)
{
if (args == null || args.Length == 0) return line;
try
{
return string.Format(line, args);
}
catch
{
return line;
}
}
#region Logging
6 years ago
public static void Raw(string line, params object[] args)
{
_router.Write(LogLevel.Raw, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// Info message
6 years ago
/// </summary>
public static void Info(string line, params object[] args)
{
_router.Write(LogLevel.Info, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// Warning message
6 years ago
/// </summary>
public static void Warning(string line, params object[] args)
{
_router.Write(LogLevel.Warning, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// Error message
6 years ago
/// </summary>
public static void Error(string line, params object[] args)
{
_router.Write(LogLevel.Error, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// Error message
6 years ago
/// </summary>
public static void Error(Exception ex, string line, params object[] args)
{
_router.Write(LogLevel.Error, FormatMessage(line, args) + "\r\n" + ex.ToString());
}
6 years ago
/// <summary>
/// Fatal crash
6 years ago
/// </summary>
public static void Fatal(string line, params object[] args)
{
_router.Write(LogLevel.Fatal, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// Fatal message (mean stop app after crash)
6 years ago
/// </summary>
public static void Fatal(Exception ex, string line, params object[] args)
{
_router.Write(LogLevel.Fatal, FormatMessage(line, args) + "\r\n" + ex.ToString());
}
6 years ago
/// <summary>
/// Debug message
6 years ago
/// </summary>
public static void Debug(string line, params object[] args)
{
_router.Write(LogLevel.Debug, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// Low-level debug message
6 years ago
/// </summary>
public static void Verbose(string line, params object[] args)
{
_router.Write(LogLevel.Verbose, FormatMessage(line, args));
}
/// <summary>
/// System message
6 years ago
/// </summary>
public static void SystemInfo(string line, params object[] args)
{
_router.Write(LogLevel.SystemInfo, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// System warning
6 years ago
/// </summary>
public static void SystemWarning(string line, params object[] args)
{
_router.Write(LogLevel.SystemWarning, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// System error
6 years ago
/// </summary>
public static void SystemError(string line, params object[] args)
{
_router.Write(LogLevel.SystemError, FormatMessage(line, args));
}
6 years ago
/// <summary>
/// System error
6 years ago
/// </summary>
public static void SystemError(Exception ex, string line, params object[] args)
{
_router.Write(LogLevel.SystemError, FormatMessage(line, args) + "\r\n" + ex.ToString());
}
#endregion Logging
6 years ago
#region Register loggers
6 years ago
public static void AddLogger(ILogger logger, LogLevel level = LogLevel.Standart)
{
(_router as ILogComposer)?.AddLogger(logger, level);
}
#region Delegate logger
6 years ago
public static void AddDelegateLogger(Action<string> handler, LogLevel level = LogLevel.Standart)
{
AddLogger(new DelegateLogger(handler), level);
}
#endregion Delegate logger
6 years ago
#region Console
6 years ago
private static bool _console_log_enabled = false;
6 years ago
public static void AddConsoleLogger(LogLevel level = LogLevel.Standart)
{
6 years ago
if (_console_log_enabled == false)
{
AddLogger(new ConsoleLogger(), level);
_console_log_enabled = true;
}
6 years ago
}
#endregion Console
6 years ago
#region TextLogs
6 years ago
public static void AddTextFileLogger(TextFileLoggerOptions options, LogLevel level = LogLevel.FullDebug)
{
AddLogger(new TextFileLogger(options), level);
}
public static void AddTextFileLogger(string path, LogLevel level = LogLevel.FullDebug)
{
AddLogger(new FileLogger(path), level);
}
#endregion TextLogs
6 years ago
#region Encrypted file log
6 years ago
public static void AddEncryptedFileLogger(EncryptedFileLogOptions options, LogLevel level = LogLevel.FullDebug)
{
AddLogger(new EncryptedFileLog(options), level);
}
#endregion Encrypted file log
#endregion Register loggers
6 years ago
#region Settings
public static void CreateLoggingFromConfiguration(IConfigurationSet configSet)
6 years ago
{
IConfiguration config;
bool log_section = false;
if (configSet.Default.Contains("log"))
6 years ago
{
config = configSet.Default;
6 years ago
}
else if (configSet.ContainsSection("log"))
6 years ago
{
config = configSet["log"];
log_section = true;
6 years ago
}
else
6 years ago
{
return;
6 years ago
}
string logPath = null;
if (config.Contains("log"))
6 years ago
{
logPath = config.First("log");
6 years ago
}
else if (log_section && config.Contains("path"))
6 years ago
{
logPath = config.First("path");
}
if (false == string.IsNullOrWhiteSpace(logPath))
{
var options = TextFileLoggerOptions.CreateOptionsBy(config, logPath, log_section ? string.Empty : "log.");
6 years ago
if (options != null)
{
AddTextFileLogger(options);
6 years ago
}
}
if (config.FirstOrDefault("console", false))
{
AddConsoleLogger(LogLevel.System | LogLevel.FullDebug);
}
6 years ago
}
6 years ago
/// <summary>
6 years ago
/// Set max count log-messages in queue
6 years ago
/// </summary>
public static void Backlog(long backlog)
{
(_router as ILogComposer)?.SetupBacklog(backlog);
}
#endregion Settings
6 years ago
#region Disposable
6 years ago
public static void Dispose()
{
_router.Dispose();
}
#endregion Disposable
6 years ago
}
}

Powered by TurnKey Linux.