PolicyKit Library Reference Manual |
---|
To gain authorizations through authentication, an Authentication Agent is used. The section defines an abstract interface that applications can use to interact with such an agent. This allows different desktop environments to implement different agents with native look and feel.
The interface is quite simple. Basically, a PolicyKit
Authentication Agent must provide the D-Bus session service with
the unique
name org.freedesktop.PolicyKit.AuthenticationAgent
that exposes a single object with the path /
that exports the
org.freedesktop.PolicyKit.AuthenticationAgent
D-Bus interface. The interface is defined by the following D-Bus
introspection data:
<!DOCTYPE node PUBLIC "-//freedesktop//DTD D-BUS Object Introspection 1.0//EN" "http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd"> <!-- This file is provided by the PolicyKit project --> <node> <interface name="org.freedesktop.PolicyKit.AuthenticationAgent"> <method name="ObtainAuthorization"> <!-- IN: PolicyKit action identifier; see PolKitAction --> <arg name="action_id" direction="in" type="s"/> <!-- IN: X11 window ID for the top-level X11 window the dialog will be transient for (pass zero if no window) --> <arg name="xid" direction="in" type="u"/> <!-- IN: Process ID to grant authorization to --> <arg name="pid" direction="in" type="u"/> <!-- OUT: whether the user gained the authorization --> <arg name="gained_authorization" direction="out" type="b"/> </method> </interface> </node>
This file is available
as /usr/share/dbus-1/interfaces/org.freedesktop.PolicyKit.AuthenticationAgent.xml
on a system with PolicyKit development packages installed. It
can be used to generating client glue code.