Skip to content

Commit

Permalink
79e52ea Check path validity on Windows will validate NTFS permissions…
Browse files Browse the repository at this point in the history
… for network drives.

Signed-off-by: Alkl58 <[email protected]>
  • Loading branch information
Alkl58 authored and allexzander committed Nov 8, 2023
1 parent 6dd72cb commit a52fd47
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 13 deletions.
2 changes: 2 additions & 0 deletions src/common/utility.h
Original file line number Diff line number Diff line change
Expand Up @@ -275,6 +275,8 @@ namespace Utility {

OCSYNC_EXPORT QString formatWinError(long error);

OCSYNC_EXPORT bool canCreateFile(const QString &filePath);

class OCSYNC_EXPORT NtfsPermissionLookupRAII
{
public:
Expand Down
13 changes: 13 additions & 0 deletions src/common/utility_win.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -430,6 +430,19 @@ void Utility::UnixTimeToLargeIntegerFiletime(time_t t, LARGE_INTEGER *hundredNSe
hundredNSecs->HighPart = ll >>32;
}

bool Utility::canCreateFile(const QString &filePath)
{
Q_ASSERT(!filePath.isEmpty());
QFile testFile(filePath);
if (!testFile.open(QIODevice::WriteOnly)) {
return false;
}
testFile.close();
if (!testFile.remove()) {
return false;
}
return true;
}

QString Utility::formatWinError(long errorCode)
{
Expand Down
19 changes: 6 additions & 13 deletions src/gui/folderman.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1704,17 +1704,11 @@ static QString checkPathValidityRecursive(const QString &path)
#ifdef Q_OS_WIN
if (!selFile.isWritable()) {
// isWritable() doesn't cover all NTFS permissions
// Try write
const auto testPath = selFile.dir().filePath("nextcloud-write-test-file.txt");
const auto fp = fopen(testPath.toStdWString().c_str(), "w");
if (!fp) {
return FolderMan::tr("You have no permission to write to the selected folder!");
}
fclose(fp);

// Try delete
const auto rc = remove(testPath.toStdWString().c_str());
if (rc) {
// try creating and removing a test file, and make sure it is excluded from sync
const QString pathWithSlash = !path.endsWith(QLatin1Char('/')) ? path + QLatin1Char('/') : path;
const QString testFileName = pathWithSlash + QStringLiteral("~$%1-write-test-file-%2").arg(OCC::Theme::instance()->appNameGUI())
.arg(QDateTime::currentDateTime().toMSecsSinceEpoch());
if (!Utility::canCreateFile(testFileName)) {
return FolderMan::tr("You have no permission to write to the selected folder!");
}
}
Expand All @@ -1723,8 +1717,7 @@ static QString checkPathValidityRecursive(const QString &path)
return FolderMan::tr("You have no permission to write to the selected folder!");
}
#endif

return QString();
return {};
}

// QFileInfo::canonicalPath returns an empty string if the file does not exist.
Expand Down

0 comments on commit a52fd47

Please sign in to comment.