LogWindow.xaml.cs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. using MediaBrowser.Common.Kernel;
  2. using NLog;
  3. using NLog.Config;
  4. using NLog.Targets;
  5. using System.ComponentModel;
  6. using System.Threading;
  7. using System.Threading.Tasks;
  8. using System.Windows;
  9. namespace MediaBrowser.ServerApplication.Logging
  10. {
  11. /// <summary>
  12. /// Interaction logic for LogWindow.xaml
  13. /// </summary>
  14. public partial class LogWindow : Window
  15. {
  16. /// <summary>
  17. /// The _ui thread
  18. /// </summary>
  19. private readonly TaskScheduler _uiThread;
  20. /// <summary>
  21. /// The _kernel
  22. /// </summary>
  23. private readonly IKernel _kernel;
  24. /// <summary>
  25. /// Initializes a new instance of the <see cref="LogWindow" /> class.
  26. /// </summary>
  27. /// <param name="kernel">The kernel.</param>
  28. public LogWindow(IKernel kernel)
  29. {
  30. InitializeComponent();
  31. _uiThread = TaskScheduler.FromCurrentSynchronizationContext();
  32. _kernel = kernel;
  33. Loaded += LogWindow_Loaded;
  34. }
  35. /// <summary>
  36. /// Handles the Loaded event of the LogWindow control.
  37. /// </summary>
  38. /// <param name="sender">The source of the event.</param>
  39. /// <param name="e">The <see cref="RoutedEventArgs" /> instance containing the event data.</param>
  40. void LogWindow_Loaded(object sender, RoutedEventArgs e)
  41. {
  42. var target = new TraceTarget
  43. {
  44. Layout = "${longdate}, ${level}, ${logger}, ${message}"
  45. };
  46. AddLogTarget(target, "LogWindowTraceTarget");
  47. }
  48. /// <summary>
  49. /// Raises the <see cref="E:System.Windows.Window.Closing" /> event.
  50. /// </summary>
  51. /// <param name="e">A <see cref="T:System.ComponentModel.CancelEventArgs" /> that contains the event data.</param>
  52. protected override void OnClosing(CancelEventArgs e)
  53. {
  54. base.OnClosing(e);
  55. RemoveLogTarget("LogWindowTraceTarget");
  56. }
  57. /// <summary>
  58. /// Logs the message.
  59. /// </summary>
  60. /// <param name="msg">The MSG.</param>
  61. public async void LogMessage(string msg)
  62. {
  63. await Task.Factory.StartNew(() => lbxLogData.Items.Insert(0, msg.TrimEnd('\n')), CancellationToken.None, TaskCreationOptions.None, _uiThread);
  64. }
  65. /// <summary>
  66. /// The log layout
  67. /// </summary>
  68. /// <value>The log layout.</value>
  69. public string LogLayout
  70. {
  71. get { return "${longdate}, ${level}, ${logger}, ${message}"; }
  72. }
  73. /// <summary>
  74. /// Adds the log target.
  75. /// </summary>
  76. /// <param name="target">The target.</param>
  77. /// <param name="name">The name.</param>
  78. private void AddLogTarget(Target target, string name)
  79. {
  80. var config = NLog.LogManager.Configuration;
  81. config.RemoveTarget(name);
  82. target.Name = name;
  83. config.AddTarget(name, target);
  84. var level = _kernel.Configuration.EnableDebugLevelLogging ? LogLevel.Debug : LogLevel.Info;
  85. var rule = new LoggingRule("*", level, target);
  86. config.LoggingRules.Add(rule);
  87. NLog.LogManager.Configuration = config;
  88. }
  89. /// <summary>
  90. /// Removes the log target.
  91. /// </summary>
  92. /// <param name="name">The name.</param>
  93. private void RemoveLogTarget(string name)
  94. {
  95. var config = NLog.LogManager.Configuration;
  96. config.RemoveTarget(name);
  97. NLog.LogManager.Configuration = config;
  98. }
  99. /// <summary>
  100. /// Shuts down.
  101. /// </summary>
  102. public async void ShutDown()
  103. {
  104. await Task.Factory.StartNew(Close, CancellationToken.None, TaskCreationOptions.None, _uiThread);
  105. }
  106. }
  107. }