WSFederationHttpSecurity.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. //------------------------------------------------------------
  2. // Copyright (c) Microsoft Corporation. All rights reserved.
  3. //------------------------------------------------------------
  4. namespace System.ServiceModel
  5. {
  6. using System.Runtime;
  7. using System.ServiceModel.Channels;
  8. using System.ComponentModel;
  9. public sealed class WSFederationHttpSecurity
  10. {
  11. internal const WSFederationHttpSecurityMode DefaultMode = WSFederationHttpSecurityMode.Message;
  12. WSFederationHttpSecurityMode mode;
  13. FederatedMessageSecurityOverHttp messageSecurity;
  14. public WSFederationHttpSecurity()
  15. : this(DefaultMode, new FederatedMessageSecurityOverHttp())
  16. {
  17. }
  18. WSFederationHttpSecurity(WSFederationHttpSecurityMode mode, FederatedMessageSecurityOverHttp messageSecurity)
  19. {
  20. Fx.Assert(WSFederationHttpSecurityModeHelper.IsDefined(mode), string.Format("Invalid WSFederationHttpSecurityMode value: {0}", mode.ToString()));
  21. this.mode = mode;
  22. this.messageSecurity = messageSecurity == null ? new FederatedMessageSecurityOverHttp() : messageSecurity;
  23. }
  24. public WSFederationHttpSecurityMode Mode
  25. {
  26. get { return this.mode; }
  27. set
  28. {
  29. if (!WSFederationHttpSecurityModeHelper.IsDefined(value))
  30. {
  31. throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentOutOfRangeException("value"));
  32. }
  33. this.mode = value;
  34. }
  35. }
  36. public FederatedMessageSecurityOverHttp Message
  37. {
  38. get { return this.messageSecurity; }
  39. set { this.messageSecurity = value; }
  40. }
  41. internal SecurityBindingElement CreateMessageSecurity(bool isReliableSessionEnabled, MessageSecurityVersion version)
  42. {
  43. if (this.mode == WSFederationHttpSecurityMode.Message || this.mode == WSFederationHttpSecurityMode.TransportWithMessageCredential)
  44. {
  45. return this.messageSecurity.CreateSecurityBindingElement(this.Mode == WSFederationHttpSecurityMode.TransportWithMessageCredential, isReliableSessionEnabled, version);
  46. }
  47. else
  48. {
  49. return null;
  50. }
  51. }
  52. internal static bool TryCreate(SecurityBindingElement sbe,
  53. WSFederationHttpSecurityMode mode,
  54. HttpTransportSecurity transportSecurity,
  55. bool isReliableSessionEnabled,
  56. MessageSecurityVersion version,
  57. out WSFederationHttpSecurity security)
  58. {
  59. security = null;
  60. FederatedMessageSecurityOverHttp messageSecurity = null;
  61. if (sbe == null)
  62. {
  63. mode = WSFederationHttpSecurityMode.None;
  64. }
  65. else
  66. {
  67. mode &= WSFederationHttpSecurityMode.Message | WSFederationHttpSecurityMode.TransportWithMessageCredential;
  68. Fx.Assert(WSFederationHttpSecurityModeHelper.IsDefined(mode), string.Format("Invalid WSFederationHttpSecurityMode value: {0}", mode.ToString()));
  69. if (!FederatedMessageSecurityOverHttp.TryCreate(sbe, mode == WSFederationHttpSecurityMode.TransportWithMessageCredential, isReliableSessionEnabled, version, out messageSecurity))
  70. return false;
  71. }
  72. security = new WSFederationHttpSecurity(mode, messageSecurity);
  73. return true;
  74. }
  75. internal bool InternalShouldSerialize()
  76. {
  77. return this.ShouldSerializeMode()
  78. || this.ShouldSerializeMessage();
  79. }
  80. [EditorBrowsable(EditorBrowsableState.Never)]
  81. public bool ShouldSerializeMode()
  82. {
  83. return this.Mode != DefaultMode;
  84. }
  85. [EditorBrowsable(EditorBrowsableState.Never)]
  86. public bool ShouldSerializeMessage()
  87. {
  88. return this.Message.InternalShouldSerialize();
  89. }
  90. }
  91. }