mirror of
https://github.com/rapid7/metasploit-payloads
synced 2025-01-08 14:36:22 +01:00
Fix LocalAlloc call, start on the handling of other bindings (user)
This commit is contained in:
parent
41ac07dbe0
commit
b32fd52bfd
@ -30,7 +30,8 @@ VOID MeterpreterInvoke(unsigned int isLocal, unsigned char* input, unsigned int
|
||||
if (packet.partner != NULL)
|
||||
{
|
||||
dprintf("[PSH BINDING] Response packet generated");
|
||||
*output = (unsigned char*)LocalAlloc(LHND, packet.partner->payloadLength);
|
||||
// This memory is deliberately left allocated, because the .NET side will clean it up
|
||||
*output = (unsigned char*)LocalAlloc(LPTR, packet.partner->payloadLength);
|
||||
*outputLength = packet.partner->payloadLength;
|
||||
memcpy(*output, packet.partner->payload, packet.partner->payloadLength);
|
||||
packet_destroy(packet.partner);
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -6,7 +6,7 @@
|
||||
#ifndef _METERPRETER_SOURCE_EXTENSION_POWERSHELL_RUNNER_H
|
||||
#define _METERPRETER_SOURCE_EXTENSION_POWERSHELL_RUNNER_H
|
||||
|
||||
#define PSHRUNNER_DLL_LEN 20992
|
||||
#define PSHRUNNER_DLL_LEN 22016
|
||||
|
||||
extern unsigned char PowerShellRunnerDll[PSHRUNNER_DLL_LEN];
|
||||
|
||||
|
@ -41,6 +41,7 @@
|
||||
<Compile Include="Meterpreter\Elevate.cs" />
|
||||
<Compile Include="Meterpreter\Enumerations.cs" />
|
||||
<Compile Include="Meterpreter\Core.cs" />
|
||||
<Compile Include="Meterpreter\User.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="Runner.cs" />
|
||||
<Compile Include="Meterpreter\Tlv.cs" />
|
||||
|
@ -53,6 +53,7 @@ namespace MSF.Powershell.Meterpreter
|
||||
{
|
||||
if (output != IntPtr.Zero)
|
||||
{
|
||||
System.Diagnostics.Debug.Write(string.Format("[PSH BINDINGS] Freeing up memory allocated from the C++ Binding: {0:X}", output));
|
||||
Marshal.FreeCoTaskMem(output);
|
||||
}
|
||||
}
|
||||
|
@ -44,11 +44,11 @@ namespace MSF.Powershell.Meterpreter
|
||||
}
|
||||
}
|
||||
|
||||
public static Dictionary<TlvType, List<object>> FromResponse(byte[] response, int length = 0)
|
||||
public static Dictionary<TlvType, List<object>> FromResponse(byte[] response, int start = 0, int length = 0)
|
||||
{
|
||||
var dict = new Dictionary<TlvType, List<object>>();
|
||||
|
||||
var offset = 0;
|
||||
var offset = start;
|
||||
|
||||
if (length == 0)
|
||||
{
|
||||
@ -96,6 +96,13 @@ namespace MSF.Powershell.Meterpreter
|
||||
dict[tlvType].Add(value);
|
||||
break;
|
||||
}
|
||||
case MetaType.Group:
|
||||
{
|
||||
var value = FromResponse(response, offset + 8, size);
|
||||
System.Diagnostics.Debug.Write(string.Format("Type {0} value is a dictionary of {1} elements", tlvType, value.Count));
|
||||
dict[tlvType].Add(value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
offset += size;
|
||||
|
28
powershell/MSF.Powershell/Meterpreter/User.cs
Executable file
28
powershell/MSF.Powershell/Meterpreter/User.cs
Executable file
@ -0,0 +1,28 @@
|
||||
namespace MSF.Powershell.Meterpreter
|
||||
{
|
||||
public static class User
|
||||
{
|
||||
private const string SystemSID = "S-1-5-18";
|
||||
|
||||
public static string GetUid()
|
||||
{
|
||||
System.Diagnostics.Debug.Write("[PSH BINDING] Invoking binding call GetUid");
|
||||
|
||||
Tlv tlv = new Tlv();
|
||||
|
||||
var result = Core.InvokeMeterpreterBinding(true, tlv.ToRequest("stdapi_sys_config_getuid"));
|
||||
|
||||
if (result != null)
|
||||
{
|
||||
var responseTlv = Tlv.FromResponse(result);
|
||||
if (responseTlv[TlvType.Result].Count > 0 &&
|
||||
(int)responseTlv[TlvType.Result][0] == 0)
|
||||
{
|
||||
return (string)responseTlv[TlvType.UserName][0];
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user