Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / Net / System / Net / _ProxyChain.cs / 1 / _ProxyChain.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net { using System.Collections; using System.Collections.Generic; internal interface IAutoWebProxy : IWebProxy { ProxyChain GetProxies(Uri destination); } internal abstract class ProxyChain : IEnumerable, IDisposable { private List m_Cache = new List (); private bool m_CacheComplete; private ProxyEnumerator m_MainEnumerator; private Uri m_Destination; private HttpAbortDelegate m_HttpAbortDelegate; protected ProxyChain(Uri destination) { m_Destination = destination; } public IEnumerator GetEnumerator() { ProxyEnumerator enumerator = new ProxyEnumerator(this); if (m_MainEnumerator == null) { m_MainEnumerator = enumerator; } return enumerator; } IEnumerator IEnumerable.GetEnumerator() { return GetEnumerator(); } public virtual void Dispose() { } internal IEnumerator Enumerator { get { return m_MainEnumerator == null ? GetEnumerator() : m_MainEnumerator; } } internal Uri Destination { get { return m_Destination; } } // MoveNext can be time-consuming (download proxy script). This lets you abort it. internal virtual void Abort() { } internal bool HttpAbort(HttpWebRequest request, WebException webException) { Abort(); return true; } internal HttpAbortDelegate HttpAbortDelegate { get { if (m_HttpAbortDelegate == null) { m_HttpAbortDelegate = new HttpAbortDelegate(HttpAbort); } return m_HttpAbortDelegate; } } protected abstract bool GetNextProxy(out Uri proxy); // This implementation prevents DIRECT (null) from being returned more than once. private class ProxyEnumerator : IEnumerator { private ProxyChain m_Chain; private bool m_Finished; private int m_CurrentIndex = -1; private bool m_TriedDirect; internal ProxyEnumerator(ProxyChain chain) { m_Chain = chain; } public Uri Current { get { if (m_Finished || m_CurrentIndex < 0) { throw new InvalidOperationException(SR.GetString(SR.InvalidOperation_EnumOpCantHappen)); } GlobalLog.Assert(m_Chain.m_Cache.Count > m_CurrentIndex, "ProxyEnumerator::Current|Not all proxies made it to the cache."); return m_Chain.m_Cache[m_CurrentIndex]; } } object IEnumerator.Current { get { return Current; } } public bool MoveNext() { if (m_Finished) { return false; } checked{m_CurrentIndex++;} if (m_Chain.m_Cache.Count > m_CurrentIndex) { return true; } if (m_Chain.m_CacheComplete) { m_Finished = true; return false; } lock (m_Chain.m_Cache) { if (m_Chain.m_Cache.Count > m_CurrentIndex) { return true; } if (m_Chain.m_CacheComplete) { m_Finished = true; return false; } Uri nextProxy; while (true) { if (!m_Chain.GetNextProxy(out nextProxy)) { m_Finished = true; m_Chain.m_CacheComplete = true; return false; } if (nextProxy == null) { if (m_TriedDirect) { continue; } m_TriedDirect = true; } break; } m_Chain.m_Cache.Add(nextProxy); GlobalLog.Assert(m_Chain.m_Cache.Count > m_CurrentIndex, "ProxyEnumerator::MoveNext|Not all proxies made it to the cache."); return true; } } public void Reset() { m_Finished = false; m_CurrentIndex = -1; } public void Dispose() { } } } // This class implements failover logic for proxy scripts. internal class ProxyScriptChain : ProxyChain { private WebProxy m_Proxy; private Uri[] m_ScriptProxies; private int m_CurrentIndex; private int m_SyncStatus; internal ProxyScriptChain(WebProxy proxy, Uri destination) : base(destination) { m_Proxy = proxy; } protected override bool GetNextProxy(out Uri proxy) { if (m_CurrentIndex < 0) { proxy = null; return false; } if (m_CurrentIndex == 0) { AutoWebProxyState state; m_ScriptProxies = m_Proxy.GetProxiesAuto(Destination, out state, ref m_SyncStatus); if (state != AutoWebProxyState.ExecutionSuccess) { m_ScriptProxies = null; } } if (m_ScriptProxies == null || m_CurrentIndex >= m_ScriptProxies.Length) { proxy = m_Proxy.GetProxyAutoFailover(Destination); m_CurrentIndex = -1; return true; } proxy = m_ScriptProxies[m_CurrentIndex++]; return true; } internal override void Abort() { m_Proxy.AbortGetProxiesAuto(ref m_SyncStatus); } } // This class says to use no proxy. internal class DirectProxy : ProxyChain { private bool m_ProxyRetrieved; internal DirectProxy(Uri destination) : base(destination) { } protected override bool GetNextProxy(out Uri proxy) { proxy = null; if (m_ProxyRetrieved) { return false; } m_ProxyRetrieved = true; return true; } } // This class says to use a single fixed proxy. internal class StaticProxy : ProxyChain { private Uri m_Proxy; internal StaticProxy(Uri destination, Uri proxy) : base(destination) { if (proxy == null) { throw new ArgumentNullException("proxy"); } m_Proxy = proxy; } protected override bool GetNextProxy(out Uri proxy) { proxy = m_Proxy; if (proxy == null) { return false; } m_Proxy = null; return true; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net { using System.Collections; using System.Collections.Generic; internal interface IAutoWebProxy : IWebProxy { ProxyChain GetProxies(Uri destination); } internal abstract class ProxyChain : IEnumerable, IDisposable { private List m_Cache = new List (); private bool m_CacheComplete; private ProxyEnumerator m_MainEnumerator; private Uri m_Destination; private HttpAbortDelegate m_HttpAbortDelegate; protected ProxyChain(Uri destination) { m_Destination = destination; } public IEnumerator GetEnumerator() { ProxyEnumerator enumerator = new ProxyEnumerator(this); if (m_MainEnumerator == null) { m_MainEnumerator = enumerator; } return enumerator; } IEnumerator IEnumerable.GetEnumerator() { return GetEnumerator(); } public virtual void Dispose() { } internal IEnumerator Enumerator { get { return m_MainEnumerator == null ? GetEnumerator() : m_MainEnumerator; } } internal Uri Destination { get { return m_Destination; } } // MoveNext can be time-consuming (download proxy script). This lets you abort it. internal virtual void Abort() { } internal bool HttpAbort(HttpWebRequest request, WebException webException) { Abort(); return true; } internal HttpAbortDelegate HttpAbortDelegate { get { if (m_HttpAbortDelegate == null) { m_HttpAbortDelegate = new HttpAbortDelegate(HttpAbort); } return m_HttpAbortDelegate; } } protected abstract bool GetNextProxy(out Uri proxy); // This implementation prevents DIRECT (null) from being returned more than once. private class ProxyEnumerator : IEnumerator { private ProxyChain m_Chain; private bool m_Finished; private int m_CurrentIndex = -1; private bool m_TriedDirect; internal ProxyEnumerator(ProxyChain chain) { m_Chain = chain; } public Uri Current { get { if (m_Finished || m_CurrentIndex < 0) { throw new InvalidOperationException(SR.GetString(SR.InvalidOperation_EnumOpCantHappen)); } GlobalLog.Assert(m_Chain.m_Cache.Count > m_CurrentIndex, "ProxyEnumerator::Current|Not all proxies made it to the cache."); return m_Chain.m_Cache[m_CurrentIndex]; } } object IEnumerator.Current { get { return Current; } } public bool MoveNext() { if (m_Finished) { return false; } checked{m_CurrentIndex++;} if (m_Chain.m_Cache.Count > m_CurrentIndex) { return true; } if (m_Chain.m_CacheComplete) { m_Finished = true; return false; } lock (m_Chain.m_Cache) { if (m_Chain.m_Cache.Count > m_CurrentIndex) { return true; } if (m_Chain.m_CacheComplete) { m_Finished = true; return false; } Uri nextProxy; while (true) { if (!m_Chain.GetNextProxy(out nextProxy)) { m_Finished = true; m_Chain.m_CacheComplete = true; return false; } if (nextProxy == null) { if (m_TriedDirect) { continue; } m_TriedDirect = true; } break; } m_Chain.m_Cache.Add(nextProxy); GlobalLog.Assert(m_Chain.m_Cache.Count > m_CurrentIndex, "ProxyEnumerator::MoveNext|Not all proxies made it to the cache."); return true; } } public void Reset() { m_Finished = false; m_CurrentIndex = -1; } public void Dispose() { } } } // This class implements failover logic for proxy scripts. internal class ProxyScriptChain : ProxyChain { private WebProxy m_Proxy; private Uri[] m_ScriptProxies; private int m_CurrentIndex; private int m_SyncStatus; internal ProxyScriptChain(WebProxy proxy, Uri destination) : base(destination) { m_Proxy = proxy; } protected override bool GetNextProxy(out Uri proxy) { if (m_CurrentIndex < 0) { proxy = null; return false; } if (m_CurrentIndex == 0) { AutoWebProxyState state; m_ScriptProxies = m_Proxy.GetProxiesAuto(Destination, out state, ref m_SyncStatus); if (state != AutoWebProxyState.ExecutionSuccess) { m_ScriptProxies = null; } } if (m_ScriptProxies == null || m_CurrentIndex >= m_ScriptProxies.Length) { proxy = m_Proxy.GetProxyAutoFailover(Destination); m_CurrentIndex = -1; return true; } proxy = m_ScriptProxies[m_CurrentIndex++]; return true; } internal override void Abort() { m_Proxy.AbortGetProxiesAuto(ref m_SyncStatus); } } // This class says to use no proxy. internal class DirectProxy : ProxyChain { private bool m_ProxyRetrieved; internal DirectProxy(Uri destination) : base(destination) { } protected override bool GetNextProxy(out Uri proxy) { proxy = null; if (m_ProxyRetrieved) { return false; } m_ProxyRetrieved = true; return true; } } // This class says to use a single fixed proxy. internal class StaticProxy : ProxyChain { private Uri m_Proxy; internal StaticProxy(Uri destination, Uri proxy) : base(destination) { if (proxy == null) { throw new ArgumentNullException("proxy"); } m_Proxy = proxy; } protected override bool GetNextProxy(out Uri proxy) { proxy = m_Proxy; if (proxy == null) { return false; } m_Proxy = null; return true; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ServicePoint.cs
- BuilderPropertyEntry.cs
- Calendar.cs
- BaseTemplateBuildProvider.cs
- BamlBinaryReader.cs
- DisableDpiAwarenessAttribute.cs
- StaticDataManager.cs
- RequestContext.cs
- StrongNameKeyPair.cs
- StrokeCollectionDefaultValueFactory.cs
- CssStyleCollection.cs
- SchemaElementDecl.cs
- Visitors.cs
- SimpleWorkerRequest.cs
- ScriptRegistrationManager.cs
- RelationshipType.cs
- InputScopeNameConverter.cs
- ReachPrintTicketSerializerAsync.cs
- JpegBitmapDecoder.cs
- StaticExtension.cs
- TimelineGroup.cs
- X509AsymmetricSecurityKey.cs
- StandardBindingReliableSessionElement.cs
- Point3DAnimationBase.cs
- CheckableControlBaseAdapter.cs
- ProjectedSlot.cs
- DataGridrowEditEndingEventArgs.cs
- WriteFileContext.cs
- OutKeywords.cs
- ThaiBuddhistCalendar.cs
- DomainUpDown.cs
- UnsafeNativeMethods.cs
- Latin1Encoding.cs
- BaseTemplateParser.cs
- SqlFlattener.cs
- AppDomainUnloadedException.cs
- FixedFlowMap.cs
- TimeManager.cs
- RoleManagerSection.cs
- CompatibleIComparer.cs
- XmlSchemaType.cs
- HttpCachePolicyElement.cs
- PartialArray.cs
- TextEmbeddedObject.cs
- HierarchicalDataSourceControl.cs
- MenuAutomationPeer.cs
- Timer.cs
- QilName.cs
- HtmlControlPersistable.cs
- BitmapData.cs
- VariableAction.cs
- WindowsSpinner.cs
- HtmlForm.cs
- StylusPointPropertyInfo.cs
- CellQuery.cs
- PostBackTrigger.cs
- BindingContext.cs
- EntityDataSourceQueryBuilder.cs
- Matrix.cs
- LinqExpressionNormalizer.cs
- UpDownEvent.cs
- Vector3DAnimation.cs
- SmiMetaData.cs
- FastEncoderWindow.cs
- MyContact.cs
- PropertyNames.cs
- EntityDataSourceSelectingEventArgs.cs
- DragDropManager.cs
- BinHexDecoder.cs
- EtwTrackingParticipant.cs
- SQLDateTime.cs
- GZipStream.cs
- TrackingLocationCollection.cs
- FixedStringLookup.cs
- NavigationWindowAutomationPeer.cs
- DbConnectionPoolGroupProviderInfo.cs
- Type.cs
- ResourcePool.cs
- JpegBitmapEncoder.cs
- FileVersionInfo.cs
- SelectingProviderEventArgs.cs
- WorkflowTimerService.cs
- FileLevelControlBuilderAttribute.cs
- WorkflowHostingResponseContext.cs
- ProvidersHelper.cs
- WebPartConnectionsCloseVerb.cs
- RelatedView.cs
- SystemMulticastIPAddressInformation.cs
- ProcessHostMapPath.cs
- WebPartChrome.cs
- XPathNavigatorKeyComparer.cs
- ReferenceEqualityComparer.cs
- SerializationStore.cs
- DataFormat.cs
- IResourceProvider.cs
- ControlHelper.cs
- HostedElements.cs
- Manipulation.cs
- PathFigure.cs
- BinHexDecoder.cs