Skip to content

Commit

Permalink
Add support for quarantine on macOS
Browse files Browse the repository at this point in the history
  • Loading branch information
Chocobo1 committed Oct 29, 2023
1 parent b4642ca commit 98576da
Show file tree
Hide file tree
Showing 5 changed files with 58 additions and 23 deletions.
4 changes: 2 additions & 2 deletions src/base/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -205,9 +205,9 @@ target_link_libraries(qbt_base
)

if (CMAKE_SYSTEM_NAME STREQUAL "Darwin")
find_library(IOKit_LIBRARY IOKit)
find_library(Carbon_LIBRARY Carbon)
find_library(AppKit_LIBRARY AppKit)
find_library(Carbon_LIBRARY Carbon)
find_library(IOKit_LIBRARY IOKit)

target_link_libraries(qbt_base PRIVATE
${AppKit_LIBRARY}
Expand Down
8 changes: 4 additions & 4 deletions src/base/bittorrent/torrentimpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -68,9 +68,9 @@
#include "peerinfo.h"
#include "sessionimpl.h"

#ifdef Q_OS_WIN
#if defined(Q_OS_MACOS) || defined(Q_OS_WIN)
#include "base/utils/misc.h"
#endif
#endif // Q_OS_MACOS || Q_OS_WIN

using namespace BitTorrent;

Expand Down Expand Up @@ -2200,14 +2200,14 @@ void TorrentImpl::handleFileCompletedAlert(const lt::file_completed_alert *p)

const Path actualPath = actualFilePath(fileIndex);

#ifdef Q_OS_WIN
#if defined(Q_OS_MACOS) || defined(Q_OS_WIN)
// only apply Mark-of-the-Web to new download files
if (isDownloading())
{
const Path fullpath = actualStorageLocation() / actualPath;
Utils::Misc::applyMarkOfTheWeb(fullpath);
}
#endif
#endif // Q_OS_MACOS || Q_OS_WIN

if (m_session->isAppendExtensionEnabled())
{
Expand Down
8 changes: 4 additions & 4 deletions src/base/net/downloadhandlerimpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -150,9 +150,9 @@ void Net::DownloadHandlerImpl::processFinishedDownload()
{
m_result.filePath = result.value();

#ifdef Q_OS_WIN
#if defined(Q_OS_MACOS) || defined(Q_OS_WIN)
Utils::Misc::applyMarkOfTheWeb(m_result.filePath, m_result.url);
#endif
#endif // Q_OS_MACOS || Q_OS_WIN
}
else
{
Expand All @@ -166,9 +166,9 @@ void Net::DownloadHandlerImpl::processFinishedDownload()
{
m_result.filePath = destinationPath;

#ifdef Q_OS_WIN
#if defined(Q_OS_MACOS) || defined(Q_OS_WIN)
Utils::Misc::applyMarkOfTheWeb(m_result.filePath, m_result.url);
#endif
#endif // Q_OS_MACOS || Q_OS_WIN
}
else
{
Expand Down
56 changes: 44 additions & 12 deletions src/base/utils/misc.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@

#ifdef Q_OS_MACOS
#include <Carbon/Carbon.h>
#include <CoreFoundation/CoreFoundation.h>
#include <CoreServices/CoreServices.h>
#endif

Expand All @@ -52,6 +53,7 @@
#include <openssl/opensslv.h>
#include <zlib.h>

#include <QtAssert>
#include <QCoreApplication>
#include <QDebug>
#include <QLocale>
Expand Down Expand Up @@ -620,10 +622,50 @@ QString Utils::Misc::zlibVersionString()
}

#ifdef Q_OS_WIN
Path Utils::Misc::windowsSystemPath()
{
static const Path path = []() -> Path
{
WCHAR systemPath[MAX_PATH] = {0};
GetSystemDirectoryW(systemPath, sizeof(systemPath) / sizeof(WCHAR));
return Path(QString::fromWCharArray(systemPath));
}();
return path;
}
#endif // Q_OS_WIN

#if defined(Q_OS_MACOS) || defined(Q_OS_WIN)
bool Utils::Misc::applyMarkOfTheWeb(const Path &file, const QString &url)
{
Q_ASSERT(url.isEmpty() || url.startsWith(u"http:") || url.startsWith(u"https:"));

#ifdef Q_OS_MACOS
// References:
// https://searchfox.org/mozilla-central/rev/ffdc4971dc18e1141cb2a90c2b0b776365650270/xpcom/io/CocoaFileUtils.mm#230
// https://github.com/transmission/transmission/blob/f62f7427edb1fd5c430e0ef6956bbaa4f03ae597/macosx/Torrent.mm#L1945-L1955

CFMutableDictionaryRef properties = ::CFDictionaryCreateMutable(kCFAllocatorDefault, 0
, &kCFTypeDictionaryKeyCallBacks, &kCFTypeDictionaryValueCallBacks);
if (properties == NULL)
return false;

::CFDictionarySetValue(properties, kLSQuarantineTypeKey, kLSQuarantineTypeOtherDownload);
if (!url.isEmpty())
::CFDictionarySetValue(properties, kLSQuarantineDataURLKey, url.toCFString());

const CFStringRef fileString = file.toString().toCFString();
const CFURLRef fileURL = ::CFURLCreateWithFileSystemPath(kCFAllocatorDefault
, fileString, kCFURLPOSIXPathStyle, false);

const Boolean success = ::CFURLSetResourcePropertyForKey(fileURL, kCFURLQuarantinePropertiesKey
, properties, NULL);

::CFRelease(fileURL);
::CFRelease(fileString);
::CFRelease(properties);

return success;
#elif defined(Q_OS_WIN)
const QString zoneIDStream = file.toString() + u":Zone.Identifier";
HANDLE handle = ::CreateFileW(zoneIDStream.toStdWString().c_str(), GENERIC_WRITE
, (FILE_SHARE_DELETE | FILE_SHARE_READ | FILE_SHARE_WRITE)
Expand All @@ -642,16 +684,6 @@ bool Utils::Misc::applyMarkOfTheWeb(const Path &file, const QString &url)
::CloseHandle(handle);

return writeResult && (written == zoneID.size());
#endif
}

Path Utils::Misc::windowsSystemPath()
{
static const Path path = []() -> Path
{
WCHAR systemPath[MAX_PATH] = {0};
GetSystemDirectoryW(systemPath, sizeof(systemPath) / sizeof(WCHAR));
return Path(QString::fromWCharArray(systemPath));
}();
return path;
}
#endif // Q_OS_WIN
#endif // Q_OS_MACOS || Q_OS_WIN
5 changes: 4 additions & 1 deletion src/base/utils/misc.h
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,6 @@ namespace Utils::Misc
QString languageToLocalizedString(const QString &localeStr);

#ifdef Q_OS_WIN
bool applyMarkOfTheWeb(const Path &file, const QString &url = {});
Path windowsSystemPath();

template <typename T>
Expand All @@ -105,4 +104,8 @@ namespace Utils::Misc
return reinterpret_cast<T>(::GetProcAddress(::LoadLibraryW(path.c_str()), funcName));
}
#endif // Q_OS_WIN

#if defined(Q_OS_MACOS) || defined(Q_OS_WIN)
bool applyMarkOfTheWeb(const Path &file, const QString &url = {});
#endif // Q_OS_MACOS || Q_OS_WIN
}

0 comments on commit 98576da

Please sign in to comment.