mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2024-12-30 06:55:27 +00:00
f2ac1ece55
add
46 lines
1.6 KiB
C#
46 lines
1.6 KiB
C#
// Decompiled with JetBrains decompiler
|
|
// Type: Microsoft.InfoCards.RpcCryptoRequest
|
|
// 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.IO;
|
|
|
|
namespace Microsoft.InfoCards
|
|
{
|
|
internal abstract class RpcCryptoRequest
|
|
{
|
|
private RpcCryptoContext m_context;
|
|
|
|
protected RpcCryptoRequest(RpcCryptoContext context) => this.m_context = context;
|
|
|
|
public abstract string Name { get; }
|
|
|
|
public void Process()
|
|
{
|
|
MemoryStream memoryStream = new MemoryStream();
|
|
this.MarshalOutArgs((Stream) memoryStream);
|
|
byte[] buffer1 = memoryStream.GetBuffer();
|
|
byte[] buffer2;
|
|
try
|
|
{
|
|
buffer2 = NativeMcppMethods.RpcCryptoDispatchRequest(this.m_context.InterfaceHandle, this.m_context.ContextKey, this.Name, buffer1, 0, Convert.ToInt32(memoryStream.Length));
|
|
}
|
|
catch (Win32Exception ex)
|
|
{
|
|
if (ex.NativeErrorCode == -2146434962)
|
|
throw InfoCardTrace.ThrowHelperError((Exception) new UserCancelledException((string) null, (Exception) ex));
|
|
throw InfoCardTrace.ThrowHelperError((Exception) new CommunicationException((string) null, (Exception) ex));
|
|
}
|
|
this.MarshalReturnArgs((Stream) new MemoryStream(buffer2));
|
|
}
|
|
|
|
protected abstract void MarshalOutArgs(Stream stream);
|
|
|
|
protected abstract void MarshalReturnArgs(Stream stream);
|
|
}
|
|
}
|