NLogger.cs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. using MediaBrowser.Model.Logging;
  2. using System;
  3. using System.Text;
  4. namespace MediaBrowser.Common.Implementations.Logging
  5. {
  6. /// <summary>
  7. /// Class NLogger
  8. /// </summary>
  9. public class NLogger : ILogger
  10. {
  11. /// <summary>
  12. /// The _logger
  13. /// </summary>
  14. private readonly NLog.Logger _logger;
  15. private readonly ILogManager _logManager;
  16. /// <summary>
  17. /// The _lock object
  18. /// </summary>
  19. private static readonly object LockObject = new object();
  20. /// <summary>
  21. /// Initializes a new instance of the <see cref="NLogger" /> class.
  22. /// </summary>
  23. /// <param name="name">The name.</param>
  24. /// <param name="logManager">The log manager.</param>
  25. public NLogger(string name, ILogManager logManager)
  26. {
  27. _logManager = logManager;
  28. lock (LockObject)
  29. {
  30. _logger = NLog.LogManager.GetLogger(name);
  31. }
  32. }
  33. /// <summary>
  34. /// Infoes the specified message.
  35. /// </summary>
  36. /// <param name="message">The message.</param>
  37. /// <param name="paramList">The param list.</param>
  38. public void Info(string message, params object[] paramList)
  39. {
  40. _logger.Info(message, paramList);
  41. }
  42. /// <summary>
  43. /// Errors the specified message.
  44. /// </summary>
  45. /// <param name="message">The message.</param>
  46. /// <param name="paramList">The param list.</param>
  47. public void Error(string message, params object[] paramList)
  48. {
  49. _logger.Error(message, paramList);
  50. }
  51. /// <summary>
  52. /// Warns the specified message.
  53. /// </summary>
  54. /// <param name="message">The message.</param>
  55. /// <param name="paramList">The param list.</param>
  56. public void Warn(string message, params object[] paramList)
  57. {
  58. _logger.Warn(message, paramList);
  59. }
  60. /// <summary>
  61. /// Debugs the specified message.
  62. /// </summary>
  63. /// <param name="message">The message.</param>
  64. /// <param name="paramList">The param list.</param>
  65. public void Debug(string message, params object[] paramList)
  66. {
  67. _logger.Debug(message, paramList);
  68. }
  69. /// <summary>
  70. /// Logs the exception.
  71. /// </summary>
  72. /// <param name="message">The message.</param>
  73. /// <param name="exception">The exception.</param>
  74. /// <param name="paramList">The param list.</param>
  75. /// <exception cref="System.NotImplementedException"></exception>
  76. public void ErrorException(string message, Exception exception, params object[] paramList)
  77. {
  78. LogException(LogSeverity.Error, message, exception, paramList);
  79. }
  80. /// <summary>
  81. /// Logs the exception.
  82. /// </summary>
  83. /// <param name="level">The level.</param>
  84. /// <param name="message">The message.</param>
  85. /// <param name="exception">The exception.</param>
  86. /// <param name="paramList">The param list.</param>
  87. private void LogException(LogSeverity level, string message, Exception exception, params object[] paramList)
  88. {
  89. message = FormatMessage(message, paramList).Replace(Environment.NewLine, ". ");
  90. var messageText = LogHelper.GetLogMessage(exception);
  91. var prefix = _logManager.ExceptionMessagePrefix;
  92. if (!string.IsNullOrWhiteSpace(prefix))
  93. {
  94. messageText.Insert(0, prefix);
  95. }
  96. LogMultiline(message, level, messageText);
  97. }
  98. /// <summary>
  99. /// Formats the message.
  100. /// </summary>
  101. /// <param name="message">The message.</param>
  102. /// <param name="paramList">The param list.</param>
  103. /// <returns>System.String.</returns>
  104. private static string FormatMessage(string message, params object[] paramList)
  105. {
  106. if (paramList != null)
  107. {
  108. for (var i = 0; i < paramList.Length; i++)
  109. {
  110. message = message.Replace("{" + i + "}", paramList[i].ToString());
  111. }
  112. }
  113. return message;
  114. }
  115. /// <summary>
  116. /// Logs the multiline.
  117. /// </summary>
  118. /// <param name="message">The message.</param>
  119. /// <param name="severity">The severity.</param>
  120. /// <param name="additionalContent">Content of the additional.</param>
  121. public void LogMultiline(string message, LogSeverity severity, StringBuilder additionalContent)
  122. {
  123. additionalContent.Insert(0, message + Environment.NewLine);
  124. const char tabChar = '\t';
  125. var text = additionalContent.ToString()
  126. .Replace(Environment.NewLine, Environment.NewLine + tabChar)
  127. .TrimEnd(tabChar);
  128. if (text.EndsWith(Environment.NewLine))
  129. {
  130. text = text.Substring(0, text.LastIndexOf(Environment.NewLine, StringComparison.OrdinalIgnoreCase));
  131. }
  132. _logger.Log(GetLogLevel(severity), text);
  133. }
  134. /// <summary>
  135. /// Gets the log level.
  136. /// </summary>
  137. /// <param name="severity">The severity.</param>
  138. /// <returns>NLog.LogLevel.</returns>
  139. private NLog.LogLevel GetLogLevel(LogSeverity severity)
  140. {
  141. switch (severity)
  142. {
  143. case LogSeverity.Debug:
  144. return NLog.LogLevel.Debug;
  145. case LogSeverity.Error:
  146. return NLog.LogLevel.Error;
  147. case LogSeverity.Warn:
  148. return NLog.LogLevel.Warn;
  149. case LogSeverity.Fatal:
  150. return NLog.LogLevel.Fatal;
  151. case LogSeverity.Info:
  152. return NLog.LogLevel.Info;
  153. default:
  154. throw new ArgumentException("Unknown LogSeverity: " + severity.ToString());
  155. }
  156. }
  157. /// <summary>
  158. /// Logs the specified severity.
  159. /// </summary>
  160. /// <param name="severity">The severity.</param>
  161. /// <param name="message">The message.</param>
  162. /// <param name="paramList">The param list.</param>
  163. public void Log(LogSeverity severity, string message, params object[] paramList)
  164. {
  165. _logger.Log(GetLogLevel(severity), message, paramList);
  166. }
  167. /// <summary>
  168. /// Fatals the specified message.
  169. /// </summary>
  170. /// <param name="message">The message.</param>
  171. /// <param name="paramList">The param list.</param>
  172. public void Fatal(string message, params object[] paramList)
  173. {
  174. _logger.Fatal(message, paramList);
  175. }
  176. /// <summary>
  177. /// Fatals the exception.
  178. /// </summary>
  179. /// <param name="message">The message.</param>
  180. /// <param name="exception">The exception.</param>
  181. /// <param name="paramList">The param list.</param>
  182. public void FatalException(string message, Exception exception, params object[] paramList)
  183. {
  184. LogException(LogSeverity.Fatal, message, exception, paramList);
  185. }
  186. }
  187. }