Struct gio::DBusServer [−][src]
pub struct DBusServer(_);
Expand description
DBusServer
is a helper for listening to and accepting D-Bus
connections. This can be used to create a new D-Bus server, allowing two
peers to use the D-Bus protocol for their own specialized communication.
A server instance provided in this way will not perform message routing or
implement the org.freedesktop.DBus interface.
To just export an object on a well-known name on a message bus, such as the
session or system bus, you should instead use g_bus_own_name()
.
An example of peer-to-peer communication with GDBus can be found in gdbus-example-peer.c.
Note that a minimal DBusServer
will accept connections from any
peer. In many use-cases it will be necessary to add a DBusAuthObserver
that only accepts connections that have successfully authenticated
as the same user that is running the DBusServer
. Since GLib 2.68 this can
be achieved more simply by passing the
G_DBUS_SERVER_FLAGS_AUTHENTICATION_REQUIRE_SAME_USER
flag to the server.
Implements
Implementations
pub fn new_sync<P: IsA<Cancellable>>(
address: &str,
flags: DBusServerFlags,
guid: &str,
observer: Option<&DBusAuthObserver>,
cancellable: Option<&P>
) -> Result<DBusServer, Error>
pub fn new_sync<P: IsA<Cancellable>>(
address: &str,
flags: DBusServerFlags,
guid: &str,
observer: Option<&DBusAuthObserver>,
cancellable: Option<&P>
) -> Result<DBusServer, Error>
Creates a new D-Bus server that listens on the first address in
address
that works.
Once constructed, you can use client_address()
to
get a D-Bus address string that clients can use to connect.
To have control over the available authentication mechanisms and
the users that are authorized to connect, it is strongly recommended
to provide a non-None
DBusAuthObserver
.
Connect to the signal::DBusServer::new-connection
signal to handle
incoming connections.
The returned DBusServer
isn’t active - you have to start it with
start()
.
DBusServer
is used in this [example][gdbus-peer-to-peer].
This is a synchronous failable constructor. There is currently no asynchronous version.
address
A D-Bus address.
flags
Flags from the DBusServerFlags
enumeration.
guid
A D-Bus GUID.
observer
A DBusAuthObserver
or None
.
cancellable
A Cancellable
or None
.
Returns
A DBusServer
or None
if error
is set. Free with
g_object_unref()
.
Gets a
D-Bus address
string that can be used by clients to connect to self
.
Returns
A D-Bus address string. Do not free, the string is owned
by self
.
A DBusAuthObserver
object to assist in the authentication process or None
.
pub fn connect_new_connection<F: Fn(&Self, &DBusConnection) -> bool + 'static>(
&self,
f: F
) -> SignalHandlerId
pub fn connect_new_connection<F: Fn(&Self, &DBusConnection) -> bool + 'static>(
&self,
f: F
) -> SignalHandlerId
Emitted when a new authenticated connection has been made. Use
DBusConnection::peer_credentials()
to figure out what
identity (if any), was authenticated.
If you want to accept the connection, take a reference to the
connection
object and return true
. When you are done with the
connection call DBusConnection::close()
and give up your
reference. Note that the other peer may disconnect at any time -
a typical thing to do when accepting a connection is to listen to
the signal::DBusConnection::closed
signal.
If property::DBusServer::flags
contains DBusServerFlags::RUN_IN_THREAD
then the signal is emitted in a new thread dedicated to the
connection. Otherwise the signal is emitted in the
[thread-default main context][g-main-context-push-thread-default]
of the thread that server
was constructed in.
You are guaranteed that signal handlers for this signal runs
before incoming messages on connection
are processed. This means
that it’s suitable to call g_dbus_connection_register_object()
or
similar from the signal handler.
connection
A DBusConnection
for the new connection.
Returns
Trait Implementations
This method returns an ordering between self
and other
values if one exists. Read more
This method tests less than (for self
and other
) and is used by the <
operator. Read more
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
This method tests greater than (for self
and other
) and is used by the >
operator. Read more
Returns the type identifier of Self
.
Auto Trait Implementations
impl RefUnwindSafe for DBusServer
impl !Send for DBusServer
impl !Sync for DBusServer
impl Unpin for DBusServer
impl UnwindSafe for DBusServer
Blanket Implementations
Mutably borrows from an owned value. Read more
Upcasts an object to a superclass or interface T
. Read more
Upcasts an object to a reference of its superclass or interface T
. Read more
Tries to downcast to a subclass or interface implementor T
. Read more
Tries to downcast to a reference of its subclass or interface implementor T
. Read more
Tries to cast to an object of type T
. This handles upcasting, downcasting
and casting between interface and interface implementors. All checks are performed at
runtime, while downcast
and upcast
will do many checks at compile-time already. Read more
Tries to cast to reference to an object of type T
. This handles upcasting, downcasting
and casting between interface and interface implementors. All checks are performed at
runtime, while downcast
and upcast
will do many checks at compile-time already. Read more
Casts to T
unconditionally. Read more
Casts to &T
unconditionally. Read more
Returns true
if the object is an instance of (can be cast to) T
.
pub fn set_properties_from_value(
&self,
property_values: &[(&str, Value)]
) -> Result<(), BoolError>
pub fn set_property<'a, N, V>(
&self,
property_name: N,
value: V
) -> Result<(), BoolError> where
V: ToValue,
N: Into<&'a str>,
pub fn set_property_from_value<'a, N>(
&self,
property_name: N,
value: &Value
) -> Result<(), BoolError> where
N: Into<&'a str>,
Safety Read more
Safety Read more
Safety Read more
Safety Read more
pub fn connect_notify<F>(&self, name: Option<&str>, f: F) -> SignalHandlerId where
F: 'static + Fn(&T, &ParamSpec) + Send + Sync,
pub fn connect_notify_local<F>(
&self,
name: Option<&str>,
f: F
) -> SignalHandlerId where
F: 'static + Fn(&T, &ParamSpec),
pub unsafe fn connect_notify_unsafe<F>(
&self,
name: Option<&str>,
f: F
) -> SignalHandlerId where
F: Fn(&T, &ParamSpec),
pub fn has_property<'a, N>(&self, property_name: N, type_: Option<Type>) -> bool where
N: Into<&'a str>,
pub fn find_property<'a, N>(&self, property_name: N) -> Option<ParamSpec> where
N: Into<&'a str>,
pub fn connect<'a, N, F>(
&self,
signal_name: N,
after: bool,
callback: F
) -> Result<SignalHandlerId, BoolError> where
F: Fn(&[Value]) -> Option<Value> + Send + Sync + 'static,
N: Into<&'a str>,
Same as connect
but takes a SignalId
instead of a signal name.
pub fn connect_local<'a, N, F>(
&self,
signal_name: N,
after: bool,
callback: F
) -> Result<SignalHandlerId, BoolError> where
F: Fn(&[Value]) -> Option<Value> + 'static,
N: Into<&'a str>,
Same as connect_local
but takes a SignalId
instead of a signal name.
pub unsafe fn connect_unsafe<'a, N, F>(
&self,
signal_name: N,
after: bool,
callback: F
) -> Result<SignalHandlerId, BoolError> where
F: Fn(&[Value]) -> Option<Value>,
N: Into<&'a str>,
Same as connect_unsafe
but takes a SignalId
instead of a signal name.
Emit signal by signal id.
Emit signal with details by signal id.
Emit signal by it’s name.
pub fn bind_property<'a, O, N, M>(
&'a self,
source_property: N,
target: &'a O,
target_property: M
) -> BindingBuilder<'a> where
O: ObjectType,
N: Into<&'a str>,
M: Into<&'a str>,
Same as emit
but takes Value
for the arguments.
Same as emit_by_name
but takes Value
for the arguments.
Returns a SendValue
clone of self
.
impl<'a, T, C> FromValueOptional<'a> for T where
C: ValueTypeChecker<Error = ValueTypeMismatchOrNoneError>,
T: FromValue<'a, Checker = C>,