[epiphany/wip/tingping/profile-migration: 3/7] Move profile directories to data dir
- From: Patrick Griffis <pgriffis src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [epiphany/wip/tingping/profile-migration: 3/7] Move profile directories to data dir
- Date: Sun, 6 Jan 2019 18:34:31 +0000 (UTC)
commit 06e3fb65bbab21af266d88114e8256a20da74b29
Author: Patrick Griffis <pgriffis igalia com>
Date: Fri Dec 21 09:21:27 2018 -0500
Move profile directories to data dir
Fixes #182
lib/ephy-file-helpers.c | 2 +-
lib/ephy-web-app-utils.c | 13 +-
src/profile-migrator/ephy-profile-migrator.c | 174 +++++++++++++++++++++------
3 files changed, 151 insertions(+), 38 deletions(-)
---
diff --git a/lib/ephy-file-helpers.c b/lib/ephy-file-helpers.c
index 209f16f46..001f1491d 100644
--- a/lib/ephy-file-helpers.c
+++ b/lib/ephy-file-helpers.c
@@ -288,7 +288,7 @@ ephy_default_dot_dir (void)
{
return dot_dir_type == EPHY_PROFILE_DIR_TEST ?
g_strdup (ephy_dot_dir ()) :
- g_build_filename (g_get_user_config_dir (), "epiphany", NULL);
+ g_build_filename (g_get_user_data_dir (), "epiphany", NULL);
}
/**
diff --git a/lib/ephy-web-app-utils.c b/lib/ephy-web-app-utils.c
index 8afddd73f..a75ae995f 100644
--- a/lib/ephy-web-app-utils.c
+++ b/lib/ephy-web-app-utils.c
@@ -161,7 +161,7 @@ ephy_web_application_get_profile_directory (const char *id)
return NULL;
dot_dir = !ephy_dot_dir_is_default () ? ephy_default_dot_dir () : NULL;
- profile_dir = g_build_filename (dot_dir ? dot_dir : g_get_user_config_dir (), app_dir, NULL);
+ profile_dir = g_build_filename (dot_dir ? dot_dir : g_get_user_data_dir (), app_dir, NULL);
g_free (app_dir);
g_free (dot_dir);
@@ -542,9 +542,16 @@ ephy_web_application_get_application_list_internal (gboolean only_legacy)
GList *applications = NULL;
GFile *dot_dir;
char *default_dot_dir;
+ g_autofree char *profile_base = NULL;
default_dot_dir = !ephy_dot_dir_is_default () ? ephy_default_dot_dir () : NULL;
- dot_dir = g_file_new_for_path (default_dot_dir ? default_dot_dir : only_legacy ? ephy_dot_dir () :
g_get_user_config_dir ());
+ if (only_legacy) {
+ profile_base = g_build_filename (g_get_user_config_dir (), "epiphany", NULL);
+ dot_dir = g_file_new_for_path (profile_base);
+ } else {
+ profile_base = g_strdup (g_get_user_data_dir ());
+ dot_dir = g_file_new_for_path (default_dot_dir ? default_dot_dir : g_get_user_data_dir ());
+ }
children = g_file_enumerate_children (dot_dir,
"standard::name",
0, NULL, NULL);
@@ -560,7 +567,7 @@ ephy_web_application_get_application_list_internal (gboolean only_legacy)
EphyWebApplication *app;
char *profile_dir;
- profile_dir = g_build_filename (default_dot_dir ? default_dot_dir : ephy_dot_dir (), name, NULL);
+ profile_dir = g_build_filename (profile_base, name, NULL);
app = ephy_web_application_for_profile_directory (profile_dir);
if (app) {
if (!only_legacy) {
diff --git a/src/profile-migrator/ephy-profile-migrator.c b/src/profile-migrator/ephy-profile-migrator.c
index 76c70f390..159bcac20 100644
--- a/src/profile-migrator/ephy-profile-migrator.c
+++ b/src/profile-migrator/ephy-profile-migrator.c
@@ -57,6 +57,38 @@ static int do_step_n = -1;
static int migration_version = -1;
static char *profile_dir = NULL;
+/* The legacy dir is used by everything before version 29 which migrates
+ * to the new directory */
+static const char *
+legacy_default_profile_dir (void)
+{
+ static char *dir = NULL;
+ if (dir == NULL)
+ dir = g_build_filename (g_get_user_config_dir (), "epiphany", NULL);
+ return dir;
+}
+
+static const char *
+legacy_profile_dir (void)
+{
+ static char *dir = NULL;
+ if (dir == NULL)
+ {
+ /* If this isn't actually a legacy dir it starts at a later migrating step anyway */
+ if (profile_dir != NULL)
+ dir = profile_dir;
+ else
+ dir = (char *)legacy_default_profile_dir ();
+ }
+ return dir;
+}
+
+static gboolean
+legacy_dir_is_default (void)
+{
+ return !strcmp (legacy_profile_dir (), legacy_default_profile_dir ());
+}
+
/*
* What to do to add new migration steps:
* - Bump EPHY_PROFILE_MIGRATION_VERSION in lib/ephy-profile-utils.h
@@ -68,7 +100,13 @@ typedef void (*EphyProfileMigrator) (void);
static gboolean
profile_dir_exists (void)
{
- return g_file_test (ephy_dot_dir (), G_FILE_TEST_EXISTS | G_FILE_TEST_IS_DIR);
+ if (g_file_test (ephy_dot_dir (), G_FILE_TEST_EXISTS | G_FILE_TEST_IS_DIR))
+ return TRUE;
+
+ if (g_file_test (legacy_profile_dir (), G_FILE_TEST_EXISTS | G_FILE_TEST_IS_DIR))
+ return TRUE;
+
+ return FALSE;
}
static void
@@ -170,7 +208,7 @@ migrate_insecure_passwords (void)
* if this migrator has already run there. This way we avoid adding a new flag
* file to clutter the profile dir just to check if this migrator has run.
*/
- default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(ephy_default_dot_dir ());
+ default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(legacy_default_profile_dir ());
if (default_profile_migration_version >= EPHY_INSECURE_PASSWORDS_MIGRATION_VERSION) {
LOG ("Skipping insecure password migration because default profile has already migrated");
return;
@@ -345,14 +383,14 @@ migrate_bookmarks (void)
xmlNodePtr child;
xmlNodePtr root;
- filename = g_build_filename (ephy_dot_dir (),
+ filename = g_build_filename (legacy_profile_dir (),
EPHY_BOOKMARKS_FILE,
NULL);
if (g_file_test (filename, G_FILE_TEST_EXISTS))
goto out;
g_free (filename);
- filename = g_build_filename (ephy_dot_dir (),
+ filename = g_build_filename (legacy_profile_dir (),
"bookmarks.rdf",
NULL);
if (!g_file_test (filename, G_FILE_TEST_EXISTS))
@@ -389,7 +427,7 @@ migrate_bookmarks (void)
g_warning ("Failed to delete %s: %s", filename, g_strerror (errno));
g_free (filename);
- filename = g_build_filename (ephy_dot_dir (),
+ filename = g_build_filename (legacy_profile_dir (),
"ephy-bookmarks.xml",
NULL);
if (g_unlink (filename) != 0)
@@ -408,22 +446,18 @@ migrate_adblock_filters (void)
GPtrArray *filters_array = NULL;
GError *error = NULL;
- adblock_dir = g_build_filename (ephy_dot_dir (), "adblock", NULL);
+ adblock_dir = g_build_filename (legacy_profile_dir (), "adblock", NULL);
if (!g_file_test (adblock_dir, G_FILE_TEST_IS_DIR)) {
g_free (adblock_dir);
return;
}
- if (!ephy_dot_dir_is_default ()) {
- char *default_dot_dir;
-
+ if (!legacy_dir_is_default ()) {
/* Adblock filters rules are now shared to save space */
ephy_file_delete_dir_recursively (adblock_dir, NULL);
g_free (adblock_dir);
- default_dot_dir = ephy_default_dot_dir ();
- adblock_dir = g_build_filename (default_dot_dir, "adblock", NULL);
- g_free (default_dot_dir);
+ adblock_dir = g_build_filename (legacy_default_profile_dir (), "adblock", NULL);
}
filters_filename = g_build_filename (adblock_dir, "filters.list", NULL);
@@ -488,7 +522,7 @@ migrate_initial_state (void)
/* EphyInitialState no longer exists. It's just window sizes, so "migrate" it
* by simply removing the file to avoid cluttering the profile dir. */
- filename = g_build_filename (ephy_dot_dir (), "states.xml", NULL);
+ filename = g_build_filename (legacy_profile_dir (), "states.xml", NULL);
file = g_file_new_for_path (filename);
g_file_delete (file, NULL, &error);
@@ -508,7 +542,7 @@ migrate_permissions (void)
char *filename;
GFile *file;
- filename = g_build_filename (ephy_dot_dir (), "hosts.ini", NULL);
+ filename = g_build_filename (legacy_profile_dir (), "hosts.ini", NULL);
file = g_file_new_for_path (filename);
g_free (filename);
@@ -556,14 +590,14 @@ migrate_settings (void)
* so if the profile dir is not the default one, it's a web app.
* If not a web app, migrate deprecated settings.
*/
- if (ephy_dot_dir_is_default ()) {
+ if (ephy_dot_dir_is_default () || legacy_dir_is_default ()) {
migrate_deprecated_settings ();
return;
}
/* If it's a web app, inherit settings from the default profile. */
/* If the default profile hasn't been migrated yet, use the deprecated settings. */
- default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(ephy_default_dot_dir ());
+ default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(legacy_default_profile_dir ());
if (default_profile_migration_version < EPHY_SETTINGS_MIGRATION_VERSION) {
GSettings *settings;
@@ -590,7 +624,7 @@ migrate_settings (void)
g_variant_unref (value);
}
} else
- ephy_web_application_initialize_settings (ephy_dot_dir ());
+ ephy_web_application_initialize_settings (legacy_profile_dir ());
g_settings_sync ();
}
@@ -613,7 +647,7 @@ migrate_search_engines (void)
/* Search engine settings are only used in browser mode, so no need to migrate
* if we are not in browser mode. */
- if (!ephy_dot_dir_is_default ())
+ if (!legacy_dir_is_default ())
return;
bookmarks_manager = ephy_bookmarks_manager_new ();
@@ -693,7 +727,7 @@ migrate_passwords_to_firefox_sync_passwords (void)
* password schema, fields that are not taken into consideration when
* querying passwords.
*/
- default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(ephy_default_dot_dir ());
+ default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(legacy_default_profile_dir ());
if (default_profile_migration_version >= EPHY_FIREFOX_SYNC_PASSWORDS_MIGRATION_VERSION)
return;
@@ -759,7 +793,7 @@ migrate_history_to_firefox_sync_history (void)
char *history_filename;
const char *sql_query;
- history_filename = g_build_filename (ephy_dot_dir (), EPHY_HISTORY_FILE, NULL);
+ history_filename = g_build_filename (legacy_profile_dir (), EPHY_HISTORY_FILE, NULL);
if (!g_file_test (history_filename, G_FILE_TEST_EXISTS)) {
LOG ("There is no history to migrate...");
goto out;
@@ -821,7 +855,7 @@ migrate_passwords_add_target_origin (void)
* Adds target_origin field to all existing records,
* with the same value as origin.
*/
- default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(ephy_default_dot_dir ());
+ default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(legacy_default_profile_dir ());
if (default_profile_migration_version >= EPHY_TARGET_ORIGIN_MIGRATION_VERSION)
return;
@@ -908,7 +942,7 @@ migrate_sync_settings_path (void)
/* Sync settings are only used in browser mode, so no need to migrate if we
* are not in browser mode. */
- if (!ephy_dot_dir_is_default ())
+ if (!legacy_dir_is_default ())
return;
for (guint i = 0; i < G_N_ELEMENTS (old_sync_settings); i++) {
@@ -955,7 +989,7 @@ migrate_sync_device_info (void)
char *record;
int default_profile_migration_version;
- default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(ephy_default_dot_dir ());
+ default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(legacy_default_profile_dir ());
if (default_profile_migration_version >= EPHY_SYNC_DEVICE_ID_MIGRATION_VERSION)
return;
@@ -1047,7 +1081,7 @@ migrate_bookmarks_timestamp (void)
char *filename;
int length;
- filename = g_build_filename (ephy_dot_dir (), EPHY_BOOKMARKS_FILE, NULL);
+ filename = g_build_filename (legacy_profile_dir (), EPHY_BOOKMARKS_FILE, NULL);
root_table_in = gvdb_table_new (filename, TRUE, &error);
if (error) {
g_warning ("Failed to create Gvdb table: %s", error->message);
@@ -1128,7 +1162,7 @@ migrate_passwords_timestamp (void)
int default_profile_migration_version;
/* We want this migration to run only once. */
- default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(ephy_default_dot_dir ());
+ default_profile_migration_version = ephy_profile_utils_get_migration_version_for_profile_dir
(legacy_default_profile_dir ());
if (default_profile_migration_version >= EPHY_PASSWORDS_TIMESTAMP_MIGRATION_VERSION)
return;
@@ -1215,8 +1249,48 @@ migrate_annoyance_list (void)
g_strfreev (modified_filters);
}
+static gboolean
+move_directory_contents (GFile *source,
+ GFile *dest)
+{
+ /* Just a sanity check as it should already exist */
+ g_file_make_directory (dest, NULL, NULL);
+
+ g_autoptr(GError) error = NULL;
+ g_autoptr(GFileEnumerator) direnum = g_file_enumerate_children (source, G_FILE_ATTRIBUTE_STANDARD_NAME,
+ G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS,
+ NULL, &error);
+ if (error) {
+ LOG ("Failed to enumerate files: %s", error->message);
+ return FALSE;
+ }
+
+ while (TRUE) {
+ GFileInfo *info;
+ g_autoptr(GError) error = NULL;
+ if (!g_file_enumerator_iterate (direnum, &info, NULL, NULL, &error)) {
+ LOG ("Failed to enumerate dir: %s", error->message);
+ return FALSE;
+ }
+ if (!info)
+ break;
+
+ g_autoptr(GFile) source_f = g_file_get_child (source, g_file_info_get_name (info));
+ g_autoptr(GFile) dest_f = g_file_get_child (dest, g_file_info_get_name (info));
+ if (!g_file_move (source_f, dest_f, G_FILE_COPY_NONE, NULL, NULL, NULL, &error)) {
+ LOG ("Failed to move %s: %s", g_file_info_get_name (info), error->message);
+ return FALSE;
+ }
+ }
+
+ if (!g_file_delete (source, NULL, &error))
+ LOG ("Failed to delete left-over source: %s", error->message);
+
+ return TRUE;
+}
+
static void
-migrate_app_profile_directories (void)
+migrate_profile_directories (void)
{
GList *web_apps, *l;
@@ -1227,13 +1301,13 @@ migrate_app_profile_directories (void)
g_autoptr(GError) error = NULL;
g_autofree char *old_name = g_strconcat ("app-epiphany-", app->id, NULL);
- g_autofree char *old_path = g_build_filename (ephy_default_dot_dir (), old_name, NULL);
+ g_autofree char *old_path = g_build_filename (legacy_profile_dir (), old_name, NULL);
g_autoptr(GFile) old_directory = g_file_new_for_path (old_path);
+
g_autofree char *app_path = ephy_web_application_get_profile_directory (app->id);
g_autoptr(GFile) new_directory = g_file_new_for_path (app_path);
- if (!g_file_move (old_directory, new_directory, G_FILE_COPY_NONE, NULL, NULL, NULL, &error)) {
- LOG ("Failed to move directory %s to %s: %s", old_path, app_path, error->message);
+ if (!move_directory_contents (old_directory, new_directory)) {
continue;
}
@@ -1255,21 +1329,52 @@ migrate_app_profile_directories (void)
}
g_autoptr(GRegex) re = g_regex_new ("epiphany/app-epiphany-", 0, 0, NULL);
- g_autofree char *new_exec = g_regex_replace (re, exec, -1, 0, "/epiphany-", 0, &error);
+ g_autofree char *new_exec = g_regex_replace (re, exec, -1, 0, "epiphany-", 0, &error);
if (error != NULL) {
LOG ("Failed to replace Exec line %s: %s", exec, error->message);
g_clear_error (&error);
}
- LOG ("migrate_app_profile_directories: setting Exec to %s", new_exec);
+ LOG ("migrate_profile_directories: setting Exec to %s", new_exec);
g_key_file_set_string (file, G_KEY_FILE_DESKTOP_GROUP, G_KEY_FILE_DESKTOP_KEY_EXEC, new_exec);
if (!g_key_file_save_to_file (file, desktop_file_path, &error))
LOG ("Failed to save desktop file %s", error->message);
+
+ g_autofree char *desktop_symlink_path = g_build_filename (g_get_user_data_dir (),
+ "applications",
+ app->desktop_file,
+ NULL);
+ g_autoptr(GFile) desktop_symlink = g_file_new_for_path (desktop_symlink_path);
+ LOG ("Symlinking %s to %s", desktop_symlink_path, desktop_file_path);
+
+ // Try removing old symlink, failure is ok assuming it doesn't exist.
+ if (!g_file_delete (desktop_symlink, NULL, &error)) {
+ g_warning ("Failed to remove old symbolic link: %s", error->message);
+ g_clear_error (&error);
+ }
+
+ if (!g_file_make_symbolic_link (desktop_symlink, desktop_file_path, NULL, &error))
+ g_warning ("Failed to make symbolic link: %s", error->message);
}
ephy_web_application_free_application_list (web_apps);
+
+ /* The default profile also changed directories */
+ g_autoptr(GFile) old_directory = g_file_new_for_path (legacy_default_profile_dir ());
+ g_autoptr(GFile) new_directory = g_file_new_for_path (ephy_default_dot_dir ());
+
+ if (!move_directory_contents (old_directory, new_directory))
+ return;
+
+ /* We are also moving some cache directories so just remove the old ones */
+ g_autoptr(GFile) adblock_directory = g_file_get_child (new_directory, "adblock");
+ g_file_delete (adblock_directory, NULL, NULL);
+ g_autoptr(GFile) gsb_file = g_file_get_child (new_directory, "gsb-threats.db");
+ g_file_delete (gsb_file, NULL, NULL);
+ g_autoptr(GFile) gsb_journal_file = g_file_get_child (new_directory, "gsb-threats.db-journal");
+ g_file_delete (gsb_journal_file, NULL, NULL);
}
static void
@@ -1392,8 +1497,8 @@ const EphyProfileMigrator migrators[] = {
/* 26 */ migrate_nothing,
/* 27 */ migrate_search_engines,
/* 28 */ migrate_annoyance_list,
- /* 29 */ migrate_zoom_level
- /* 30 */ migrate_app_profile_directories,
+ /* 29 */ migrate_zoom_level,
+ /* 30 */ migrate_profile_directories,
};
static gboolean
@@ -1424,7 +1529,8 @@ ephy_migrator (void)
return TRUE;
}
- latest = ephy_profile_utils_get_migration_version ();
+ latest = MAX (ephy_profile_utils_get_migration_version (),
+ ephy_profile_utils_get_migration_version_for_profile_dir (legacy_profile_dir ()));
LOG ("Running migrators up to version %d, current migration version is %d.",
EPHY_PROFILE_MIGRATION_VERSION, latest);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]