Blame SOURCES/0002-Drop-pal_asn1_print-in-favor-of-the-managed-code.patch

a359fa
From 3fd578c3ccea681efd14aea07a0364b3baa3cca7 Mon Sep 17 00:00:00 2001
a359fa
From: Filip Navara <filip.navara@gmail.com>
a359fa
Date: Mon, 9 Jul 2018 19:08:50 +0200
a359fa
Subject: [PATCH 2/7] Drop pal_asn1_print in favor of the managed code
a359fa
a359fa
* Drop pal_asn1_print in favor of the managed code that is already used on macOS.
a359fa
a359fa
* Add handling of T61 strings to ManagedCertificateFinder.DerStringToManagedString.
a359fa
---
a359fa
 .../Interop.ASN1.Print.cs                     | 144 ------------------
a359fa
 .../Win32/SafeHandles/Asn1SafeHandles.Unix.cs |  28 ----
a359fa
 .../pal_asn1_print.cpp                        |   5 +
a359fa
 .../pal_asn1_print.h                          |   5 +
a359fa
 .../Internal/Cryptography/Pal.OSX/FindPal.cs  |  28 ----
a359fa
 .../Pal.Unix/ManagedCertificateFinder.cs      |  31 +++-
a359fa
 .../Pal.Unix/OpenSslCertificateFinder.cs      |   5 -
a359fa
 ...urity.Cryptography.X509Certificates.csproj |   3 -
a359fa
 8 files changed, 40 insertions(+), 209 deletions(-)
a359fa
 delete mode 100644 src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.ASN1.Print.cs
