gecko-dev/toolkit/xre/ProfileReset.h
Nick Alexander bf2b677248 Bug 1736876 - Stop migrating profiles into App Package builds. r=agashlin
The product experience migrating a profile when a non-MSIX Firefox is
running is not ideal, so we're going to always start with a fresh
profile for simplicity.

This is a straight backout of the "meat" of Bug 1709969 - Migrate from
an existing profile when running from an app package for the first
time, namely `hg backout -r 5136d2f684012dc3d586dcb10374f8c6eda8b6d7`.
The changes from follow-up Bug 1723298 (correcting test failures on
devedition), namely revision a4bca433c8f7003a90fda61248f38d9b389c394e,
were manually reverted and the test files deleted.

Differential Revision: https://phabricator.services.mozilla.com/D129066
2021-10-20 21:54:07 +00:00

85 lines
3.0 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "nsToolkitProfileService.h"
#include "nsIFile.h"
#include "nsIThread.h"
#include "nsThreadUtils.h"
static bool gProfileResetCleanupCompleted = false;
static const char kResetProgressURL[] =
"chrome://global/content/resetProfileProgress.xhtml";
nsresult ProfileResetCleanup(nsToolkitProfileService* aService,
nsIToolkitProfile* aOldProfile);
class ProfileResetCleanupResultTask : public mozilla::Runnable {
public:
ProfileResetCleanupResultTask()
: mozilla::Runnable("ProfileResetCleanupResultTask"),
mWorkerThread(do_GetCurrentThread()) {
MOZ_ASSERT(!NS_IsMainThread());
}
NS_IMETHOD Run() override {
MOZ_ASSERT(NS_IsMainThread());
mWorkerThread->Shutdown();
return NS_OK;
}
private:
nsCOMPtr<nsIThread> mWorkerThread;
};
class ProfileResetCleanupAsyncTask : public mozilla::Runnable {
public:
ProfileResetCleanupAsyncTask(nsIFile* aProfileDir, nsIFile* aProfileLocalDir,
nsIFile* aTargetDir, const nsAString& aLeafName)
: mozilla::Runnable("ProfileResetCleanupAsyncTask"),
mProfileDir(aProfileDir),
mProfileLocalDir(aProfileLocalDir),
mTargetDir(aTargetDir),
mLeafName(aLeafName) {}
/**
* Copy a root profile to a backup folder before deleting it. Then delete the
* local profile dir.
*/
NS_IMETHOD Run() override {
// Copy profile's files to the destination. The profile folder will be
// removed after the changes to the known profiles have been flushed to disk
// in nsToolkitProfileService::ApplyResetProfile which isn't called until
// after this thread finishes copying the files.
nsresult rv = mProfileDir->CopyToFollowingLinks(mTargetDir, mLeafName);
// I guess we just warn if we fail to make the backup?
if (NS_WARN_IF(NS_FAILED(rv))) {
NS_WARNING("Could not backup the root profile directory");
}
// If we have a separate local cache profile directory, just delete it.
// Don't return an error if this fails so that reset can proceed if it can't
// be deleted.
bool sameDir;
nsresult rvLocal = mProfileDir->Equals(mProfileLocalDir, &sameDir);
if (NS_SUCCEEDED(rvLocal) && !sameDir) {
rvLocal = mProfileLocalDir->Remove(true);
if (NS_FAILED(rvLocal)) {
NS_WARNING("Could not remove the old local profile directory (cache)");
}
}
gProfileResetCleanupCompleted = true;
nsCOMPtr<nsIRunnable> resultRunnable = new ProfileResetCleanupResultTask();
NS_DispatchToMainThread(resultRunnable);
return NS_OK;
}
private:
nsCOMPtr<nsIFile> mProfileDir;
nsCOMPtr<nsIFile> mProfileLocalDir;
nsCOMPtr<nsIFile> mTargetDir;
nsString mLeafName;
};