[PATCH virt-viewer v2] ovirt-foreign-menu: Fix endpoint for storage domains query

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Instead of fetching toplevel REST API query, we use the one relative
from the data center, which returns more detailed information,
especially the status of the storage domain.

This fixes https://bugzilla.redhat.com/show_bug.cgi?id=1427467

Signed-off-by: Eduardo Lima (Etrunko) <etrunko@xxxxxxxxxx>
---

in V2:
 - Improve usage of boolean domain_valid

---
 src/ovirt-foreign-menu.c | 26 ++++++++++++++++++++------
 1 file changed, 20 insertions(+), 6 deletions(-)

diff --git a/src/ovirt-foreign-menu.c b/src/ovirt-foreign-menu.c
index 59c3d48..75f9ac4 100644
--- a/src/ovirt-foreign-menu.c
+++ b/src/ovirt-foreign-menu.c
@@ -683,6 +683,7 @@ static void storage_domains_fetched_cb(GObject *source_object,
     OvirtCollection *collection = OVIRT_COLLECTION(source_object);
     GHashTableIter iter;
     OvirtStorageDomain *domain;
+    gboolean domain_valid = FALSE;
 
     ovirt_collection_fetch_finish(collection, result, &error);
     if (error != NULL) {
@@ -696,7 +697,8 @@ static void storage_domains_fetched_cb(GObject *source_object,
     while (g_hash_table_iter_next(&iter, NULL, (gpointer *)&domain)) {
         OvirtCollection *file_collection;
 
-        if (!storage_domain_validate(menu, domain))
+        domain_valid = storage_domain_validate(menu, domain);
+        if (!domain_valid)
             continue;
 
         file_collection = ovirt_storage_domain_get_files(domain);
@@ -713,9 +715,11 @@ static void storage_domains_fetched_cb(GObject *source_object,
     if (menu->priv->files != NULL) {
         ovirt_foreign_menu_next_async_step(menu, task, STATE_STORAGE_DOMAIN);
     } else {
-        g_debug("Could not find iso file collection");
-        g_task_return_new_error(task, OVIRT_ERROR, OVIRT_ERROR_FAILED,
-                                "Could not find ISO file collection");
+        const char *msg = domain_valid ? "Could not find ISO file collection"
+                                       : "Could not find valid ISO storage domain";
+
+        g_debug(msg);
+        g_task_return_new_error(task, OVIRT_ERROR, OVIRT_ERROR_FAILED, msg);
         g_object_unref(task);
     }
 }
@@ -724,9 +728,19 @@ static void storage_domains_fetched_cb(GObject *source_object,
 static void ovirt_foreign_menu_fetch_storage_domain_async(OvirtForeignMenu *menu,
                                                           GTask *task)
 {
-    OvirtCollection *collection = ovirt_api_get_storage_domains(menu->priv->api);
+    OvirtCollection *collection = NULL;
+
+#ifdef HAVE_OVIRT_DATA_CENTER
+    g_return_if_fail(OVIRT_IS_FOREIGN_MENU(menu));
+    g_return_if_fail(OVIRT_IS_PROXY(menu->priv->proxy));
+    g_return_if_fail(OVIRT_IS_DATA_CENTER(menu->priv->data_center));
+
+    collection = ovirt_data_center_get_storage_domains(menu->priv->data_center);
+#else
+    collection = ovirt_api_get_storage_domains(menu->priv->api);
+#endif
 
-    g_debug("Start fetching oVirt REST collection");
+    g_debug("Start fetching iso file collection");
     ovirt_collection_fetch_async(collection, menu->priv->proxy,
                                  g_task_get_cancellable(task),
                                  storage_domains_fetched_cb, task);
-- 
2.21.0

_______________________________________________
virt-tools-list mailing list
virt-tools-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/virt-tools-list



[Index of Archives]     [Linux Virtualization]     [KVM Development]     [CentOS Virtualization]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite Forum]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]     [Video 4 Linux]

  Powered by Linux