a359fa
a359fa
diff --git a/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.ASN1.Print.cs b/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.ASN1.Print.cs
a359fa
deleted file mode 100644
a359fa
index 12199563c8..0000000000
a359fa
--- a/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.ASN1.Print.cs
a359fa
+++ /dev/null
a359fa
@@ -1,144 +0,0 @@
a359fa
-// Licensed to the .NET Foundation under one or more agreements.
a359fa
-// The .NET Foundation licenses this file to you under the MIT license.
a359fa
-// See the LICENSE file in the project root for more information.
a359fa
-
a359fa
-using System;
a359fa
-using System.Runtime.InteropServices;
a359fa
-using System.Text;
a359fa
-using Microsoft.Win32.SafeHandles;
a359fa
-
a359fa
-internal static partial class Interop
a359fa
-{
a359fa
-    internal static partial class Crypto
a359fa
-    {
a359fa
-        [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_DecodeAsn1TypeBytes")]
a359fa
-        private static extern SafeAsn1StringHandle DecodeAsn1TypeBytes(byte[] buf, int len, Asn1StringTypeFlags flags);
a359fa
-
a359fa
-        [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_Asn1StringPrintEx")]
a359fa
-        private static extern int Asn1StringPrintEx(SafeBioHandle bio, SafeAsn1StringHandle str, Asn1StringPrintFlags flags);
a359fa
-
a359fa
-        [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_Asn1StringPrintEx")]
a359fa
-        private static extern int Asn1StringPrintEx(SafeBioHandle bio, SafeSharedAsn1StringHandle str, Asn1StringPrintFlags flags);
a359fa
-
a359fa
-        internal static string DerStringToManagedString(byte[] derString)
a359fa
-        {
a359fa
-            SafeAsn1StringHandle asn1String = DecodeAsn1TypeBytes(derString, derString.Length, AnyTextStringType);
a359fa
-
a359fa
-            if (asn1String.IsInvalid)
a359fa
-            {
a359fa
-                Interop.Crypto.ErrClearError();
a359fa
-                return null;
a359fa
-            }
a359fa
-
a359fa
-            using (asn1String)
a359fa
-            {
a359fa
-                return Asn1StringToManagedString(
a359fa
-                    asn1String,
a359fa
-                    (bio, str, flags) => Asn1StringPrintEx(bio, str, flags));
a359fa
-            }
a359fa
-        }
a359fa
-
a359fa
-        internal static string Asn1StringToManagedString(SafeSharedAsn1StringHandle asn1String)
a359fa
-        {
a359fa
-            CheckValidOpenSslHandle(asn1String);
a359fa
-
a359fa
-            return Asn1StringToManagedString(
a359fa
-                asn1String,
a359fa
-                (bio, str, flags) => Asn1StringPrintEx(bio, str, flags));
a359fa
-        }
a359fa
-
a359fa
-        private static string Asn1StringToManagedString<THandle>(
a359fa
-            THandle asn1String,
a359fa
-            Func<SafeBioHandle, THandle, Asn1StringPrintFlags, int> asn1StringPrintEx)
a359fa
-        {
a359fa
-            byte[] utf8Bytes;
a359fa
-
a359fa
-            using (SafeBioHandle bio = CreateMemoryBio())
a359fa
-            {
a359fa
-                CheckValidOpenSslHandle(bio);
a359fa
-                
a359fa
-                int len = asn1StringPrintEx(bio, asn1String, Asn1StringPrintFlags.ASN1_STRFLGS_UTF8_CONVERT);
a359fa
-
a359fa
-                if (len < 0)
a359fa
-                {
a359fa
-                    throw CreateOpenSslCryptographicException();
a359fa
-                }
a359fa
-
a359fa
-                if (len == 0)
a359fa
-                {
a359fa
-                    return "";
a359fa
-                }
a359fa
-
a359fa
-                int bioSize = GetMemoryBioSize(bio);
a359fa
-                utf8Bytes = new byte[bioSize + 1];
a359fa
-
a359fa
-                int read = BioRead(bio, utf8Bytes, utf8Bytes.Length);
a359fa
-
a359fa
-                if (read < 0)
a359fa
-                {
a359fa
-                    throw CreateOpenSslCryptographicException();
a359fa
-                }
a359fa
-            }
a359fa
-
a359fa
-            int nonNullCount = utf8Bytes.Length;
a359fa
-
a359fa
-            if (utf8Bytes[utf8Bytes.Length - 1] == 0)
a359fa
-            {
a359fa
-                for (int i = utf8Bytes.Length - 1; i >= 0; i--)
a359fa
-                {
a359fa
-                    if (utf8Bytes[i] != 0)
a359fa
-                    {
a359fa
-                        break;
a359fa
-                    }
a359fa
-
a359fa
-                    nonNullCount = i;
a359fa
-                }
a359fa
-            }
a359fa
-
a359fa
-            return Encoding.UTF8.GetString(utf8Bytes, 0, nonNullCount);
a359fa
-        }
a359fa
-
a359fa
-        [Flags]
a359fa
-        private enum Asn1StringPrintFlags : ulong
a359fa
-        {
a359fa
-            ASN1_STRFLGS_UTF8_CONVERT = 0x10,
a359fa
-        }
a359fa
-
a359fa
-        [Flags]
a359fa
-        private enum Asn1StringTypeFlags
a359fa
-        {
a359fa
-            B_ASN1_NUMERICSTRING = 0x0001,
a359fa
-            B_ASN1_PRINTABLESTRING = 0x0002,
a359fa
-            B_ASN1_T61STRING = 0x0004,
a359fa
-            B_ASN1_VIDEOTEXSTRING = 0x0008,
a359fa
-            B_ASN1_IA5STRING = 0x0010,
a359fa
-            B_ASN1_GRAPHICSTRING = 0x0020,
a359fa
-            B_ASN1_VISIBLESTRING = 0x0040,
a359fa
-            B_ASN1_GENERALSTRING = 0x0080,
a359fa
-            B_ASN1_UNIVERSALSTRING = 0x0100,
a359fa
-            B_ASN1_OCTET_STRING = 0x0200,
a359fa
-            B_ASN1_BIT_STRING = 0x0400,
a359fa
-            B_ASN1_BMPSTRING = 0x0800,
a359fa
-            B_ASN1_UNKNOWN = 0x1000,
a359fa
-            B_ASN1_UTF8STRING = 0x2000,
a359fa
-            B_ASN1_UTCTIME = 0x4000,
a359fa
-            B_ASN1_GENERALIZEDTIME = 0x8000,
a359fa
-            B_ASN1_SEQUENCE = 0x10000,
a359fa
-        }
a359fa
-
a359fa
-        private const Asn1StringTypeFlags AnyTextStringType =
a359fa
-            Asn1StringTypeFlags.B_ASN1_NUMERICSTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_PRINTABLESTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_T61STRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_VIDEOTEXSTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_IA5STRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_GRAPHICSTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_VISIBLESTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_GENERALSTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_UNIVERSALSTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_BMPSTRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_UTF8STRING |
a359fa
-            Asn1StringTypeFlags.B_ASN1_UTCTIME |
a359fa
-            Asn1StringTypeFlags.B_ASN1_GENERALIZEDTIME;
a359fa
-    }
a359fa
-}
a359fa
diff --git a/src/Common/src/Microsoft/Win32/SafeHandles/Asn1SafeHandles.Unix.cs b/src/Common/src/Microsoft/Win32/SafeHandles/Asn1SafeHandles.Unix.cs
a359fa
index 3fdde3f602..ddf413110c 100644
a359fa
--- a/src/Common/src/Microsoft/Win32/SafeHandles/Asn1SafeHandles.Unix.cs
a359fa
+++ b/src/Common/src/Microsoft/Win32/SafeHandles/Asn1SafeHandles.Unix.cs
a359fa
@@ -68,34 +68,6 @@ namespace Microsoft.Win32.SafeHandles
a359fa
         }
a359fa
     }
a359fa
 
a359fa
-    internal sealed class SafeAsn1StringHandle : SafeHandle
a359fa
-    {
a359fa
-        private SafeAsn1StringHandle() :
a359fa
-            base(IntPtr.Zero, ownsHandle: true)
a359fa
-        {
a359fa
-        }
a359fa
-
a359fa
-        protected override bool ReleaseHandle()
a359fa
-        {
a359fa
-            Interop.Crypto.Asn1StringFree(handle);
a359fa
-            SetHandle(IntPtr.Zero);
a359fa
-            return true;
a359fa
-        }
a359fa
-
a359fa
-        public override bool IsInvalid
a359fa
-        {
a359fa
-            get { return handle == IntPtr.Zero; }
a359fa
-        }
a359fa
-    }
a359fa
-
a359fa
-    internal sealed class SafeSharedAsn1StringHandle : SafeInteriorHandle
a359fa
-    {
a359fa
-        private SafeSharedAsn1StringHandle() :
a359fa
-            base(IntPtr.Zero, ownsHandle: true)
a359fa
-        {
a359fa
-        }
a359fa
-    }
a359fa
-
a359fa
     internal sealed class SafeSharedAsn1IntegerHandle : SafeInteriorHandle
a359fa
     {
a359fa
         private SafeSharedAsn1IntegerHandle() :
a359fa
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.cpp b/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.cpp
a359fa
index ffbfef980d..01a544f5e9 100644
a359fa
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.cpp
a359fa
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.cpp
a359fa
@@ -4,6 +4,11 @@
a359fa
 
a359fa
 #include "pal_asn1_print.h"
a359fa
 
a359fa
+/*
a359fa
+ * This file is completely unused. It's kept around for compatiblity between
a359fa
+ * servicing updates.
a359fa
+ */
a359fa
+
a359fa
 static_assert(PAL_B_ASN1_NUMERICSTRING == B_ASN1_NUMERICSTRING, "");
a359fa
 static_assert(PAL_B_ASN1_PRINTABLESTRING == B_ASN1_PRINTABLESTRING, "");
a359fa
 static_assert(PAL_B_ASN1_T61STRING == B_ASN1_T61STRING, "");
a359fa
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.h b/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.h
a359fa
index 982506e420..71205cc13c 100644
a359fa
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.h
a359fa
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_asn1_print.h
a359fa
@@ -5,6 +5,11 @@
a359fa
 #include "pal_types.h"
a359fa
 #include "opensslshim.h"
a359fa
 
a359fa
+/*
a359fa
+ * This file is completely unused. It's kept around for compatiblity between
a359fa
+ * servicing updates.
a359fa
+ */
a359fa
+
a359fa
 /*
a359fa
 Flags for the 'type' parameter of CryptoNative_DecodeAsn1TypeBytes.
a359fa
 */
a359fa
diff --git a/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.OSX/FindPal.cs b/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.OSX/FindPal.cs
a359fa
index b2d2846c1a..e66bad7e76 100644
a359fa
--- a/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.OSX/FindPal.cs
a359fa
+++ b/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.OSX/FindPal.cs
a359fa
@@ -22,34 +22,6 @@ namespace Internal.Cryptography.Pal
a359fa
             {
a359fa
             }
a359fa
 
a359fa
-            protected override string DerStringToManagedString(byte[] anyString)
a359fa
-            {
a359fa
-                DerSequenceReader reader = DerSequenceReader.CreateForPayload(anyString);
a359fa
-
a359fa
-                var tag = (DerSequenceReader.DerTag)reader.PeekTag();
a359fa
-                string value = null;
a359fa
-
a359fa
-                switch (tag)
a359fa
-                {
a359fa
-                    case DerSequenceReader.DerTag.BMPString:
a359fa
-                        value = reader.ReadBMPString();
a359fa
-                        break;
a359fa
-                    case DerSequenceReader.DerTag.IA5String:
a359fa
-                        value = reader.ReadIA5String();
a359fa
-                        break;
a359fa
-                    case DerSequenceReader.DerTag.PrintableString:
a359fa
-                        value = reader.ReadPrintableString();
a359fa
-                        break;
a359fa
-                    case DerSequenceReader.DerTag.UTF8String:
a359fa
-                        value = reader.ReadUtf8String();
a359fa
-                        break;
a359fa
-
a359fa
-                    // Ignore anything we don't know how to read.
a359fa
-                }
a359fa
-
a359fa
-                return value;
a359fa
-            }
a359fa
-
a359fa
             protected override byte[] GetSubjectPublicKeyInfo(X509Certificate2 cert)
a359fa
             {
a359fa
                 AppleCertificatePal pal = (AppleCertificatePal)cert.Pal;
a359fa
diff --git a/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/ManagedCertificateFinder.cs b/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/ManagedCertificateFinder.cs
a359fa
index ebc5ee48d1..a70bf1488d 100644
a359fa
--- a/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/ManagedCertificateFinder.cs
a359fa
+++ b/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/ManagedCertificateFinder.cs
a359fa
@@ -123,7 +123,36 @@ namespace Internal.Cryptography.Pal
a359fa
             FindCore(cert => cert.NotAfter < normalized);
a359fa
         }
a359fa
 
a359fa
-        protected abstract string DerStringToManagedString(byte[] anyString);
a359fa
+        private string DerStringToManagedString(byte[] anyString)
a359fa
+        {
a359fa
+            DerSequenceReader reader = DerSequenceReader.CreateForPayload(anyString);
a359fa
+
a359fa
+            var tag = (DerSequenceReader.DerTag)reader.PeekTag();
a359fa
+            string value = null;
a359fa
+
a359fa
+            switch (tag)
a359fa
+            {
a359fa
+                case DerSequenceReader.DerTag.BMPString:
a359fa
+                    value = reader.ReadBMPString();
a359fa
+                    break;
a359fa
+                case DerSequenceReader.DerTag.IA5String:
a359fa
+                    value = reader.ReadIA5String();
a359fa
+                    break;
a359fa
+                case DerSequenceReader.DerTag.PrintableString:
a359fa
+                    value = reader.ReadPrintableString();
a359fa
+                    break;
a359fa
+                case DerSequenceReader.DerTag.UTF8String:
a359fa
+                    value = reader.ReadUtf8String();
a359fa
+                    break;
a359fa
+                case DerSequenceReader.DerTag.T61String:
a359fa
+                    value = reader.ReadT61String();
a359fa
+                    break;
a359fa
+
a359fa
+                // Ignore anything we don't know how to read.
a359fa
+            }
a359fa
+
a359fa
+            return value;
a359fa
+        }
a359fa
 
a359fa
         public void FindByTemplateName(string templateName)
a359fa
         {
a359fa
diff --git a/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/OpenSslCertificateFinder.cs b/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/OpenSslCertificateFinder.cs
a359fa
index 720c298994..717ee3753b 100644
a359fa
--- a/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/OpenSslCertificateFinder.cs
a359fa
+++ b/src/System.Security.Cryptography.X509Certificates/src/Internal/Cryptography/Pal.Unix/OpenSslCertificateFinder.cs
a359fa
@@ -13,11 +13,6 @@ namespace Internal.Cryptography.Pal
a359fa
         {
a359fa
         }
a359fa
 
a359fa
-        protected override string DerStringToManagedString(byte[] anyString)
a359fa
-        {
a359fa
-            return Interop.Crypto.DerStringToManagedString(anyString);
a359fa
-        }
a359fa
-
a359fa
         protected override byte[] GetSubjectPublicKeyInfo(X509Certificate2 cert)
a359fa
         {
a359fa
             OpenSslX509CertificateReader certPal = (OpenSslX509CertificateReader)cert.Pal;
a359fa
diff --git a/src/System.Security.Cryptography.X509Certificates/src/System.Security.Cryptography.X509Certificates.csproj b/src/System.Security.Cryptography.X509Certificates/src/System.Security.Cryptography.X509Certificates.csproj
a359fa
index 3bdef009b9..5d9e22a7f3 100644
a359fa
--- a/src/System.Security.Cryptography.X509Certificates/src/System.Security.Cryptography.X509Certificates.csproj
a359fa
+++ b/src/System.Security.Cryptography.X509Certificates/src/System.Security.Cryptography.X509Certificates.csproj
a359fa
@@ -186,9 +186,6 @@
a359fa
     <Compile Include="$(CommonPath)\Interop\Unix\System.Security.Cryptography.Native\Interop.ASN1.GetIntegerBytes.cs">
a359fa
       <Link>Common\Interop\Unix\System.Security.Cryptography.Native\Interop.ASN1.GetIntegerBytes.cs</Link>
a359fa
     </Compile>
a359fa
-    <Compile Include="$(CommonPath)\Interop\Unix\System.Security.Cryptography.Native\Interop.ASN1.Print.cs">
a359fa
-      <Link>Common\Interop\Unix\System.Security.Cryptography.Native\Interop.ASN1.Print.cs</Link>
a359fa
-    </Compile>
a359fa
     <Compile Include="$(CommonPath)\Interop\Unix\System.Security.Cryptography.Native\Interop.Bignum.cs">
a359fa
       <Link>Common\Interop\Unix\System.Security.Cryptography.Native\Interop.Bignum.cs</Link>
a359fa
     </Compile>
a359fa
-- 
a359fa
2.20.1
a359fa