Files
tdesktop/Telegram/ThirdParty/xdg-desktop-portal/data/org.freedesktop.impl.portal.Usb.xml
allhaileris afb81b8278
Some checks failed
Docker. / Ubuntu (push) Has been cancelled
User-agent updater. / User-agent (push) Failing after 15s
Lock Threads / lock (push) Failing after 10s
Waiting for answer. / waiting-for-answer (push) Failing after 22s
Needs user action. / needs-user-action (push) Failing after 8s
Can't reproduce. / cant-reproduce (push) Failing after 8s
Close stale issues and PRs / stale (push) Has been cancelled
init
2026-02-16 15:50:16 +03:00

86 lines
3.4 KiB
XML

<?xml version="1.0"?>
<!--
Copyright (C) 2023-2024 GNOME Foundation Inc.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library. If not, see <http://www.gnu.org/licenses/>.
Author: Georges Basile Stavracas Neto <georges.stavracas@gmail.com>
-->
<node name="/" xmlns:doc="http://www.freedesktop.org/dbus/1.0/doc.dtd">
<!--
org.freedesktop.impl.portal.Usb:
@short_description: USB portal backend interface
This interface lets sandboxed applications monitor and request
access to connected USB devices.
The implementation side allows requesting permission from the user
to access USB devices with a GUI.
This documentation describes version 1 of this interface.
-->
<interface name="org.freedesktop.impl.portal.Usb">
<!--
AcquireDevices:
@handle: Object path for the :ref:`org.freedesktop.impl.portal.Request` object representing this call
@parent_window: Identifier for the application window, see :doc:`window-identifiers`
@app_id: App id of the application
@devices: Array of identifier, device information, and access options for each device
@options: Vardict with optional further information
@response: Numeric Request response
@results: Vardict with the results of the call
Selects the devices to open.
Each element of the @devices array contains the ID, information and
access options for each device the app wants to acquire.
The supported keys in the information vardict are the same as the
keys in the @devices vardict of
:ref:`org.freedesktop.portal.Usb.EnumerateDevices`.
The supported keys in the access options vardict are:
* ``writable`` (``b``)
Whether the device will be opened in read-write or read-only mode.
Default: False
There are no supported keys in the @options vardict.
The following results get returned via the @results vardict:
* ``devices`` (``a(sa{sv})``)
An array of identifier and access options which is a subset of
what was passed in via @devices.
-->
<method name="AcquireDevices">
<arg type="o" name="handle" direction="in"/>
<arg type="s" name="parent_window" direction="in"/>
<arg type="s" name="app_id" direction="in"/>
<annotation name="org.qtproject.QtDBus.QtTypeName.In3" value="QList&lt;std::tuple&lt;QString,QVariantMap,QVariantMap&gt;&gt;"/>
<arg type="a(sa{sv}a{sv})" name="devices" direction="in"/>
<annotation name="org.qtproject.QtDBus.QtTypeName.In4" value="QVariantMap"/>
<arg type="a{sv}" name="options" direction="in"/>
<arg type="u" name="response" direction="out"/>
<annotation name="org.qtproject.QtDBus.QtTypeName.Out1" value="QVariantMap"/>
<arg type="a{sv}" name="results" direction="out"/>
</method>
<property name="version" type="u" access="read"/>
</interface>
</node>