BaseService.cs 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. using System;
  2. using Rac.Models;
  3. namespace Rac.Common
  4. {
  5. public abstract class BaseService
  6. {
  7. public abstract void Start();
  8. public abstract void Stop();
  9. public event EventHandler<LogEventArgs> Log = delegate { };
  10. protected void LogDebug(string message)
  11. {
  12. OnMessage(new LogEventArgs { Level = LogLevel.Debug, Log = message });
  13. }
  14. protected void LogTrace(string message)
  15. {
  16. OnMessage(new LogEventArgs { Level = LogLevel.Trace, Log = message });
  17. }
  18. protected void LogInfo(string message)
  19. {
  20. OnMessage(new LogEventArgs { Level = LogLevel.Info, Log = message });
  21. }
  22. protected void LogWarning(string message)
  23. {
  24. OnMessage(new LogEventArgs { Level = LogLevel.Warning, Log = message });
  25. }
  26. protected void LogError(string message)
  27. {
  28. OnMessage(new LogEventArgs { Level = LogLevel.Error, Log = message });
  29. }
  30. protected void LogFatal(string message)
  31. {
  32. OnMessage(new LogEventArgs { Level = LogLevel.Fatal, Log = message });
  33. }
  34. protected virtual void OnMessage(LogEventArgs e)
  35. {
  36. Log(this, e);
  37. }
  38. }
  39. }