MalwareSourceCode/MSIL/Virus/Win32/E/Virus.Win32.Expiro.w-69bb73081eac86b8cf86f45e33515d0095855636967076e2b593d7a30cd80a07/Microsoft/InfoCards/SafeRsaProviderHandle.cs
2022-08-18 06:28:56 -05:00

55 lines
2.1 KiB
C#

// 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);
}
}