From a3af773faaac114c30db5784ba2d663c77d3d5bf Mon Sep 17 00:00:00 2001 From: Stefan Hundhammer Date: Sun, 4 Jun 2017 16:28:51 +0200 Subject: [PATCH] Check dir exec + read permissions before reading --- src/DirReadJob.cpp | 34 +++++++++++++++++++++++++--------- 1 file changed, 25 insertions(+), 9 deletions(-) diff --git a/src/DirReadJob.cpp b/src/DirReadJob.cpp index 5cf28db8..27b6c085 100644 --- a/src/DirReadJob.cpp +++ b/src/DirReadJob.cpp @@ -11,7 +11,6 @@ #include #include #include -#include #include @@ -163,7 +162,31 @@ void LocalDirReadJob::startReading() // logDebug() << _dir << endl; - if ( ( _diskDir = opendir( dirName.toUtf8() ) ) ) + bool ok = true; + + if ( access( dirName.toUtf8(), X_OK | R_OK ) != 0 ) + { + ok = false; + logWarning() << "No permission to read directory " << dirName << endl; + _dir->setReadState( DirError ); + finishReading( _dir ); + } + + if ( ok ) + { + _diskDir = opendir( dirName.toUtf8() ); + + if ( ! _diskDir ) + { + ok = false; + _dir->setReadState( DirError ); + logWarning() << "opendir(" << dirName << ") failed" << endl; + // opendir() doesn't set 'errno' according to POSIX :-( + finishReading( _dir ); + } + } + + if ( ok ) { _dir->setReadState( DirReading ); @@ -301,13 +324,6 @@ void LocalDirReadJob::startReading() _dir->setReadState( DirFinished ); finishReading( _dir ); } - else - { - _dir->setReadState( DirError ); - logWarning() << "opendir(" << dirName << ") failed" << endl; - // opendir() doesn't set 'errno' according to POSIX :-( - finishReading( _dir ); - } finished(); // Don't add anything after finished() since this deletes this job!