5 // Martin Baulig <martin.baulig@xamarin.com>
7 // Copyright (C) 2016 Xamarin, Inc. (http://www.xamarin.com)
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 #if MONO_SECURITY_ALIAS
31 extern alias MonoSecurity;
34 #if MONO_SECURITY_ALIAS
35 using MonoSecurity::Mono.Security.Interface;
37 #if !FEATURE_NO_BSD_SOCKETS
38 using Mono.Security.Interface;
42 #if !FEATURE_NO_BSD_SOCKETS
50 namespace System.Security.Cryptography.X509Certificates
52 internal static class X509Helper2
54 internal static long GetSubjectNameHash (X509Certificate certificate)
56 return GetSubjectNameHash (certificate.Impl);
59 internal static long GetSubjectNameHash (X509CertificateImpl impl)
62 using (var x509 = GetNativeInstance (impl))
63 return GetSubjectNameHash (x509);
65 throw new NotSupportedException ();
69 internal static void ExportAsPEM (X509Certificate certificate, Stream stream, bool includeHumanReadableForm)
71 ExportAsPEM (certificate.Impl, stream, includeHumanReadableForm);
74 internal static void ExportAsPEM (X509CertificateImpl impl, Stream stream, bool includeHumanReadableForm)
77 using (var x509 = GetNativeInstance (impl))
78 ExportAsPEM (x509, stream, includeHumanReadableForm);
80 throw new NotSupportedException ();
85 internal static void Initialize ()
87 X509Helper.InstallNativeHelper (new MyNativeHelper ());
90 internal static void ThrowIfContextInvalid (X509CertificateImpl impl)
92 X509Helper.ThrowIfContextInvalid (impl);
95 #if FEATURE_NO_BSD_SOCKETS
96 static X509Certificate GetNativeInstance (X509CertificateImpl impl)
98 throw new PlatformNotSupportedException ();
101 static MonoBtlsX509 GetNativeInstance (X509CertificateImpl impl)
103 ThrowIfContextInvalid (impl);
104 var btlsImpl = impl as X509CertificateImplBtls;
105 if (btlsImpl != null)
106 return btlsImpl.X509.Copy ();
108 return MonoBtlsX509.LoadFromData (impl.GetRawCertData (), MonoBtlsX509Format.DER);
111 internal static long GetSubjectNameHash (MonoBtlsX509 x509)
113 using (var subject = x509.GetSubjectName ())
114 return subject.GetHash ();
117 internal static void ExportAsPEM (MonoBtlsX509 x509, Stream stream, bool includeHumanReadableForm)
119 using (var bio = MonoBtlsBio.CreateMonoStream (stream)) {
120 x509.ExportAsPEM (bio, includeHumanReadableForm);
123 #endif // !FEATURE_NO_BSD_SOCKETS
125 internal static X509Certificate2Impl Import (byte[] rawData, string password, X509KeyStorageFlags keyStorageFlags)
127 #if !FEATURE_NO_BSD_SOCKETS
128 var provider = MonoTlsProviderFactory.GetProvider ();
129 if (provider.HasNativeCertificates) {
130 var impl = provider.GetNativeCertificate (rawData, password, keyStorageFlags);
133 #endif // FEATURE_NO_BSD_SOCKETS
134 var impl2 = new X509Certificate2ImplMono ();
135 impl2.Import (rawData, password, keyStorageFlags);
139 internal static X509Certificate2Impl Import (X509Certificate cert)
141 #if !FEATURE_NO_BSD_SOCKETS
142 var provider = MonoTlsProviderFactory.GetProvider ();
143 if (provider.HasNativeCertificates) {
144 var impl = provider.GetNativeCertificate (cert);
147 #endif // FEATURE_NO_BSD_SOCKETS
148 var impl2 = cert.Impl as X509Certificate2Impl;
150 return (X509Certificate2Impl)impl2.Clone ();
151 return Import (cert.GetRawCertData (), null, X509KeyStorageFlags.DefaultKeySet);
154 internal static X509ChainImpl CreateChainImpl (bool useMachineContext)
156 return new X509ChainImplMono (useMachineContext);
159 public static bool IsValid (X509ChainImpl impl)
161 return impl != null && impl.IsValid;
164 internal static void ThrowIfContextInvalid (X509ChainImpl impl)
167 throw GetInvalidChainContextException ();
170 internal static Exception GetInvalidChainContextException ()
172 return new CryptographicException (Locale.GetText ("Chain instance is empty."));
175 class MyNativeHelper : INativeCertificateHelper
177 public X509CertificateImpl Import (
178 byte[] data, string password, X509KeyStorageFlags flags)
180 return X509Helper2.Import (data, password, flags);
183 public X509CertificateImpl Import (X509Certificate cert)
185 return X509Helper2.Import (cert);