SimpleSecurityTokenProvider.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. //------------------------------------------------------------
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. //------------------------------------------------------------
  4. using System;
  5. using System.IdentityModel.Selectors;
  6. using System.IdentityModel.Tokens;
  7. using System.Collections.ObjectModel;
  8. using System.IdentityModel.Policy;
  9. using System.ServiceModel;
  10. using System.Collections.Generic;
  11. using System.IdentityModel.Claims;
  12. using System.ServiceModel.Security.Tokens;
  13. using System.IdentityModel;
  14. namespace System.ServiceModel.Security
  15. {
  16. /// <summary>
  17. /// Creates a security token provider that produces a security token as an issued token
  18. /// for federated bindings.
  19. /// </summary>
  20. public class SimpleSecurityTokenProvider : SecurityTokenProvider
  21. {
  22. SecurityToken _securityToken;
  23. /// <summary>
  24. /// Creates a security token provider that produces a security token as an issued token
  25. /// for federated bindings.
  26. /// </summary>
  27. /// <param name="token">The security token to provide.</param>
  28. /// <param name="tokenRequirement">
  29. /// The requirements described by the binding that will use <paramref name="token"/> to secure
  30. /// messages.
  31. /// </param>
  32. /// <exception cref="ArgumentNullException"><paramref name="token"/> is set to null.</exception>
  33. public SimpleSecurityTokenProvider(SecurityToken token, SecurityTokenRequirement tokenRequirement)
  34. {
  35. if (token == null)
  36. {
  37. throw DiagnosticUtility.ExceptionUtility.ThrowHelperArgumentNull("token");
  38. }
  39. GenericXmlSecurityToken xmlIssuedToken = token as GenericXmlSecurityToken;
  40. if (xmlIssuedToken != null)
  41. {
  42. _securityToken = WrapWithAuthPolicy(xmlIssuedToken, tokenRequirement);
  43. }
  44. else
  45. {
  46. _securityToken = token;
  47. }
  48. }
  49. /// <summary>
  50. /// Creates a security token according to a gieven timeout.
  51. /// </summary>
  52. /// <param name="timeout">The <see cref="TimeSpan"/>.</param>
  53. /// <returns></returns>
  54. protected override SecurityToken GetTokenCore(TimeSpan timeout)
  55. {
  56. return _securityToken;
  57. }
  58. /// <summary>
  59. /// Gets a GenericXmlSecurityToken that wraps the provided issued token
  60. /// with the authorization policies necessary.
  61. /// </summary>
  62. static GenericXmlSecurityToken WrapWithAuthPolicy(GenericXmlSecurityToken issuedToken,
  63. SecurityTokenRequirement tokenRequirement)
  64. {
  65. EndpointIdentity endpointIdentity = null;
  66. var issuedTokenRequirement = tokenRequirement as InitiatorServiceModelSecurityTokenRequirement;
  67. if (issuedTokenRequirement != null)
  68. {
  69. EndpointAddress targetAddress = issuedTokenRequirement.TargetAddress;
  70. if (targetAddress.Uri.IsAbsoluteUri)
  71. {
  72. endpointIdentity = EndpointIdentity.CreateDnsIdentity(targetAddress.Uri.DnsSafeHost);
  73. }
  74. }
  75. ReadOnlyCollection<IAuthorizationPolicy> authorizationPolicies
  76. = GetServiceAuthorizationPolicies(endpointIdentity);
  77. return new GenericXmlSecurityToken(issuedToken.TokenXml,
  78. issuedToken.ProofToken,
  79. issuedToken.ValidFrom,
  80. issuedToken.ValidTo,
  81. issuedToken.InternalTokenReference,
  82. issuedToken.ExternalTokenReference,
  83. authorizationPolicies);
  84. }
  85. //
  86. // Modeled after WCF's CoreFederatedTokenProvider.GetServiceAuthorizationPolicies
  87. //
  88. static ReadOnlyCollection<IAuthorizationPolicy> GetServiceAuthorizationPolicies(EndpointIdentity endpointIdentity)
  89. {
  90. if (endpointIdentity != null)
  91. {
  92. List<Claim> claims = new List<Claim>(1);
  93. claims.Add(endpointIdentity.IdentityClaim);
  94. List<IAuthorizationPolicy> policies = new List<IAuthorizationPolicy>(1);
  95. policies.Add(new UnconditionalPolicy(SecurityUtils.CreateIdentity(endpointIdentity.IdentityClaim.Resource.ToString()),
  96. new DefaultClaimSet(ClaimSet.System, claims)));
  97. return policies.AsReadOnly();
  98. }
  99. else
  100. {
  101. return EmptyReadOnlyCollection<IAuthorizationPolicy>.Instance;
  102. }
  103. }
  104. }
  105. }