File: index.rst

package info (click to toggle)
dbus-fast 4.0.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,816 kB
  • sloc: python: 10,129; xml: 39; makefile: 29; sh: 5
file content (118 lines) | stat: -rw-r--r-- 3,871 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
The Low Level Interface
=======================

.. toctree::
   :maxdepth: 2

   message

The low-level interface allows you to work with messages directly
through the :class:`MessageBus <dbus_fast.message_bus.BaseMessageBus>`
with the :class:`Message <dbus_fast.Message>` class. This might be
useful in the following cases:

- Implementing an application that works with DBus directly like
  ``dbus-send(1)`` or ``dbus-monitor(1)``.
- Creating a new implementation of the :class:`BaseMessageBus
  <dbus_fast.message_bus.BaseMessageBus>`.
- Creating clients or services that use an alternative to the standard
  DBus interfaces.

The primary methods and classes of the low-level interface are:

- :class:`Message <dbus_fast.Message>`
- :func:`MessageBus.send() <dbus_fast.message_bus.BaseMessageBus.send>`
- :func:`MessageBus.add_message_handler()
  <dbus_fast.message_bus.BaseMessageBus.add_message_handler>`
- :func:`MessageBus.remove_message_handler()
  <dbus_fast.message_bus.BaseMessageBus.remove_message_handler>`
- :func:`MessageBus.next_serial()
  <dbus_fast.message_bus.BaseMessageBus.next_serial>`
- :func:`aio.MessageBus.call() <dbus_fast.aio.MessageBus.call>`
- :func:`glib.MessageBus.call() <dbus_fast.glib.MessageBus.call>`
- :func:`glib.MessageBus.call_sync()
  <dbus_fast.glib.MessageBus.call_sync>`

Mixed use of the low and high level interfaces on the same bus
connection is not recommended.

:example:
   Call a standard interface

.. code-block:: python3

    bus = await MessageBus().connect()

    msg = Message(destination='org.freedesktop.DBus',
                  path='/org/freedesktop/DBus',
                  interface='org.freedesktop.DBus',
                  member='ListNames',
                  serial=bus.next_serial())

    reply = await bus.call(msg)

    assert reply.message_type == MessageType.METHOD_RETURN

    print(reply.body[0])

:example:
   A custom method handler. Note that to receive these messages, you
   must `add a match rule
   <https://dbus.freedesktop.org/doc/dbus-specification.html#message-bus-routing-match-rules>`_
   for the types of messages you want to receive.

.. code-block:: python3

    bus = await MessageBus().connect()

    reply = await bus.call(
        Message(destination='org.freedesktop.DBus',
                path='/org/freedesktop/DBus',
                member='AddMatch',
                signature='s',
                body=["member='MyMember', interface='com.test.interface'"]))

    assert reply.message_type == MessageType.METHOD_RETURN

    def message_handler(msg):
        if msg.interface == 'com.test.interface' and msg.member == 'MyMember':
            return Message.new_method_return(msg, 's', ['got it'])

    bus.add_message_handler(message_handler)

    await bus.wait_for_disconnect()

:example:
   Emit a signal

.. code-block:: python3

    bus = await MessageBus().connect()

    await bus.send(Message.new_signal('/com/test/path',
                                      'com.test.interface',
                                      'SomeSignal',
                                      's', ['a signal']))

:example:
   Send a file descriptor. The message format will be the same when
   received on the client side. You are responsible for closing any file
   descriptor that is sent or received by the bus. You must set the
   ``negotiate_unix_fd`` flag to ``True`` in the ``MessageBus``
   constructor to use unix file descriptors.

.. code-block:: python3

    bus = await MessageBus().connect(negotiate_unix_fd=True)

    fd = os.open('/dev/null', os.O_RDONLY)

    msg = Message(destination='org.test.destination',
                  path='/org/test/destination',
                  interface='org.test.interface',
                  member='TestMember',
                  signature='h',
                  body=[0],
                  unix_fds=[fd])

    await bus.send(msg)