-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcertvalidate-common.csx
55 lines (48 loc) · 1.61 KB
/
certvalidate-common.csx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
using System.Security.Cryptography.X509Certificates;
using System.Text.RegularExpressions;
private static byte[] ConvertPEMtoDER(byte[] pemData)
{
// strips ---HEADERS--- then base64-decodes the PEM body to arrive at the
// DER-encoded certificate data
string b64String = Encoding.UTF8.GetString(pemData);
b64String = Regex.Replace(b64String, "-+BEGIN CERTIFICATE-+", "");
b64String = Regex.Replace(b64String, "-+END CERTIFICATE-+", "");
return Convert.FromBase64String(b64String.Trim());
}
private static X509Certificate2 LoadCertificateFromFile(string certificatePath)
{
byte[] derData;
if (certificatePath.EndsWith(".pem"))
{
var pemData = File.ReadAllBytes(certificatePath);
derData = ConvertPEMtoDER(pemData);
}
else {
// Already using a DER-formatted certificate
derData = File.ReadAllBytes(certificatePath);
}
return new X509Certificate2(derData);
}
private static void PrintX509VerificationResults(bool isVerified, X509Chain chain)
{
Console.WriteLine($"X509Chain.Build() verification: {isVerified}\n");
if (chain.ChainStatus.Length == 0)
{
Console.WriteLine("Chain status: N/A (no flags)");
}
else
{
Console.WriteLine("Chain status:");
foreach (var status in chain.ChainStatus)
{
Console.WriteLine($"- {status.Status}: {status.StatusInformation}");
}
Console.WriteLine();
}
Console.WriteLine("Chain elements:");
foreach (var element in chain.ChainElements)
{
Console.WriteLine($"- {element.Certificate.Thumbprint} ({element.Certificate.Subject}, expiry {element.Certificate.GetExpirationDateString()})");
}
Console.WriteLine();
}