Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qdarwinpermissionplugin.mm
Go to the documentation of this file.
1// Copyright (C) 2022 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
5
7
8QDarwinPermissionPlugin::QDarwinPermissionPlugin(QDarwinPermissionHandler *handler)
10 , m_handler(handler)
11{
12}
13
14QDarwinPermissionPlugin::~QDarwinPermissionPlugin()
15{
16 [m_handler release];
17}
18
19Qt::PermissionStatus QDarwinPermissionPlugin::checkPermission(const QPermission &permission)
20{
21 return [m_handler checkPermission:permission];
22}
23
24void QDarwinPermissionPlugin::requestPermission(const QPermission &permission, const PermissionCallback &callback)
25{
26 if (!verifyUsageDescriptions(permission)) {
28 return;
29 }
30
31 [m_handler requestPermission:permission withCallback:[=](Qt::PermissionStatus status) {
32 // In case the callback comes in on a secondary thread we need to marshal it
33 // back to the main thread. And if it doesn't, we still want to propagate it
34 // via an event, to avoid any GCD locks deadlocking the application on iOS
35 // if the user responds to the result by running a nested event loop.
36 // Luckily Qt::QueuedConnection gives us exactly what we need.
37 QMetaObject::invokeMethod(this, "permissionUpdated", Qt::QueuedConnection,
39 }];
40}
41
42void QDarwinPermissionPlugin::permissionUpdated(Qt::PermissionStatus status, const PermissionCallback &callback)
43{
44 callback(status);
45}
46
47bool QDarwinPermissionPlugin::verifyUsageDescriptions(const QPermission &permission)
48{
49 // FIXME: Look up the responsible process and inspect that,
50 // as that's what needs to have the usage descriptions.
51 // FIXME: Verify entitlements if the process is sandboxed.
52 auto *infoDictionary = NSBundle.mainBundle.infoDictionary;
53 for (auto description : [m_handler usageDescriptionsFor:permission]) {
54 if (!infoDictionary[description.toNSString()]) {
55 qCWarning(lcPermissions) <<
56 "Requesting" << permission.type().name() <<
57 "requires" << description << "in Info.plist";
58 return false;
59 }
60 }
61 return true;
62}
63
65
67
69
70- (Qt::PermissionStatus)checkPermission:(QPermission)permission
71{
72 Q_UNREACHABLE(); // All handlers should at least provide a check
73}
74
75- (void)requestPermission:(QPermission)permission withCallback:(PermissionCallback)callback
76{
77 Q_UNUSED(permission);
78 qCWarning(lcPermissions).nospace() << "Could not request " << permission.type().name() << ". "
79 << "Please make sure you have included the required usage description in your Info.plist";
81}
82
83- (QStringList)usageDescriptionsFor:(QPermission)permission
84{
85 return {};
86}
87
88@end
89
90#include "moc_qdarwinpermissionplugin_p.cpp"
constexpr const char * name() const
Definition qmetatype.h:2680
\inmodule QtCore \inheaderfile QPermissions
QMetaType type() const
Returns the type of the permission.
\inmodule QtCore
void requestPermission(const QPermission &permission, const PermissionCallback &callback)
std::function< void(Qt::PermissionStatus)> PermissionCallback
Qt::PermissionStatus checkPermission(const QPermission &permission)
Combined button and popup list for selecting options.
Definition qcompare.h:63
PermissionStatus
@ QueuedConnection
DBusConnection const char DBusError DBusBusType DBusError return DBusConnection DBusHandleMessageFunction void DBusFreeFunction return DBusConnection return DBusConnection return const char DBusError return DBusConnection DBusMessage dbus_uint32_t return DBusConnection dbus_bool_t DBusConnection DBusAddWatchFunction DBusRemoveWatchFunction DBusWatchToggledFunction void DBusFreeFunction return DBusConnection DBusDispatchStatusFunction void DBusFreeFunction DBusTimeout return DBusTimeout return DBusWatch return DBusWatch unsigned int return DBusError const DBusError return const DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessageIter int const void return DBusMessageIter DBusMessageIter return DBusMessageIter void DBusMessageIter void int return DBusMessage DBusMessageIter return DBusMessageIter return DBusMessageIter DBusMessageIter const char const char const char const char return DBusMessage return DBusMessage const char return DBusMessage dbus_bool_t return DBusMessage dbus_uint32_t return DBusMessage void
#define qCWarning(category,...)
#define Q_ARG(Type, data)
Definition qobjectdefs.h:63
#define Q_UNUSED(x)
sem release()
static bool invokeMethod(QObject *obj, const char *member, Qt::ConnectionType, QGenericReturnArgument ret, QGenericArgument val0=QGenericArgument(nullptr), QGenericArgument val1=QGenericArgument(), QGenericArgument val2=QGenericArgument(), QGenericArgument val3=QGenericArgument(), QGenericArgument val4=QGenericArgument(), QGenericArgument val5=QGenericArgument(), QGenericArgument val6=QGenericArgument(), QGenericArgument val7=QGenericArgument(), QGenericArgument val8=QGenericArgument(), QGenericArgument val9=QGenericArgument())
\threadsafe This is an overloaded member function, provided for convenience. It differs from the abov...