Files
acceptance-tests
data
debian
docs
external
ikvm-native
libgc
llvm
m4
man
mcs
build
class
Accessibility
Commons.Xml.Relaxng
Cscompmgd
CustomMarshalers
Facades
I18N
IBM.Data.DB2
ICSharpCode.SharpZipLib
Microsoft.Build
Microsoft.Build.Engine
Microsoft.Build.Framework
Microsoft.Build.Tasks
Microsoft.Build.Utilities
Microsoft.CSharp
Microsoft.NuGet.Build.Tasks
Microsoft.VisualC
Microsoft.Web.Infrastructure
MicrosoftAjaxLibrary
Mono.Btls.Interface
Mono.C5
Mono.CSharp
Mono.Cairo
Mono.Cecil
Mono.Cecil.Mdb
Mono.CodeContracts
Mono.CompilerServices.SymbolWriter
Mono.Data.Sqlite
Mono.Data.Tds
Mono.Debugger.Soft
Mono.Http
Mono.Management
Mono.Messaging
Mono.Messaging.RabbitMQ
Mono.Options
Mono.Parallel
Mono.Posix
Mono.Profiler.Log
Mono.Runtime.Tests
Mono.Security
Mono.Security.Win32
Mono.Simd
Mono.Tasklets
Mono.WebBrowser
Mono.XBuild.Tasks
Novell.Directory.Ldap
PEAPI
RabbitMQ.Client
SMDiagnostics
System
System.ComponentModel.Composition.4.5
System.ComponentModel.DataAnnotations
System.Configuration
System.Configuration.Install
System.Core
System.Data
System.Data.DataSetExtensions
System.Data.Entity
System.Data.Linq
System.Data.OracleClient
System.Data.Services
System.Data.Services.Client
System.Deployment
System.Design
System.DirectoryServices
System.DirectoryServices.Protocols
System.Drawing
System.Drawing.Design
System.Dynamic
System.EnterpriseServices
System.IO.Compression
System.IO.Compression.FileSystem
System.IdentityModel
System.IdentityModel.Selectors
System.Json
System.Json.Microsoft
System.Management
System.Messaging
System.Net
System.Net.Http
System.Net.Http.Formatting
System.Net.Http.WebRequest
System.Net.Http.WinHttpHandler
System.Numerics
System.Numerics.Vectors
System.Reactive.Core
System.Reactive.Debugger
System.Reactive.Experimental
System.Reactive.Interfaces
System.Reactive.Linq
System.Reactive.Observable.Aliases
System.Reactive.PlatformServices
System.Reactive.Providers
System.Reactive.Runtime.Remoting
System.Reactive.Windows.Forms
System.Reactive.Windows.Threading
System.Reflection.Context
System.Runtime.Caching
System.Runtime.CompilerServices.Unsafe
System.Runtime.DurableInstancing
System.Runtime.Remoting
System.Runtime.Serialization
System.Runtime.Serialization.Formatters.Soap
System.Security
System.ServiceModel
System.ServiceModel.Activation
System.ServiceModel.Discovery
System.ServiceModel.Internals
System.ServiceModel.Routing
System.ServiceModel.Web
System.ServiceProcess
System.Threading.Tasks.Dataflow
System.Transactions
System.Web
System.Web.Abstractions
System.Web.ApplicationServices
System.Web.DynamicData
System.Web.Extensions
System.Web.Extensions.Design
System.Web.Http
System.Web.Http.SelfHost
System.Web.Http.WebHost
System.Web.Mobile
System.Web.Mvc3
System.Web.Razor
System.Web.RegularExpressions
System.Web.Routing
System.Web.Services
System.Web.WebPages
System.Web.WebPages.Deployment
System.Web.WebPages.Razor
System.Windows
System.Windows.Forms
System.Windows.Forms.DataVisualization
System.Workflow.Activities
System.Workflow.ComponentModel
System.Workflow.Runtime
System.XML
System.Xaml
System.Xml.Linq
System.Xml.Serialization
SystemWebTestShim
WebMatrix.Data
WindowsBase
aot-compiler
corlib
dlr
doc
legacy
lib
monodoc
notes
reference-assemblies
referencesource
SMDiagnostics
System
System.Activities
System.Activities.Core.Presentation
System.Activities.DurableInstancing
System.Activities.Presentation
System.ComponentModel.DataAnnotations
System.Configuration
System.Core
System.Data
System.Data.DataSetExtensions
System.Data.Entity
System.Data.Entity.Design
System.Data.Linq
System.Data.SqlXml
System.IdentityModel
System.IdentityModel.Selectors
System.Net
System.Numerics
System.Runtime.Caching
System.Runtime.DurableInstancing
System.Runtime.Serialization
System.ServiceModel
InternalApis
Serialization
System
Collections
ServiceModel
Activation
Administration
Channels
AddressHeader.cs
AddressHeaderCollection.cs
Addressing.cs
AddressingVersion.cs
AppContainerInfo.cs
ApplicationContainerSettings.cs
AsymmetricSecurityBindingElement.cs
AuthenticationSchemesBindingParameter.cs
AuthenticationSchemesHelper.cs
BaseUriWithWildcard.cs
BinaryMessageEncoder.cs
BinaryMessageEncodingBindingElement.cs
BinaryVersion.cs
Binding.cs
BindingContext.cs
BindingElement.cs
BindingElementCollection.cs
BindingParameterCollection.cs
BodyWriter.cs
BufferManager.cs
BufferManagerOutputStream.cs
BufferedConnection.cs
BufferedMessageData.cs
BufferedMessageWriter.cs
BufferedOutputAsyncStream.cs
BufferedReceiveMessageProperty.cs
BufferedRequestContext.cs
CallbackContextMessageHeader.cs
CallbackContextMessageProperty.cs
ChainedAsyncResult.cs
ChannelAcceptor.cs
ChannelBase.cs
ChannelBindingMessageProperty.cs
ChannelBindingProviderHelper.cs
ChannelBindingUtility.cs
ChannelBuilder.cs
ChannelDemuxer.cs.REMOVED.git-id
ChannelFactoryBase.cs
ChannelListenerBase.cs
ChannelManagerBase.cs
ChannelParameterCollection.cs
ChannelPool.cs
ChannelPoolSettings.cs
ChannelReliableSession.cs
ChannelRequirements.cs
ChannelTracker.cs
ClientContextProtocol.cs
ClientReliableChannelBinder.cs
ClientWebSocketFactory.cs
ClientWebSocketTransportDuplexSessionChannel.cs
CloseCollectionAsyncResult.cs
CloseSequence.cs
CloseSequenceResponse.cs
CommunicationObject.cs
CommunicationObjectManager.cs
CompositeDuplexBindingElement.cs
CompositeDuplexBindingElementImporter.cs
CompressionFormat.cs
CompressionFormatHelper.cs
ConnectAlgorithms.cs
Connection.cs
ConnectionAcceptor.cs
ConnectionBufferPool.cs
ConnectionDemuxer.cs
ConnectionDumpInitiator.cs
ConnectionModeReader.cs
ConnectionOrientedTransportBindingElement.cs
ConnectionOrientedTransportChannelFactory.cs
ConnectionOrientedTransportChannelListener.cs
ConnectionOrientedTransportManager.cs
ConnectionPool.cs
ConnectionPoolRegistry.cs
ContentOnlyMessage.cs
ContextAddressHeader.cs
ContextBindingElement.cs
ContextBindingElementImporter.cs
ContextBindingElementPolicy.cs
ContextChannelFactory.cs
ContextChannelListener.cs
ContextChannelRequestContext.cs
ContextDictionary.cs
ContextDuplexSessionChannel.cs
ContextExchangeCorrelationHelper.cs
ContextExchangeMechanism.cs
ContextExchangeMechanismHelper.cs
ContextInputChannel.cs
ContextInputChannelBase.cs
ContextInputSessionChannel.cs
ContextMessageHeader.cs
ContextMessageProperty.cs
ContextOutputChannel.cs
ContextOutputChannelBase.cs
ContextOutputSessionChannel.cs
ContextProtocol.cs
ContextReplyChannel.cs
ContextReplySessionChannel.cs
ContextRequestChannel.cs
ContextRequestChannelBase.cs
ContextRequestSessionChannel.cs
CorrelationCallbackMessageProperty.cs
CorrelationDataDescription.cs
CorrelationDataMessageProperty.cs
CorrelationDataSourceHelper.cs
CorrelationKey.cs
CorrelationMessageProperty.cs
CreateSequence.cs
CreateSequenceResponse.cs
CustomBinding.cs
DatagramAdapter.cs
DefaultWebSocketConnectionHandler.cs
DelegatingChannelListener.cs
DelegatingMessage.cs
DelegatingStream.cs
DeliveryFailure.cs
DeliveryStatus.cs
DeliveryStrategy.cs
DetectEofStream.cs
DirectionalAction.cs
DnsCache.cs
DoneReceivingAsyncResult.cs
DuplexChannel.cs
EncoderHelpers.cs
EndpointSettings.cs
ExclusiveNamedPipeTransportManager.cs
ExclusiveTcpTransportManager.cs
FaultConverter.cs
FramingChannels.cs
FramingDecoders.cs
FramingEncoders.cs
FramingFormat.cs
HttpAnonymousUriPrefixMatcher.cs
HttpChannelFactory.cs
HttpChannelHelpers.cs.REMOVED.git-id
HttpChannelListener.cs
HttpCookieContainerBindingElement.cs
HttpCookieContainerManager.cs
HttpHeaderInfo.cs
HttpHeadersWebHeaderCollection.cs
HttpMessageHandlerFactory.cs
HttpMessageSettings.cs
HttpPipeline.cs
HttpPipelineCancellationTokenSource.cs
HttpRequestContext.cs
HttpRequestMessageExtensionMethods.cs
HttpRequestMessageProperty.cs
HttpResponseMessageExtensionMethods.cs
HttpResponseMessageProperty.cs
HttpTransportBindingElement.cs
HttpTransportManager.cs
HttpsChannelFactory.cs
HttpsChannelListener.cs
HttpsTransportBindingElement.cs
IAnonymousUriPrefixMatcher.cs
IBindingDeliveryCapabilities.cs
IBindingMulticastCapabilities.cs
IBindingRuntimePreferences.cs
IChannel.cs
IChannelAcceptor.cs
IChannelBindingProvider.cs
IChannelFactory.cs
IChannelListener.cs
ICompressedMessageEncoder.cs
IContextBindingElement.cs
IContextManager.cs
ICorrelationDataSource.cs
ICorrelatorKey.cs
IDuplexChannel.cs
IDuplexSession.cs
IDuplexSessionChannel.cs
IHttpCookieContainerManager.cs
IInputChannel.cs
IInputSession.cs
IInputSessionChannel.cs
ILockingQueue.cs
IMergeEnabledMessageProperty.cs
IMessageProperty.cs
IMessageSource.cs
IOutputChannel.cs
IOutputSession.cs
IOutputSessionChannel.cs
IPeerNeighbor.cs
IPoisonHandlingStrategy.cs
IReceiveContextSettings.cs
IReliableChannelBinder.cs
IReliableFactorySettings.cs
IReplyChannel.cs
IReplySessionChannel.cs
IRequestChannel.cs
IRequestReplyCorrelator.cs
IRequestSessionChannel.cs
ISecurityCapabilities.cs
ISession.cs
ISessionChannel.cs
IStreamUpgradeChannelBindingProvider.cs
IStreamedMessageEncoder.cs
ITransactedBindingElement.cs
ITransactionChannelManager.cs
ITransportCompressionSupport.cs
ITransportFactorySettings.cs
ITransportTokenAssertionProvider.cs
IWebMessageEncoderHelper.cs
IWebsocketCloseDetails.cs
IdlingCommunicationPool.cs
InitialServerConnectionReader.cs
InputChannel.cs
InputChannelAcceptor.cs
InputQueueChannel.cs
InputQueueChannelAcceptor.cs
InternalDuplexBindingElement.cs
InternalDuplexChannelFactory.cs
InternalDuplexChannelListener.cs
InvalidChannelBindingException.cs
LateBoundChannelParameterCollection.cs
LayeredChannel.cs
LayeredChannelFactory.cs
LayeredChannelListener.cs
LifetimeManager.cs
LocalClientSecuritySettings.cs
LocalServiceSecuritySettings.cs
LockHelper.cs
MaxMessageSizeStream.cs
Message.cs
MessageBuffer.cs
MessageEncoder.cs
MessageEncoderCompressionHandler.cs
MessageEncoderFactory.cs
MessageEncodingBindingElement.cs
MessageEncodingBindingElementImporter.cs
MessageFault.cs
MessageHeader.cs
MessageHeaderInfo.cs
MessageHeaders.cs
MessageProperties.cs
MessageState.cs
MessageVersion.cs
Msmq.cs
Msmq3PoisonHandler.cs
Msmq4PoisonHandler.cs
Msmq4SubqueuePoisonHandler.cs
MsmqBindingElementBase.cs
MsmqBindingFilter.cs
MsmqBindingMonitor.cs
MsmqChannelFactory.cs
MsmqChannelFactoryBase.cs
MsmqChannelListenerBase.cs
MsmqDecodeHelper.cs
MsmqDefaultLockingQueue.cs
MsmqDiagnostics.cs
MsmqInputChannel.cs
MsmqInputChannelBase.cs
MsmqInputChannelListener.cs
MsmqInputChannelListenerBase.cs
MsmqInputMessage.cs
MsmqInputMessagePool.cs
MsmqInputSessionChannel.cs
MsmqInputSessionChannelListener.cs
MsmqMessageProperty.cs
MsmqNonTransactedPoisonHandler.cs
MsmqOutputChannel.cs
MsmqOutputMessage.cs
MsmqOutputSessionChannel.cs
MsmqQueue.cs
MsmqReceiveContext.cs
MsmqReceiveContextLockManager.cs
MsmqReceiveHelper.cs
MsmqReceiveParameters.cs
MsmqSubqueueLockingQueue.cs
MsmqTransportBindingElement.cs
MsmqTransportReceiveParameters.cs
MsmqUri.cs
MsmqVerifier.cs
MtomMessageEncoder.cs
MtomMessageEncodingBindingElement.cs
NamedPipeChannelFactory.cs
NamedPipeChannelListener.cs
NamedPipeConnectionPool.cs
NamedPipeConnectionPoolSettings.cs
NamedPipeSettings.cs
NamedPipeTransportBindingElement.cs
NamedPipeTransportManager.cs
NativeMsmqMessage.cs
OneWayBindingElement.cs
OneWayBindingElementImporter.cs
OneWayChannelFactory.cs
OneWayChannelListener.cs
OpaqueContent.cs
OpenCollectionAsyncResult.cs
OutputChannel.cs
OverlappedContext.cs
PeerChannelFactory.cs
PeerChannelListener.cs
PeerConnector.cs
PeerCustomResolverBindingElement.cs
PeerDuplexChannel.cs
PeerDuplexChannelListener.cs
PeerFlooder.cs
PeerHelpers.cs
PeerIPHelper.cs
PeerInputChannel.cs
PeerInputChannelListener.cs
PeerMaintainer.cs
PeerMessageDispatcher.cs
PeerNeighborManager.cs
PeerNodeImplementation.cs
PeerNodeStateManager.cs
PeerOutputChannel.cs
PeerResolverBindingElement.cs
PeerSecurityHelpers.cs
PeerSecurityManager.cs
PeerService.cs
PeerServiceMessageContracts.cs
PeerTransportBindingElement.cs
PeerUnsafeNativeCryptMethods.cs
PeerUnsafeNativeMethods.cs
PipeConnection.cs.REMOVED.git-id
PipeException.cs
PnrpPeerResolver.cs.REMOVED.git-id
PnrpPeerResolverBindingElement.cs
PrivacyNoticeBindingElement.cs
PrivacyNoticeBindingElementImporter.cs
QueuedObjectPool.cs
ReceiveContext.cs
ReceiveContextState.cs
RedirectionConstants.cs
RedirectionDuration.cs
RedirectionException.cs
RedirectionLocation.cs
RedirectionScope.cs
RedirectionType.cs
RedirectionUtility.cs
ReliableChannelBinder.cs.REMOVED.git-id
ReliableChannelFactory.cs
ReliableChannelListener.cs
ReliableDuplexSessionChannel.cs
ReliableInputConnection.cs
ReliableInputSessionChannel.cs
ReliableMessagingHelpers.cs.REMOVED.git-id
ReliableOutputConnection.cs
ReliableOutputSessionChannel.cs
ReliableReplySessionChannel.cs
ReliableRequestSessionChannel.cs
ReliableSessionBindingElement.cs
ReliableSessionBindingElementImporter.cs
RemoteEndpointMessageProperty.cs
ReplyAdapterChannelListener.cs
ReplyChannel.cs
ReplyChannelAcceptor.cs
RequestChannel.cs
RequestContext.cs
RequestContextBase.cs
RequestReplyCorrelator.cs
RetryException.cs
SafeNativeMethods.cs
SecurityAttributeGenerationHelper.cs
SecurityBindingElement.cs.REMOVED.git-id
SecurityBindingElementImporter.cs
SecurityCapabilities.cs
SecurityChannelFactory.cs
SecurityChannelFaultConverter.cs
SecurityChannelListener.cs
SecurityHeaderLayout.cs
SelfSignedCertificate.cs
SequenceRange.cs
SequenceRangeCollection.cs
ServerReliableChannelBinder.cs
ServerWebSocketTransportDuplexSessionChannel.cs
ServiceChannel.cs
ServiceChannelFactory.cs
ServiceChannelProxy.cs
ServiceContextProtocol.cs
ServiceWebSocketContext.cs
SessionConnectionReader.cs
SessionOpenNotification.cs
SharedConnectionListener.cs
SharedHttpTransportManager.cs
SharedHttpsTransportManager.cs
SharedTcpTransportManager.cs
SingletonChannelAcceptor.cs
SingletonConnectionReader.cs
SocketAsyncEventArgsPool.cs
SocketConnection.cs
SslStreamSecurityBindingElement.cs
SslStreamSecurityUpgradeProvider.cs
StandardBindingImporter.cs
StreamSecurityUpgradeAcceptor.cs
StreamSecurityUpgradeAcceptorAsyncResult.cs
StreamSecurityUpgradeAcceptorBase.cs
StreamSecurityUpgradeInitiator.cs
StreamSecurityUpgradeInitiatorAsyncResult.cs
StreamSecurityUpgradeInitiatorBase.cs
StreamSecurityUpgradeProvider.cs
StreamUpgradeAcceptor.cs
StreamUpgradeBindingElement.cs
StreamUpgradeInitiator.cs
StreamUpgradeProvider.cs
StreamedFramingRequestChannel.cs
SupportedAddressingMode.cs
SymmetricSecurityBindingElement.cs
SynchronizedMessageSource.cs
TcpChannelFactory.cs
TcpChannelListener.cs
TcpConnectionPool.cs
TcpConnectionPoolSettings.cs
TcpTransportBindingElement.cs
TcpTransportManager.cs
TerminateSequence.cs
TerminateSequenceResponse.cs
TextMessageEncoder.cs
TextMessageEncodingBindingElement.cs
TimeoutStream.cs
TracingConnection.cs
TracingConnectionInitiator.cs
TracingConnectionListener.cs
TransactionChannel.cs
TransactionChannelFactory.cs
TransactionChannelFaultConverter.cs
TransactionChannelListener.cs
TransactionFlowBindingElement.cs
TransactionFlowBindingElementImporter.cs
TransactionFlowProperty.cs
TransferSession.cs
TransmissionStrategy.cs
TransportBindingElement.cs
TransportBindingElementImporter.cs
TransportChannelFactory.cs
TransportChannelListener.cs
TransportDefaults.cs
TransportDuplexSessionChannel.cs
TransportManager.cs
TransportOutputChannel.cs
TransportReplyChannelAcceptor.cs
TransportSecurityBindingElement.cs
TransportSecurityHelpers.cs
UnderstoodHeaders.cs
UniqueTransportManagerRegistration.cs
UnrecognizedAssertionsBindingElement.cs
UnsafeNativeMethods.cs
UriGenerator.cs
UriHelper.cs
UriPrefixTable.cs
UseManagedPresentationBindingElement.cs
UseManagedPresentationBindingElementImporter.cs
UtilityExtension.cs
WebSocketConnectionHandler.cs
WebSocketHelper.cs
WebSocketMessageProperty.cs
WebSocketTransportDuplexSessionChannel.cs
WebSocketTransportSettings.cs
WebSocketTransportUsage.cs
WebSocketTransportUsageHelper.cs
WindowsStreamSecurityBindingElement.cs
WindowsStreamSecurityUpgradeProvider.cs
WrappedOptions.cs
WsrmFault.cs
WsrmMessageInfo.cs
XmlSerializerImportOptions.cs
ComIntegration
Configuration
Description
Diagnostics
Dispatcher
MsmqIntegration
PeerResolvers
Security
Syndication
Transactions
XamlIntegration
ActionMismatchAddressingException.cs
ActionNotSupportedException.cs
AddressAccessDeniedException.cs
AddressAlreadyInUseException.cs
AddressFilterMode.cs
AppContextDefaultValues.Default.cs
AuditLevel.cs
AuditLogLocation.cs
BasicHttpBinding.cs
BasicHttpContextBinding.cs
BasicHttpMessageCredentialType.cs
BasicHttpMessageSecurity.cs
BasicHttpSecurity.cs
BasicHttpSecurityMode.cs
BasicHttpsBinding.cs
BasicHttpsSecurity.cs
BasicHttpsSecurityMode.cs
CacheSetting.cs
CallbackBehaviorAttribute.cs
ChannelFactory.cs
ChannelFactoryRefCache.cs
ChannelTerminatedException.cs
ClientBase.cs
CommunicationException.cs
CommunicationObjectAbortedException.cs
CommunicationObjectFaultedException.cs
CommunicationState.cs
ConcurrencyMode.cs
ConfigurationEndpointTrait.cs
DXD.cs
DataContractFormatAttribute.cs
DeadLetterQueue.cs
DeliveryRequirementsAttribute.cs
DnsEndpointIdentity.cs
DuplexChannelFactory.cs
DuplexClientBase.cs
EmptyArray.cs
EndpointAddress.cs
EndpointAddress10.cs
EndpointAddressAugust2004.cs
EndpointIdentity.cs
EndpointNotFoundException.cs
EndpointTrait.cs
EnvelopeVersion.cs
ExceptionDetail.cs
ExceptionMapper.cs
ExtensionCollection.cs
FaultCode.cs
FaultCodeConstants.cs
FaultContractAttribute.cs
FaultException.cs
FaultImportOptions.cs
FaultReason.cs
FaultReasonText.cs
FederatedMessageSecurityOverHttp.cs
GeneralEndpointIdentity.cs
HostnameComparisonMode.cs
HttpBindingBase.cs
HttpClientCredentialType.cs
HttpProxyCredentialType.cs
HttpTransportSecurity.cs
IChannelBaseProxy.cs
IClientChannel.cs
ICommunicationObject.cs
IContextChannel.cs
IContextSessionProvider.cs
IDefaultCommunicationTimeouts.cs
IDuplexContextChannel.cs
IExtensibleObject.cs
IExtension.cs
IExtensionCollection.cs
IOnlineStatus.cs
IOperationContractAttributeProvider.cs
IServiceChannel.cs
ImpersonationOption.cs
InstanceContext.cs
InstanceContextMode.cs
InvalidMessageContractException.cs
KeyedByTypeCollection.cs
LocalAppContextSwitches.cs
MessageBodyMemberAttribute.cs
MessageContractAttribute.cs
MessageContractMemberAttribute.cs
MessageCredentialType.cs
MessageHeaderArrayAttribute.cs
MessageHeaderAttribute.cs
MessageHeaderException.cs
MessageHeaderT.cs
MessageParameterAttribute.cs
MessagePropertyAttribute.cs
MessageSecurityOverHttp.cs
MessageSecurityOverMsmq.cs
MessageSecurityOverTcp.cs
MessageSecurityVersion.cs
MostlySingletonList.cs
MsmqAuthenticationMode.cs
MsmqBindingBase.cs
MsmqEncryptionAlgorithm.cs
MsmqException.cs
MsmqPoisonMessageException.cs
MsmqSecureHashAlgorithm.cs
MsmqTransportSecurity.cs
MustUnderstandSoapException.cs
NamedPipeTransportSecurity.cs
NetHttpBinding.cs
NetHttpMessageEncoding.cs
NetHttpMessageEncodingHelper.cs
NetHttpsBinding.cs
NetMsmqBinding.cs
NetMsmqSecurity.cs
NetMsmqSecurityMode.cs
NetNamedPipeBinding.cs
NetNamedPipeSecurity.cs
NetNamedPipeSecurityMode.cs
NetPeerTcpBinding.cs
NetTcpBinding.cs
NetTcpContextBinding.cs
NetTcpSecurity.cs
NonDualMessageSecurityOverHttp.cs
OSEnvironmentHelper.cs
OSVersion.cs
OperationBehaviorAttribute.cs
OperationContext.cs
OperationContextScope.cs
OperationContractAttribute.cs
OperationFormatStyle.cs
OperationFormatUse.cs
PeerHopCountAttribute.cs
PeerMessageOrigination.cs
PeerMessagePropagation.cs
PeerMessagePropagationFilter.cs
PeerNode.cs
PeerNodeAddress.cs
PeerResolver.cs
PeerSecuritySettings.cs
PeerTransportCredentialType.cs
PeerTransportSecuritySettings.cs
PoisonMessageException.cs
Pool.cs
ProgrammaticEndpointTrait.cs
ProtocolException.cs
QueueTransferProtocol.cs
QueuedDeliveryRequirementsMode.cs
QuotaExceededException.cs
ReceiveContextEnabledAttribute.cs
ReceiveErrorHandling.cs
ReleaseInstanceMode.cs
ReliableMessagingVersion.cs
ReliableSession.cs
RsaEndpointIdentity.cs
SecurityMode.cs
ServerTooBusyException.cs
ServiceActivationException.cs
ServiceAuthenticationManager.cs
ServiceAuthorizationManager.cs
ServiceBehaviorAttribute.cs
ServiceChannelManager.cs
ServiceConfiguration.cs
ServiceContractAttribute.cs
ServiceDefaults.cs
ServiceEndpointTrait.cs
ServiceHost.cs
ServiceKnownTypeAttribute.cs
ServiceModelAppSettings.cs
ServiceModelAttributeTargets.cs
ServiceModelDictionary.cs
ServiceModelStrings.cs
ServiceModelStringsVersion1.cs
ServiceSecurityContext.cs
SessionMode.cs
SpnEndpointIdentity.cs
StringUtil.cs
SynchronizedCollection.cs
SynchronizedDisposablePool.cs
SynchronizedKeyedCollection.cs
SynchronizedReadOnlyCollection.cs
TcpClientCredentialType.cs
TcpTransportSecurity.cs
ThreadTrace.cs
TimeSpanHelper.cs
TransactionFlowAttribute.cs
TransactionFlowOption.cs
TransactionProtocol.cs
TransferMode.cs
UnifiedSecurityMode.cs
UnknownMessageReceivedEventArgs.cs
UpnEndpointIdentity.cs
UriSchemeKeyedCollection.cs
WS2007FederationHttpBinding.cs
WS2007HttpBinding.cs
WSAddressing10ProblemHeaderQNameFault.cs
WSDualHttpBinding.cs
WSDualHttpSecurity.cs
WSDualHttpSecurityMode.cs
WSFederationHttpBinding.cs
WSFederationHttpSecurity.cs
WSFederationHttpSecurityMode.cs
WSHttpBinding.cs
WSHttpBindingBase.cs
WSHttpContextBinding.cs
WSHttpSecurity.cs
WSMessageEncoding.cs
WrappedDispatcherException.cs
X509CertificateEndpointIdentity.cs
XD.cs.REMOVED.git-id
XPathMessageQuery.cs
XmlBuffer.cs
XmlSerializerFormatAttribute.cs
XmlUtil.cs
UriTemplate.cs
UriTemplateCompoundPathSegment.cs
UriTemplateEquivalenceComparer.cs
UriTemplateHelpers.cs
UriTemplateLiteralPathSegment.cs
UriTemplateLiteralQueryValue.cs
UriTemplateMatch.cs
UriTemplateMatchException.cs
UriTemplatePartType.cs
UriTemplatePathPartiallyEquivalentSet.cs
UriTemplatePathSegment.cs
UriTemplateQueryValue.cs
UriTemplateTable.cs
UriTemplateTableMatchCandidate.cs
UriTemplateTrieIntraNodeLocation.cs
UriTemplateTrieLocation.cs
UriTemplateTrieNode.cs
UriTemplateVariablePathSegment.cs
UriTemplateVariableQueryValue.cs
AssemblyInfo.cs
System.ServiceModel.txt.REMOVED.git-id
TD.Designer.cs.REMOVED.git-id
System.ServiceModel.Activation
System.ServiceModel.Activities
System.ServiceModel.Channels
System.ServiceModel.Discovery
System.ServiceModel.Internals
System.ServiceModel.Routing
System.ServiceModel.WasHosting
System.ServiceModel.Web
System.Web
System.Web.ApplicationServices
System.Web.DataVisualization
System.Web.DynamicData
System.Web.Entity
System.Web.Entity.Design
System.Web.Extensions
System.Web.Mobile
System.Web.Routing
System.Web.Services
System.Workflow.Activities
System.Workflow.ComponentModel
System.Workflow.Runtime
System.WorkflowServices
System.Xaml.Hosting
System.Xml
System.Xml.Linq
XamlBuildTask
mscorlib
LICENSE.txt
PATENTS.TXT
README.Mono.md
README.md
test-helpers
LICENSE
Makefile
Open.snk
README
ecma.pub
mono.pub
mono.snk
msfinal.pub
reactive.pub
silverlight.pub
winfx.pub
winfx3.pub
docs
errors
ilasm
jay
mcs
packages
tests
tools
AUTHORS
COPYING
INSTALL.txt
Makefile
MonoIcon.png
README
ScalableMonoIcon.svg
mkinstalldirs
mk
mono
msvc
po
runtime
samples
scripts
support
tools
COPYING.LIB
LICENSE
Makefile.am
Makefile.in
NEWS
README.md
acinclude.m4
aclocal.m4
autogen.sh
code_of_conduct.md
compile
config.guess
config.h.in
config.rpath
config.sub
configure.REMOVED.git-id
configure.ac.REMOVED.git-id
depcomp
install-sh
ltmain.sh.REMOVED.git-id
missing
mkinstalldirs
mono-uninstalled.pc.in
test-driver
winconfig.h

