2017-07-04 16:50:00 +02:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
|
|
<body>
|
|
|
|
<h1>D-Bus API bindings</h1>
|
|
|
|
|
|
|
|
<ul id="toc"></ul>
|
|
|
|
|
2019-08-27 17:21:32 +02:00
|
|
|
<h2><a id="description">Description</a></h2>
|
2017-07-04 16:50:00 +02:00
|
|
|
|
|
|
|
<p>
|
|
|
|
libvirt-dbus wraps libvirt API to provide a high-level object-oriented
|
|
|
|
API better suited for dbus-based applications.
|
|
|
|
</p>
|
|
|
|
|
2019-08-27 17:21:32 +02:00
|
|
|
<h2><a id="git">GIT source repository</a></h2>
|
2017-07-04 16:50:00 +02:00
|
|
|
<p>
|
|
|
|
The D-Bus bindings source code is maintained in a
|
|
|
|
<a href="https://git-scm.com/">git</a> repository available on
|
2020-06-03 12:42:34 +02:00
|
|
|
<a href="https://gitlab.com/libvirt/libvirt-dbus">gitlab.com</a>:
|
2017-07-04 16:50:00 +02:00
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre>
|
2020-06-03 12:42:34 +02:00
|
|
|
git clone https://gitlab.com/libvirt/libvirt-dbus.git
|
2017-07-04 16:50:00 +02:00
|
|
|
</pre>
|
|
|
|
|
2019-08-27 17:21:32 +02:00
|
|
|
<h2><a id="usage">Usage</a></h2>
|
2017-07-04 16:50:00 +02:00
|
|
|
|
|
|
|
<p>
|
|
|
|
libvirt-dbus exports libvirt API using D-Bus objects with methods and
|
|
|
|
properties described by interfaces. Currently only local connection
|
|
|
|
to libvirt is exported and the list of supported drivers depends
|
|
|
|
on the type of the bus connection (session or system).
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The name of the libvirt-dbus service is <code>org.libvirt</code>.
|
|
|
|
libvirt-dbus distributes an interface XML descriptions which can be
|
|
|
|
usually found at <code>/usr/share/dbus-1/interfaces/</code>.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
By default unprivileged user has access only to the session D-Bus
|
|
|
|
connection. In order to allow specific user "foo" to access the system
|
|
|
|
D-Bus connection you need to create a file
|
|
|
|
<code>/etc/dbus-1/system.d/org.libvirt.conf</code> that contains:
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
<?xml version="1.0"?>
|
|
|
|
<!DOCTYPE busconfig PUBLIC "-//freedesktop//DTD D-BUS Bus Configuration 1.0//EN"
|
|
|
|
"http://www.freedesktop.org/standards/dbus/1.0/busconfig.dtd">
|
|
|
|
|
|
|
|
<busconfig>
|
|
|
|
|
|
|
|
<policy user="foo">
|
|
|
|
<allow send_destination="org.libvirt"/>
|
|
|
|
</policy>
|
|
|
|
|
|
|
|
</busconfig>
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
To get a list of supported drivers for the specific bus connection
|
|
|
|
you can run these commands (not all drivers may be available on
|
|
|
|
the host):
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
gdbus introspect --xml --session --dest org.libvirt --object-path /org/libvirt
|
|
|
|
gdbus introspect --xml --system --dest org.libvirt --object-path /org/libvirt
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Every object is introspectable so you can get a list of available
|
|
|
|
interfaces with methods, signals and properties running this command:
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
gdbus introspect --xml --system --dest org.libvirt --object-path /org/libvirt/QEMU
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
To get a list of domains for specific connection driver you can run
|
|
|
|
this command:
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
gdbus call --system --dest org.libvirt --object-path /org/libvirt/QEMU \
|
|
|
|
--method org.libvirt.Connect.ListDomains 0
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
</body>
|
|
|
|
</html>
|