ServiceAuthenticationManager.cs 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. //-----------------------------------------------------------------------------
  4. namespace System.ServiceModel
  5. {
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Collections.ObjectModel;
  9. using System.IdentityModel.Policy;
  10. using System.ServiceModel.Channels;
  11. using System.Collections;
  12. using System.ServiceModel.Security.Tokens;
  13. using System.ServiceModel.Security;
  14. public class ServiceAuthenticationManager
  15. {
  16. public virtual ReadOnlyCollection<IAuthorizationPolicy> Authenticate(ReadOnlyCollection<IAuthorizationPolicy> authPolicy, Uri listenUri, ref Message message)
  17. {
  18. return authPolicy;
  19. }
  20. }
  21. internal class SCTServiceAuthenticationManagerWrapper : ServiceAuthenticationManager
  22. {
  23. ServiceAuthenticationManager wrappedAuthenticationManager;
  24. internal SCTServiceAuthenticationManagerWrapper(ServiceAuthenticationManager wrappedServiceAuthManager)
  25. {
  26. if (wrappedServiceAuthManager == null)
  27. {
  28. throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("wrappedServiceAuthManager");
  29. }
  30. this.wrappedAuthenticationManager = wrappedServiceAuthManager;
  31. }
  32. public override ReadOnlyCollection<IAuthorizationPolicy> Authenticate(ReadOnlyCollection<IAuthorizationPolicy> authPolicy, Uri listenUri, ref Message message)
  33. {
  34. if ((message != null) &&
  35. (message.Properties != null) &&
  36. (message.Properties.Security != null) &&
  37. (message.Properties.Security.TransportToken != null) &&
  38. (message.Properties.Security.ServiceSecurityContext != null) &&
  39. (message.Properties.Security.ServiceSecurityContext.AuthorizationPolicies != null))
  40. {
  41. List<IAuthorizationPolicy> authPolicies = new List<IAuthorizationPolicy>(message.Properties.Security.ServiceSecurityContext.AuthorizationPolicies);
  42. foreach (IAuthorizationPolicy policy in message.Properties.Security.TransportToken.SecurityTokenPolicies)
  43. {
  44. authPolicies.Remove(policy);
  45. }
  46. authPolicy = authPolicies.AsReadOnly();
  47. }
  48. return this.wrappedAuthenticationManager.Authenticate(authPolicy, listenUri, ref message);
  49. }
  50. }
  51. internal class ServiceAuthenticationManagerWrapper : ServiceAuthenticationManager
  52. {
  53. ServiceAuthenticationManager wrappedAuthenticationManager;
  54. string[] filteredActionUriCollection;
  55. internal ServiceAuthenticationManagerWrapper(ServiceAuthenticationManager wrappedServiceAuthManager, string[] actionUriFilter)
  56. {
  57. if (wrappedServiceAuthManager == null)
  58. {
  59. throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("wrappedServiceAuthManager");
  60. }
  61. if ((actionUriFilter != null) && (actionUriFilter.Length > 0))
  62. {
  63. this.filteredActionUriCollection = new string[actionUriFilter.Length];
  64. for (int i = 0; i < actionUriFilter.Length; ++i)
  65. {
  66. this.filteredActionUriCollection[i] = actionUriFilter[i];
  67. }
  68. }
  69. this.wrappedAuthenticationManager = wrappedServiceAuthManager;
  70. }
  71. public override ReadOnlyCollection<IAuthorizationPolicy> Authenticate(ReadOnlyCollection<IAuthorizationPolicy> authPolicy, Uri listenUri, ref Message message)
  72. {
  73. if (CanSkipAuthentication(message))
  74. {
  75. return authPolicy;
  76. }
  77. if (this.filteredActionUriCollection != null)
  78. {
  79. for (int i = 0; i < this.filteredActionUriCollection.Length; ++i)
  80. {
  81. if ((message != null) &&
  82. (message.Headers != null) &&
  83. !String.IsNullOrEmpty(message.Headers.Action) &&
  84. (message.Headers.Action == this.filteredActionUriCollection[i]))
  85. {
  86. return authPolicy;
  87. }
  88. }
  89. }
  90. return this.wrappedAuthenticationManager.Authenticate(authPolicy, listenUri, ref message);
  91. }
  92. //
  93. // We skip the authentication step if the client already has an SCT and there are no Transport level tokens.
  94. // ServiceAuthenticationManager would have been called when the SCT was issued and there is no need to do
  95. // Authentication again. If TransportToken was present then we would call ServiceAutenticationManager as
  96. // TransportTokens are not authenticated during SCT issuance.
  97. //
  98. bool CanSkipAuthentication(Message message)
  99. {
  100. if ((message != null) && (message.Properties != null) && (message.Properties.Security != null) && (message.Properties.Security.TransportToken == null))
  101. {
  102. if ((message.Properties.Security.ProtectionToken != null) &&
  103. (message.Properties.Security.ProtectionToken.SecurityToken != null) &&
  104. (message.Properties.Security.ProtectionToken.SecurityToken.GetType() == typeof(SecurityContextSecurityToken)))
  105. {
  106. return true;
  107. }
  108. if (message.Properties.Security.HasIncomingSupportingTokens)
  109. {
  110. foreach (SupportingTokenSpecification tokenSpecification in message.Properties.Security.IncomingSupportingTokens)
  111. {
  112. if ((tokenSpecification.SecurityTokenAttachmentMode == SecurityTokenAttachmentMode.Endorsing) &&
  113. (tokenSpecification.SecurityToken.GetType() == typeof(SecurityContextSecurityToken)))
  114. {
  115. return true;
  116. }
  117. }
  118. }
  119. }
  120. return false;
  121. }
  122. }
  123. }