Taint installed apps until the directory is selected
authorTim Düsterhus <duesterhus@woltlab.com>
Tue, 9 Mar 2021 09:41:33 +0000 (10:41 +0100)
committerTim Düsterhus <duesterhus@woltlab.com>
Tue, 9 Mar 2021 09:55:02 +0000 (10:55 +0100)
The row in wcf1_application is created very early in the installation process,
even before the application directory is selected. This causes it to contain
bogus data. Now when pressing F5 during the folder section for whatever reason
the application technically is installed, but it's not usable due to the
missing XXXCore class. When the cache is being cleared this will brick the
whole community.

Taint apps until a proper application directory is selected. This reduces the
time window for human error, because it's likely that the `file` PIP runs very
soon after.

wcfsetup/install/files/lib/system/package/PackageInstallationDispatcher.class.php

index e2621d57c0b5d1d774dbae771a0c2eb6c2074d65..29ab84f96ad968a3cf043f7446819fb835951590 100644 (file)
@@ -527,7 +527,8 @@ class PackageInstallationDispatcher {
                                        'domainName' => $host,
                                        'domainPath' => $path,
                                        'cookieDomain' => $host,
-                                       'packageID' => $package->packageID
+                                       'packageID' => $package->packageID,
+                                       'isTainted' => 1,
                                ]);
                        }
                }
@@ -960,10 +961,13 @@ class PackageInstallationDispatcher {
                                
                                $domainPath = FileUtil::addLeadingSlash($domainPath);
                                
-                               // update application path
+                               // update application path and untaint application
                                $application = new Application($this->getPackage()->packageID);
                                $applicationEditor = new ApplicationEditor($application);
-                               $applicationEditor->update(['domainPath' => $domainPath]);
+                               $applicationEditor->update([
+                                       'domainPath' => $domainPath,
+                                       'isTainted' => 0,
+                               ]);
                                
                                // create directory and set permissions
                                @mkdir($packageDir, 0777, true);