[gnome-boxes/wip/system-libvirt-import2: 2/2] tmp
- From: Zeeshan Ali Khattak <zeeshanak src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-boxes/wip/system-libvirt-import2: 2/2] tmp
- Date: Tue, 12 Nov 2013 18:15:42 +0000 (UTC)
commit 3df44b9cac76c72f5004e5a97790575b18b0e5b2
Author: Zeeshan Ali (Khattak) <zeeshanak gnome org>
Date: Tue Oct 15 20:49:41 2013 -0400
tmp
src/Makefile.am | 3 ++
src/installed-media.vala | 9 ++++-
src/libvirt-broker.vala | 8 +++-
src/libvirt-system-importer.vala | 67 +++++++++++++++++++++++++++++++++++
src/libvirt-system-media.vala | 25 +++++++++++++
src/libvirt-system-vm-importer.vala | 38 ++++++++++++++++++++
src/vm-configurator.vala | 8 ++++
src/vm-importer.vala | 12 ++++--
8 files changed, 162 insertions(+), 8 deletions(-)
---
diff --git a/src/Makefile.am b/src/Makefile.am
index 12c41db..cbfec97 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -88,6 +88,7 @@ gnome_boxes_SOURCES = \
i-properties-provider.vala \
installer-media.vala \
installed-media.vala \
+ libvirt-system-media.vala \
iso-extractor.vala \
libvirt-broker.vala \
libvirt-machine.vala \
@@ -113,6 +114,8 @@ gnome_boxes_SOURCES = \
vm-configurator.vala \
vm-creator.vala \
vm-importer.vala \
+ libvirt-system-importer.vala \
+ libvirt-system-vm-importer.vala \
vnc-display.vala \
wizard-source.vala \
wizard.vala \
diff --git a/src/installed-media.vala b/src/installed-media.vala
index 31e41bc..301aeae 100644
--- a/src/installed-media.vala
+++ b/src/installed-media.vala
@@ -18,6 +18,8 @@ private class Boxes.InstalledMedia : Boxes.InstallerMedia {
public string format { get { return device_file.has_suffix (".qcow2")? "qcow2" : "raw"; } }
+ protected string qemu_img_cmd = "qemu-img";
+
protected override string? architecture {
owned get {
// Many distributors provide arch name on the image file so lets try to use that if possible
@@ -36,7 +38,7 @@ private class Boxes.InstalledMedia : Boxes.InstallerMedia {
}
}
- public async InstalledMedia (string path, MediaManager media_manager) throws GLib.Error {
+ public async InstalledMedia (string path, MediaManager? media_manager = null) throws GLib.Error {
var supported = false;
foreach (var extension in supported_extensions) {
supported = path.has_suffix (extension);
@@ -50,6 +52,9 @@ private class Boxes.InstalledMedia : Boxes.InstallerMedia {
device_file = path;
from_image = true;
+ if (media_manager == null)
+ return;
+
if (path.contains ("gnome-continuous") || path.contains ("gnome-ostree")) {
try {
os = yield media_manager.os_db.get_os_by_id ("http://gnome.org/continuous/3.10");
@@ -70,7 +75,7 @@ private class Boxes.InstalledMedia : Boxes.InstallerMedia {
public async void copy (string destination_path) throws GLib.Error {
var decompressed = yield decompress ();
- string[] argv = { "qemu-img", "convert", "-O", "qcow2", device_file, destination_path };
+ string[] argv = { qemu_img_cmd, "convert", "-O", "qcow2", device_file, destination_path };
var converting = !device_file.has_suffix (".qcow2");
diff --git a/src/libvirt-broker.vala b/src/libvirt-broker.vala
index 2073570..af4adf2 100644
--- a/src/libvirt-broker.vala
+++ b/src/libvirt-broker.vala
@@ -53,12 +53,16 @@ private class Boxes.LibvirtBroker : Boxes.Broker {
var machine = add_domain (source, connection, domain);
var config = machine.domain_config;
+ // These instance will take care of their own lifecycles
if (VMConfigurator.is_install_config (config) || VMConfigurator.is_live_config (config)) {
debug ("Continuing installation/live session for '%s', ..", machine.name);
- new VMCreator.for_install_completion (machine); // This instance will take care of its own
lifecycle
+ new VMCreator.for_install_completion (machine);
} else if (VMConfigurator.is_import_config (config)) {
debug ("Continuing import of '%s', ..", machine.name);
- new VMImporter.for_import_completion (machine); // This instance will take care of its own
lifecycle
+ new VMImporter.for_import_completion (machine);
+ } else if (VMConfigurator.is_libvirt_system_import_config (config)) {
+ debug ("Continuing import of '%s', ..", machine.name);
+ new LibvirtSystemVMImporter.for_import_completion (machine);
}
} catch (GLib.Error error) {
warning ("Failed to create source '%s': %s", source.name, error.message);
diff --git a/src/libvirt-system-importer.vala b/src/libvirt-system-importer.vala
new file mode 100644
index 0000000..d85a98e
--- /dev/null
+++ b/src/libvirt-system-importer.vala
@@ -0,0 +1,67 @@
+// This file is part of GNOME Boxes. License: LGPLv2+
+using GVir;
+
+private class Boxes.LibvirtSystemImporter: GLib.Object {
+ public bool import_needed {
+ get {
+ return (domains.length () + pools.length ()) != 0;
+ }
+ }
+
+ private GVir.Connection connection;
+ private GLib.List<GVir.Domain> domains;
+ private GLib.List<GVir.StoragePool> pools;
+
+ public async LibvirtSystemImporter () throws GLib.Error {
+ connection = new GVir.Connection ("qemu+unix:///system");
+
+ yield connection.open_read_only_async (null);
+ yield connection.fetch_domains_async (null);
+
+ domains = connection.get_domains ();
+ }
+
+ public void import () {
+ foreach (var domain in domains)
+ try {
+ import_domain (domain);
+ } catch (GLib.Error error) {
+ warning ("Failed to import '%s': %s", domain.get_name (), error.message);
+ }
+ }
+
+ private void import_domain (Domain domain) throws GLib.Error {
+ string device_file = null;
+
+ var config = domain.get_config (DomainXMLFlags.INACTIVE);
+ var devices = config.get_devices ();
+ foreach (var device in devices) {
+ if (!(device is DomainDisk))
+ continue;
+
+ var disk = device as GVirConfig.DomainDisk;
+ if (disk.get_guest_device_type () == GVirConfig.DomainDiskGuestDeviceType.DISK) {
+ device_file = disk.get_source ();
+
+ break;
+ }
+ }
+
+ if (device_file == null) {
+ warning ("Failed to find suitable disk to import for '%s'", config.name);
+
+ return;
+ }
+
+ var media = new LibvirtSystemMedia (device_file, config);
+ var vm_importer = media.get_vm_creator ();
+ vm_importer.create_vm.begin (null, (obj, result) => {
+ try {
+ var machine = vm_importer.create_vm.end (result);
+ vm_importer.launch_vm (machine);
+ } catch (GLib.Error error) {
+ warning ("Failed to import '%s': %s", config.name, error.message);
+ }
+ });
+ }
+}
diff --git a/src/libvirt-system-media.vala b/src/libvirt-system-media.vala
new file mode 100644
index 0000000..75225d6
--- /dev/null
+++ b/src/libvirt-system-media.vala
@@ -0,0 +1,25 @@
+// This file is part of GNOME Boxes. License: LGPLv2+
+
+using GVirConfig;
+
+private class Boxes.LibvirtSystemMedia : Boxes.InstalledMedia {
+ protected override string? architecture {
+ owned get {
+ return domain_config.get_os ().get_arch ();
+ }
+ }
+
+ public Domain domain_config { get; private set; }
+
+ public async LibvirtSystemMedia (string path, Domain domain_config) throws GLib.Error {
+ base (path);
+
+ this.domain_config = domain_config;
+ label = domain_config.title?? domain_config.name;
+ qemu_img_cmd = "pkexec qemu-img";
+ }
+
+ public override VMCreator get_vm_creator () {
+ return new LibvirtSystemVMImporter (this);
+ }
+}
diff --git a/src/libvirt-system-vm-importer.vala b/src/libvirt-system-vm-importer.vala
new file mode 100644
index 0000000..75bc31f
--- /dev/null
+++ b/src/libvirt-system-vm-importer.vala
@@ -0,0 +1,38 @@
+// This file is part of GNOME Boxes. License: LGPLv2+
+
+using Osinfo;
+using GVirConfig;
+
+private class Boxes.LibvirtSystemVMImporter : Boxes.VMImporter {
+ public LibvirtSystemVMImporter (InstalledMedia source_media) {
+ base (source_media);
+ start_after_import = false;
+ }
+
+ public LibvirtSystemVMImporter.for_import_completion (LibvirtMachine machine) {
+ base.for_install_completion (machine);
+ start_after_import = false;
+ }
+
+ protected override async Domain create_domain_config (string name,
+ string title,
+ GVir.StorageVol volume,
+ Cancellable? cancellable) throws GLib.Error {
+ var media = install_media as LibvirtSystemMedia;
+ var devices = media.domain_config.get_devices ();
+ foreach (var device in devices) {
+ if (!(device is DomainDisk))
+ continue;
+
+ var disk = device as DomainDisk;
+ if (disk.get_source () == media.device_file) {
+ disk.set_source (volume.get_path ());
+
+ break;
+ }
+ }
+ media.domain_config.set_devices (devices);
+
+ return media.domain_config;
+ }
+}
diff --git a/src/vm-configurator.vala b/src/vm-configurator.vala
index 491a2ec..b1669cd 100644
--- a/src/vm-configurator.vala
+++ b/src/vm-configurator.vala
@@ -14,10 +14,12 @@ private class Boxes.VMConfigurator {
private const string LIVE_STATE = "live";
private const string INSTALLATION_STATE = "installation";
private const string IMPORT_STATE = "importing";
+ private const string LIBVIRT_SYS_IMPORT_STATE = "libvirt-system-importing";
private const string INSTALLED_STATE = "installed";
private const string LIVE_XML = "<os-state>" + LIVE_STATE + "</os-state>";
private const string INSTALLATION_XML = "<os-state>" + INSTALLATION_STATE + "</os-state>";
private const string IMPORT_XML = "<os-state>" + IMPORT_STATE + "</os-state>";
+ private const string LIBVIRT_SYS_IMPORT_XML = "<os-state>" + LIBVIRT_SYS_IMPORT_STATE + "</os-state>";
private const string INSTALLED_XML = "<os-state>" + INSTALLED_STATE + "</os-state>";
private const string OS_ID_XML = "<os-id>%s</os-id>";
@@ -133,6 +135,10 @@ private class Boxes.VMConfigurator {
return get_os_state (domain) == IMPORT_STATE;
}
+ public static bool is_libvirt_system_import_config (Domain domain) {
+ return get_os_state (domain) == LIBVIRT_SYS_IMPORT_STATE;
+ }
+
public static StorageVol create_volume_config (string name, int64 storage) throws GLib.Error {
var volume = new StorageVol ();
volume.set_name (name);
@@ -340,6 +346,8 @@ private class Boxes.VMConfigurator {
custom_xml = INSTALLED_XML;
else if (install_media is InstalledMedia)
custom_xml = IMPORT_XML;
+ else if (install_media is LibvirtSystemMedia)
+ custom_xml = LIBVIRT_SYS_IMPORT_XML;
else
custom_xml = (install_media.live) ? LIVE_XML : INSTALLATION_XML;
diff --git a/src/vm-importer.vala b/src/vm-importer.vala
index 262451a..a53232c 100644
--- a/src/vm-importer.vala
+++ b/src/vm-importer.vala
@@ -6,6 +6,8 @@ using GVir;
private class Boxes.VMImporter : Boxes.VMCreator {
public InstalledMedia source_media { get { return install_media as InstalledMedia; } }
+ protected bool start_after_import = true;
+
public VMImporter (InstalledMedia source_media) {
base (source_media);
}
@@ -56,10 +58,12 @@ private class Boxes.VMImporter : Boxes.VMCreator {
}
set_post_install_config (machine);
- try {
- machine.domain.start (0);
- } catch (GLib.Error error) {
- warning ("Failed to start domain '%s': %s", machine.domain.get_name (), error.message);
+ if (start_after_import) {
+ try {
+ machine.domain.start (0);
+ } catch (GLib.Error error) {
+ warning ("Failed to start domain '%s': %s", machine.domain.get_name (), error.message);
+ }
}
machine.info = null;
machine.vm_creator = null;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]