glibmm 2.80.0
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Related Symbols | List of all members
Gio::DBus::Connection Class Reference

A D-Bus Connection. More...

#include <giomm/dbusconnection.h>

Inheritance diagram for Gio::DBus::Connection:
Inheritance graph
[legend]

Public Types

using SlotSignal = sigc::slot< void(const Glib::RefPtr< Connection > &, const Glib::ustring &, const Glib::ustring &, const Glib::ustring &, const Glib::ustring &, const Glib::VariantContainerBase &)>
 Signature for slot used in signal_subscribe().
 
using SlotMessageFilter = sigc::slot< Glib::RefPtr< Message >(const Glib::RefPtr< Connection > &, const Glib::RefPtr< Message > &, bool)>
 Signature for slot used in add_filter().
 
- Public Types inherited from Glib::Object
using DestroyNotify = void(*)(gpointer data)
 

Public Member Functions

 Connection (Connection &&src) noexcept
 
Connectionoperator= (Connection &&src) noexcept
 
 ~Connection () noexcept override
 
GDBusConnectiongobj ()
 Provides access to the underlying C GObject.
 
const GDBusConnectiongobj () const
 Provides access to the underlying C GObject.
 
GDBusConnectiongobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
 
void close ()
 Closes the connection.
 
void close (const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable)
 Closes the connection.
 
void close (const SlotAsyncReady &slot)
 Closes the connection.
 
bool close_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with g_dbus_connection_close().
 
void close_sync (const Glib::RefPtr< Cancellable > &cancellable)
 Synchronously closes connection.
 
void close_sync ()
 A close_sync() convenience overload.
 
void flush ()
 Asynchronously flushes the connection, that is, writes all queued outgoing message to the transport and then flushes the transport (using Gio::OutputStream::flush_async()).
 
void flush (const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable)
 Asynchronously flushes the connection, that is, writes all queued outgoing message to the transport and then flushes the transport (using Gio::OutputStream::flush_async()).
 
void flush (const SlotAsyncReady &slot)
 Asynchronously flushes the connection, that is, writes all queued outgoing message to the transport and then flushes the transport (using Gio::OutputStream::flush_async()).
 
bool flush_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with g_dbus_connection_flush().
 
void flush_sync (const Glib::RefPtr< Cancellable > &cancellable)
 Synchronously flushes connection.
 
void flush_sync ()
 A flush_sync() convenience overload.
 
bool get_exit_on_close () const
 Gets whether the process is terminated when connection is closed by the remote peer.
 
void set_exit_on_close (bool exit_on_close=true)
 Sets whether the process should be terminated when connection is closed by the remote peer.
 
bool send_message (const Glib::RefPtr< Message > & message, SendMessageFlags flags, guint32 &out_serial)
 Asynchronously sends message to the peer represented by connection.
 
bool send_message (const Glib::RefPtr< Message > & message, SendMessageFlags flags=Gio::DBus::SendMessageFlags::NONE)
 A send_message() without an "out_serial" parameter.
 
void send_message_with_reply (const Glib::RefPtr< Message > & message, int timeout_msec, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable)
 Asynchronously sends message to the peer represented by the connection.
 
void send_message_with_reply (const Glib::RefPtr< Message > & message, int timeout_msec, const SlotAsyncReady &slot)
 Non-cancellable version of send_message_with_reply().
 
Glib::RefPtr< Messagesend_message_with_reply_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with g_dbus_connection_send_message_with_reply().
 
Glib::RefPtr< Messagesend_message_with_reply_sync (const Glib::RefPtr< Message > & message, const Glib::RefPtr< Cancellable > &cancellable, gint timeout_msec)
 Synchronously sends message to the peer represented by the connection and blocks the calling thread until a reply is received or the timeout is reached.
 
Glib::RefPtr< Messagesend_message_with_reply_sync (const Glib::RefPtr< Message > & message, gint timeout_msec)
 A non-cancellable version of send_message_with_reply_sync().
 
void start_message_processing ()
 If connection was created with Gio::DBus::ConnectionFlags::DELAY_MESSAGE_PROCESSING, this method starts processing messages.
 
bool is_closed () const
 Gets whether connection is closed.
 
Glib::RefPtr< IOStreamget_stream ()
 Gets the underlying stream used for IO.
 
Glib::RefPtr< const IOStreamget_stream () const
 Gets the underlying stream used for IO.
 
std::string get_guid () const
 The GUID of the peer performing the role of server when authenticating.
 
Glib::ustring get_unique_name () const
 Gets the unique name of connection as assigned by the message bus.
 
CapabilityFlags get_capabilities () const
 Gets the capabilities negotiated with the remote peer.
 
ConnectionFlags get_flags () const
 Gets the flags used to construct this connection.
 
Glib::RefPtr< Credentialsget_peer_credentials ()
 Gets the credentials of the authenticated peer.
 
Glib::RefPtr< const Credentialsget_peer_credentials () const
 Gets the credentials of the authenticated peer.
 
guint32 get_last_serial () const
 Retrieves the last serial number assigned to a Gio::DBus::Message on the current thread.
 
