aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorXan Lopez <xan@igalia.com>2012-05-09 18:24:06 +0800
committerXan Lopez <xan@igalia.com>2012-05-09 18:24:06 +0800
commitdd510ece07f5e01debec5cd1605913cf7dec568d (patch)
tree12188b13f9c87a670bd2dc6813f15a60f8137558 /lib
parentf3a7c0fe44514d52f5a475e93470afea80390895 (diff)
downloadgsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.tar
gsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.tar.gz
gsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.tar.bz2
gsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.tar.lz
gsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.tar.xz
gsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.tar.zst
gsoc2013-epiphany-dd510ece07f5e01debec5cd1605913cf7dec568d.zip
ephy-profile-migrator: migrate Web Applications to new profile location
We need to update their desktop files (they had references to the profile directory) and the symlink of the .desktop file in the Shell applications directory. It would be much easier to just delete and re-add the applications, but unfortunately that would wipe out the existing profile data in the apps (like cookies).
Diffstat (limited to 'lib')
-rw-r--r--lib/ephy-profile-migrator.c87
-rw-r--r--lib/ephy-profile-utils.h2
2 files changed, 87 insertions, 2 deletions
diff --git a/lib/ephy-profile-migrator.c b/lib/ephy-profile-migrator.c
index ac5e1846a..ab933f0ec 100644
--- a/lib/ephy-profile-migrator.c
+++ b/lib/ephy-profile-migrator.c
@@ -37,6 +37,7 @@
#include "ephy-history-service.h"
#include "ephy-profile-utils.h"
#include "ephy-settings.h"
+#include "ephy-web-app-utils.h"
#ifdef ENABLE_NSS
#include "ephy-nss-glue.h"
#endif
@@ -677,6 +678,89 @@ migrate_profile_gnome2_to_xdg ()
g_free (old_dir);
}
+static char *
+fix_desktop_file_and_return_new_location (const char *dir)
+{
+ GRegex * regex;
+ char *result, *old_profile_dir, *replacement, *contents, *new_contents;
+ gsize length;
+
+ old_profile_dir = g_build_filename (g_get_home_dir (),
+ ".gnome2",
+ NULL);
+ replacement = g_build_filename (g_get_user_config_dir (),
+ NULL);
+ regex = g_regex_new (old_profile_dir, 0, 0, NULL);
+
+ /* We want to modify both the link destination and the contents of
+ * the .desktop file itself. */
+ result = g_regex_replace (regex, dir, -1,
+ 0, replacement, 0, NULL);
+ g_file_get_contents (result, &contents, &length, NULL);
+ new_contents = g_regex_replace (regex, contents, -1, 0,
+ replacement, 0, NULL);
+ g_file_set_contents (result, new_contents, length, NULL);
+
+ g_free (contents);
+ g_free (new_contents);
+ g_free (old_profile_dir);
+ g_free (replacement);
+
+ g_regex_unref (regex);
+
+ return result;
+}
+
+static void
+migrate_web_app_links ()
+{
+ GList *apps, *p;
+
+ apps = ephy_web_application_get_application_list ();
+ for (p = apps; p; p = p->next) {
+ char *desktop_file, *app_link;
+ EphyWebApplication *app = (EphyWebApplication*)p->data;
+
+ desktop_file = app->desktop_file;
+
+ /* Update the link in applications. */
+ app_link = g_build_filename (g_get_user_data_dir (), "applications", desktop_file, NULL);
+ if (g_file_test (app_link, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_SYMLINK)) {
+ /* Change the link to point to the new profile dir. */
+ GFileInfo *info;
+ const char *target;
+ GFile *file = g_file_new_for_path (app_link);
+
+ info = g_file_query_info (file, G_FILE_ATTRIBUTE_STANDARD_SYMLINK_TARGET,
+ 0, NULL, NULL);
+ if (info) {
+ char *new_target;
+
+ target = g_file_info_get_symlink_target (info);
+ new_target = fix_desktop_file_and_return_new_location (target);
+
+ /* FIXME: Updating the file info and setting it again should
+ * work, but it does not? Just delete and create the link
+ * again. */
+ g_file_delete (file, 0, 0);
+ g_object_unref (file);
+
+ file = g_file_new_for_path (app_link);
+ g_file_make_symbolic_link (file, new_target, NULL, NULL);
+
+ g_object_unref (info);
+ g_free (new_target);
+ }
+
+ g_object_unref (file);
+ }
+
+ g_free (app_link);
+ }
+
+ ephy_web_application_free_application_list (apps);
+}
+
const EphyProfileMigrator migrators[] = {
migrate_cookies,
migrate_passwords,
@@ -687,7 +771,8 @@ const EphyProfileMigrator migrators[] = {
* login/passwords for page forms, which we previously ignored */
migrate_passwords2,
migrate_history,
- migrate_tabs_visibility
+ migrate_tabs_visibility,
+ migrate_web_app_links
};
static void
diff --git a/lib/ephy-profile-utils.h b/lib/ephy-profile-utils.h
index 353a5605b..d26fe1ca5 100644
--- a/lib/ephy-profile-utils.h
+++ b/lib/ephy-profile-utils.h
@@ -26,7 +26,7 @@
#define FORM_USERNAME_KEY "form_username"
#define FORM_PASSWORD_KEY "form_password"
-#define EPHY_PROFILE_MIGRATION_VERSION 6
+#define EPHY_PROFILE_MIGRATION_VERSION 7
int ephy_profile_utils_get_migration_version (void);