// Decompiled with JetBrains decompiler // Type: Microsoft.InfoCards.SafeRsaProviderHandle // Assembly: infocard, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 // MVID: 516D8B44-4448-4D2C-8B8E-FFBB3FFE472B // Assembly location: C:\Users\Administrateur\Downloads\Virusshare-00000-msil\Virus.Win32.Expiro.w-69bb73081eac86b8cf86f45e33515d0095855636967076e2b593d7a30cd80a07.exe using Microsoft.InfoCards.Diagnostics; using System; using System.ComponentModel; using System.Runtime.ConstrainedExecution; using System.Runtime.InteropServices; using System.Security; namespace Microsoft.InfoCards { internal class SafeRsaProviderHandle : SafeHandle { [SuppressUnmanagedCodeSecurity] [DllImport("advapi32.dll", EntryPoint = "CryptAcquireContextW", CharSet = CharSet.Unicode, SetLastError = true)] private static extern bool CryptAcquireContext( out SafeRsaProviderHandle hProv, [In] string pszContainer, [In] string pszProvider, [In] uint dwProvType, [In] uint dwFlags); [SuppressUnmanagedCodeSecurity] [ReliabilityContract(Consistency.WillNotCorruptState, Cer.Success)] [DllImport("advapi32.dll", CharSet = CharSet.Unicode, SetLastError = true)] private static extern bool CryptReleaseContext([In] IntPtr hProv, [In] uint dwFlags); public static SafeRsaProviderHandle Construct() { SafeRsaProviderHandle hProv; if (!SafeRsaProviderHandle.CryptAcquireContext(out hProv, (string) null, (string) null, 24U, 4026531840U)) { Win32Exception e = new Win32Exception(Marshal.GetLastWin32Error()); InfoCardTrace.CloseInvalidOutSafeHandle((SafeHandle) hProv); InfoCardTrace.TraceAndLogException((Exception) e); throw InfoCardTrace.ThrowHelperError((Exception) new CommunicationException(e.Message)); } return hProv; } private SafeRsaProviderHandle() : base(IntPtr.Zero, true) { } public override bool IsInvalid => IntPtr.Zero == this.handle; protected override bool ReleaseHandle() => SafeRsaProviderHandle.CryptReleaseContext(this.handle, 0U); } }