Selaa lähdekoodia

Logging SHA-256 of WinSCP.exe, when its product version does not match .NET assembly

Source commit: d5dcb74d034e2d16c0383cab41707da7131d2bc1
Martin Prikryl 5 vuotta sitten
vanhempi
sitoutus
8b3bcbd3ff
1 muutettua tiedostoa jossa 16 lisäystä ja 0 poistoa
  1. 16 0
      dotnet/internal/ExeSessionProcess.cs

+ 16 - 0
dotnet/internal/ExeSessionProcess.cs

@@ -11,6 +11,7 @@ using System.Reflection;
 using System.Security.Principal;
 using System.Security.AccessControl;
 using System.ComponentModel;
+using System.Security.Cryptography;
 
 namespace WinSCP
 {
@@ -1055,6 +1056,21 @@ namespace WinSCP
                     }
                     else if (assemblyVersion.ProductVersion != version.ProductVersion)
                     {
+                        try
+                        {
+                            using (SHA256 SHA256 = SHA256.Create())
+                            using (FileStream stream = File.OpenRead(exePath))
+                            {
+                                string sha256 = Convert.ToBase64String(SHA256.ComputeHash(stream));
+                                _logger.WriteLine($"SHA-256 of the executable file is {sha256}");
+                            }
+                        }
+                        catch (Exception e)
+                        {
+                            _logger.WriteLine("Calculating SHA-256 of the executable file failed");
+                            _logger.WriteException(e);
+                        }
+
                         string message;
                         if (string.IsNullOrEmpty(version.ProductVersion) && (accessException != null))
                         {