- added new event checks - Explicit Logon Events, Logon Events, PowerShell Events, Process Creation Events - added PrintSecurityPackagesCredentials check - added Windows Defender enumeration
65 lines
2.8 KiB
C#
65 lines
2.8 KiB
C#
using System;
|
|
using System.Runtime.ConstrainedExecution;
|
|
using System.Runtime.InteropServices;
|
|
using winPEAS.Info.SystemInfo.NamedPipes;
|
|
|
|
namespace winPEAS.Native
|
|
{
|
|
internal class Kernel32
|
|
{
|
|
//[DllImport("kernel32.dll", SetLastError = true)]
|
|
//[return: MarshalAs(UnmanagedType.Bool)]
|
|
//internal static extern bool CloseHandle(IntPtr hObject);
|
|
|
|
[DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
|
|
internal static extern IntPtr FindFirstFile(string lpFileName, out NamedPipes.WIN32_FIND_DATA lpFindFileData);
|
|
|
|
[DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
|
|
internal static extern bool FindNextFile(IntPtr hFindFile, out NamedPipes.WIN32_FIND_DATA
|
|
lpFindFileData);
|
|
|
|
[DllImport("kernel32.dll", SetLastError = true)]
|
|
internal static extern bool FindClose(IntPtr hFindFile);
|
|
|
|
[DllImport("kernel32.dll")]
|
|
internal static extern IntPtr LoadLibrary(string dllFilePath);
|
|
|
|
[DllImport("kernel32", CharSet = CharSet.Ansi, ExactSpelling = true, SetLastError = true)]
|
|
internal static extern IntPtr GetProcAddress(IntPtr hModule, string procName);
|
|
|
|
|
|
[ReliabilityContract(Consistency.WillNotCorruptState, Cer.Success), DllImport("Kernel32.dll", SetLastError = true)]
|
|
[return: MarshalAs(UnmanagedType.Bool)]
|
|
internal static extern bool CloseHandle(IntPtr handle);
|
|
|
|
[DllImport("Kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
|
|
internal static extern IntPtr GetCurrentProcess();
|
|
|
|
[DllImport("Kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
|
|
internal static extern IntPtr GetCurrentThread();
|
|
|
|
/// <summary>
|
|
/// The GlobalLock function locks a global memory object and returns a pointer to the first byte of the object's memory block.
|
|
/// GlobalLock function increments the lock count by one.
|
|
/// Needed for the clipboard functions when getting the data from IDataObject
|
|
/// </summary>
|
|
/// <param name="hMem"></param>
|
|
/// <returns></returns>
|
|
[DllImport("Kernel32.dll", SetLastError = true)]
|
|
internal static extern IntPtr GlobalLock(IntPtr hMem);
|
|
|
|
/// <summary>
|
|
/// The GlobalUnlock function decrements the lock count associated with a memory object.
|
|
/// </summary>
|
|
/// <param name="hMem"></param>
|
|
/// <returns></returns>
|
|
[DllImport("Kernel32.dll", SetLastError = true)]
|
|
[return: MarshalAs(UnmanagedType.Bool)]
|
|
internal static extern bool GlobalUnlock(IntPtr hMem);
|
|
|
|
[DllImport("Kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
|
|
[return: MarshalAs(UnmanagedType.Bool)]
|
|
internal static extern bool FreeLibrary(IntPtr lib);
|
|
}
|
|
}
|