Bug 1233434 - Fixing download failure on a multi-user GNU/Linux machine. r?bagder draft
authorAidin Gharibnavaz <aidin@aidinhut.com>
Sat, 19 Dec 2015 22:11:00 +0330
changeset 316571 07ec362866977f37e638fc88e3079621fd7aef96
parent 315548 cb66ffeb6725e8344818e8e2f707ae2eaeb953b4
child 512179 c117bb3820fc8dec569f216ae073206beac50304
push id8567
push useraidin@aidinhut.com
push dateSat, 19 Dec 2015 18:41:46 +0000
reviewersbagder
bugs1233434
milestone46.0a1
Bug 1233434 - Fixing download failure on a multi-user GNU/Linux machine. r?bagder
uriloader/exthandler/nsExternalHelperAppService.cpp
--- a/uriloader/exthandler/nsExternalHelperAppService.cpp
+++ b/uriloader/exthandler/nsExternalHelperAppService.cpp
@@ -411,22 +411,22 @@ static nsresult GetDownloadDirectory(nsI
   PRUint32 permissions;
   rv = dir->GetPermissions(&permissions);
   NS_ENSURE_SUCCESS(rv, rv);
 
   if (permissions != PR_IRWXU) {
     const char* userName = PR_GetEnv("USERNAME");
     if (!userName || !*userName) {
       userName = PR_GetEnv("USER");
-      if (!userName || !*userName) {
-        userName = PR_GetEnv("LOGNAME");
-      }
-      else {
-        userName = "mozillaUser";
-      }
+    }
+    if (!userName || !*userName) {
+      userName = PR_GetEnv("LOGNAME");
+    }
+    if (!userName || !*userName) {
+      userName = "mozillaUser";
     }
 
     nsAutoString userDir;
     userDir.AssignLiteral("mozilla_");
     userDir.AppendASCII(userName);
     userDir.ReplaceChar(FILE_PATH_SEPARATOR FILE_ILLEGAL_CHARACTERS, '_');
 
     int counter = 0;
@@ -442,17 +442,22 @@ static nsresult GetDownloadDirectory(nsI
       rv = finalPath->Exists(&pathExists);
       NS_ENSURE_SUCCESS(rv, rv);
 
       if (pathExists) {
         // If this path has the right permissions, use it.
         rv = finalPath->GetPermissions(&permissions);
         NS_ENSURE_SUCCESS(rv, rv);
 
-        if (permissions == PR_IRWXU) {
+        // Ensuring the path is writable by the current user.
+        bool isWritable;
+        rv = finalPath->IsWritable(&isWritable);
+        NS_ENSURE_SUCCESS(rv, rv);
+
+        if (permissions == PR_IRWXU && isWritable) {
           dir = finalPath;
           break;
         }
       }
 
       rv = finalPath->Create(nsIFile::DIRECTORY_TYPE, PR_IRWXU);
       if (NS_SUCCEEDED(rv)) {
         dir = finalPath;