EventTraceActivityHelper.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. // <copyright>
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. // </copyright>
  4. namespace System.ServiceModel.Diagnostics
  5. {
  6. using System;
  7. using System.Diagnostics;
  8. using System.Runtime;
  9. using System.Runtime.Diagnostics;
  10. using System.Security;
  11. using System.Security.Permissions;
  12. using System.ServiceModel.Channels;
  13. using System.Xml;
  14. internal static class EventTraceActivityHelper
  15. {
  16. public static bool TryAttachActivity(Message message, EventTraceActivity activity)
  17. {
  18. if (FxTrace.Trace.IsEnd2EndActivityTracingEnabled && (message != null) && (activity != null))
  19. {
  20. if (!message.Properties.ContainsKey(EventTraceActivity.Name))
  21. {
  22. message.Properties.Add(EventTraceActivity.Name, activity);
  23. return true;
  24. }
  25. }
  26. return false;
  27. }
  28. public static EventTraceActivity TryExtractActivity(Message message)
  29. {
  30. return TryExtractActivity(message, false);
  31. }
  32. public static EventTraceActivity TryExtractActivity(Message message, bool createIfNotExist)
  33. {
  34. EventTraceActivity eventTraceActivity = null;
  35. if (message != null && message.State != MessageState.Closed)
  36. {
  37. object property;
  38. if (message.Properties.TryGetValue(EventTraceActivity.Name, out property))
  39. {
  40. eventTraceActivity = property as EventTraceActivity;
  41. }
  42. if (eventTraceActivity == null)
  43. {
  44. Guid activityId;
  45. if (GetMessageId(message, out activityId))
  46. {
  47. eventTraceActivity = new EventTraceActivity(activityId);
  48. }
  49. else
  50. {
  51. UniqueId uid = message.Headers.RelatesTo;
  52. if (uid != null)
  53. {
  54. if (uid.TryGetGuid(out activityId))
  55. {
  56. eventTraceActivity = new EventTraceActivity(activityId);
  57. }
  58. }
  59. }
  60. if (eventTraceActivity == null && createIfNotExist)
  61. {
  62. eventTraceActivity = new EventTraceActivity();
  63. }
  64. if (eventTraceActivity != null)
  65. {
  66. // Attach the trace activity to the message
  67. message.Properties[EventTraceActivity.Name] = eventTraceActivity;
  68. }
  69. }
  70. }
  71. return eventTraceActivity;
  72. }
  73. [Fx.Tag.SecurityNote(Critical = "This sets the ActivityId on the thread. Must not be settable from PT code unless from safe context.")]
  74. [SecurityCritical]
  75. [SecurityPermission(SecurityAction.Assert, Unrestricted = true)]
  76. internal static void SetOnThread(EventTraceActivity eventTraceActivity)
  77. {
  78. if (eventTraceActivity != null)
  79. {
  80. Trace.CorrelationManager.ActivityId = eventTraceActivity.ActivityId;
  81. }
  82. }
  83. private static bool GetMessageId(Message message, out Guid guid)
  84. {
  85. UniqueId uniqueId = message.Headers.MessageId;
  86. if (uniqueId == null)
  87. {
  88. guid = Guid.Empty;
  89. return false;
  90. }
  91. return uniqueId.TryGetGuid(out guid);
  92. }
  93. }
  94. }