You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			247 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			247 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //  | ||
|  | // System.Web.Services.Protocols.HttpWebClientProtocol.cs | ||
|  | // | ||
|  | // Author: | ||
|  | //   Tim Coleman (tim@timcoleman.com) | ||
|  | // | ||
|  | // Copyright (C) Tim Coleman, 2002 | ||
|  | // | ||
|  | 
 | ||
|  | // | ||
|  | // Permission is hereby granted, free of charge, to any person obtaining | ||
|  | // a copy of this software and associated documentation files (the | ||
|  | // "Software"), to deal in the Software without restriction, including | ||
|  | // without limitation the rights to use, copy, modify, merge, publish, | ||
|  | // distribute, sublicense, and/or sell copies of the Software, and to | ||
|  | // permit persons to whom the Software is furnished to do so, subject to | ||
|  | // the following conditions: | ||
|  | //  | ||
|  | // The above copyright notice and this permission notice shall be | ||
|  | // included in all copies or substantial portions of the Software. | ||
|  | //  | ||
|  | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||
|  | // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||
|  | // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||
|  | // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||
|  | // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||
|  | // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||
|  | // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
|  | // | ||
|  | 
 | ||
|  | using System; | ||
|  | using System.ComponentModel; | ||
|  | using System.Net; | ||
|  | using System.Security.Cryptography.X509Certificates; | ||
|  | using System.Threading; | ||
|  | using System.Web.Services; | ||
|  | using System.Collections; | ||
|  | 
 | ||
