| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | // | 
					
						
							|  |  |  | // MonoTlsProviderFactory.cs | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Author: | 
					
						
							|  |  |  | //       Martin Baulig <martin.baulig@xamarin.com> | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Copyright (c) 2015 Xamarin, Inc. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // 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. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if SECURITY_DEP | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | #if MONO_SECURITY_ALIAS | 
					
						
							|  |  |  | extern alias MonoSecurity; | 
					
						
							|  |  |  | using MSI = MonoSecurity::Mono.Security.Interface; | 
					
						
							|  |  |  | using MX = MonoSecurity::Mono.Security.X509; | 
					
						
							|  |  |  | #else | 
					
						
							|  |  |  | using MSI = Mono.Security.Interface; | 
					
						
							|  |  |  | using MX = Mono.Security.X509; | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | using System.Security.Cryptography.X509Certificates; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using System; | 
					
						
							|  |  |  | using System.Net; | 
					
						
							| 
									
										
										
										
											2017-10-19 20:04:20 +00:00
										 |  |  | using System.Diagnostics; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | using System.Collections.Generic; | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | using System.Runtime.CompilerServices; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | using Mono.Btls; | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if MONO_FEATURE_APPLETLS | 
					
						
							|  |  |  | using Mono.AppleTls; | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | #if !MOBILE | 
					
						
							|  |  |  | using System.Reflection; | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Mono.Net.Security | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* | 
					
						
							|  |  |  | 	 * Keep in sync with Mono.Security/Mono.Security.Interface/MonoTlsProvider.cs. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	static partial class MonoTlsProviderFactory | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #region Internal API | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* | 
					
						
							|  |  |  | 		 * APIs in this section are for consumption within System.dll only - do not access via | 
					
						
							|  |  |  | 		 * reflection or from friend assemblies. | 
					
						
							|  |  |  | 		 *  | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 		internal static MSI.MonoTlsProvider GetProviderInternal () | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			lock (locker) { | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 				InitializeInternal (); | 
					
						
							|  |  |  | 				return defaultProvider; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 		internal static void InitializeInternal () | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			lock (locker) { | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 				if (initialized) | 
					
						
							|  |  |  | 					return; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-09 08:20:59 +00:00
										 |  |  | 				SystemDependencyProvider.Initialize (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 				InitializeProviderRegistration (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 				MSI.MonoTlsProvider provider; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 				try { | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 					provider = CreateDefaultProviderImpl (); | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 				} catch (Exception ex) { | 
					
						
							|  |  |  | 					throw new NotSupportedException ("TLS Support not available.", ex); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 				if (provider == null) | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 					throw new NotSupportedException ("TLS Support not available."); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 				if (!providerCache.ContainsKey (provider.ID)) | 
					
						
							|  |  |  | 					providerCache.Add (provider.ID, provider); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				defaultProvider = provider; | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 				initialized = true; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 		internal static void InitializeInternal (string provider)  | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 			lock (locker) { | 
					
						
							|  |  |  | 				if (initialized) | 
					
						
							|  |  |  | 					throw new NotSupportedException ("TLS Subsystem already initialized."); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-09 08:20:59 +00:00
										 |  |  | 				SystemDependencyProvider.Initialize (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 				defaultProvider = LookupProvider (provider, true); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 				initialized = true; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		static object locker = new object (); | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 		static bool initialized; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 		static MSI.MonoTlsProvider defaultProvider; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 		/* | 
					
						
							|  |  |  | 		 * @providerRegistration maps provider names to a tuple containing its ID and full type name. | 
					
						
							|  |  |  | 		 * On non-reflection enabled systems (such as XI and XM), we can use the Guid to uniquely | 
					
						
							|  |  |  | 		 * identify the provider. | 
					
						
							|  |  |  | 		 * | 
					
						
							|  |  |  | 		 * @providerCache maps the provider's Guid to the MSI.MonoTlsProvider instance. | 
					
						
							|  |  |  | 		 * | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		static Dictionary<string,Tuple<Guid,string>> providerRegistration; | 
					
						
							|  |  |  | 		static Dictionary<Guid,MSI.MonoTlsProvider> providerCache; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #if !ONLY_APPLETLS && !MONOTOUCH && !XAMMAC | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		static Type LookupProviderType (string name, bool throwOnError) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			lock (locker) { | 
					
						
							|  |  |  | 				InitializeProviderRegistration (); | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 				Tuple<Guid,string> entry; | 
					
						
							|  |  |  | 				if (!providerRegistration.TryGetValue (name, out entry)) { | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 					if (throwOnError) | 
					
						
							|  |  |  | 						throw new NotSupportedException (string.Format ("No such TLS Provider: `{0}'.", name)); | 
					
						
							|  |  |  | 					return null; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 				var type = Type.GetType (entry.Item2, false); | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 				if (type == null && throwOnError) | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 					throw new NotSupportedException (string.Format ("Could not find TLS Provider: `{0}'.", entry.Item2)); | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 				return type; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		static MSI.MonoTlsProvider LookupProvider (string name, bool throwOnError) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 			lock (locker) { | 
					
						
							|  |  |  | 				InitializeProviderRegistration (); | 
					
						
							|  |  |  | 				Tuple<Guid,string> entry; | 
					
						
							|  |  |  | 				if (!providerRegistration.TryGetValue (name, out entry)) { | 
					
						
							|  |  |  | 					if (throwOnError) | 
					
						
							|  |  |  | 						throw new NotSupportedException (string.Format ("No such TLS Provider: `{0}'.", name)); | 
					
						
							|  |  |  | 					return null; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				// Check cache before doing the reflection lookup. | 
					
						
							|  |  |  | 				MSI.MonoTlsProvider provider; | 
					
						
							|  |  |  | 				if (providerCache.TryGetValue (entry.Item1, out provider)) | 
					
						
							|  |  |  | 					return provider; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !ONLY_APPLETLS && !MONOTOUCH && !XAMMAC | 
					
						
							|  |  |  | 				var type = Type.GetType (entry.Item2, false); | 
					
						
							|  |  |  | 				if (type == null && throwOnError) | 
					
						
							|  |  |  | 					throw new NotSupportedException (string.Format ("Could not find TLS Provider: `{0}'.", entry.Item2)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				try { | 
					
						
							|  |  |  | 					provider = (MSI.MonoTlsProvider)Activator.CreateInstance (type, true); | 
					
						
							|  |  |  | 				} catch (Exception ex) { | 
					
						
							|  |  |  | 					throw new NotSupportedException (string.Format ("Unable to instantiate TLS Provider `{0}'.", type), ex); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if (provider == null) { | 
					
						
							|  |  |  | 					if (throwOnError) | 
					
						
							|  |  |  | 						throw new NotSupportedException (string.Format ("No such TLS Provider: `{0}'.", name)); | 
					
						
							|  |  |  | 					return null; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				providerCache.Add (entry.Item1, provider); | 
					
						
							|  |  |  | 				return provider; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-19 20:04:20 +00:00
										 |  |  | 		static bool enableDebug; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Conditional ("MONO_TLS_DEBUG")] | 
					
						
							|  |  |  | 		static void InitializeDebug () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (Environment.GetEnvironmentVariable ("MONO_TLS_DEBUG") != null) | 
					
						
							|  |  |  | 				enableDebug = true; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Conditional ("MONO_TLS_DEBUG")] | 
					
						
							|  |  |  | 		internal static void Debug (string message, params object[] args) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (enableDebug) | 
					
						
							|  |  |  | 				Console.Error.WriteLine (message, args); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #endregion | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		internal static readonly Guid AppleTlsId = new Guid ("981af8af-a3a3-419a-9f01-a518e3a17c1c"); | 
					
						
							|  |  |  | 		internal static readonly Guid BtlsId = new Guid ("432d18c9-9348-4b90-bfbf-9f2a10e1f15b"); | 
					
						
							|  |  |  | 		internal static readonly Guid LegacyId = new Guid ("809e77d5-56cc-4da8-b9f0-45e65ba9cceb"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		static void InitializeProviderRegistration () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			lock (locker) { | 
					
						
							|  |  |  | 				if (providerRegistration != null) | 
					
						
							|  |  |  | 					return; | 
					
						
							| 
									
										
										
										
											2017-10-19 20:04:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				InitializeDebug (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 				providerRegistration = new Dictionary<string,Tuple<Guid,string>> (); | 
					
						
							|  |  |  | 				providerCache = new Dictionary<Guid,MSI.MonoTlsProvider> (); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 				PopulateProviders (); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-01-09 11:04:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #if ONLY_APPLETLS || MONOTOUCH || XAMMAC | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 		// TODO: Should be redundant | 
					
						
							|  |  |  | 		static void PopulateProviders () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var appleTlsEntry = new Tuple<Guid,String> (AppleTlsId, typeof (Mono.AppleTls.AppleTlsProvider).FullName); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			providerRegistration.Add ("default", appleTlsEntry); | 
					
						
							|  |  |  | 			providerRegistration.Add ("apple", appleTlsEntry); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | #elif MONODROID | 
					
						
							|  |  |  | 		// TODO: Should be redundant		 | 
					
						
							|  |  |  | 		static void PopulateProviders () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var legacyEntry = new Tuple<Guid,String> (LegacyId, typeof (Mono.Net.Security.LegacyTlsProvider).FullName); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			providerRegistration.Add ("legacy", legacyEntry); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	#if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | 			var btlsEntry = new Tuple<Guid,String> (BtlsId, typeof (Mono.Btls.MonoBtlsProvider).FullName); | 
					
						
							|  |  |  | 			if (btlsEntry != null) | 
					
						
							|  |  |  | 				providerRegistration.Add ("default", btlsEntry); | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 	#endif | 
					
						
							|  |  |  | 			providerRegistration.Add ("default", legacyEntry); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #else | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 		static void PopulateProviders () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | #if MONO_FEATURE_APPLETLS | 
					
						
							|  |  |  | 			var appleTlsEntry = new Tuple<Guid,String> (AppleTlsId, typeof (Mono.AppleTls.AppleTlsProvider).FullName); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 			var legacyEntry = new Tuple<Guid,String> (LegacyId, typeof (Mono.Net.Security.LegacyTlsProvider).FullName); | 
					
						
							|  |  |  | 			providerRegistration.Add ("legacy", legacyEntry); | 
					
						
							| 
									
										
										
										
											2017-05-11 09:38:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 			Tuple<Guid,String> btlsEntry = null; | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #if MONO_FEATURE_BTLS | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 			if (IsBtlsSupported ()) { | 
					
						
							|  |  |  | 				btlsEntry = new Tuple<Guid,String> (BtlsId, typeof (Mono.Btls.MonoBtlsProvider).FullName); | 
					
						
							|  |  |  | 				providerRegistration.Add ("btls", btlsEntry); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2017-05-11 09:38:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | #if MONO_FEATURE_APPLETLS | 
					
						
							|  |  |  | 			if (Platform.IsMacOS) | 
					
						
							|  |  |  | 				providerRegistration.Add ("default", appleTlsEntry); | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | #if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | 			if (btlsEntry != null) | 
					
						
							|  |  |  | 				providerRegistration.Add ("default", btlsEntry); | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 				providerRegistration.Add ("default", legacyEntry); | 
					
						
							| 
									
										
										
										
											2017-05-11 09:38:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | #if MONO_FEATURE_APPLETLS | 
					
						
							|  |  |  | 			providerRegistration.Add ("apple", appleTlsEntry); | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | 		[MethodImpl (MethodImplOptions.InternalCall)] | 
					
						
							|  |  |  | 		internal extern static bool IsBtlsSupported (); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		static MSI.MonoTlsProvider CreateDefaultProviderImpl () | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | #if MONODROID | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 			MSI.MonoTlsProvider provider = null; | 
					
						
							|  |  |  | 			var type = Environment.GetEnvironmentVariable ("XA_TLS_PROVIDER"); | 
					
						
							|  |  |  | 			switch (type) { | 
					
						
							|  |  |  | 			case null: | 
					
						
							|  |  |  | 			case "default": | 
					
						
							|  |  |  | 			case "legacy": | 
					
						
							|  |  |  | 				return new LegacyTlsProvider (); | 
					
						
							|  |  |  | #if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | 			case "btls": | 
					
						
							|  |  |  | 				if (!IsBtlsSupported ()) | 
					
						
							|  |  |  | 					throw new NotSupportedException ("BTLS in not supported!"); | 
					
						
							|  |  |  | 				return new MonoBtlsProvider (); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 			default: | 
					
						
							|  |  |  | 				throw new NotSupportedException (string.Format ("Invalid TLS Provider: `{0}'.", provider)); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #elif ONLY_APPLETLS || MONOTOUCH || XAMMAC | 
					
						
							|  |  |  | 			return new AppleTlsProvider (); | 
					
						
							|  |  |  | #else | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 			var type = Environment.GetEnvironmentVariable ("MONO_TLS_PROVIDER"); | 
					
						
							|  |  |  | 			if (string.IsNullOrEmpty (type)) | 
					
						
							|  |  |  | 				type = "default"; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 			switch (type) { | 
					
						
							|  |  |  | 			case "default": | 
					
						
							|  |  |  | #if MONO_FEATURE_APPLETLS | 
					
						
							|  |  |  | 				if (Platform.IsMacOS) | 
					
						
							|  |  |  | 					goto case "apple"; | 
					
						
							| 
									
										
										
										
											2016-08-23 13:20:38 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | #if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | 				if (IsBtlsSupported ()) | 
					
						
							|  |  |  | 					goto case "btls"; | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 				goto case "legacy"; | 
					
						
							|  |  |  | #if MONO_FEATURE_APPLETLS | 
					
						
							|  |  |  | 			case "apple": | 
					
						
							|  |  |  | 				return new AppleTlsProvider (); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | #if MONO_FEATURE_BTLS | 
					
						
							|  |  |  | 			case "btls": | 
					
						
							|  |  |  | 				return new MonoBtlsProvider (); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 			case "legacy": | 
					
						
							|  |  |  | 				return new Mono.Net.Security.LegacyTlsProvider (); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-24 09:31:23 +00:00
										 |  |  | 			return LookupProvider (type, true); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #region Mono.Security visible API | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* | 
					
						
							|  |  |  | 		 * "Public" section, intended to be consumed via reflection. | 
					
						
							|  |  |  | 		 *  | 
					
						
							|  |  |  | 		 * Mono.Security.dll provides a public wrapper around these. | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		internal static MSI.MonoTlsProvider GetProvider () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var provider = GetProviderInternal (); | 
					
						
							|  |  |  | 			if (provider == null) | 
					
						
							|  |  |  | 				throw new NotSupportedException ("No TLS Provider available."); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 			return provider; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 		internal static bool IsProviderSupported (string name) | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | 			lock (locker) { | 
					
						
							|  |  |  | 				InitializeProviderRegistration (); | 
					
						
							|  |  |  | 				return providerRegistration.ContainsKey (name); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		internal static MSI.MonoTlsProvider GetProvider (string name) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			return LookupProvider (name, false); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 		internal static bool IsInitialized { | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 			get { | 
					
						
							|  |  |  | 				lock (locker) { | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 					return initialized; | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 		internal static void Initialize () | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2016-11-10 13:04:39 +00:00
										 |  |  | 			InitializeInternal (); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		internal static void Initialize (string provider) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			InitializeInternal (provider); | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-08-21 15:34:15 +00:00
										 |  |  | #endregion | 
					
						
							| 
									
										
										
										
											2016-02-22 11:00:01 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-04-10 11:41:01 +00:00
										 |  |  | #endif |