1145 lines
43 KiB
C#
Raw Normal View History

//----------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
//----------------------------------------------------------------------------
namespace System.ServiceModel.Channels
{
using System;
using System.Diagnostics;
using System.IO;
using System.Net;
using System.Net.Http;
using System.Net.WebSockets;
using System.Runtime;
using System.Runtime.Diagnostics;
using System.Security.Authentication.ExtendedProtection;
using System.ServiceModel;
using System.ServiceModel.Diagnostics;
using System.ServiceModel.Diagnostics.Application;
using System.ServiceModel.Security;
using System.Threading;
using System.Threading.Tasks;
using System.Xml;
abstract class HttpRequestContext : RequestContextBase
{
HttpOutput httpOutput;
bool errorGettingHttpInput;
HttpChannelListener listener;
SecurityMessageProperty securityProperty;
EventTraceActivity eventTraceActivity;
HttpPipeline httpPipeline;
ServerWebSocketTransportDuplexSessionChannel webSocketChannel;
protected HttpRequestContext(HttpChannelListener listener, Message requestMessage, EventTraceActivity eventTraceActivity)
: base(requestMessage, listener.InternalCloseTimeout, listener.InternalSendTimeout)
{
this.listener = listener;
this.eventTraceActivity = eventTraceActivity;
}
public bool KeepAliveEnabled
{
get
{
return listener.KeepAliveEnabled;
}
}
public bool HttpMessagesSupported
{
get { return this.listener.HttpMessageSettings.HttpMessagesSupported; }
}
public abstract string HttpMethod { get; }
public abstract bool IsWebSocketRequest { get; }
internal ServerWebSocketTransportDuplexSessionChannel WebSocketChannel
{
get
{
return this.webSocketChannel;
}
set
{
Fx.Assert(this.webSocketChannel == null, "webSocketChannel should not be set twice.");
this.webSocketChannel = value;
}
}
internal HttpChannelListener Listener
{
get { return this.listener; }
}
internal EventTraceActivity EventTraceActivity
{
get
{
return this.eventTraceActivity;
}
}
// Note: This method will return null in the case where throwOnError is false, and a non-fatal error occurs.
// Please exercice caution when passing in throwOnError = false. This should basically only be done in error
// code paths, or code paths where there is very good reason that you would not want this method to throw.
// When passing in throwOnError = false, please handle the case where this method returns null.
public HttpInput GetHttpInput(bool throwOnError)
{
HttpPipeline pipeline = this.httpPipeline;
if ((pipeline != null) && pipeline.IsHttpInputInitialized)
{
return pipeline.HttpInput;
}
HttpInput httpInput = null;
if (throwOnError || !this.errorGettingHttpInput)
{
try
{
httpInput = GetHttpInput();
this.errorGettingHttpInput = false;
}
catch (Exception e)
{
this.errorGettingHttpInput = true;
if (throwOnError || Fx.IsFatal(e))
{
throw;
}
DiagnosticUtility.TraceHandledException(e, TraceEventType.Warning);
}
}
return httpInput;
}
internal static HttpRequestContext CreateContext(HttpChannelListener listener, HttpListenerContext listenerContext, EventTraceActivity eventTraceActivity)
{
return new ListenerHttpContext(listener, listenerContext, eventTraceActivity);
}
protected abstract SecurityMessageProperty OnProcessAuthentication();
public abstract HttpOutput GetHttpOutput(Message message);
protected abstract HttpInput GetHttpInput();
public HttpOutput GetHttpOutputCore(Message message)
{
if (this.httpOutput != null)
{
return this.httpOutput;
}
return this.GetHttpOutput(message);
}
protected override void OnAbort()
{
if (this.httpOutput != null)
{
this.httpOutput.Abort(HttpAbortReason.Aborted);
}
this.Cleanup();
}
protected override void OnClose(TimeSpan timeout)
{
try
{
if (this.httpOutput != null)
{
this.httpOutput.Close();
}
}
finally
{
this.Cleanup();
}
}
protected virtual void Cleanup()
{
if (this.httpPipeline != null)
{
this.httpPipeline.Close();
}
}
public void InitializeHttpPipeline(TransportIntegrationHandler transportIntegrationHandler)
{
this.httpPipeline = HttpPipeline.CreateHttpPipeline(this, transportIntegrationHandler, this.IsWebSocketRequest);
}
internal void SetMessage(Message message, Exception requestException)
{
if ((message == null) && (requestException == null))
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
new ProtocolException(SR.GetString(SR.MessageXmlProtocolError),
new XmlException(SR.GetString(SR.MessageIsEmpty))));
}
this.TraceHttpMessageReceived(message);
if (requestException != null)
{
base.SetRequestMessage(requestException);
message.Close();
}
else
{
message.Properties.Security = (this.securityProperty != null) ? (SecurityMessageProperty)this.securityProperty.CreateCopy() : null;
base.SetRequestMessage(message);
}
}
void TraceHttpMessageReceived(Message message)
{
if (FxTrace.Trace.IsEnd2EndActivityTracingEnabled)
{
bool attached = false;
Guid relatedId = this.eventTraceActivity != null ? this.eventTraceActivity.ActivityId : Guid.Empty;
HttpRequestMessageProperty httpProperty;
// Encoder will always add an activity. We need to remove this and read it
// from the web headers for http since correlation might be propogated.
if (message.Headers.MessageId == null &&
message.Properties.TryGetValue<HttpRequestMessageProperty>(HttpRequestMessageProperty.Name, out httpProperty))
{
try
{
string e2eId = httpProperty.Headers[EventTraceActivity.Name];
if (!String.IsNullOrEmpty(e2eId))
{
byte[] data = Convert.FromBase64String(e2eId);
if (data != null && data.Length == 16)
{
Guid id = new Guid(data);
this.eventTraceActivity = new EventTraceActivity(id, true);
message.Properties[EventTraceActivity.Name] = this.eventTraceActivity;
attached = true;
}
}
}
catch (Exception ex)
{
if (Fx.IsFatal(ex))
{
throw;
}
}
}
if (!attached)
{
this.eventTraceActivity = EventTraceActivityHelper.TryExtractActivity(message, true);
}
if (TD.MessageReceivedByTransportIsEnabled())
{
TD.MessageReceivedByTransport(
this.eventTraceActivity,
this.listener != null && this.listener.Uri != null ? this.listener.Uri.AbsoluteUri : string.Empty,
relatedId);
}
}
}
protected abstract HttpStatusCode ValidateAuthentication();
bool PrepareReply(ref Message message)
{
bool closeOnReceivedEof = false;
// null means we're done
if (message == null)
{
// A null message means either a one-way request or that the service operation returned null and
// hence we can close the HttpOutput. By default we keep the HttpOutput open to allow the writing to the output
// even after the HttpInput EOF is received and the HttpOutput will be closed only on close of the HttpRequestContext.
closeOnReceivedEof = true;
message = CreateAckMessage(HttpStatusCode.Accepted, string.Empty);
}
if (!listener.ManualAddressing)
{
if (message.Version.Addressing == AddressingVersion.WSAddressingAugust2004)
{
if (message.Headers.To == null ||
listener.AnonymousUriPrefixMatcher == null ||
!listener.AnonymousUriPrefixMatcher.IsAnonymousUri(message.Headers.To))
{
message.Headers.To = message.Version.Addressing.AnonymousUri;
}
}
else if (message.Version.Addressing == AddressingVersion.WSAddressing10
|| message.Version.Addressing == AddressingVersion.None)
{
if (message.Headers.To != null &&
(listener.AnonymousUriPrefixMatcher == null ||
!listener.AnonymousUriPrefixMatcher.IsAnonymousUri(message.Headers.To)))
{
message.Headers.To = null;
}
}
else
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
new ProtocolException(SR.GetString(SR.AddressingVersionNotSupported, message.Version.Addressing)));
}
}
message.Properties.AllowOutputBatching = false;
this.httpOutput = GetHttpOutputCore(message);
// Reuse the HttpInput we got previously.
HttpInput input = this.httpPipeline.HttpInput;
if (input != null)
{
HttpDelayedAcceptStream requestStream = input.GetInputStream(false) as HttpDelayedAcceptStream;
if (requestStream != null && TransferModeHelper.IsRequestStreamed(listener.TransferMode)
&& requestStream.EnableDelayedAccept(this.httpOutput, closeOnReceivedEof))
{
return false;
}
}
return true;
}
protected override void OnReply(Message message, TimeSpan timeout)
{
TimeoutHelper timeoutHelper = new TimeoutHelper(timeout);
Message responseMessage = message;
try
{
bool closeOutputAfterReply = PrepareReply(ref responseMessage);
this.httpPipeline.SendReply(responseMessage, timeoutHelper.RemainingTime());
if (closeOutputAfterReply)
{
httpOutput.Close();
}
if (TD.MessageSentByTransportIsEnabled())
{
TD.MessageSentByTransport(eventTraceActivity, this.Listener.Uri.AbsoluteUri);
}
}
finally
{
if (message != null &&
!object.ReferenceEquals(message, responseMessage))
{
responseMessage.Close();
}
}
}
protected override IAsyncResult OnBeginReply(
Message message, TimeSpan timeout, AsyncCallback callback, object state)
{
return new ReplyAsyncResult(this, message, timeout, callback, state);
}
protected override void OnEndReply(IAsyncResult result)
{
ReplyAsyncResult.End(result);
}
public bool ProcessAuthentication()
{
if (TD.HttpContextBeforeProcessAuthenticationIsEnabled())
{
TD.HttpContextBeforeProcessAuthentication(this.eventTraceActivity);
}
HttpStatusCode statusCode = ValidateAuthentication();
if (statusCode == HttpStatusCode.OK)
{
bool authenticationSucceeded = false;
statusCode = HttpStatusCode.Forbidden;
try
{
this.securityProperty = OnProcessAuthentication();
authenticationSucceeded = true;
return true;
}
catch (Exception e)
{
if (Fx.IsFatal(e))
{
throw;
}
if (e.Data.Contains(HttpChannelUtilities.HttpStatusCodeKey))
{
if (e.Data[HttpChannelUtilities.HttpStatusCodeKey] is HttpStatusCode)
{
statusCode = (HttpStatusCode)e.Data[HttpChannelUtilities.HttpStatusCodeKey];
}
}
throw;
}
finally
{
if (!authenticationSucceeded)
{
SendResponseAndClose(statusCode);
}
}
}
else
{
SendResponseAndClose(statusCode);
return false;
}
}
internal void SendResponseAndClose(HttpStatusCode statusCode)
{
SendResponseAndClose(statusCode, string.Empty);
}
internal void SendResponseAndClose(HttpStatusCode statusCode, string statusDescription)
{
if (ReplyInitiated)
{
this.Close();
return;
}
using (Message ackMessage = CreateAckMessage(statusCode, statusDescription))
{
this.Reply(ackMessage);
}
this.Close();
}
internal void SendResponseAndClose(HttpResponseMessage httpResponseMessage)
{
if (this.TryInitiateReply())
{
// Send the response message.
try
{
if (this.httpOutput == null)
{
this.httpOutput = this.GetHttpOutputCore(new NullMessage());
}
this.httpOutput.Send(httpResponseMessage, this.DefaultSendTimeout);
}
catch (Exception ex)
{
if (Fx.IsFatal(ex))
{
throw;
}
DiagnosticUtility.TraceHandledException(ex, TraceEventType.Information);
}
}
// Close the request context.
try
{
this.Close(); // this also closes the HttpOutput
}
catch (Exception ex)
{
if (Fx.IsFatal(ex))
{
throw;
}
DiagnosticUtility.TraceHandledException(ex, TraceEventType.Information);
}
}
Message CreateAckMessage(HttpStatusCode statusCode, string statusDescription)
{
Message ackMessage = new NullMessage();
HttpResponseMessageProperty httpResponseProperty = new HttpResponseMessageProperty();
httpResponseProperty.StatusCode = statusCode;
httpResponseProperty.SuppressEntityBody = true;
if (statusDescription.Length > 0)
{
httpResponseProperty.StatusDescription = statusDescription;
}
ackMessage.Properties.Add(HttpResponseMessageProperty.Name, httpResponseProperty);
return ackMessage;
}
[System.Diagnostics.CodeAnalysis.SuppressMessage(FxCop.Category.ReliabilityBasic, "Reliability104",
Justification = "The exceptions will be traced and thrown by the handling method.")]
public void AcceptWebSocket(HttpResponseMessage response, string protocol, TimeSpan timeout)
{
Task<WebSocketContext> acceptTask;
bool success = false;
try
{
acceptTask = this.AcceptWebSocketCore(response, protocol);
try
{
if (!acceptTask.Wait(TimeoutHelper.ToMilliseconds(timeout)))
{
throw FxTrace.Exception.AsError(new TimeoutException(SR.GetString(SR.AcceptWebSocketTimedOutError)));
}
}
catch (Exception ex)
{
if (Fx.IsFatal(ex))
{
throw;
}
WebSocketHelper.ThrowCorrectException(ex);
}
success = true;
}
finally
{
if (!success)
{
this.OnAcceptWebSocketError();
}
}
this.SetReplySent();
this.OnAcceptWebSocketSuccess(acceptTask.Result, response.RequestMessage);
}
protected abstract Task<WebSocketContext> AcceptWebSocketCore(HttpResponseMessage response, string protocol);
protected virtual void OnAcceptWebSocketError()
{
}
protected abstract void OnAcceptWebSocketSuccess(WebSocketContext context, HttpRequestMessage requestMessage);
protected void OnAcceptWebSocketSuccess(
WebSocketContext context,
RemoteEndpointMessageProperty remoteEndpointMessageProperty,
byte[] webSocketInternalBuffer,
bool shouldDisposeWebSocketAfterClose,
HttpRequestMessage requestMessage)
{
this.webSocketChannel.SetWebSocketInfo(
context,
remoteEndpointMessageProperty,
this.securityProperty,
webSocketInternalBuffer,
shouldDisposeWebSocketAfterClose,
requestMessage);
}
public IAsyncResult BeginAcceptWebSocket(HttpResponseMessage response, string protocol, AsyncCallback callback, object state)
{
return new AcceptWebSocketAsyncResult(this, response, protocol, callback, state);
}
public void EndAcceptWebSocket(IAsyncResult result)
{
AcceptWebSocketAsyncResult.End(result);
}
class ReplyAsyncResult : AsyncResult
{
static AsyncCallback onSendCompleted;
static Action<object, HttpResponseMessage> onHttpPipelineSend;
bool closeOutputAfterReply;
HttpRequestContext context;
Message message;
Message responseMessage;
TimeoutHelper timeoutHelper;
public ReplyAsyncResult(HttpRequestContext context, Message message, TimeSpan timeout, AsyncCallback callback, object state)
: base(callback, state)
{
this.context = context;
this.message = message;
this.responseMessage = null;
this.timeoutHelper = new TimeoutHelper(timeout);
ThreadTrace.Trace("Begin sending http reply");
this.responseMessage = this.message;
if (this.SendResponse())
{
base.Complete(true);
}
}
public static void End(IAsyncResult result)
{
AsyncResult.End<ReplyAsyncResult>(result);
}
void OnSendResponseCompleted(IAsyncResult result)
{
try
{
context.httpOutput.EndSend(result);
ThreadTrace.Trace("End sending http reply");
if (this.closeOutputAfterReply)
{
context.httpOutput.Close();
}
}
finally
{
if (this.message != null &&
!object.ReferenceEquals(this.message, this.responseMessage))
{
this.responseMessage.Close();
}
}
}
static void OnSendResponseCompletedCallback(IAsyncResult result)
{
if (result.CompletedSynchronously)
{
return;
}
ReplyAsyncResult thisPtr = (ReplyAsyncResult)result.AsyncState;
Exception completionException = null;
try
{
thisPtr.OnSendResponseCompleted(result);
}
catch (Exception e)
{
if (Fx.IsFatal(e))
{
throw;
}
completionException = e;
}
thisPtr.Complete(false, completionException);
}
static void OnHttpPipelineSendCallback(object target, HttpResponseMessage httpResponseMessage)
{
ReplyAsyncResult thisPtr = (ReplyAsyncResult)target;
Exception pendingException = null;
bool completed = false;
try
{
completed = thisPtr.SendResponse(httpResponseMessage);
}
catch (Exception e)
{
if (Fx.IsFatal(e))
{
throw;
}
pendingException = e;
completed = true;
}
if (completed)
{
thisPtr.Complete(false, pendingException);
}
}
public bool SendResponse(HttpResponseMessage httpResponseMessage)
{
if (onSendCompleted == null)
{
onSendCompleted = Fx.ThunkCallback(new AsyncCallback(OnSendResponseCompletedCallback));
}
bool success = false;
try
{
return this.SendResponseCore(httpResponseMessage, out success);
}
finally
{
if (!success && this.message != null &&
!object.ReferenceEquals(this.message, this.responseMessage))
{
this.responseMessage.Close();
}
}
}
public bool SendResponse()
{
if (onSendCompleted == null)
{
onSendCompleted = Fx.ThunkCallback(new AsyncCallback(OnSendResponseCompletedCallback));
}
bool success = false;
try
{
this.closeOutputAfterReply = context.PrepareReply(ref this.responseMessage);
if (onHttpPipelineSend == null)
{
onHttpPipelineSend = new Action<object, HttpResponseMessage>(OnHttpPipelineSendCallback);
}
if (context.httpPipeline.SendAsyncReply(this.responseMessage, onHttpPipelineSend, this) == AsyncCompletionResult.Queued)
{
//// In Async send + HTTP pipeline path, we will send the response back after the result coming out from the pipeline.
//// So we don't need to call it here.
success = true;
return false;
}
HttpResponseMessage httpResponseMessage = null;
if (this.context.HttpMessagesSupported)
{
httpResponseMessage = HttpResponseMessageProperty.GetHttpResponseMessageFromMessage(this.responseMessage);
}
return this.SendResponseCore(httpResponseMessage, out success);
}
finally
{
if (!success && this.message != null &&
!object.ReferenceEquals(this.message, this.responseMessage))
{
this.responseMessage.Close();
}
}
}
bool SendResponseCore(HttpResponseMessage httpResponseMessage, out bool success)
{
success = false;
IAsyncResult result;
if (httpResponseMessage == null)
{
result = context.httpOutput.BeginSend(this.timeoutHelper.RemainingTime(), onSendCompleted, this);
}
else
{
result = context.httpOutput.BeginSend(httpResponseMessage, this.timeoutHelper.RemainingTime(), onSendCompleted, this);
}
success = true;
if (!result.CompletedSynchronously)
{
return false;
}
this.OnSendResponseCompleted(result);
return true;
}
}
internal IAsyncResult BeginProcessInboundRequest(
ReplyChannelAcceptor replyChannelAcceptor,
Action acceptorCallback,
AsyncCallback callback,
object state)
{
return this.httpPipeline.BeginProcessInboundRequest(replyChannelAcceptor, acceptorCallback, callback, state);
}
internal void EndProcessInboundRequest(IAsyncResult result)
{
this.httpPipeline.EndProcessInboundRequest(result);
}
class ListenerHttpContext : HttpRequestContext, HttpRequestMessageProperty.IHttpHeaderProvider
{
HttpListenerContext listenerContext;
byte[] webSocketInternalBuffer;
public ListenerHttpContext(HttpChannelListener listener,
HttpListenerContext listenerContext, EventTraceActivity eventTraceActivity)
: base(listener, null, eventTraceActivity)
{
this.listenerContext = listenerContext;
}
public override string HttpMethod
{
get { return listenerContext.Request.HttpMethod; }
}
public override bool IsWebSocketRequest
{
get { return this.listenerContext.Request.IsWebSocketRequest; }
}
protected override HttpInput GetHttpInput()
{
return new ListenerContextHttpInput(this);
}
protected override Task<WebSocketContext> AcceptWebSocketCore(HttpResponseMessage response, string protocol)
{
// CopyHeaders would still throw when the response contains a "WWW-Authenticate"-header
// But this is ok in this case because the "WWW-Authenticate"-header doesn't make sense
// for a response returning 101 (Switching Protocol)
HttpChannelUtilities.CopyHeaders(response, this.listenerContext.Response.Headers.Add);
this.webSocketInternalBuffer = this.Listener.TakeWebSocketInternalBuffer();
return this.listenerContext.AcceptWebSocketAsync(
protocol,
WebSocketHelper.GetReceiveBufferSize(this.listener.MaxReceivedMessageSize),
this.Listener.WebSocketSettings.GetEffectiveKeepAliveInterval(),
new ArraySegment<byte>(this.webSocketInternalBuffer)).Upcast<HttpListenerWebSocketContext, WebSocketContext>();
}
protected override void OnAcceptWebSocketError()
{
byte[] buffer = Interlocked.CompareExchange<byte[]>(ref this.webSocketInternalBuffer, null, this.webSocketInternalBuffer);
if (buffer != null)
{
this.Listener.ReturnWebSocketInternalBuffer(buffer);
}
}
protected override void OnAcceptWebSocketSuccess(WebSocketContext context, HttpRequestMessage requestMessage)
{
RemoteEndpointMessageProperty remoteEndpointMessageProperty = null;
if (this.listenerContext.Request.RemoteEndPoint != null)
{
remoteEndpointMessageProperty = new RemoteEndpointMessageProperty(this.listenerContext.Request.RemoteEndPoint);
}
base.OnAcceptWebSocketSuccess(context, remoteEndpointMessageProperty, this.webSocketInternalBuffer, true, requestMessage);
}
public override HttpOutput GetHttpOutput(Message message)
{
// work around http.sys keep alive bug with chunked requests, see MB 49676, this is fixed in Vista
if (listenerContext.Request.ContentLength64 == -1 && !OSEnvironmentHelper.IsVistaOrGreater)
{
listenerContext.Response.KeepAlive = false;
}
else
{
listenerContext.Response.KeepAlive = listener.KeepAliveEnabled;
}
ICompressedMessageEncoder compressedMessageEncoder = listener.MessageEncoderFactory.Encoder as ICompressedMessageEncoder;
if (compressedMessageEncoder != null && compressedMessageEncoder.CompressionEnabled)
{
string acceptEncoding = listenerContext.Request.Headers[HttpChannelUtilities.AcceptEncodingHeader];
compressedMessageEncoder.AddCompressedMessageProperties(message, acceptEncoding);
}
return HttpOutput.CreateHttpOutput(listenerContext.Response, Listener, message, this.HttpMethod);
}
protected override SecurityMessageProperty OnProcessAuthentication()
{
return Listener.ProcessAuthentication(listenerContext);
}
protected override HttpStatusCode ValidateAuthentication()
{
return Listener.ValidateAuthentication(listenerContext);
}
protected override void OnAbort()
{
listenerContext.Response.Abort();
// CSDMain 259910, we should remove this and call base.OnAbort() instead to improve maintainability
this.Cleanup();
}
protected override void OnClose(TimeSpan timeout)
{
TimeoutHelper timeoutHelper = new TimeoutHelper(timeout);
base.OnClose(timeoutHelper.RemainingTime());
try
{
listenerContext.Response.Close();
}
catch (HttpListenerException listenerException)
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
HttpChannelUtilities.CreateCommunicationException(listenerException));
}
}
void HttpRequestMessageProperty.IHttpHeaderProvider.CopyHeaders(WebHeaderCollection headers)
{
HttpListenerRequest listenerRequest = this.listenerContext.Request;
headers.Add(listenerRequest.Headers);
// MB 57988 - System.Net strips off user-agent from the headers collection
if (listenerRequest.UserAgent != null && headers[HttpRequestHeader.UserAgent] == null)
{
headers.Add(HttpRequestHeader.UserAgent, listenerRequest.UserAgent);
}
}
class ListenerContextHttpInput : HttpInput
{
ListenerHttpContext listenerHttpContext;
string cachedContentType; // accessing the header in System.Net involves a native transition
byte[] preReadBuffer;
public ListenerContextHttpInput(ListenerHttpContext listenerHttpContext)
: base(listenerHttpContext.Listener, true, listenerHttpContext.listener.IsChannelBindingSupportEnabled)
{
this.listenerHttpContext = listenerHttpContext;
if (this.listenerHttpContext.listenerContext.Request.ContentLength64 == -1)
{
this.preReadBuffer = new byte[1];
if (this.listenerHttpContext.listenerContext.Request.InputStream.Read(preReadBuffer, 0, 1) == 0)
{
this.preReadBuffer = null;
}
}
}
public override long ContentLength
{
get
{
return this.listenerHttpContext.listenerContext.Request.ContentLength64;
}
}
protected override string ContentTypeCore
{
get
{
if (this.cachedContentType == null)
{
this.cachedContentType = this.listenerHttpContext.listenerContext.Request.ContentType;
}
return this.cachedContentType;
}
}
protected override bool HasContent
{
get { return (this.preReadBuffer != null || this.ContentLength > 0); }
}
protected override string SoapActionHeader
{
get
{
return this.listenerHttpContext.listenerContext.Request.Headers["SOAPAction"];
}
}
protected override ChannelBinding ChannelBinding
{
get
{
return ChannelBindingUtility.GetToken(this.listenerHttpContext.listenerContext.Request.TransportContext);
}
}
protected override void AddProperties(Message message)
{
HttpRequestMessageProperty requestProperty = new HttpRequestMessageProperty(this.listenerHttpContext);
requestProperty.Method = this.listenerHttpContext.listenerContext.Request.HttpMethod;
// Uri.Query always includes the '?'
if (this.listenerHttpContext.listenerContext.Request.Url.Query.Length > 1)
{
requestProperty.QueryString = this.listenerHttpContext.listenerContext.Request.Url.Query.Substring(1);
}
message.Properties.Add(HttpRequestMessageProperty.Name, requestProperty);
message.Properties.Via = this.listenerHttpContext.listenerContext.Request.Url;
RemoteEndpointMessageProperty remoteEndpointProperty = new RemoteEndpointMessageProperty(this.listenerHttpContext.listenerContext.Request.RemoteEndPoint);
message.Properties.Add(RemoteEndpointMessageProperty.Name, remoteEndpointProperty);
}
public override void ConfigureHttpRequestMessage(HttpRequestMessage message)
{
message.Method = new HttpMethod(this.listenerHttpContext.listenerContext.Request.HttpMethod);
message.RequestUri = this.listenerHttpContext.listenerContext.Request.Url;
foreach (string webHeaderKey in this.listenerHttpContext.listenerContext.Request.Headers.Keys)
{
message.AddHeader(webHeaderKey, this.listenerHttpContext.listenerContext.Request.Headers[webHeaderKey]);
}
message.Properties.Add(RemoteEndpointMessageProperty.Name, new RemoteEndpointMessageProperty(this.listenerHttpContext.listenerContext.Request.RemoteEndPoint));
}
protected override Stream GetInputStream()
{
if (this.preReadBuffer != null)
{
return new ListenerContextInputStream(listenerHttpContext, preReadBuffer);
}
else
{
return new ListenerContextInputStream(listenerHttpContext);
}
}
class ListenerContextInputStream : HttpDelayedAcceptStream
{
public ListenerContextInputStream(ListenerHttpContext listenerHttpContext)
: base(listenerHttpContext.listenerContext.Request.InputStream)
{
}
public ListenerContextInputStream(ListenerHttpContext listenerHttpContext, byte[] preReadBuffer)
: base(new PreReadStream(listenerHttpContext.listenerContext.Request.InputStream, preReadBuffer))
{
}
public override IAsyncResult BeginRead(byte[] buffer, int offset, int count, AsyncCallback callback, object state)
{
try
{
return base.BeginRead(buffer, offset, count, callback, state);
}
catch (HttpListenerException listenerException)
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
HttpChannelUtilities.CreateCommunicationException(listenerException));
}
}
public override int EndRead(IAsyncResult result)
{
try
{
return base.EndRead(result);
}
catch (HttpListenerException listenerException)
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
HttpChannelUtilities.CreateCommunicationException(listenerException));
}
}
public override int Read(byte[] buffer, int offset, int count)
{
try
{
return base.Read(buffer, offset, count);
}
catch (HttpListenerException listenerException)
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
HttpChannelUtilities.CreateCommunicationException(listenerException));
}
}
public override int ReadByte()
{
try
{
return base.ReadByte();
}
catch (HttpListenerException listenerException)
{
throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(
HttpChannelUtilities.CreateCommunicationException(listenerException));
}
}
}
}
}
class AcceptWebSocketAsyncResult : AsyncResult
{
static AsyncCallback onHandleAcceptWebSocketResult = Fx.ThunkCallback(new AsyncCallback(HandleAcceptWebSocketResult));
HttpRequestContext context;
SignalGate gate = new SignalGate();
HttpResponseMessage response;
public AcceptWebSocketAsyncResult(HttpRequestContext context, HttpResponseMessage response, string protocol, AsyncCallback callback, object state)
: base(callback, state)
{
Fx.Assert(context != null, "context should not be null.");
Fx.Assert(response != null, "response should not be null.");
this.context = context;
this.response = response;
IAsyncResult result = this.context.AcceptWebSocketCore(response, protocol).AsAsyncResult<WebSocketContext>(onHandleAcceptWebSocketResult, this);
if (this.gate.Unlock())
{
this.CompleteAcceptWebSocket(result);
base.Complete(true);
}
}
public static void End(IAsyncResult result)
{
AsyncResult.End<AcceptWebSocketAsyncResult>(result);
}
static void HandleAcceptWebSocketResult(IAsyncResult result)
{
AcceptWebSocketAsyncResult thisPtr = (AcceptWebSocketAsyncResult)result.AsyncState;
if (!thisPtr.gate.Signal())
{
return;
}
Exception pendingException = null;
try
{
thisPtr.CompleteAcceptWebSocket(result);
}
catch (Exception ex)
{
if (Fx.IsFatal(ex))
{
throw;
}
pendingException = ex;
}
thisPtr.Complete(false, pendingException);
}
void CompleteAcceptWebSocket(IAsyncResult result)
{
Task<WebSocketContext> acceptTask = result as Task<WebSocketContext>;
Fx.Assert(acceptTask != null, "acceptTask should not be null.");
if (acceptTask.IsFaulted)
{
this.context.OnAcceptWebSocketError();
throw FxTrace.Exception.AsError<WebSocketException>(acceptTask.Exception);
}
else if (acceptTask.IsCanceled)
{
this.context.OnAcceptWebSocketError();
//
throw FxTrace.Exception.AsError(new TimeoutException(SR.GetString(SR.AcceptWebSocketTimedOutError)));
}
this.context.SetReplySent();
this.context.OnAcceptWebSocketSuccess(acceptTask.Result, response.RequestMessage);
}
}
}
}