|  | namespace System.Web.Services.Protocols { | ||
|  | 	[System.Runtime.InteropServices.ComVisible (true)] | ||
|  | 	public abstract class HttpWebClientProtocol : WebClientProtocol { | ||
|  | 
 | ||
|  | 		#region Fields | ||
|  | 
 | ||
|  | 		bool allowAutoRedirect, enableDecompression; | ||
|  | 		X509CertificateCollection clientCertificates; | ||
|  | 		CookieContainer cookieContainer; | ||
|  | 		IWebProxy proxy; | ||
|  | 		string userAgent; | ||
|  | 		 | ||
|  | 		bool _unsafeAuthenticated; | ||
|  | 		#endregion | ||
|  | 
 | ||
|  | 		#region Constructors | ||
|  | 
 | ||
|  | 		protected HttpWebClientProtocol ()  | ||
|  | 		{ | ||
|  | 			allowAutoRedirect = false; | ||
|  | 			clientCertificates = null; | ||
|  | 			cookieContainer = null; | ||
|  | 			proxy = null; // FIXME | ||
|  | 			userAgent = String.Format ("Mono Web Services Client Protocol {0}", Environment.Version); | ||
|  | 		} | ||
|  | 		 | ||
|  | 		#endregion // Constructors | ||
|  | 
 | ||
|  | 		#region Properties | ||
|  | 
 | ||
|  | 		[DefaultValue (false)] | ||
|  | 		[WebServicesDescription ("Enable automatic handling of server redirects.")] | ||
|  | 		public bool AllowAutoRedirect { | ||
|  | 			get { return allowAutoRedirect; } | ||
|  | 			set { allowAutoRedirect = value; } | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[Browsable (false)] | ||
|  | 		[DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] | ||
|  | 		[WebServicesDescription ("The client certificates that will be sent to the server, if the server requests them.")] | ||
|  | 		public X509CertificateCollection ClientCertificates { | ||
|  | 			get { | ||
|  | 				if (clientCertificates == null) | ||
|  | 					clientCertificates = new X509CertificateCollection (); | ||
|  | 				return clientCertificates; | ||
|  | 			} | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[DefaultValue (null)] | ||
|  | 		[WebServicesDescription ("A container for all cookies received from servers in the current session.")] | ||
|  | 		public CookieContainer CookieContainer { | ||
|  | 			get { return cookieContainer; } | ||
|  | 			set { cookieContainer = value; } | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[DefaultValue (false)] | ||
|  | 		public bool EnableDecompression { | ||
|  | 			get { return enableDecompression; } | ||
|  | 			set { enableDecompression = value; } | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[Browsable (false)] | ||
|  | 		[DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] | ||
|  | 		public IWebProxy Proxy { | ||
|  | 			get { return proxy; } | ||
|  | 			set { proxy = value; } | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[WebServicesDescription ("Sets the user agent http header for the request.")] | ||
|  | 		[Browsable (false)] | ||
|  | 		[DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] | ||
|  | 		public string UserAgent { | ||
|  | 			get { return userAgent; } | ||
|  | 			set { userAgent = value; } | ||
|  | 		} | ||
|  | 		 | ||
|  | 		[Browsable (false)] | ||
|  | 		[DesignerSerializationVisibility (DesignerSerializationVisibility.Hidden)] | ||
|  | 		public bool UnsafeAuthenticatedConnectionSharing | ||
|  | 		{ | ||
|  | 			get { return _unsafeAuthenticated; } | ||
|  | 			set { _unsafeAuthenticated = value; } | ||
|  | 		} | ||
|  | 
 | ||
|  | 		#endregion // Properties | ||
|  | 
 | ||
|  | 		#region Methods | ||
|  | 
 | ||
|  | 		internal virtual void CheckForCookies (HttpWebResponse response) | ||
|  | 		{ | ||
|  | 			CookieCollection cookies = response.Cookies; | ||
|  | 			if (cookieContainer == null || cookies.Count == 0) | ||
|  | 				return; | ||
|  | 
 | ||
|  | 			CookieCollection coll = cookieContainer.GetCookies (uri); | ||
|  | 			foreach (Cookie c in cookies) { | ||
|  | 				bool add = true; | ||
|  | 				foreach (Cookie prev in coll) { | ||
|  | 					if (c.Equals (prev)) { | ||
|  | 						add = false; | ||
|  | 						break; | ||
|  | 					} | ||
|  | 				} | ||
|  | 				if (add) | ||
|  | 					cookieContainer.Add (c); | ||
|  | 			} | ||
|  | 		} | ||
|  | 		 | ||
|  | 		protected override WebRequest GetWebRequest (Uri uri) | ||
|  | 		{ | ||
|  | 			WebRequest req = base.GetWebRequest (uri); | ||
|  | 			HttpWebRequest request = req as HttpWebRequest; | ||
|  | 			if (request == null) | ||
|  | 				return req; | ||
|  | 			if (enableDecompression) | ||
|  | 				request.AutomaticDecompression = DecompressionMethods.GZip; | ||
|  | 
 | ||
|  | 			request.AllowAutoRedirect = allowAutoRedirect; | ||
|  | 			if (clientCertificates != null) | ||
|  | 				request.ClientCertificates.AddRange (clientCertificates); | ||
|  | 
 | ||
|  | 			request.CookieContainer = cookieContainer; | ||
|  | 			if (proxy != null) | ||
|  | 				request.Proxy = proxy; | ||
|  | 
 | ||
|  | 			request.UserAgent = userAgent; | ||
|  | 
 | ||
|  | 			return request; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		protected override WebResponse GetWebResponse (WebRequest request) | ||
|  | 		{ | ||
|  | 			WebResponse response = base.GetWebResponse (request); | ||
|  | 			HttpWebResponse wr = response as HttpWebResponse; | ||
|  | 			if (wr != null) | ||
|  | 				CheckForCookies (wr); | ||
|  | 				 | ||
|  | 			return response; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		protected override WebResponse GetWebResponse (WebRequest request, IAsyncResult result) | ||
|  | 		{ | ||
|  | 			WebResponse response = base.GetWebResponse (request, result); | ||
|  | 			HttpWebResponse wr = response as HttpWebResponse; | ||
|  | 			if (wr != null) | ||
|  | 				CheckForCookies (wr); | ||
|  | 				 | ||
|  | 			return response; | ||
|  | 		} | ||
|  | 		 | ||
|  | 		Hashtable mappings = new Hashtable (); | ||
|  | 		 | ||
|  | 		internal void RegisterMapping (object userState, WebClientAsyncResult result) | ||
|  | 		{ | ||
|  | 			if (userState == null) | ||
|  | 				userState = typeof (string); | ||
|  | 			 | ||
|  | 			mappings [userState] = result; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		internal void UnregisterMapping (object userState) | ||
|  | 		{ | ||
|  | 			if (userState == null) | ||
|  | 				userState = typeof (string); | ||
|  | 			 | ||
|  | 			mappings.Remove (userState); | ||
|  | 		} | ||
|  | 		 | ||
|  | 		protected void CancelAsync (object userState) | ||
|  | 		{ | ||
|  | 			WebClientAsyncResult result = (WebClientAsyncResult) mappings [userState]; | ||
|  | 
 | ||
|  | 			if (result == null) | ||
|  | 				return; | ||
|  | 			 | ||
|  | 			mappings.Remove (userState); | ||
|  | 			result.Abort (); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[MonoTODO] | ||
|  | 		public static bool GenerateXmlMappings (Type type, ArrayList mapping) | ||
|  | 		{ | ||
|  | 			throw new NotImplementedException (); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		[MonoTODO] | ||
|  | 		public static Hashtable GenerateXmlMappings (Type[] types, ArrayList mapping) | ||
|  | 		{ | ||
|  | 			throw new NotImplementedException (); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		#endregion // Methods | ||
|  | 	} | ||
|  | 	 | ||
|  | 	internal class InvokeAsyncInfo | ||
|  | 	{ | ||
|  | 		public SynchronizationContext Context; | ||
|  | 		public object UserState; | ||
|  | 		public SendOrPostCallback Callback; | ||
|  | 		 | ||
|  | 		public InvokeAsyncInfo (SendOrPostCallback callback, object userState) | ||
|  | 		{ | ||
|  | 			Callback = callback; | ||
|  | 			UserState = userState; | ||
|  | 			Context = SynchronizationContext.Current; | ||
|  | 		} | ||
|  | 	} | ||
|  | } |