-
Notifications
You must be signed in to change notification settings - Fork 192
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit aef7e6b
Showing
89 changed files
with
41,235 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,187 @@ | ||
/* Benjamin DELPY `gentilkiwi` | ||
http://blog.gentilkiwi.com | ||
[email protected] | ||
With BIG thanks and love to: | ||
- @msuiche <3 | ||
- @halsten | ||
- @malwareunicorn | ||
- @adriengnt (https://github.com/aguinet/wannakey) | ||
This guy discovered how to retrieve prime numbers of the private key when it's not possible to get it in a normal way | ||
He rocks \o/ - I was unable to fix his code where the Private Key is malformed, so I made it here with OpenSSL lib :) | ||
.. Just to help ... | ||
Licence : https://creativecommons.org/licenses/by/4.0/ | ||
*/ | ||
#include "fileutil.h" | ||
|
||
BOOL kull_m_file_getCurrentDirectory(wchar_t ** ppDirName) | ||
{ | ||
BOOL reussite = FALSE; | ||
DWORD tailleRequise = GetCurrentDirectory(0, NULL); | ||
if(*ppDirName = (wchar_t *) LocalAlloc(LPTR, tailleRequise * sizeof(wchar_t))) | ||
if(!(reussite = (tailleRequise > 0 && (GetCurrentDirectory(tailleRequise, *ppDirName) == tailleRequise - 1)))) | ||
LocalFree(*ppDirName); | ||
|
||
return reussite; | ||
} | ||
|
||
BOOL kull_m_file_getAbsolutePathOf(PCWCHAR thisData, wchar_t ** reponse) | ||
{ | ||
BOOL reussite = FALSE; | ||
wchar_t *monRep; | ||
*reponse = (wchar_t *) LocalAlloc(LPTR, MAX_PATH); | ||
|
||
if(PathIsRelative(thisData)) | ||
{ | ||
if(kull_m_file_getCurrentDirectory(&monRep)) | ||
{ | ||
reussite = (PathCombine(*reponse , monRep, thisData) != NULL); | ||
LocalFree(monRep); | ||
} | ||
} | ||
else | ||
reussite = PathCanonicalize(*reponse, thisData); | ||
|
||
if(!reussite) | ||
LocalFree(*reponse); | ||
|
||
return reussite; | ||
} | ||
|
||
BOOL kull_m_file_isFileExist(PCWCHAR fileName) | ||
{ | ||
BOOL reussite = FALSE; | ||
HANDLE hFile = NULL; | ||
|
||
reussite = ((hFile = CreateFile(fileName, 0, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, NULL)) && hFile != INVALID_HANDLE_VALUE); | ||
if(reussite) | ||
CloseHandle(hFile); | ||
return reussite; | ||
} | ||
|
||
BOOL kull_m_file_writeData(PCWCHAR fileName, LPCVOID data, DWORD lenght) | ||
{ | ||
BOOL reussite = FALSE; | ||
DWORD dwBytesWritten = 0; | ||
HANDLE hFile = NULL; | ||
if((hFile = CreateFile(fileName, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, 0, NULL)) && hFile != INVALID_HANDLE_VALUE) | ||
{ | ||
if(WriteFile(hFile, data, lenght, &dwBytesWritten, NULL) && (lenght == dwBytesWritten)) | ||
reussite = FlushFileBuffers(hFile); | ||
CloseHandle(hFile); | ||
} | ||
return reussite; | ||
} | ||
|
||
BOOL kull_m_file_readData(PCWCHAR fileName, PBYTE * data, PDWORD lenght) // for ""little"" files ! | ||
{ | ||
BOOL reussite = FALSE; | ||
DWORD dwBytesReaded; | ||
LARGE_INTEGER filesize; | ||
HANDLE hFile = NULL; | ||
if((hFile = CreateFile(fileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, NULL)) && hFile != INVALID_HANDLE_VALUE) | ||
{ | ||
if(GetFileSizeEx(hFile, &filesize) && !filesize.HighPart) | ||
{ | ||
*lenght = filesize.LowPart; | ||
if(*data = (PBYTE) LocalAlloc(LPTR, *lenght)) | ||
{ | ||
if(!(reussite = ReadFile(hFile, *data, *lenght, &dwBytesReaded, NULL) && (*lenght == dwBytesReaded))) | ||
LocalFree(*data); | ||
} | ||
} | ||
CloseHandle(hFile); | ||
} | ||
return reussite; | ||
} | ||
|
||
const wchar_t kull_m_file_forbiddenChars[] = {L'\\', L'/', L':', L'*', L'?', L'\"', L'<', L'>', L'|'}; | ||
void kull_m_file_cleanFilename(PWCHAR fileName) | ||
{ | ||
DWORD i, j; | ||
for(i = 0; fileName[i]; i++) | ||
for(j = 0; j < ARRAYSIZE(kull_m_file_forbiddenChars); j++) | ||
if(fileName[i] == kull_m_file_forbiddenChars[j]) | ||
fileName[i] = L'~'; | ||
} | ||
|
||
PWCHAR kull_m_file_fullPath(PCWCHAR fileName) | ||
{ | ||
PWCHAR buffer = NULL; | ||
DWORD bufferLen; | ||
if(fileName) | ||
if(bufferLen = ExpandEnvironmentStrings(fileName, NULL, 0)) | ||
if(buffer = (PWCHAR) LocalAlloc(LPTR, bufferLen * sizeof(wchar_t))) | ||
if(bufferLen != ExpandEnvironmentStrings(fileName, buffer, bufferLen)) | ||
buffer = (PWCHAR) LocalFree(buffer); | ||
return buffer; | ||
} | ||
|
||
BOOL kull_m_file_Find(PCWCHAR directory, PCWCHAR filter, BOOL isRecursive /*TODO*/, DWORD level, BOOL isPrintInfos, PKULL_M_FILE_FIND_CALLBACK callback, PVOID pvArg) | ||
{ | ||
BOOL status = FALSE, bFind = FALSE; | ||
DWORD dwAttrib; | ||
HANDLE hFind; | ||
WIN32_FIND_DATA fData; | ||
PWCHAR fullpath; | ||
|
||
dwAttrib = GetFileAttributes(directory); | ||
if((dwAttrib != INVALID_FILE_ATTRIBUTES) && (dwAttrib & FILE_ATTRIBUTE_DIRECTORY)) | ||
{ | ||
if(isPrintInfos && !level) | ||
{ | ||
kprintf(L"%*s" L"Directory \'%s\'", level << 1, L"", directory); | ||
if(filter) | ||
kprintf(L" (%s)", filter); | ||
kprintf(L"\n"); | ||
} | ||
if(fullpath = (wchar_t *) LocalAlloc(LPTR, MAX_PATH * sizeof(wchar_t))) | ||
{ | ||
if(wcscpy_s(fullpath, MAX_PATH, directory) == 0) | ||
{ | ||
if(wcscat_s(fullpath, MAX_PATH, L"\\") == 0) | ||
{ | ||
if(wcscat_s(fullpath, MAX_PATH, filter ? filter : L"*") == 0) | ||
{ | ||
hFind = FindFirstFile(fullpath, &fData); | ||
if(hFind != INVALID_HANDLE_VALUE) | ||
{ | ||
do | ||
{ | ||
if(_wcsicmp(fData.cFileName, L".") && _wcsicmp(fData.cFileName, L"..")) | ||
{ | ||
if(wcscpy_s(fullpath, MAX_PATH, directory) == 0) | ||
{ | ||
if(wcscat_s(fullpath, MAX_PATH, L"\\") == 0) | ||
{ | ||
dwAttrib = (DWORD) wcslen(fullpath); | ||
if(wcscat_s(fullpath, MAX_PATH, fData.cFileName) == 0) | ||
{ | ||
if(isPrintInfos) | ||
kprintf(L"%*s" L"%3u %c|'%s\'\n", level << 1, L"", level, (fData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) ? L'D' : L'F' , fData.cFileName); | ||
|
||
if(!(fData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)) | ||
{ | ||
if(callback) | ||
status = callback(level, fullpath, fullpath + dwAttrib, pvArg); | ||
|
||
} | ||
else if(isRecursive && fData.cFileName) | ||
status = kull_m_file_Find(fullpath, filter, TRUE, level + 1, isPrintInfos, callback, pvArg); | ||
} | ||
} | ||
} | ||
} | ||
} while(!status && FindNextFile(hFind, &fData)); | ||
FindClose(hFind); | ||
} | ||
} | ||
} | ||
} | ||
} | ||
LocalFree(fullpath); | ||
} | ||
return status; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
/* Benjamin DELPY `gentilkiwi` | ||
http://blog.gentilkiwi.com | ||
[email protected] | ||
With BIG thanks and love to: | ||
- @msuiche <3 | ||
- @halsten | ||
- @malwareunicorn | ||
- @adriengnt (https://github.com/aguinet/wannakey) | ||
This guy discovered how to retrieve prime numbers of the private key when it's not possible to get it in a normal way | ||
He rocks \o/ - I was unable to fix his code where the Private Key is malformed, so I made it here with OpenSSL lib :) | ||
.. Just to help ... | ||
Licence : https://creativecommons.org/licenses/by/4.0/ | ||
*/ | ||
#pragma once | ||
#include "globals.h" | ||
|
||
typedef BOOL (CALLBACK * PKULL_M_FILE_FIND_CALLBACK) (DWORD level, PCWCHAR fullpath, PCWCHAR path, PVOID pvArg); | ||
|
||
BOOL kull_m_file_getCurrentDirectory(wchar_t ** ppDirName); | ||
BOOL kull_m_file_getAbsolutePathOf(PCWCHAR thisData, wchar_t ** reponse); | ||
BOOL kull_m_file_isFileExist(PCWCHAR fileName); | ||
BOOL kull_m_file_writeData(PCWCHAR fileName, LPCVOID data, DWORD lenght); | ||
BOOL kull_m_file_readData(PCWCHAR fileName, PBYTE * data, PDWORD lenght); // for 'little' files ! | ||
void kull_m_file_cleanFilename(PWCHAR fileName); | ||
PWCHAR kull_m_file_fullPath(PCWCHAR fileName); | ||
BOOL kull_m_file_Find(PCWCHAR directory, PCWCHAR filter, BOOL isRecursive /*TODO*/, DWORD level, BOOL isPrintInfos, PKULL_M_FILE_FIND_CALLBACK callback, PVOID pvArg); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
/* Benjamin DELPY `gentilkiwi` | ||
http://blog.gentilkiwi.com | ||
[email protected] | ||
With BIG thanks and love to: | ||
- @msuiche <3 | ||
- @halsten | ||
- @malwareunicorn | ||
- @adriengnt (https://github.com/aguinet/wannakey) | ||
This guy discovered how to retrieve prime numbers of the private key when it's not possible to get it in a normal way | ||
He rocks \o/ - I was unable to fix his code where the Private Key is malformed, so I made it here with OpenSSL lib :) | ||
.. Just to help ... | ||
Licence : https://creativecommons.org/licenses/by/4.0/ | ||
*/ | ||
#pragma once | ||
#include <ntstatus.h> | ||
#define WIN32_NO_STATUS | ||
#include <Windows.h> | ||
#include <stdio.h> | ||
#include <Shlwapi.h> | ||
|
||
#include "fileutil.h" | ||
#include "process.h" | ||
|
||
#define WANA_PUBKEY_FILE L"00000000.pky" | ||
#define WANA_PRIKEY_FILE L"00000000.dky" | ||
#define WANA_FILE_EXT L".WNCRY" | ||
|
||
|
||
#ifndef NT_SUCCESS | ||
#define NT_SUCCESS(Status) ((NTSTATUS)(Status) >= 0) | ||
#endif | ||
|
||
#define kprintf wprintf | ||
|
||
#ifndef PRINT_ERROR | ||
#define PRINT_ERROR(...) (kprintf(L"ERROR " TEXT(__FUNCTION__) L" ; " __VA_ARGS__)) | ||
#endif | ||
|
||
#ifndef PRINT_ERROR_AUTO | ||
#define PRINT_ERROR_AUTO(func) (kprintf(L"ERROR " TEXT(__FUNCTION__) L" ; " func L" (0x%08x)\n", GetLastError())) | ||
#endif | ||
|
||
#ifndef W00T | ||
#define W00T(...) (kprintf(TEXT(__FUNCTION__) L" w00t! ; " __VA_ARGS__)) | ||
#endif |
Oops, something went wrong.