LogConfigFilter.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Globalization;
  4. using System.Text.RegularExpressions;
  5. using System.Xml;
  6. namespace Wayne.Lib.Log
  7. {
  8. /// <summary>
  9. /// Filter for a log configuration.
  10. /// </summary>
  11. public class LogConfigFilter
  12. {
  13. /// <summary>
  14. /// List of subfilters
  15. /// </summary>
  16. public readonly List<LogConfigSubFilter> SubFilters = new List<LogConfigSubFilter>();
  17. /// <summary>
  18. /// Entity type regex
  19. /// </summary>
  20. public string EntityTypeRegexFilter { get; set; }
  21. /// <summary>
  22. /// Entity subtype regex
  23. /// </summary>
  24. public string EntitySubTypeRegexFilter { get; set; }
  25. /// <summary>
  26. /// Regex for the ID
  27. /// </summary>
  28. public string IdRegexFilter { get; set; }
  29. /// <summary>
  30. /// Filter level
  31. /// </summary>
  32. public DebugLogLevel FilterLevel { get; set; }
  33. /// <summary>
  34. /// Constructor
  35. /// </summary>
  36. public LogConfigFilter()
  37. {
  38. }
  39. /// <summary>
  40. /// Constructor
  41. /// </summary>
  42. /// <param name="entityTypeRegexFilter"></param>
  43. /// <param name="entitySubTypeRegexFilter"></param>
  44. /// <param name="idRegexFilter"></param>
  45. /// <param name="filterLevel"></param>
  46. public LogConfigFilter(string entityTypeRegexFilter, string entitySubTypeRegexFilter, string idRegexFilter, DebugLogLevel filterLevel)
  47. {
  48. EntityTypeRegexFilter = entityTypeRegexFilter;
  49. EntitySubTypeRegexFilter = entitySubTypeRegexFilter;
  50. IdRegexFilter = idRegexFilter;
  51. FilterLevel = filterLevel;
  52. }
  53. /// <summary>
  54. /// Deserialization constructor
  55. /// </summary>
  56. /// <param name="logFilterNode"></param>
  57. internal LogConfigFilter(XmlNode logFilterNode)
  58. {
  59. XmlAttribute entityTypeAttribute = logFilterNode.Attributes["EntityType"];
  60. if (entityTypeAttribute != null)
  61. EntityTypeRegexFilter = entityTypeAttribute.Value;
  62. else
  63. EntityTypeRegexFilter = string.Empty;
  64. XmlAttribute entitySubTypeAttribute = logFilterNode.Attributes["EntitySubType"];
  65. if (entitySubTypeAttribute != null)
  66. EntitySubTypeRegexFilter = entitySubTypeAttribute.Value;
  67. else
  68. EntitySubTypeRegexFilter = string.Empty;
  69. XmlAttribute idAttribute = logFilterNode.Attributes["Id"];
  70. if (idAttribute != null)
  71. IdRegexFilter = idAttribute.Value;
  72. else
  73. IdRegexFilter = string.Empty;
  74. XmlAttribute filterLevelttribute = logFilterNode.Attributes["FilterLevel"];
  75. if (filterLevelttribute != null)
  76. FilterLevel = EnumSupport.Parse(filterLevelttribute.Value, false, DebugLogLevel.Normal);
  77. else
  78. FilterLevel = DebugLogLevel.Normal;
  79. foreach (XmlNode childNode in logFilterNode.ChildNodes)
  80. {
  81. if (childNode.Name.Equals("SubFilter", StringComparison.Ordinal))
  82. {
  83. XmlAttribute enabledAttribute = childNode.Attributes["Enabled"];
  84. if ((enabledAttribute != null) && !XmlConvert.ToBoolean(enabledAttribute.Value))
  85. continue;
  86. SubFilters.Add(new LogConfigSubFilter(childNode));
  87. }
  88. }
  89. }
  90. internal bool MatchFilter(EntityCategory entityCategory, out DebugLogLevel debugLogLevel)
  91. {
  92. bool entityTypeMatch = (string.IsNullOrEmpty(EntityTypeRegexFilter) || Regex.IsMatch(entityCategory.Entity.EntityType, EntityTypeRegexFilter, RegexOptions.IgnoreCase));
  93. if (entityTypeMatch)
  94. {
  95. bool entitySubTypeMatch = (string.IsNullOrEmpty(EntitySubTypeRegexFilter) || Regex.IsMatch(entityCategory.Entity.EntitySubType, EntitySubTypeRegexFilter, RegexOptions.IgnoreCase));
  96. if (entitySubTypeMatch)
  97. {
  98. bool idMatch = string.IsNullOrEmpty(IdRegexFilter);
  99. if (!idMatch)
  100. {
  101. if (entityCategory.Entity.Id == IdentifiableEntity.NoId)
  102. idMatch = Regex.IsMatch(string.Empty, IdRegexFilter, RegexOptions.IgnoreCase);
  103. else
  104. idMatch = Regex.IsMatch(entityCategory.Entity.Id.ToString(CultureInfo.InvariantCulture), IdRegexFilter, RegexOptions.IgnoreCase);
  105. }
  106. if (idMatch)
  107. {
  108. foreach (LogConfigSubFilter subFilter in SubFilters)
  109. {
  110. if (subFilter.MatchFilter(entityCategory, out debugLogLevel))
  111. {
  112. // Use the first match found.
  113. return true;
  114. }
  115. }
  116. debugLogLevel = FilterLevel;
  117. return true;
  118. }
  119. }
  120. }
  121. debugLogLevel = DebugLogLevel.Excluded;
  122. return false;
  123. }
  124. /// <summary>
  125. /// ToString
  126. /// </summary>
  127. /// <returns></returns>
  128. public override string ToString()
  129. {
  130. return string.Concat("EntityType=\"", EntityTypeRegexFilter ?? string.Empty,
  131. "\", SubType=\"", EntitySubTypeRegexFilter ?? string.Empty,
  132. "\", Id=\"", IdRegexFilter ?? string.Empty,
  133. "\", Level=\"", FilterLevel, "\"");
  134. }
  135. /// <summary>
  136. /// Serialization
  137. /// </summary>
  138. /// <param name="xmlWriter"></param>
  139. internal void WriteXml(XmlWriter xmlWriter)
  140. {
  141. xmlWriter.WriteStartElement("Filter");
  142. if (!string.IsNullOrEmpty(EntityTypeRegexFilter))
  143. xmlWriter.WriteAttributeString("EntityType", EntityTypeRegexFilter ?? string.Empty);
  144. if (!string.IsNullOrEmpty(EntitySubTypeRegexFilter))
  145. xmlWriter.WriteAttributeString("EntitySubType", EntitySubTypeRegexFilter ?? string.Empty);
  146. if (!string.IsNullOrEmpty(IdRegexFilter))
  147. xmlWriter.WriteAttributeString("Id", IdRegexFilter ?? string.Empty);
  148. xmlWriter.WriteAttributeString("FilterLevel", FilterLevel.ToString());
  149. foreach (LogConfigSubFilter subFilter in SubFilters)
  150. subFilter.WriteXml(xmlWriter);
  151. xmlWriter.WriteEndElement(); // Filter
  152. }
  153. }
  154. }