// Decompiled with JetBrains decompiler // Type: Microsoft.InfoCards.SafeRsaProviderHandle // Assembly: infocard, Version=3.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 // MVID: ADE0A079-11DB-4A46-8BDE-D2A592CA8DEA // Assembly location: C:\Users\Administrateur\Downloads\Virusshare-00000-msil\Virus.Win32.Expiro.w-67b630ead60119692b9abbdfd8717c96904ef041127c2cae033c86b718eaa61e.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); } }