| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- //------------------------------------------------------------
- // Copyright (c) Microsoft Corporation. All rights reserved.
- //------------------------------------------------------------
- namespace System.ServiceModel
- {
- using System;
- using System.Text;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.Configuration;
- using System.Globalization;
- using System.Net;
- using System.Net.Security;
- using System.Runtime.Serialization;
- using System.Security.Principal;
- using System.ServiceModel.Channels;
- using System.ServiceModel.Configuration;
- using System.ServiceModel.Security;
- using System.Xml;
- public class WS2007HttpBinding : WSHttpBinding
- {
- static readonly ReliableMessagingVersion WS2007ReliableMessagingVersion = ReliableMessagingVersion.WSReliableMessaging11;
- static readonly TransactionProtocol WS2007TransactionProtocol = TransactionProtocol.WSAtomicTransaction11;
- static readonly MessageSecurityVersion WS2007MessageSecurityVersion = MessageSecurityVersion.WSSecurity11WSTrust13WSSecureConversation13WSSecurityPolicy12BasicSecurityProfile10;
- public WS2007HttpBinding(string configName)
- : this()
- {
- ApplyConfiguration(configName);
- }
- public WS2007HttpBinding()
- : base()
- {
- this.ReliableSessionBindingElement.ReliableMessagingVersion = WS2007ReliableMessagingVersion;
- this.TransactionFlowBindingElement.TransactionProtocol = WS2007TransactionProtocol;
- this.HttpsTransport.MessageSecurityVersion = WS2007MessageSecurityVersion;
- }
- public WS2007HttpBinding(SecurityMode securityMode)
- : this(securityMode, false)
- {
- }
- public WS2007HttpBinding(SecurityMode securityMode, bool reliableSessionEnabled)
- : base(securityMode, reliableSessionEnabled)
- {
- this.ReliableSessionBindingElement.ReliableMessagingVersion = WS2007ReliableMessagingVersion;
- this.TransactionFlowBindingElement.TransactionProtocol = WS2007TransactionProtocol;
- this.HttpsTransport.MessageSecurityVersion = WS2007MessageSecurityVersion;
- }
- internal WS2007HttpBinding(WSHttpSecurity security, bool reliableSessionEnabled)
- : base(security, reliableSessionEnabled)
- {
- this.ReliableSessionBindingElement.ReliableMessagingVersion = WS2007ReliableMessagingVersion;
- this.TransactionFlowBindingElement.TransactionProtocol = WS2007TransactionProtocol;
- this.HttpsTransport.MessageSecurityVersion = WS2007MessageSecurityVersion;
- }
- void ApplyConfiguration(string configurationName)
- {
- WS2007HttpBindingCollectionElement section = WS2007HttpBindingCollectionElement.GetBindingCollectionElement();
- WS2007HttpBindingElement element = section.Bindings[configurationName];
- if (element == null)
- {
- throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException(
- SR.GetString(SR.ConfigInvalidBindingConfigurationName,
- configurationName,
- ConfigurationStrings.WS2007HttpBindingCollectionElementName)));
- }
- else
- {
- element.ApplyConfiguration(this);
- }
- }
- protected override SecurityBindingElement CreateMessageSecurity()
- {
- return this.Security.CreateMessageSecurity(this.ReliableSession.Enabled, WS2007MessageSecurityVersion);
- }
- // This is effectively just a copy of WSHttpBinding.TryCreate(), only it news up the 2007 version
- internal new static bool TryCreate(SecurityBindingElement sbe, TransportBindingElement transport, ReliableSessionBindingElement rsbe, TransactionFlowBindingElement tfbe, out Binding binding)
- {
- bool isReliableSession = (rsbe != null);
- binding = null;
- // reverse GetTransport
- HttpTransportSecurity transportSecurity = WSHttpSecurity.GetDefaultHttpTransportSecurity();
- UnifiedSecurityMode mode;
- if (!WSHttpBinding.GetSecurityModeFromTransport(transport, transportSecurity, out mode))
- {
- return false;
- }
- HttpsTransportBindingElement httpsBinding = transport as HttpsTransportBindingElement;
- if (httpsBinding != null && httpsBinding.MessageSecurityVersion != null)
- {
- if (httpsBinding.MessageSecurityVersion.SecurityPolicyVersion != WS2007MessageSecurityVersion.SecurityPolicyVersion)
- {
- return false;
- }
- }
- WSHttpSecurity security;
- if (WS2007HttpBinding.TryCreateSecurity(sbe, mode, transportSecurity, isReliableSession, out security))
- {
- WS2007HttpBinding ws2007HttpBinding = new WS2007HttpBinding(security, isReliableSession);
- bool allowCookies;
- if (!WSHttpBinding.TryGetAllowCookiesFromTransport(transport, out allowCookies))
- {
- return false;
- }
- ws2007HttpBinding.AllowCookies = allowCookies;
- binding = ws2007HttpBinding;
- }
- if (rsbe != null && rsbe.ReliableMessagingVersion != ReliableMessagingVersion.WSReliableMessaging11)
- {
- return false;
- }
- if (tfbe != null && tfbe.TransactionProtocol != TransactionProtocol.WSAtomicTransaction11)
- {
- return false;
- }
- return binding != null;
- }
- // This is effectively just a copy of WSHttpBinding.TryCreateSecurity(), only it passes the 2007 security version
- static bool TryCreateSecurity(SecurityBindingElement sbe, UnifiedSecurityMode mode, HttpTransportSecurity transportSecurity, bool isReliableSession, out WSHttpSecurity security)
- {
- if (!WSHttpSecurity.TryCreate(sbe, mode, transportSecurity, isReliableSession, out security))
- return false;
- // the last check: make sure that security binding element match the incoming security
- return SecurityElement.AreBindingsMatching(security.CreateMessageSecurity(isReliableSession, WS2007MessageSecurityVersion), sbe);
- }
- }
- }
|