[gnome-software/uajain/sync-back-installed-apps-state: 6/7] transaction: Sync main app's state if a related ref is installed
- From: Umang Jain <uajain src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-software/uajain/sync-back-installed-apps-state: 6/7] transaction: Sync main app's state if a related ref is installed
- Date: Tue, 3 Dec 2019 05:11:33 +0000 (UTC)
commit fb998a1fceb14d6987b40a7a83c13fd336f0a4ca
Author: Umang Jain <umang endlessm com>
Date: Wed Nov 6 11:49:53 2019 +0530
transaction: Sync main app's state if a related ref is installed
Starting libflatpak-1.5.1 [1], flatpak will start returning
application refs as updatable if mandatory extensions related
refs are not found to be installed on the installation.
Hence, detect such kind of cases and sync the main-app's
state back to installed accordingly.
[1] https://github.com/flatpak/flatpak/pull/3204
https://phabricator.endlessm.com/T28302
plugins/flatpak/gs-flatpak-transaction.c | 59 ++++++++++++++++++++++++++++++++
plugins/flatpak/gs-plugin-flatpak.c | 3 ++
2 files changed, 62 insertions(+)
---
diff --git a/plugins/flatpak/gs-flatpak-transaction.c b/plugins/flatpak/gs-flatpak-transaction.c
index 57b7a05c..e646915c 100644
--- a/plugins/flatpak/gs-flatpak-transaction.c
+++ b/plugins/flatpak/gs-flatpak-transaction.c
@@ -70,6 +70,41 @@ gs_flatpak_transaction_set_no_deploy (FlatpakTransaction *transaction, gboolean
}
#endif
+/* Checks if a ref is a related ref to one of the installed ref.
+ * If yes, return the GsApp corresponding to the installed ref,
+ * NULL otherwise.
+ */
+static GsApp *
+get_installed_main_app_of_related_ref (FlatpakTransaction *transaction,
+ FlatpakTransactionOperation *operation)
+{
+ FlatpakInstallation *installation = flatpak_transaction_get_installation (transaction);
+ const gchar *remote = flatpak_transaction_operation_get_remote (operation);
+ const gchar *op_ref = flatpak_transaction_operation_get_ref (operation);
+ GsFlatpakTransaction *self = GS_FLATPAK_TRANSACTION (transaction);
+ g_autoptr(GList) keys = NULL;
+
+ if (g_str_has_prefix (op_ref, "app/"))
+ return NULL;
+
+ keys = g_hash_table_get_keys (self->refhash);
+ for (GList *l = keys; l != NULL; l = l->next) {
+ g_autoptr(GPtrArray) related_refs = NULL;
+ related_refs = flatpak_installation_list_installed_related_refs_sync (installation, remote,
+ l->data, NULL, NULL);
+ if (related_refs == NULL)
+ continue;
+
+ for (guint i = 0; i < related_refs->len; i++) {
+ g_autofree gchar *rref = flatpak_ref_format_ref (g_ptr_array_index (related_refs, i));
+ if (g_strcmp0 (rref, op_ref) == 0) {
+ return g_hash_table_lookup (self->refhash, l->data);
+ }
+ }
+ }
+ return NULL;
+}
+
GsApp *
gs_flatpak_transaction_get_app_by_ref (FlatpakTransaction *transaction, const gchar *ref)
{
@@ -266,6 +301,8 @@ _transaction_operation_done (FlatpakTransaction *transaction,
#if !FLATPAK_CHECK_VERSION(1,5,1)
GsFlatpakTransaction *self = GS_FLATPAK_TRANSACTION (transaction);
#endif
+ GsApp *main_app = NULL;
+
/* invalidate */
GsApp *app = _transaction_operation_get_app (operation);
if (app == NULL) {
@@ -275,6 +312,28 @@ _transaction_operation_done (FlatpakTransaction *transaction,
}
switch (flatpak_transaction_operation_get_operation_type (operation)) {
case FLATPAK_TRANSACTION_OPERATION_INSTALL:
+#if FLATPAK_CHECK_VERSION(1,5,1)
+ /* Handle special snowflake where "should-download" related refs for an installed ref
+ * goes missing. In that case, libflatpak marks the main app ref as updatable
+ * and then FlatpakTransaction resolves one of its ops to install the related ref(s).
+ *
+ * We can depend on libflatpak till here. Since, libflatpak returns the main app
+ * ref as updatable (instead of the related ref), we need to sync the main app's
+ * state for UI/UX.
+ *
+ * Map the current op's ref (which is related ref) to its main app ref (which is
+ * currently shown in the UI) and set the state of the main GsApp object back
+ * to INSTALLED here.
+ *
+ * This detection whether a related ref belongs to a main ref is quite sub-optimal as
+ * of now.
+ */
+ main_app = get_installed_main_app_of_related_ref (transaction, operation);
+ if (main_app != NULL)
+ gs_app_set_state (main_app, AS_APP_STATE_INSTALLED);
+#endif
+ gs_app_set_state (app, AS_APP_STATE_INSTALLED);
+ break;
case FLATPAK_TRANSACTION_OPERATION_INSTALL_BUNDLE:
gs_app_set_state (app, AS_APP_STATE_INSTALLED);
break;
diff --git a/plugins/flatpak/gs-plugin-flatpak.c b/plugins/flatpak/gs-plugin-flatpak.c
index 628d2da2..c0ba73de 100644
--- a/plugins/flatpak/gs-plugin-flatpak.c
+++ b/plugins/flatpak/gs-plugin-flatpak.c
@@ -758,6 +758,9 @@ gs_plugin_flatpak_update (GsPlugin *plugin,
gs_flatpak_error_convert (error);
return FALSE;
}
+
+ /* Add the update applist for easier lookup */
+ gs_flatpak_transaction_add_app (transaction, app);
}
/* run transaction */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]