mirror of
https://github.com/JakubMelka/PDF4QT.git
synced 2024-12-29 09:40:26 +01:00
Issue #110: PDF4QT Viewer Lite : Arbitrary Code can execute when using Send by Email
This commit is contained in:
parent
851374dc73
commit
ff6dd4b249
@ -41,8 +41,22 @@ bool PDFSendMail::sendMail(QWidget* parent, QString subject, QString fileName)
|
||||
std::wstring fileNameString = fileInfo.fileName().toStdWString();
|
||||
std::wstring filePathString = QDir::toNativeSeparators(fileInfo.absoluteFilePath()).toStdWString();
|
||||
|
||||
std::array<wchar_t, MAX_PATH> systemDirectoryBuffer = { };
|
||||
if (!::GetSystemDirectoryW(systemDirectoryBuffer.data(), uint(systemDirectoryBuffer.size())))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
HMODULE mapiLib = ::LoadLibrary(L"MAPI32.DLL");
|
||||
QString systemDirectory = QString::fromWCharArray(systemDirectoryBuffer.data());
|
||||
QString mapiDllPath = QString("%1\\MAPI32.dll").arg(systemDirectory);
|
||||
QFileInfo mapiDllPathInfo(mapiDllPath);
|
||||
QString mapiDllPathCorrected = mapiDllPathInfo.absoluteFilePath();
|
||||
|
||||
std::vector<wchar_t> mapiDllPathWchar(mapiDllPathCorrected.size() + 1);
|
||||
qsizetype length = mapiDllPathCorrected.toWCharArray(mapiDllPathWchar.data());
|
||||
mapiDllPathWchar[length] = 0;
|
||||
|
||||
HMODULE mapiLib = ::LoadLibraryW(mapiDllPathWchar.data());
|
||||
if (!mapiLib)
|
||||
{
|
||||
return false;
|
||||
|
Loading…
Reference in New Issue
Block a user