void call (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 Asynchronously invokes the method_name method on the interface_name D-Bus interface on the remote object at object_path owned by bus_name.
 
void call (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const SlotAsyncReady &slot, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 A non-cancellable version of call().
 
Glib::VariantContainerBase call_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with call().
 
Glib::VariantContainerBase call_sync (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const Glib::RefPtr< Cancellable > &cancellable, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 Synchronously invokes the method_name method on the interface_name D-Bus interface on the remote object at object_path owned by bus_name.
 
Glib::VariantContainerBase call_sync (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 A non-cancellable version of call_sync().
 
void call (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, const Glib::RefPtr< UnixFDList > &fd_list, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 Like call() but also takes a GUnixFDList object.
 
void call (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const SlotAsyncReady &slot, const Glib::RefPtr< UnixFDList > &fd_list, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 A non-cancellable version of call() (with a UnixFDList).
 
Glib::VariantContainerBase call_finish (const Glib::RefPtr< AsyncResult > &res, Glib::RefPtr< UnixFDList > &out_fd_list)
 Finishes an operation started with call() (with a UnixFDList).
 
Glib::VariantContainerBase call_sync (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const Glib::RefPtr< Cancellable > &cancellable, const Glib::RefPtr< UnixFDList > &fd_list, Glib::RefPtr< UnixFDList > &out_fd_list, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 Like g_dbus_connection_call_sync() but also takes and returns UnixFDList objects.
 
Glib::VariantContainerBase call_sync (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &method_name, const Glib::VariantContainerBase &parameters, const Glib::RefPtr< UnixFDList > &fd_list, Glib::RefPtr< UnixFDList > &out_fd_list, const Glib::ustring &bus_name={}, int timeout_msec=-1, CallFlags flags=Gio::DBus::CallFlags::NONE, const Glib::VariantType &reply_type={})
 A call_sync() convenience overload.
 
void emit_signal (const Glib::ustring &object_path, const Glib::ustring &interface_name, const Glib::ustring &signal_name, const Glib::ustring &destination_bus_name={}, const Glib::VariantContainerBase &parameters={})
 Emits a signal.
 
guint signal_subscribe (const SlotSignal &slot, const Glib::ustring &sender={}, const Glib::ustring &interface_name={}, const Glib::ustring &member={}, const Glib::ustring &object_path={}, const Glib::ustring &arg0={}, SignalFlags flags=Gio::DBus::SignalFlags::NONE)
 Subscribes to signals on the connection and invokes slot with a whenever the signal is received.
 
void signal_unsubscribe (guint subscription_id)
 Unsubscribes from signals.
 
guint add_filter (const SlotMessageFilter &slot)
 Adds a message filter.
 
void remove_filter (guint filter_id)
 Removes a filter.
 
guint register_object (const Glib::ustring &object_path, const Glib::RefPtr< InterfaceInfo > &interface_info, const InterfaceVTable &vtable)
 Registers slots for exported objects at object_path with the D-Bus interface that is described in interface_info.
 
guint register_object (const Glib::ustring &object_path, const Glib::RefPtr< InterfaceInfo > &interface_info)
 Registers exported objects at object_path with the D-Bus interface that is described in interface_info.
 
bool unregister_object (guint registration_id)
 Unregisters an object.
 
guint register_subtree (const Glib::ustring &object_path, const SubtreeVTable &vtable, SubtreeFlags flags=Gio::DBus::SubtreeFlags::NONE)
 Registers a whole subtree of “dynamic” objects.
 
bool unregister_subtree (guint registration_id)
 Unregisters a subtree.
 
guint export_action_group (const Glib::ustring &object_path, const Glib::RefPtr< ActionGroup > &action_group)
 Exports action_group on connection at object_path.
 
void unexport_action_group (guint export_id)
 Reverses the effect of a previous call to g_dbus_connection_export_action_group().
 
guint export_menu_model (const Glib::ustring &object_path, const Glib::RefPtr< MenuModel > &menu)
 Exports menu on connection at object_path.
 
void unexport_menu_model (guint export_id)
 Reverses the effect of a previous call to g_dbus_connection_export_menu_model().
 
Glib::PropertyProxy_ReadOnly< CapabilityFlagsproperty_capabilities () const
 Flags from the DBusCapabilityFlags enumeration representing connection features negotiated with the other peer.
 
Glib::PropertyProxy_ReadOnly< bool > property_closed () const
 A boolean specifying whether the connection has been closed.
 
Glib::PropertyProxy< bool > property_exit_on_close ()
 A boolean specifying whether the process will be terminated (by calling raise(SIGTERM)) if the connection is closed by the remote peer.
 
Glib::PropertyProxy_ReadOnly< bool > property_exit_on_close () const
 A boolean specifying whether the process will be terminated (by calling raise(SIGTERM)) if the connection is closed by the remote peer.
 
Glib::PropertyProxy_ReadOnly< ConnectionFlagsproperty_flags () const
 Flags from the DBusConnectionFlags enumeration.
 
Glib::PropertyProxy_ReadOnly< std::stringproperty_guid () const
 The GUID of the peer performing the role of server when authenticating.
 
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< IOStream > > property_stream () const
 The underlying IOStream used for I/O.
 
Glib::PropertyProxy_ReadOnly< Glib::ustringproperty_unique_name () const
 The unique name as assigned by the message bus or nullptr if the connection is not open or not a message bus connection.
 
Glib::SignalProxy< void(bool, const Glib::Error &)> signal_closed ()
 
- Public Member Functions inherited from Glib::Object
 Object (const Object &)=delete
 
Objectoperator= (const Object &)=delete
 
 Object (Object &&src) noexcept
 
Objectoperator= (Object &&src) noexcept
 
voidget_data (const QueryQuark & key)
 
void set_data (const Quark & key, void *data)
 
void set_data_with_c_callback (const Quark & key, void *data, GDestroyNotify notify)
 
void set_data (const Quark & key, void *data, DestroyNotify notify)
 Prefer set_data_with_c_callback() with a callback with C linkage.
 
void remove_data (const QueryQuark &quark)
 
voidsteal_data (const QueryQuark &quark)
 
- Public Member Functions inherited from Glib::ObjectBase
 ObjectBase (const ObjectBase &)=delete
 
ObjectBaseoperator= (const ObjectBase &)=delete
 
void set_property_value (const Glib::ustring & property_name, const Glib::ValueBase & value)
 You probably want to use a specific property_*() accessor method instead.
 
void get_property_value (const Glib::ustring & property_name, Glib::ValueBase & value) const
 You probably want to use a specific property_*() accessor method instead.
 
template<class PropertyType >
void set_property (const Glib::ustring & property_name, const PropertyType & value)
 You probably want to use a specific property_*() accessor method instead.
 
template<class PropertyType >
void get_property (const Glib::ustring & property_name, PropertyType & value) const
 You probably want to use a specific property_*() accessor method instead.
 
template<class PropertyType >
PropertyType get_property (const Glib::ustring & property_name) const
 You probably want to use a specific property_*() accessor method instead.
 
sigc::connection connect_property_changed (const Glib::ustring & property_name, const sigc::slot< void()> &slot)
 You can use the signal_changed() signal of the property proxy instead.
 
sigc::connection connect_property_changed (const Glib::ustring & property_name, sigc::slot< void()> &&slot)
 You can use the signal_changed() signal of the property proxy instead.
 
void freeze_notify ()
 Increases the freeze count on object.
 
void thaw_notify ()
 Reverts the effect of a previous call to freeze_notify().
 
virtual void reference () const
 Increment the reference count for this object.
 
virtual void unreference () const
 Decrement the reference count for this object.
 
GObject * gobj ()
 Provides access to the underlying C GObject.
 
const GObject * gobj () const
 Provides access to the underlying C GObject.
 
GObject * gobj_copy () const
 Give a ref-ed copy to someone. Use for direct struct access.
 
- Public Member Functions inherited from Gio::Initable
 Initable (Initable &&src) noexcept
 
Initableoperator= (Initable &&src) noexcept
 
 ~Initable () noexcept override
 
GInitablegobj ()
 Provides access to the underlying C GObject.
 
const GInitablegobj () const
 Provides access to the underlying C GObject.
 
- Public Member Functions inherited from Glib::Interface
 Interface ()
 A Default constructor.
 
 Interface (Interface &&src) noexcept
 
Interfaceoperator= (Interface &&src) noexcept
 
 Interface (const Glib::Interface_Class &interface_class)
 Called by constructors of derived classes.
 
 Interface (GObject *castitem)
 Called by constructors of derived classes.
 
 ~Interface () noexcept override
 
 Interface (const Interface &)=delete
 
Interfaceoperator= (const Interface &)=delete
 
GObject * gobj ()
 
const GObject * gobj () const
 
- Public Member Functions inherited from Gio::AsyncInitable
 AsyncInitable (AsyncInitable &&src) noexcept
 
AsyncInitableoperator= (AsyncInitable &&src) noexcept
 
 ~AsyncInitable () noexcept override
 
GAsyncInitablegobj ()
 Provides access to the underlying C GObject.
 
const GAsyncInitablegobj () const
 Provides access to the underlying C GObject.
 

Static Public Member Functions

static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system.
 
static void get (BusType bus_type, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable)
 Asynchronously connects to the message bus specified by bus_type.
 
static void get (BusType bus_type, const SlotAsyncReady &slot)
 Non-cancellable version of get().
 
static Glib::RefPtr< Connectionget_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with g_bus_get().
 
static Glib::RefPtr< Connectionget_sync (BusType bus_type, const Glib::RefPtr< Cancellable > &cancellable)
 Synchronously connects to the message bus specified by bus_type.
 
static Glib::RefPtr< Connectionget_sync (BusType bus_type)
 A get_sync() convenience overload.
 
static void create (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Asynchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.
 
static void create (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Asynchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.
 
static void create (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create().
 
static void create (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const SlotAsyncReady &slot, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create().
 
static Glib::RefPtr< Connectioncreate_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with g_dbus_connection_new().
 
static void create_for_address (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Asynchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.
 
static void create_for_address (const std::string &address, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Asynchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.
 
static void create_for_address (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create_for_address().
 
static void create_for_address (const std::string &address, const SlotAsyncReady &slot, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create_for_address().
 
static Glib::RefPtr< Connectioncreate_for_address_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes an operation started with g_dbus_connection_new_for_address().
 
static Glib::RefPtr< Connectioncreate_sync (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Synchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.
 
static Glib::RefPtr< Connectioncreate_sync (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Synchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.
 
static Glib::RefPtr< Connectioncreate_sync (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create_sync().
 
static Glib::RefPtr< Connectioncreate_sync (const Glib::RefPtr< IOStream > &stream, const std::string &guid, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create_sync().
 
static Glib::RefPtr< Connectioncreate_for_address_sync (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Synchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.
 
static Glib::RefPtr< Connectioncreate_for_address_sync (const std::string &address, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Synchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.
 
static Glib::RefPtr< Connectioncreate_for_address_sync (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create_for_address_sync().
 
static Glib::RefPtr< Connectioncreate_for_address_sync (const std::string &address, ConnectionFlags flags=Gio::DBus::ConnectionFlags::NONE)
 Non-cancellable version of create_for_address_sync().
 
- Static Public Member Functions inherited from Gio::Initable
static void add_interface (GType gtype_implementer)
 
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system.
 
- Static Public Member Functions inherited from Gio::AsyncInitable
static void add_interface (GType gtype_implementer)
 
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system.
 

Protected Member Functions

 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const SlotAsyncReady &slot, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, const Glib::RefPtr< AuthObserver > &observer, ConnectionFlags flags)
 
 Connection (const Glib::RefPtr< IOStream > &stream, const std::string &guid, ConnectionFlags flags)
 
 Connection (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const std::string &address, const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, const SlotAsyncReady &slot, ConnectionFlags flags)
 
 Connection (const std::string &address, const SlotAsyncReady &slot, ConnectionFlags flags)
 
 Connection (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const std::string &address, const Glib::RefPtr< Cancellable > &cancellable, ConnectionFlags flags)
 
 Connection (const std::string &address, const Glib::RefPtr< AuthObserver > &observer, ConnectionFlags flags)
 
 Connection (const std::string &address, ConnectionFlags flags)
 
- Protected Member Functions inherited from Glib::Object
 Object ()
 
 Object (const Glib::ConstructParams &construct_params)
 
 Object (GObject *castitem)
 
 ~Object () noexcept override
 
- Protected Member Functions inherited from Glib::ObjectBase
 ObjectBase ()
 This default constructor is called implicitly from the constructor of user-derived classes, even if, for instance, Gtk::Button calls a different ObjectBase constructor.
 
 ObjectBase (const char *custom_type_name)
 A derived constructor always overrides this choice.
 
 ObjectBase (const std::type_info &custom_type_info)
 This constructor is a special feature to allow creation of derived types on the fly, without having to use g_object_new() manually.
 
 ObjectBase (ObjectBase &&src) noexcept
 
ObjectBaseoperator= (ObjectBase &&src) noexcept
 
virtual ~ObjectBase () noexcept=0
 
void initialize (GObject *castitem)
 
void initialize_move (GObject *castitem, Glib::ObjectBase *previous_wrapper)
 
- Protected Member Functions inherited from Gio::Initable
 Initable ()
 You should derive from this class to use it.
 
void init (const Glib::RefPtr< Cancellable > &cancellable)
 Initializes the object implementing the interface.
 
void init ()
 A init() convenience overload.
 
virtual bool init_vfunc (const Glib::RefPtr< Cancellable > &cancellable, GError **error)
 
- Protected Member Functions inherited from Gio::AsyncInitable
 AsyncInitable ()
 You should derive from this class to use it.
 
void init_async (const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, int io_priority=Glib::PRIORITY_DEFAULT)
 Starts asynchronous initialization of the object implementing the interface.
 
void init_async (const SlotAsyncReady &slot, int io_priority=Glib::PRIORITY_DEFAULT)
 Non-cancellable version of init_async().
 
bool init_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes asynchronous initialization and returns the result.
 
Glib::RefPtr< Glib::Objectcreate_finish (const Glib::RefPtr< AsyncResult > &res)
 Finishes the async construction for the various g_async_initable_new calls, returning the created object or nullptr on error.
 
virtual void init_async_vfunc (const SlotAsyncReady &slot, const Glib::RefPtr< Cancellable > &cancellable, int io_priority=Glib::PRIORITY_DEFAULT)
 
virtual bool init_finish_vfunc (const Glib::RefPtr< AsyncResult > &res)
 

Related Symbols

(Note that these are not member symbols.)

Glib::RefPtr< Gio::DBus::Connectionwrap (GDBusConnection *object, bool take_copy=false)
 A Glib::wrap() method for this object.
 

Detailed Description

A D-Bus Connection.

The Connection type is used for D-Bus connections to remote peers such as a message buses. It is a low-level API that offers a lot of flexibility. For instance, it lets you establish a connection over any transport that can by represented as an IOStream.

This class is rarely used directly in D-Bus clients. If you are writing a D-Bus client, it is often easier to use the Gio::DBus::own_name(), Gio::DBus::watch_name() or Gio::DBus::Proxy::create_for_bus() APIs.

Since glibmm 2.28:

Member Typedef Documentation

◆ SlotMessageFilter

Signature for slot used in add_filter().

For example,

Glib::RefPtr<Message> on_message_filter(const
message, bool incoming);.

A filter function is passed a Message and expected to return a Message too. Passive filter functions that don't modify the message can simply return the message object. Filter functions that wants to drop a message can simply return 0. And filter function may modify a message by copying it and return the copy.

◆ SlotSignal

Signature for slot used in signal_subscribe().

For example,

void on_signal(const Glib::RefPtr<Connection>& connection, const
Glib::ustring& sender_name, const Glib::ustring& object_path, const
Glib::ustring& object_path, const Glib::ustring& interface_name, const
Glib::ustring& signal_name, const Glib::VariantContainerBase& parameters);.
The base class for multiple-item Variants, such as Variants containing tuples or arrays,...
Definition variant.h:731
Glib::ustring has much the same interface as std::string, but contains Unicode characters encoded as ...
Definition ustring.h:336

Constructor & Destructor Documentation

◆ Connection() [1/17]

Gio::DBus::Connection::Connection ( Connection &&  src)
noexcept

◆ ~Connection()

Gio::DBus::Connection::~Connection ( )
overridenoexcept

◆ Connection() [2/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [3/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [4/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
ConnectionFlags  flags 
)
protected

◆ Connection() [5/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const SlotAsyncReady &  slot,
ConnectionFlags  flags 
)
protected

◆ Connection() [6/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [7/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [8/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
ConnectionFlags  flags 
)
protected

◆ Connection() [9/17]

Gio::DBus::Connection::Connection ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
ConnectionFlags  flags 
)
protected

◆ Connection() [10/17]

Gio::DBus::Connection::Connection ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [11/17]

Gio::DBus::Connection::Connection ( const std::string address,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [12/17]

Gio::DBus::Connection::Connection ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
ConnectionFlags  flags 
)
protected

◆ Connection() [13/17]

Gio::DBus::Connection::Connection ( const std::string address,
const SlotAsyncReady &  slot,
ConnectionFlags  flags 
)
protected

◆ Connection() [14/17]

Gio::DBus::Connection::Connection ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [15/17]

Gio::DBus::Connection::Connection ( const std::string address,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags 
)
protected

◆ Connection() [16/17]

Gio::DBus::Connection::Connection ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
ConnectionFlags  flags 
)
protected

◆ Connection() [17/17]

Gio::DBus::Connection::Connection ( const std::string address,
ConnectionFlags  flags 
)
protected

Member Function Documentation

◆ add_filter()

guint Gio::DBus::Connection::add_filter ( const SlotMessageFilter slot)

Adds a message filter.

Filters are handlers that are run on all incoming and outgoing messages, prior to standard dispatch. Filters are run in the order that they were added. The same handler can be added as a filter more than once, in which case it will be run more than once. Filters added during a filter slot won't be run on the message being processed. Filter slots are allowed to modify and even drop messages.

Note that filters are run in a dedicated message handling thread so they can't block and, generally, can't do anything but signal a worker thread. Also note that filters are rarely needed - use API such as send_message_with_reply(), signal_subscribe() or call() instead.

If a filter consumes an incoming message the message is not dispatched anywhere else - not even the standard dispatch machinery (that API such as signal_subscribe() and send_message_with_reply() relies on) will see the message. Similary, if a filter consumes an outgoing message, the message will not be sent to the other peer.

Parameters
slotA filter slot.
Returns
A filter identifier that can be used with remove_filter().
Since glibmm 2.28:

◆ call() [1/4]

void Gio::DBus::Connection::call ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
const Glib::RefPtr< UnixFDList > &  fd_list,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

Like call() but also takes a GUnixFDList object.

This method is only available on UNIX.

This is an asynchronous method. When the operation is finished, callback will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call call_with_unix_fd_finish() to get the result of the operation. See call_sync() for the synchronous version of this function.

Parameters
object_pathPath of remote object.
interface_nameD-Bus interface to invoke method on.
method_nameThe name of the method to invoke.
parametersA Glib::VariantContainerBase tuple with parameters for the method or 0 if not passing parameters.
slotA SlotAsyncReady to call when the request is satisfied.
cancellableA Cancellable.
fd_listA UnixFDList.
bus_nameA unique or well-known bus name or an empty string if the connection is not a message bus connection.
timeout_msecThe timeout in milliseconds, -1 to use the default timeout or G_MAXINT for no timeout.
flagsFlags from the Gio::DBus::CallFlags enumeration.
reply_typeThe expected type of the reply, or 0.
Since glibmm 2.34:

◆ call() [2/4]

void Gio::DBus::Connection::call ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

Asynchronously invokes the method_name method on the interface_name D-Bus interface on the remote object at object_path owned by bus_name.

If the connection is closed then the operation will fail with Gio::IO_ERROR_CLOSED. If cancellable is cancelled, the operation will fail with Gio::IO_ERROR_CANCELLED. If parameters contains a value not compatible with the D-Bus protocol, the operation fails with Gio::IO_ERROR_INVALID_ARGUMENT.

If reply_type is non-0 then the reply will be checked for having this type and an error will be raised if it does not match. Said another way, if you give a reply_type then any non-0 return value will be of this type.

This is an asynchronous method. When the operation is finished, callback will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call call_finish() to get the result of the operation. See call_sync() for the synchronous version of this function.

Parameters
object_pathPath of remote object.
interface_nameD-Bus interface to invoke method on.
method_nameThe name of the method to invoke.
parametersA Glib::VariantContainerBase tuple with parameters for the method or 0 if not passing parameters.
slotA SlotAsyncReady to call when the request is satisfied.
cancellableA Cancellable.
bus_nameA unique or well-known bus name or an empty string if the connection is not a message bus connection.
timeout_msecThe timeout in milliseconds, -1 to use the default timeout or G_MAXINT for no timeout.
flagsFlags from the Gio::DBus::CallFlags enumeration.
reply_typeThe expected type of the reply, or 0.
Since glibmm 2.28:

◆ call() [3/4]

void Gio::DBus::Connection::call ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const SlotAsyncReady &  slot,
const Glib::RefPtr< UnixFDList > &  fd_list,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

A non-cancellable version of call() (with a UnixFDList).

Since glibmm 2.34:

◆ call() [4/4]

void Gio::DBus::Connection::call ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const SlotAsyncReady &  slot,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

A non-cancellable version of call().

◆ call_finish() [1/2]

Glib::VariantContainerBase Gio::DBus::Connection::call_finish ( const Glib::RefPtr< AsyncResult > &  res)

Finishes an operation started with call().

Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to call().
Returns
A Variant tuple with return values.
Exceptions
Glib::Error.
Since glibmm 2.28:

◆ call_finish() [2/2]

Glib::VariantContainerBase Gio::DBus::Connection::call_finish ( const Glib::RefPtr< AsyncResult > &  res,
Glib::RefPtr< UnixFDList > &  out_fd_list 
)

Finishes an operation started with call() (with a UnixFDList).

Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to call().
out_fd_listReturn location for a UnixFDList.
Returns
A Variant tuple with return values.
Exceptions
Glib::Error.
Since glibmm 2.34:

◆ call_sync() [1/4]

Glib::VariantContainerBase Gio::DBus::Connection::call_sync ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const Glib::RefPtr< Cancellable > &  cancellable,
const Glib::RefPtr< UnixFDList > &  fd_list,
Glib::RefPtr< UnixFDList > &  out_fd_list,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

Like g_dbus_connection_call_sync() but also takes and returns UnixFDList objects.

See g_dbus_connection_call_with_unix_fd_list() and g_dbus_connection_call_with_unix_fd_list_finish() for more details.

This method is only available on UNIX.

Since glibmm 2.30:
Parameters
bus_nameA unique or well-known bus name or nullptr if connection is not a message bus connection.
object_pathPath of remote object.
interface_nameD-Bus interface to invoke method on.
method_nameThe name of the method to invoke.
parametersA Variant tuple with parameters for the method or nullptr if not passing parameters.
reply_typeThe expected type of the reply, or nullptr.
flagsFlags from the Gio::DBus::CallFlags enumeration.
timeout_msecThe timeout in milliseconds, -1 to use the default timeout or G_MAXINT for no timeout.
fd_listA UnixFDList or nullptr.
out_fd_listReturn location for a UnixFDList or nullptr.
cancellableA Cancellable or nullptr.
Returns
nullptr if error is set. Otherwise a non-floating Variant tuple with return values. Free with Glib::variant_unref().
Exceptions
Glib::Error

◆ call_sync() [2/4]

Glib::VariantContainerBase Gio::DBus::Connection::call_sync ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const Glib::RefPtr< Cancellable > &  cancellable,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

Synchronously invokes the method_name method on the interface_name D-Bus interface on the remote object at object_path owned by bus_name.

If the connection is closed then the operation will fail with Gio::IO_ERROR_CLOSED. If cancellable is cancelled, the operation will fail with Gio::IO_ERROR_CANCELLED. If parameters contains a value not compatible with the D-Bus protocol, the operation fails with Gio::IO_ERROR_INVALID_ARGUMENT.

If reply_type is non-0 then the reply will be checked for having this type and an error will be raised if it does not match. Said another way, if you give a reply_type then any non-0 return value will be of this type.

The calling thread is blocked until a reply is received. See call() for the asynchronous version of this method.

Parameters
object_pathPath of remote object.
interface_nameD-Bus interface to invoke method on.
method_nameThe name of the method to invoke.
parametersA Glib::VariantContainerBase tuple with parameters for the method or 0 if not passing parameters.
cancellableA Cancellable.
bus_nameA unique or well-known bus name or an empty string if the connection is not a message bus connection.
timeout_msecThe timeout in milliseconds, -1 to use the default timeout or G_MAXINT for no timeout.
flagsFlags from the Gio::DBus::CallFlags enumeration.
reply_typeThe expected type of the reply, or 0.
Returns
A Variant tuple with return values.
Exceptions
Glib::Error.
Since glibmm 2.28:

◆ call_sync() [3/4]

Glib::VariantContainerBase Gio::DBus::Connection::call_sync ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const Glib::RefPtr< UnixFDList > &  fd_list,
Glib::RefPtr< UnixFDList > &  out_fd_list,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

A call_sync() convenience overload.

◆ call_sync() [4/4]

Glib::VariantContainerBase Gio::DBus::Connection::call_sync ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring method_name,
const Glib::VariantContainerBase parameters,
const Glib::ustring bus_name = {},
int  timeout_msec = -1,
CallFlags  flags = Gio::DBus::CallFlags::NONE,
const Glib::VariantType reply_type = {} 
)

A non-cancellable version of call_sync().

◆ close() [1/3]

void Gio::DBus::Connection::close ( )

Closes the connection.

Note that this never causes the process to exit (this might only happen if the other end of a shared message bus connection disconnects, see property_exit_on_close()).

Once the connection is closed, operations such as sending a message will return with the error Gio::IO_ERROR_CLOSED. Closing a connection will not automatically flush the connection so queued messages may be lost. Use flush() if you need such guarantees.

If the connection is already closed, this method fails with Gio::IO_ERROR_CLOSED.

When the connection has been closed, the "closed" signal is emitted in the thread-default main loop of the thread that connection was constructed in.

This is an asynchronous method. See close_sync() for the synchronous version.

Since glibmm 2.28:

◆ close() [2/3]

void Gio::DBus::Connection::close ( const SlotAsyncReady &  slot)

Closes the connection.

Note that this never causes the process to exit (this might only happen if the other end of a shared message bus connection disconnects, see property_exit_on_close()).

Once the connection is closed, operations such as sending a message will return with the error Gio::IO_ERROR_CLOSED. Closing a connection will not automatically flush the connection so queued messages may be lost. Use flush() if you need such guarantees.

If the connection is already closed, this method fails with Gio::IO_ERROR_CLOSED.

When the connection has been closed, the "closed" signal is emitted in the thread-default main loop of the thread that connection was constructed in.

This is an asynchronous method. When the operation is finished, slot will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call close_finish() to get the result of the operation. See close_sync() for the synchronous version.

Parameters
slotA SlotAsyncReady to call when the request is satisfied.
Since glibmm 2.28:

◆ close() [3/3]

void Gio::DBus::Connection::close ( const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable 
)

Closes the connection.

Note that this never causes the process to exit (this might only happen if the other end of a shared message bus connection disconnects, see property_exit_on_close()).

Once the connection is closed, operations such as sending a message will return with the error Gio::IO_ERROR_CLOSED. Closing a connection will not automatically flush the connection so queued messages may be lost. Use flush() if you need such guarantees.

If the connection is already closed, this method fails with Gio::IO_ERROR_CLOSED.

When the connection has been closed, the "closed" signal is emitted in the thread-default main loop of the thread that connection was constructed in.

This is an asynchronous method. When the operation is finished, slot will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call close_finish() to get the result of the operation. See close_sync() for the synchronous version.

Parameters
slotA SlotAsyncReady to call when the request is satisfied.
cancellableA Cancellable.
Since glibmm 2.28:

◆ close_finish()

bool Gio::DBus::Connection::close_finish ( const Glib::RefPtr< AsyncResult > &  res)

Finishes an operation started with g_dbus_connection_close().

Since glibmm 2.26:
Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to g_dbus_connection_close().
Returns
true if the operation succeeded, false if error is set.
Exceptions
Glib::Error

◆ close_sync() [1/2]

void Gio::DBus::Connection::close_sync ( )

A close_sync() convenience overload.

◆ close_sync() [2/2]

void Gio::DBus::Connection::close_sync ( const Glib::RefPtr< Cancellable > &  cancellable)

Synchronously closes connection.

The calling thread is blocked until this is done. See g_dbus_connection_close() for the asynchronous version of this method and more details about what it does.

Since glibmm 2.26:
Parameters
cancellableA Cancellable or nullptr.
Exceptions
Glib::Error

◆ create() [1/4]

static void Gio::DBus::Connection::create ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create().

◆ create() [2/4]

static void Gio::DBus::Connection::create ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Asynchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.

If stream is a SocketConnection, then the corresponding Socket will be put into non-blocking mode.

The D-Bus connection will interact with stream from a worker thread. As a result, the caller should not interact with stream after this method has been called, except by calling Glib::object_unref() on it.

If observer is not nullptr it may be used to control the authentication process.

When the operation is finished, slot will be invoked. You can then call g_dbus_connection_new_finish() to get the result of the operation.

This is an asynchronous failable constructor. See g_dbus_connection_new_sync() for the synchronous version.

Since glibmm 2.26:
Parameters
streamA IOStream.
guidThe GUID to use if authenticating as a server or nullptr.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
slotA SlotAsyncReady to call when the request is satisfied.
user_dataThe data to pass to slot.

◆ create() [3/4]

static void Gio::DBus::Connection::create ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const SlotAsyncReady &  slot,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create().

◆ create() [4/4]

static void Gio::DBus::Connection::create ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Asynchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.

If stream is a SocketConnection, then the corresponding Socket will be put into non-blocking mode.

The D-Bus connection will interact with stream from a worker thread. As a result, the caller should not interact with stream after this method has been called, except by calling Glib::object_unref() on it.

If observer is not nullptr it may be used to control the authentication process.

When the operation is finished, slot will be invoked. You can then call g_dbus_connection_new_finish() to get the result of the operation.

This is an asynchronous failable constructor. See g_dbus_connection_new_sync() for the synchronous version.

Since glibmm 2.26:
Parameters
streamA IOStream.
guidThe GUID to use if authenticating as a server or nullptr.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
slotA SlotAsyncReady to call when the request is satisfied.
user_dataThe data to pass to slot.

◆ create_finish()

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_finish ( const Glib::RefPtr< AsyncResult > &  res)
static

Finishes an operation started with g_dbus_connection_new().

Since glibmm 2.26:
Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to g_dbus_connection_new().
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ create_for_address() [1/4]

static void Gio::DBus::Connection::create_for_address ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create_for_address().

◆ create_for_address() [2/4]

static void Gio::DBus::Connection::create_for_address ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Asynchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.

This constructor can only be used to initiate client-side connections - use g_dbus_connection_new() if you need to act as the server. In particular, flags cannot contain the Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER, Gio::DBus::ConnectionFlags::AUTHENTICATION_ALLOW_ANONYMOUS or Gio::DBus::ConnectionFlags::AUTHENTICATION_REQUIRE_SAME_USER flags.

When the operation is finished, slot will be invoked. You can then call g_dbus_connection_new_for_address_finish() to get the result of the operation.

If observer is not nullptr it may be used to control the authentication process.

This is an asynchronous failable constructor. See g_dbus_connection_new_for_address_sync() for the synchronous version.

Since glibmm 2.26:
Parameters
addressA D-Bus address.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
slotA SlotAsyncReady to call when the request is satisfied.
user_dataThe data to pass to slot.

◆ create_for_address() [3/4]

static void Gio::DBus::Connection::create_for_address ( const std::string address,
const SlotAsyncReady &  slot,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create_for_address().

◆ create_for_address() [4/4]

static void Gio::DBus::Connection::create_for_address ( const std::string address,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Asynchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.

This constructor can only be used to initiate client-side connections - use g_dbus_connection_new() if you need to act as the server. In particular, flags cannot contain the Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER, Gio::DBus::ConnectionFlags::AUTHENTICATION_ALLOW_ANONYMOUS or Gio::DBus::ConnectionFlags::AUTHENTICATION_REQUIRE_SAME_USER flags.

When the operation is finished, slot will be invoked. You can then call g_dbus_connection_new_for_address_finish() to get the result of the operation.

If observer is not nullptr it may be used to control the authentication process.

This is an asynchronous failable constructor. See g_dbus_connection_new_for_address_sync() for the synchronous version.

Since glibmm 2.26:
Parameters
addressA D-Bus address.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
slotA SlotAsyncReady to call when the request is satisfied.
user_dataThe data to pass to slot.

◆ create_for_address_finish()

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_for_address_finish ( const Glib::RefPtr< AsyncResult > &  res)
static

Finishes an operation started with g_dbus_connection_new_for_address().

Since glibmm 2.26:
Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to g_dbus_connection_new().
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ create_for_address_sync() [1/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_for_address_sync ( const std::string address,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create_for_address_sync().

◆ create_for_address_sync() [2/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_for_address_sync ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create_for_address_sync().

◆ create_for_address_sync() [3/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_for_address_sync ( const std::string address,
const Glib::RefPtr< AuthObserver > &  observer,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Synchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.

This constructor can only be used to initiate client-side connections - use g_dbus_connection_new_sync() if you need to act as the server. In particular, flags cannot contain the Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER, Gio::DBus::ConnectionFlags::AUTHENTICATION_ALLOW_ANONYMOUS or Gio::DBus::ConnectionFlags::AUTHENTICATION_REQUIRE_SAME_USER flags.

This is a synchronous failable constructor. See g_dbus_connection_new_for_address() for the asynchronous version.

If observer is not nullptr it may be used to control the authentication process.

Since glibmm 2.26:
Parameters
addressA D-Bus address.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ create_for_address_sync() [4/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_for_address_sync ( const std::string address,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Synchronously connects and sets up a D-Bus client connection for exchanging D-Bus messages with an endpoint specified by address which must be in the D-Bus address format.

This constructor can only be used to initiate client-side connections - use g_dbus_connection_new_sync() if you need to act as the server. In particular, flags cannot contain the Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER, Gio::DBus::ConnectionFlags::AUTHENTICATION_ALLOW_ANONYMOUS or Gio::DBus::ConnectionFlags::AUTHENTICATION_REQUIRE_SAME_USER flags.

This is a synchronous failable constructor. See g_dbus_connection_new_for_address() for the asynchronous version.

If observer is not nullptr it may be used to control the authentication process.

Since glibmm 2.26:
Parameters
addressA D-Bus address.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ create_sync() [1/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_sync ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create_sync().

◆ create_sync() [2/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_sync ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Non-cancellable version of create_sync().

◆ create_sync() [3/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_sync ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< AuthObserver > &  observer,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Synchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.

If stream is a SocketConnection, then the corresponding Socket will be put into non-blocking mode.

The D-Bus connection will interact with stream from a worker thread. As a result, the caller should not interact with stream after this method has been called, except by calling Glib::object_unref() on it.

If observer is not nullptr it may be used to control the authentication process.

This is a synchronous failable constructor. See g_dbus_connection_new() for the asynchronous version.

Since glibmm 2.26:
Parameters
streamA IOStream.
guidThe GUID to use if authenticating as a server or nullptr.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ create_sync() [4/4]

static Glib::RefPtr< Connection > Gio::DBus::Connection::create_sync ( const Glib::RefPtr< IOStream > &  stream,
const std::string guid,
const Glib::RefPtr< Cancellable > &  cancellable,
ConnectionFlags  flags = Gio::DBus::ConnectionFlags::NONE 
)
static

Synchronously sets up a D-Bus connection for exchanging D-Bus messages with the end represented by stream.

If stream is a SocketConnection, then the corresponding Socket will be put into non-blocking mode.

The D-Bus connection will interact with stream from a worker thread. As a result, the caller should not interact with stream after this method has been called, except by calling Glib::object_unref() on it.

If observer is not nullptr it may be used to control the authentication process.

This is a synchronous failable constructor. See g_dbus_connection_new() for the asynchronous version.

Since glibmm 2.26:
Parameters
streamA IOStream.
guidThe GUID to use if authenticating as a server or nullptr.
flagsFlags describing how to make the connection.
observerA Gio::DBus::AuthObserver or nullptr.
cancellableA Cancellable or nullptr.
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ emit_signal()

void Gio::DBus::Connection::emit_signal ( const Glib::ustring object_path,
const Glib::ustring interface_name,
const Glib::ustring signal_name,
const Glib::ustring destination_bus_name = {},
const Glib::VariantContainerBase parameters = {} 
)

Emits a signal.

This can only fail if parameters is not compatible with the D-Bus protocol.

Parameters
object_pathPath of remote object.
interface_nameD-Bus interface to emit a signal on.
signal_nameThe name of the signal to emit.
destination_bus_nameThe unique bus name for the destination for the signal or an empty string to emit to all listeners.
parametersA Glib::VariantContainerBase tuple with parameters for the signal or 0 if not passing parameters.
Exceptions
Glib::Error.
Since glibmm 2.28:

◆ export_action_group()

guint Gio::DBus::Connection::export_action_group ( const Glib::ustring object_path,
const Glib::RefPtr< ActionGroup > &  action_group 
)

Exports action_group on connection at object_path.

The implemented D-Bus API should be considered private. It is subject to change in the future.

A given object path can only have one action group exported on it. If this constraint is violated, the export will fail and 0 will be returned (with error set accordingly).

You can unexport the action group using g_dbus_connection_unexport_action_group() with the return value of this function.

The thread default main context is taken at the time of this call. All incoming action activations and state change requests are reported from this context. Any changes on the action group that cause it to emit signals must also come from this same context. Since incoming action activations and state change requests are rather likely to cause changes on the action group, this effectively limits a given action group to being exported from only one main context.

Since glibmm 2.32:
Parameters
object_pathA D-Bus object path.
action_groupA ActionGroup.
Returns
The ID of the export (never zero), or 0 in case of failure.
Exceptions
Glib::Error

◆ export_menu_model()

guint Gio::DBus::Connection::export_menu_model ( const Glib::ustring object_path,
const Glib::RefPtr< MenuModel > &  menu 
)

Exports menu on connection at object_path.

The implemented D-Bus API should be considered private. It is subject to change in the future.

An object path can only have one menu model exported on it. If this constraint is violated, the export will fail and 0 will be returned (with error set accordingly).

Exporting menus with sections containing more than G_MENU_EXPORTER_MAX_SECTION_SIZE items is not supported and results in undefined behavior.

You can unexport the menu model using g_dbus_connection_unexport_menu_model() with the return value of this function.

Since glibmm 2.32:
Parameters
object_pathA D-Bus object path.
menuA MenuModel.
Returns
The ID of the export (never zero), or 0 in case of failure.
Exceptions
Glib::Error

◆ flush() [1/3]

void Gio::DBus::Connection::flush ( )

Asynchronously flushes the connection, that is, writes all queued outgoing message to the transport and then flushes the transport (using Gio::OutputStream::flush_async()).

This is useful in programs that wants to emit a D-Bus signal and then exit immediately. Without flushing the connection, there is no guarantee that the message has been sent to the networking buffers in the OS kernel.

This is an asynchronous method. See flush_sync() for the synchronous version.

Since glibmm 2.28:

◆ flush() [2/3]

void Gio::DBus::Connection::flush ( const SlotAsyncReady &  slot)

Asynchronously flushes the connection, that is, writes all queued outgoing message to the transport and then flushes the transport (using Gio::OutputStream::flush_async()).

This is useful in programs that wants to emit a D-Bus signal and then exit immediately. Without flushing the connection, there is no guarantee that the message has been sent to the networking buffers in the OS kernel.

This is an asynchronous method. When the operation is finished, slot will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call flush_finish() to get the result of the operation. See flush_sync() for the synchronous version.

Parameters
slotA SlotAsyncReady to call when the request is satisfied.
Since glibmm 2.28:

◆ flush() [3/3]

void Gio::DBus::Connection::flush ( const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable 
)

Asynchronously flushes the connection, that is, writes all queued outgoing message to the transport and then flushes the transport (using Gio::OutputStream::flush_async()).

This is useful in programs that wants to emit a D-Bus signal and then exit immediately. Without flushing the connection, there is no guarantee that the message has been sent to the networking buffers in the OS kernel.

This is an asynchronous method. When the operation is finished, slot will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call flush_finish() to get the result of the operation. See flush_sync() for the synchronous version.

Parameters
slotA SlotAsyncReady to call when the request is satisfied.
cancellableA Cancellable.
Since glibmm 2.28:

◆ flush_finish()

bool Gio::DBus::Connection::flush_finish ( const Glib::RefPtr< AsyncResult > &  res)

Finishes an operation started with g_dbus_connection_flush().

Since glibmm 2.26:
Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to g_dbus_connection_flush().
Returns
true if the operation succeeded, false if error is set.
Exceptions
Glib::Error

◆ flush_sync() [1/2]

void Gio::DBus::Connection::flush_sync ( )

A flush_sync() convenience overload.

◆ flush_sync() [2/2]

void Gio::DBus::Connection::flush_sync ( const Glib::RefPtr< Cancellable > &  cancellable)

Synchronously flushes connection.

The calling thread is blocked until this is done. See g_dbus_connection_flush() for the asynchronous version of this method and more details about what it does.

Since glibmm 2.26:
Parameters
cancellableA Cancellable or nullptr.
Exceptions
Glib::Error

◆ get() [1/2]

static void Gio::DBus::Connection::get ( BusType  bus_type,
const SlotAsyncReady &  slot 
)
static

Non-cancellable version of get().

◆ get() [2/2]

static void Gio::DBus::Connection::get ( BusType  bus_type,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable 
)
static

Asynchronously connects to the message bus specified by bus_type.

When the operation is finished, slot will be invoked. You can then call get_finish() to get the result of the operation.

This is a asynchronous failable function. See get_sync() for the synchronous version.

Parameters
bus_typeA BusType.
slotA SlotAsyncReady to call when the request is satisfied.
cancellableA Cancellable.
Since glibmm 2.28:

◆ get_capabilities()

CapabilityFlags Gio::DBus::Connection::get_capabilities ( ) const

Gets the capabilities negotiated with the remote peer.

Since glibmm 2.26:
Returns
Zero or more flags from the DBusCapabilityFlags enumeration.

◆ get_exit_on_close()

bool Gio::DBus::Connection::get_exit_on_close ( ) const

Gets whether the process is terminated when connection is closed by the remote peer.

See Gio::DBus::Connection::property_exit_on_close() for more details.

Since glibmm 2.26:
Returns
Whether the process is terminated when connection is closed by the remote peer.

◆ get_finish()

static Glib::RefPtr< Connection > Gio::DBus::Connection::get_finish ( const Glib::RefPtr< AsyncResult > &  res)
static

Finishes an operation started with g_bus_get().

The returned object is a singleton, that is, shared with other callers of g_bus_get() and g_bus_get_sync() for bus_type. In the event that you need a private message bus connection, use g_dbus_address_get_for_bus_sync() and g_dbus_connection_new_for_address() with G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT and G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION flags.

Note that the returned Gio::DBus::Connection object will (usually) have the Gio::DBus::Connection::property_exit_on_close() property set to true.

Since glibmm 2.26:
Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to g_bus_get().
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ get_flags()

ConnectionFlags Gio::DBus::Connection::get_flags ( ) const

Gets the flags used to construct this connection.

Since glibmm 2.60:
Returns
Zero or more flags from the DBusConnectionFlags enumeration.

◆ get_guid()

std::string Gio::DBus::Connection::get_guid ( ) const

The GUID of the peer performing the role of server when authenticating.

See Gio::DBus::Connection::property_guid() for more details.

Since glibmm 2.26:
Returns
The GUID. Do not free this string, it is owned by connection.

◆ get_last_serial()

guint32 Gio::DBus::Connection::get_last_serial ( ) const

Retrieves the last serial number assigned to a Gio::DBus::Message on the current thread.

This includes messages sent via both low-level API such as g_dbus_connection_send_message() as well as high-level API such as g_dbus_connection_emit_signal(), g_dbus_connection_call() or g_dbus_proxy_call().

Since glibmm 2.34:
Returns
The last used serial or zero when no message has been sent within the current thread.

◆ get_peer_credentials() [1/2]

Glib::RefPtr< Credentials > Gio::DBus::Connection::get_peer_credentials ( )

Gets the credentials of the authenticated peer.

This will always return nullptr unless connection acted as a server (e.g. Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER was passed) when set up and the client passed credentials as part of the authentication process.

In a message bus setup, the message bus is always the server and each application is a client. So this method will always return nullptr for message bus clients.

Since glibmm 2.26:
Returns
A Credentials or nullptr if not available. Do not free this object, it is owned by connection.

◆ get_peer_credentials() [2/2]

Glib::RefPtr< const Credentials > Gio::DBus::Connection::get_peer_credentials ( ) const

Gets the credentials of the authenticated peer.

This will always return nullptr unless connection acted as a server (e.g. Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER was passed) when set up and the client passed credentials as part of the authentication process.

In a message bus setup, the message bus is always the server and each application is a client. So this method will always return nullptr for message bus clients.

Since glibmm 2.26:
Returns
A Credentials or nullptr if not available. Do not free this object, it is owned by connection.

◆ get_stream() [1/2]

Glib::RefPtr< IOStream > Gio::DBus::Connection::get_stream ( )

Gets the underlying stream used for IO.

While the Gio::DBus::Connection is active, it will interact with this stream from a worker thread, so it is not safe to interact with the stream directly.

Since glibmm 2.26:
Returns
The stream used for IO.

◆ get_stream() [2/2]

Glib::RefPtr< const IOStream > Gio::DBus::Connection::get_stream ( ) const

Gets the underlying stream used for IO.

While the Gio::DBus::Connection is active, it will interact with this stream from a worker thread, so it is not safe to interact with the stream directly.

Since glibmm 2.26:
Returns
The stream used for IO.

◆ get_sync() [1/2]

static Glib::RefPtr< Connection > Gio::DBus::Connection::get_sync ( BusType  bus_type)
static

A get_sync() convenience overload.

◆ get_sync() [2/2]

static Glib::RefPtr< Connection > Gio::DBus::Connection::get_sync ( BusType  bus_type,
const Glib::RefPtr< Cancellable > &  cancellable 
)
static

Synchronously connects to the message bus specified by bus_type.

Note that the returned object may shared with other callers, e.g. if two separate parts of a process calls this function with the same bus_type, they will share the same object.

This is a synchronous failable function. See g_bus_get() and g_bus_get_finish() for the asynchronous version.

The returned object is a singleton, that is, shared with other callers of g_bus_get() and g_bus_get_sync() for bus_type. In the event that you need a private message bus connection, use g_dbus_address_get_for_bus_sync() and g_dbus_connection_new_for_address() with G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT and G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION flags.

Note that the returned Gio::DBus::Connection object will (usually) have the Gio::DBus::Connection::property_exit_on_close() property set to true.

Since glibmm 2.26:
Parameters
bus_typeA BusType.
cancellableA Cancellable or nullptr.
Returns
A Gio::DBus::Connection or nullptr if error is set. Free with Glib::object_unref().
Exceptions
Glib::Error

◆ get_type()

static GType Gio::DBus::Connection::get_type ( )
static

Get the GType for this class, for use with the underlying GObject type system.

◆ get_unique_name()

Glib::ustring Gio::DBus::Connection::get_unique_name ( ) const

Gets the unique name of connection as assigned by the message bus.

This can also be used to figure out if connection is a message bus connection.

Since glibmm 2.26:
Returns
The unique name or nullptr if connection is not a message bus connection. Do not free this string, it is owned by connection.

◆ gobj() [1/2]

GDBusConnection * Gio::DBus::Connection::gobj ( )
inline

Provides access to the underlying C GObject.

◆ gobj() [2/2]

const GDBusConnection * Gio::DBus::Connection::gobj ( ) const
inline

Provides access to the underlying C GObject.

◆ gobj_copy()

GDBusConnection * Gio::DBus::Connection::gobj_copy ( )

Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.

◆ is_closed()

bool Gio::DBus::Connection::is_closed ( ) const

Gets whether connection is closed.

Since glibmm 2.26:
Returns
true if the connection is closed, false otherwise.

◆ operator=()

Connection & Gio::DBus::Connection::operator= ( Connection &&  src)
noexcept

◆ property_capabilities()

Glib::PropertyProxy_ReadOnly< CapabilityFlags > Gio::DBus::Connection::property_capabilities ( ) const

Flags from the DBusCapabilityFlags enumeration representing connection features negotiated with the other peer.

Since glibmm 2.26:

Default value: Gio::DBus::CapabilityFlags::NONE

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ property_closed()

Glib::PropertyProxy_ReadOnly< bool > Gio::DBus::Connection::property_closed ( ) const

A boolean specifying whether the connection has been closed.

Since glibmm 2.26:

Default value: false

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ property_exit_on_close() [1/2]

Glib::PropertyProxy< bool > Gio::DBus::Connection::property_exit_on_close ( )

A boolean specifying whether the process will be terminated (by calling raise(SIGTERM)) if the connection is closed by the remote peer.

Note that Gio::DBus::Connection objects returned by g_bus_get_finish() and g_bus_get_sync() will (usually) have this property set to true.

Since glibmm 2.26:

Default value: false

Returns
A PropertyProxy that allows you to get or set the value of the property, or receive notification when the value of the property changes.

◆ property_exit_on_close() [2/2]

Glib::PropertyProxy_ReadOnly< bool > Gio::DBus::Connection::property_exit_on_close ( ) const

A boolean specifying whether the process will be terminated (by calling raise(SIGTERM)) if the connection is closed by the remote peer.

Note that Gio::DBus::Connection objects returned by g_bus_get_finish() and g_bus_get_sync() will (usually) have this property set to true.

Since glibmm 2.26:

Default value: false

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ property_flags()

Glib::PropertyProxy_ReadOnly< ConnectionFlags > Gio::DBus::Connection::property_flags ( ) const

Flags from the DBusConnectionFlags enumeration.

Since glibmm 2.60:

Default value: Gio::DBus::ConnectionFlags::NONE

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ property_guid()

Glib::PropertyProxy_ReadOnly< std::string > Gio::DBus::Connection::property_guid ( ) const

The GUID of the peer performing the role of server when authenticating.

If you are constructing a Gio::DBus::Connection and pass Gio::DBus::ConnectionFlags::AUTHENTICATION_SERVER in the Gio::DBus::Connection::property_flags() property then you must also set this property to a valid guid.

If you are constructing a Gio::DBus::Connection and pass Gio::DBus::ConnectionFlags::AUTHENTICATION_CLIENT in the Gio::DBus::Connection::property_flags() property you will be able to read the GUID of the other peer here after the connection has been successfully initialized.

Note that the D-Bus specification uses the term ‘UUID’ to refer to this, whereas GLib consistently uses the term ‘GUID’ for historical reasons.

Despite its name, the format of Gio::DBus::Connection::property_guid() does not follow RFC 4122 or the Microsoft GUID format.

Since glibmm 2.26:

Default value: ""

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ property_stream()

Glib::PropertyProxy_ReadOnly< Glib::RefPtr< IOStream > > Gio::DBus::Connection::property_stream ( ) const

The underlying IOStream used for I/O.

If this is passed on construction and is a SocketConnection, then the corresponding Socket will be put into non-blocking mode.

While the Gio::DBus::Connection is active, it will interact with this stream from a worker thread, so it is not safe to interact with the stream directly.

Since glibmm 2.26:
Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ property_unique_name()

Glib::PropertyProxy_ReadOnly< Glib::ustring > Gio::DBus::Connection::property_unique_name ( ) const

The unique name as assigned by the message bus or nullptr if the connection is not open or not a message bus connection.

Since glibmm 2.26:

Default value: ""

Returns
A PropertyProxy_ReadOnly that allows you to get the value of the property, or receive notification when the value of the property changes.

◆ register_object() [1/2]

guint Gio::DBus::Connection::register_object ( const Glib::ustring object_path,
const Glib::RefPtr< InterfaceInfo > &  interface_info 
)

Registers exported objects at object_path with the D-Bus interface that is described in interface_info.

This method overload, which does not take a VTable, is useful for marker interfaces.

If an existing slot is already registered at object_path and interface_name, then a Glib::Error is thrown.

GDBus automatically implements the standard D-Bus interfaces org.freedesktop.DBus.Properties, org.freedesktop.DBus.Introspectable and org.freedesktop.Peer, so you don't have to implement those for the objects you export.

Parameters
object_pathThe object path to register at.
interface_infoIntrospection data for the interface.
Returns
A registration id (never 0) that can be used with unregister_object() if no Glib::Error is thrown.
Exceptions
Glib::Error.
Since glibmm 2.28:

◆ register_object() [2/2]

guint Gio::DBus::Connection::register_object ( const Glib::ustring object_path,
const Glib::RefPtr< InterfaceInfo > &  interface_info,
const InterfaceVTable vtable 
)

Registers slots for exported objects at object_path with the D-Bus interface that is described in interface_info.

Calls to slots in vtable will happen in the thread-default main loop of the thread you are calling this method from.

Note that all Glib::VariantBase values passed to functions in vtable will match the signature given in interface_info - if a remote caller passes incorrect values, the org.freedesktop.DBus.Error.InvalidArgs is returned to the remote caller.

Additionally, if the remote caller attempts to invoke methods or access properties not mentioned in interface_info the org.freedesktop.DBus.Error.UnknownMethod resp. org.freedesktop.DBus.Error.InvalidArgs errors are returned to the caller.

It is considered a programming error if the SlotDBusInterfaceGetProperty slot in vtable returns a Glib::VariantBase of incorrect type.

If an existing slot is already registered at object_path and interface_name, then a Glib::Error is thrown.

GDBus automatically implements the standard D-Bus interfaces org.freedesktop.DBus.Properties, org.freedesktop.DBus.Introspectable and org.freedesktop.Peer, so you don't have to implement those for the objects you export. You can implement org.freedesktop.DBus.Properties yourself, e.g. to handle getting and setting of properties asynchronously.

Parameters
object_pathThe object path to register at.
interface_infoIntrospection data for the interface.
vtableAn InterfaceVTable to call into.
Returns
A registration id (never 0) that can be used with unregister_object() if no Glib::Error is thrown.
Exceptions
Glib::Error.
Since glibmm 2.28:

◆ register_subtree()

guint Gio::DBus::Connection::register_subtree ( const Glib::ustring object_path,
const SubtreeVTable vtable,
SubtreeFlags  flags = Gio::DBus::SubtreeFlags::NONE 
)

Registers a whole subtree of “dynamic” objects.

Copies of the enumerate and introspection slots usted to create vtable are used to convey, to remote callers, what nodes exist in the subtree rooted by object_path.

When handling remote calls into any node in the subtree, first the enumerate slot is used to check if the node exists. If the node exists or the Gio::DBus::SubtreeFlags::DISPATCH_TO_UNENUMERATED_NODES flag is set the introspection slot is used to check if the node supports the requested method. If so, the dispatch function is used to determine where to dispatch the call. The collected InterfaceVTable will be used to call into the interface vtable for processing the request.

All calls into user-provided code will be invoked in the thread-default main loop of the thread you are calling this method from.

If an existing subtree is already registered at object_path or then a Glib::Error is thrown.

Note that it is valid to register regular objects (using register_object()) in a subtree registered with register_subtree() - if so, the subtree handler is tried as the last resort. One way to think about a subtree handler is to consider it a “fallback handler” for object paths not registered via register_object().

Parameters
object_pathThe object path to register the subtree at.
vtableA SubtreeVTable to enumerate, introspect and dispatch nodes in the subtree.
flagsFlags used to fine tune the behavior of the subtree.
Returns
A subtree registration id (never 0) that can be used with unregister_subtree() if no Glib::Error is thrown.
Since glibmm 2.28:

◆ remove_filter()

void Gio::DBus::Connection::remove_filter ( guint  filter_id)

Removes a filter.

Note that since filters run in a different thread, there is a race condition where it is possible that the filter will be running even after calling g_dbus_connection_remove_filter(), so you cannot just free data that the filter might be using. Instead, you should pass a DestroyNotify to g_dbus_connection_add_filter(), which will be called when it is guaranteed that the data is no longer needed.

Since glibmm 2.26:
Parameters
filter_idAn identifier obtained from g_dbus_connection_add_filter().

◆ send_message() [1/2]

bool Gio::DBus::Connection::send_message ( const Glib::RefPtr< Message > &  message,
SendMessageFlags  flags,
guint32 out_serial 
)

Asynchronously sends message to the peer represented by connection.

Unless flags contain the Gio::DBus::SendMessageFlags::PRESERVE_SERIAL flag, the serial number will be assigned by connection and set on message via g_dbus_message_set_serial(). If out_serial is not nullptr, then the serial number used will be written to this location prior to submitting the message to the underlying transport. While it has a volatile qualifier, this is a historical artifact and the argument passed to it should not be volatile.

If connection is closed then the operation will fail with Gio::Error::CLOSED. If message is not well-formed, the operation fails with Gio::Error::INVALID_ARGUMENT.

See this [server][gdbus-server] and [client][gdbus-unix-fd-client] for an example of how to use this low-level API to send and receive UNIX file descriptors.

Note that message must be unlocked, unless flags contain the Gio::DBus::SendMessageFlags::PRESERVE_SERIAL flag.

Since glibmm 2.26:
Parameters
messageA Gio::DBus::Message.
flagsFlags affecting how the message is sent.
out_serialReturn location for serial number assigned to message when sending it or nullptr.
Returns
true if the message was well-formed and queued for transmission, false if error is set.
Exceptions
Glib::Error

◆ send_message() [2/2]

bool Gio::DBus::Connection::send_message ( const Glib::RefPtr< Message > &  message,
SendMessageFlags  flags = Gio::DBus::SendMessageFlags::NONE 
)

A send_message() without an "out_serial" parameter.

◆ send_message_with_reply() [1/2]

void Gio::DBus::Connection::send_message_with_reply ( const Glib::RefPtr< Message > &  message,
int  timeout_msec,
const SlotAsyncReady &  slot 
)

Non-cancellable version of send_message_with_reply().

◆ send_message_with_reply() [2/2]

void Gio::DBus::Connection::send_message_with_reply ( const Glib::RefPtr< Message > &  message,
int  timeout_msec,
const SlotAsyncReady &  slot,
const Glib::RefPtr< Cancellable > &  cancellable 
)

Asynchronously sends message to the peer represented by the connection.

Unless flags contain the Gio::DBus::SendMessageFlags::PRESERVE_SERIAL flag, the serial number will be assigned by the connection and set on message via Gio::DBus::Message::set_serial().

If the connection is closed then the operation will fail with Gio::IO_ERROR_CLOSED. If cancellable is canceled, the operation will fail with Gio::IO_ERROR_CANCELLED. If message is not well-formed, the operation fails with Gio::IO_ERROR_INVALID_ARGUMENT.

This is an asynchronous method. When the operation is finished, slot will be invoked in the thread-default main loop of the thread you are calling this method from. You can then call send_message_with_reply_finish() to get the result of the operation. See send_message_with_reply_sync() for the synchronous version.

Note that message must be unlocked, unless flags contain the Gio::DBus::SendMessageFlags::PRESERVE_SERIAL flag.

See the C API docs for examples.

Parameters
messageA Message.
timeout_msecThe timeout in milliseconds or -1 to use the default timeout.
slotA SlotAsyncReady to call when the request is satisfied.
cancellableA Cancellable.
Since glibmm 2.28:

◆ send_message_with_reply_finish()

Glib::RefPtr< Message > Gio::DBus::Connection::send_message_with_reply_finish ( const Glib::RefPtr< AsyncResult > &  res)

Finishes an operation started with g_dbus_connection_send_message_with_reply().

Note that error is only set if a local in-process error occurred. That is to say that the returned Gio::DBus::Message object may be of type Gio::DBus::MessageType::ERROR. Use g_dbus_message_to_gerror() to transcode this to a Error.

See this [server][gdbus-server] and [client][gdbus-unix-fd-client] for an example of how to use this low-level API to send and receive UNIX file descriptors.

Since glibmm 2.26:
Parameters
resA AsyncResult obtained from the SlotAsyncReady passed to g_dbus_connection_send_message_with_reply().
Returns
A locked Gio::DBus::Message or nullptr if error is set.
Exceptions
Glib::Error

◆ send_message_with_reply_sync() [1/2]

Glib::RefPtr< Message > Gio::DBus::Connection::send_message_with_reply_sync ( const Glib::RefPtr< Message > &  message,
const Glib::RefPtr< Cancellable > &  cancellable,
gint  timeout_msec 
)

Synchronously sends message to the peer represented by the connection and blocks the calling thread until a reply is received or the timeout is reached.

See send_message_with_reply() for the asynchronous version of this method.

Unless flags contain the Gio::DBus::SendMessageFlags::PRESERVE_SERIAL flag, the serial number will be assigned by the connection and set on message via Gio::DBus::Message::set_serial().

If the connection is closed then the operation will fail with Gio::IO_ERROR_CLOSED. If cancellable is canceled, the operation will fail with Gio::IO_ERROR_CANCELLED. If message is not well-formed, the operation fails with Gio::IO_ERROR_INVALID_ARGUMENT.

Note that a Glib::Error is thrown if a local in-process error occured. That is to say that the returned Message object may be of type G_DBUS_MESSAGE_TYPE_ERROR. Use Gio::DBus::Message::to_exception() to transcode this to a Glib::Error.

See the C API docs for examples.

Note that message must be unlocked, unless flags contain the Gio::DBus::SendMessageFlags::PRESERVE_SERIAL flag.

Parameters
messageA Message.
cancellableA Cancellable.
timeout_msecThe timeout in milliseconds or -1 to use the default timeout.
Returns
A locked Message that is the reply to message or 0 if a Glib::Error is thrown.
Exceptions
Glib::Error.
Since glibmm 2.28:

◆ send_message_with_reply_sync() [2/2]

Glib::RefPtr< Message > Gio::DBus::Connection::send_message_with_reply_sync ( const Glib::RefPtr< Message > &  message,
gint  timeout_msec 
)

A non-cancellable version of send_message_with_reply_sync().

◆ set_exit_on_close()

void Gio::DBus::Connection::set_exit_on_close ( bool  exit_on_close = true)

Sets whether the process should be terminated when connection is closed by the remote peer.

See Gio::DBus::Connection::property_exit_on_close() for more details.

Note that this function should be used with care. Most modern UNIX desktops tie the notion of a user session with the session bus, and expect all of a user's applications to quit when their bus connection goes away. If you are setting exit_on_close to false for the shared session bus connection, you should make sure that your application exits when the user session ends.

Since glibmm 2.26:
Parameters
exit_on_closeWhether the process should be terminated when connection is closed by the remote peer.

◆ signal_closed()

Glib::SignalProxy< void(bool, const Glib::Error &)> Gio::DBus::Connection::signal_closed ( )
Slot Prototype:
void on_my_closed(bool remote_peer_vanished, const Glib::Error& error)

Flags: Run Last

Emitted when the connection is closed.

The cause of this event can be

  • If g_dbus_connection_close() is called. In this case remote_peer_vanished is set to false and error is nullptr.
  • If the remote peer closes the connection. In this case remote_peer_vanished is set to true and error is set.
  • If the remote peer sends invalid or malformed data. In this case remote_peer_vanished is set to false and error is set.

Upon receiving this signal, you should give up your reference to connection. You are guaranteed that this signal is emitted only once.

Since glibmm 2.26:
Parameters
remote_peer_vanishedtrue if connection is closed because the remote peer closed its end of the connection.
errorA Error with more details about the event or nullptr.

◆ signal_subscribe()

guint Gio::DBus::Connection::signal_subscribe ( const SlotSignal slot,
const Glib::ustring sender = {},
const Glib::ustring interface_name = {},
const Glib::ustring member = {},
const Glib::ustring object_path = {},
const Glib::ustring arg0 = {},
SignalFlags  flags = Gio::DBus::SignalFlags::NONE 
)

Subscribes to signals on the connection and invokes slot with a whenever the signal is received.

Note that slot will be invoked in the thread-default main loop of the thread you are calling this method from.

If the connection is not a message bus connection, sender must be 0.

If sender is a well-known name note that slot is invoked with the unique name for the owner of sender, not the well-known name as one would expect. This is because the message bus rewrites the name. As such, to avoid certain race conditions, users should be tracking the name owner of the well-known name and use that when processing the received signal.

Parameters
slotSlot to invoke when there is a signal matching the requested data.
senderSender name to match on (unique or well-known name) or 0 to listen from all senders.
interface_nameD-Bus interface name to match on or 0 to match on all interfaces.
memberD-Bus signal name to match on or 0 to match on all signals.
object_pathObject path to match on or 0 to match on all object paths.
arg0Contents of first string argument to match on or 0 to match on all kinds of arguments.
flagsFlags describing how to subscribe to the signal (currently unused).
Returns
A subscription identifier that can be used with signal_unsubscribe().
Since glibmm 2.28:

◆ signal_unsubscribe()

void Gio::DBus::Connection::signal_unsubscribe ( guint  subscription_id)

Unsubscribes from signals.

Note that there may still be D-Bus traffic to process (relating to this signal subscription) in the current thread-default MainContext after this function has returned. You should continue to iterate the MainContext until the DestroyNotify function passed to g_dbus_connection_signal_subscribe() is called, in order to avoid memory leaks through callbacks queued on the MainContext after it’s stopped being iterated. Alternatively, any idle source with a priority lower than G_PRIORITY_DEFAULT that was scheduled after unsubscription, also indicates that all resources of this subscription are released.

Since glibmm 2.26:
Parameters
subscription_idA subscription id obtained from g_dbus_connection_signal_subscribe().

◆ start_message_processing()

void Gio::DBus::Connection::start_message_processing ( )

If connection was created with Gio::DBus::ConnectionFlags::DELAY_MESSAGE_PROCESSING, this method starts processing messages.

Does nothing on if connection wasn't created with this flag or if the method has already been called.

Since glibmm 2.26:

◆ unexport_action_group()

void Gio::DBus::Connection::unexport_action_group ( guint  export_id)

Reverses the effect of a previous call to g_dbus_connection_export_action_group().

It is an error to call this function with an ID that wasn't returned from g_dbus_connection_export_action_group() or to call it with the same ID more than once.

Since glibmm 2.32:
Parameters
export_idThe ID from g_dbus_connection_export_action_group().

◆ unexport_menu_model()

void Gio::DBus::Connection::unexport_menu_model ( guint  export_id)

Reverses the effect of a previous call to g_dbus_connection_export_menu_model().

It is an error to call this function with an ID that wasn't returned from g_dbus_connection_export_menu_model() or to call it with the same ID more than once.

Since glibmm 2.32:
Parameters
export_idThe ID from g_dbus_connection_export_menu_model().

◆ unregister_object()

bool Gio::DBus::Connection::unregister_object ( guint  registration_id)

Unregisters an object.

Since glibmm 2.26:
Parameters
registration_idA registration id obtained from g_dbus_connection_register_object().
Returns
true if the object was unregistered, false otherwise.

◆ unregister_subtree()

bool Gio::DBus::Connection::unregister_subtree ( guint  registration_id)

Unregisters a subtree.

Since glibmm 2.26:
Parameters
registration_idA subtree registration id obtained from g_dbus_connection_register_subtree().
Returns
true if the subtree was unregistered, false otherwise.

Friends And Related Symbol Documentation

◆ wrap()

Glib::RefPtr< Gio::DBus::Connection > wrap ( GDBusConnection object,
bool  take_copy = false 
)
related

A Glib::wrap() method for this object.

Parameters
objectThe C instance.
take_copyFalse if the result should take ownership of the C instance. True if it should take a new copy or ref.
Returns
A C++ instance that wraps this C instance.