summaryrefslogtreecommitdiff
path: root/sal/osl/unx/security.cxx
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2014-04-02 10:42:34 +0200
committerStephan Bergmann <sbergman@redhat.com>2014-04-02 10:43:21 +0200
commit6cd87e5ee27af05cf54ba56d06f519a8f7138e8a (patch)
tree59b8ab0633eea130cc89f565bba52ec554e57564 /sal/osl/unx/security.cxx
parentd37e9645edbdabaaf16ce0f1f904405f3477dc41 (diff)
coverity#1194930 Avoid TOCTOU between access and mkdir
Change-Id: I6567313abdacd06b59f7004c970b954a4b42419e
Diffstat (limited to 'sal/osl/unx/security.cxx')
-rw-r--r--sal/osl/unx/security.cxx26
1 files changed, 18 insertions, 8 deletions
diff --git a/sal/osl/unx/security.cxx b/sal/osl/unx/security.cxx
index 77764b5caed5..d2b1c1d99718 100644
--- a/sal/osl/unx/security.cxx
+++ b/sal/osl/unx/security.cxx
@@ -25,6 +25,7 @@
#include <osl/security.h>
#include <osl/diagnose.h>
#include <rtl/bootstrap.h>
+#include <sal/log.hxx>
#include "osl/thread.h"
#include "osl/file.h"
@@ -395,7 +396,6 @@ static sal_Bool SAL_CALL osl_psz_getConfigDir(oslSecurity Security, sal_Char* ps
if (pStr == NULL || strlen(pStr) == 0 || access(pStr, 0) != 0)
{
size_t n = 0;
- sal_Bool dirOK = sal_True;
// a default equal to $HOME/.config should be used.
if (!osl_psz_getHomeDir(Security, pszDirectory, nMax))
@@ -406,34 +406,44 @@ static sal_Bool SAL_CALL osl_psz_getConfigDir(oslSecurity Security, sal_Char* ps
strncpy(pszDirectory+n, DOT_CONFIG, sizeof(DOT_CONFIG));
// try to create dir if not present
- if (access(pszDirectory, F_OK) != 0 && mkdir(pszDirectory, S_IRWXU) != 0)
- dirOK = sal_False;
- else
+ bool dirOK = true;
+ if (mkdir(pszDirectory, S_IRWXU) != 0)
+ {
+ int e = errno;
+ if (e != EEXIST)
+ {
+ SAL_WARN(
+ "sal.osl",
+ "mkdir(" << pszDirectory << "): errno=" << e);
+ dirOK = false;
+ }
+ }
+ if (dirOK)
{
// check file type and permissions
struct stat st;
if (stat(pszDirectory, &st) != 0)
{
OSL_TRACE("Could not stat $HOME/.config");
- dirOK = sal_False;
+ dirOK = false;
}
else
{
if (!S_ISDIR(st.st_mode))
{
OSL_TRACE("$HOME/.config is not a directory");
- dirOK = sal_False;
+ dirOK = false;
}
if (!(st.st_mode & S_IRUSR && st.st_mode & S_IWUSR && st.st_mode & S_IXUSR))
{
OSL_TRACE("$HOME/.config has bad permissions");
- dirOK = sal_False;
+ dirOK = false;
}
}
}
// resort to HOME
- if (dirOK == sal_False)
+ if (!dirOK)
pszDirectory[n] = '\0';
}
}