Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / ServiceModel / System / ServiceModel / WSHttpBinding.cs / 1 / WSHttpBinding.cs
//------------------------------------------------------------ // 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 WSHttpBinding : WSHttpBindingBase { static readonly MessageSecurityVersion WSMessageSecurityVersion = MessageSecurityVersion.WSSecurity11WSTrustFebruary2005WSSecureConversationFebruary2005WSSecurityPolicy11BasicSecurityProfile10; WSHttpSecurity security = new WSHttpSecurity(); public WSHttpBinding(string configName) : this() { ApplyConfiguration(configName); } public WSHttpBinding() : base() { } public WSHttpBinding(SecurityMode securityMode) : this(securityMode, false) { } public WSHttpBinding(SecurityMode securityMode, bool reliableSessionEnabled) : base(reliableSessionEnabled) { security.Mode = securityMode; } internal WSHttpBinding(WSHttpSecurity security, bool reliableSessionEnabled) : base(reliableSessionEnabled) { this.security = security == null ? new WSHttpSecurity() : security; } public bool AllowCookies { get { return HttpTransport.AllowCookies; } set { HttpTransport.AllowCookies = value; HttpsTransport.AllowCookies = value; } } public WSHttpSecurity Security { get { return this.security; } } void ApplyConfiguration(string configurationName) { WSHttpBindingCollectionElement section = WSHttpBindingCollectionElement.GetBindingCollectionElement(); WSHttpBindingElement element = section.Bindings[configurationName]; if (element == null) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ConfigurationErrorsException( SR.GetString(SR.ConfigInvalidBindingConfigurationName, configurationName, ConfigurationStrings.WSHttpBindingCollectionElementName))); } else { element.ApplyConfiguration(this); } } public override BindingElementCollection CreateBindingElements() { if (ReliableSession.Enabled) { if (this.security.Mode == SecurityMode.Transport) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new InvalidOperationException(SR.GetString(SR.WSHttpDoesNotSupportRMWithHttps))); } return base.CreateBindingElements(); } // if you make changes here, see also WS2007HttpBinding.TryCreate() internal 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 (!GetSecurityModeFromTransport(transport, transportSecurity, out mode)) { return false; } HttpsTransportBindingElement httpsBinding = transport as HttpsTransportBindingElement; if (httpsBinding != null && httpsBinding.MessageSecurityVersion != null) { if (httpsBinding.MessageSecurityVersion.SecurityPolicyVersion != WSMessageSecurityVersion.SecurityPolicyVersion) { return false; } } WSHttpSecurity security; if (TryCreateSecurity(sbe, mode, transportSecurity, isReliableSession, out security)) { WSHttpBinding wsHttpBinding = new WSHttpBinding(security, isReliableSession); bool allowCookies; if (!TryGetAllowCookiesFromTransport(transport, out allowCookies)) { return false; } wsHttpBinding.AllowCookies = allowCookies; binding = wsHttpBinding; } if (rsbe != null && rsbe.ReliableMessagingVersion != ReliableMessagingVersion.WSReliableMessagingFebruary2005) { return false; } if (tfbe != null && tfbe.TransactionProtocol != TransactionProtocol.WSAtomicTransactionOctober2004) { return false; } return binding != null; } protected override TransportBindingElement GetTransport() { if (security.Mode == SecurityMode.None || security.Mode == SecurityMode.Message) { return this.HttpTransport; } else { security.ApplyTransportSecurity(this.HttpsTransport); return this.HttpsTransport; } } internal static bool GetSecurityModeFromTransport(TransportBindingElement transport, HttpTransportSecurity transportSecurity, out UnifiedSecurityMode mode) { mode = UnifiedSecurityMode.None; if (transport is HttpsTransportBindingElement) { mode = UnifiedSecurityMode.Transport | UnifiedSecurityMode.TransportWithMessageCredential; WSHttpSecurity.ApplyTransportSecurity((HttpsTransportBindingElement)transport, transportSecurity); } else if (transport is HttpTransportBindingElement) { mode = UnifiedSecurityMode.None | UnifiedSecurityMode.Message; } else { return false; } return true; } internal static bool TryGetAllowCookiesFromTransport(TransportBindingElement transport, out bool allowCookies) { HttpTransportBindingElement httpTransportBindingElement = transport as HttpTransportBindingElement; if (httpTransportBindingElement == null) { allowCookies = false; return false; } else { allowCookies = httpTransportBindingElement.AllowCookies; return true; } } protected override SecurityBindingElement CreateMessageSecurity() { return security.CreateMessageSecurity(this.ReliableSession.Enabled, WSMessageSecurityVersion); } // if you make changes here, see also WS2007HttpBinding.TryCreateSecurity() 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, WSMessageSecurityVersion), sbe); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ValueSerializerAttribute.cs
- MultiDataTrigger.cs
- ProcessHostConfigUtils.cs
- CodePrimitiveExpression.cs
- ColumnHeader.cs
- X509ClientCertificateAuthentication.cs
- APCustomTypeDescriptor.cs
- COM2IProvidePropertyBuilderHandler.cs
- CompilationLock.cs
- exports.cs
- WebFaultClientMessageInspector.cs
- UserPersonalizationStateInfo.cs
- RectangleConverter.cs
- HostedAspNetEnvironment.cs
- ActionItem.cs
- XMLSyntaxException.cs
- TextServicesCompartmentEventSink.cs
- TypeConvertions.cs
- ConfigXmlElement.cs
- InternalBufferOverflowException.cs
- DateTimeFormat.cs
- OletxResourceManager.cs
- ReferencedAssembly.cs
- PassportAuthentication.cs
- DrawingDrawingContext.cs
- GZipStream.cs
- CompositeTypefaceMetrics.cs
- ScopedMessagePartSpecification.cs
- SubclassTypeValidatorAttribute.cs
- TimeSpanSecondsConverter.cs
- _TransmitFileOverlappedAsyncResult.cs
- DockProviderWrapper.cs
- CodeVariableDeclarationStatement.cs
- XsltContext.cs
- ToolStripButton.cs
- AttachInfo.cs
- XmlReader.cs
- PhysicalAddress.cs
- PlainXmlSerializer.cs
- ImpersonateTokenRef.cs
- ToolStripSplitButton.cs
- PointLightBase.cs
- ParseNumbers.cs
- Point3DAnimation.cs
- Tuple.cs
- SafeRegistryHandle.cs
- EncryptedKeyHashIdentifierClause.cs
- DataBindEngine.cs
- TextMetrics.cs
- SecurityPermission.cs
- SimpleBitVector32.cs
- DummyDataSource.cs
- PropertyKey.cs
- VariableQuery.cs
- HotSpotCollectionEditor.cs
- FontFamilyIdentifier.cs
- RegexCapture.cs
- ComboBoxRenderer.cs
- SafeReadContext.cs
- RelationalExpressions.cs
- PointUtil.cs
- MenuStrip.cs
- DefaultTextStore.cs
- WebPartEditorOkVerb.cs
- DataDocumentXPathNavigator.cs
- InstanceNormalEvent.cs
- NullExtension.cs
- RegexRunnerFactory.cs
- ChooseAction.cs
- ConfigsHelper.cs
- ImageListImage.cs
- ACL.cs
- ReachDocumentReferenceSerializer.cs
- ColumnProvider.cs
- WinCategoryAttribute.cs
- Win32Native.cs
- PtsContext.cs
- Scene3D.cs
- DoubleAnimationBase.cs
- ExceptionTrace.cs
- RNGCryptoServiceProvider.cs
- CustomCategoryAttribute.cs
- TextEditorLists.cs
- UpdateTracker.cs
- SmiRecordBuffer.cs
- TextTreeRootTextBlock.cs
- LinqDataSourceHelper.cs
- NullReferenceException.cs
- PropertyTabAttribute.cs
- UnsafeNativeMethods.cs
- DataGridViewRowConverter.cs
- XmlImplementation.cs
- Separator.cs
- SqlCachedBuffer.cs
- DomNameTable.cs
- ReferenceSchema.cs
- RolePrincipal.cs
- DataServiceConfiguration.cs
- ExpandSegment.cs
- FullTextBreakpoint.cs