| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | /*
 | 
					
						
							|  |  |  |  |  * Copyright © 2010 Codethink Limited | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2022-05-18 09:12:45 +01:00
										 |  |  |  |  * SPDX-License-Identifier: LGPL-2.1-or-later | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * 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 | 
					
						
							| 
									
										
										
										
											2017-05-27 18:21:30 +02:00
										 |  |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * 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 | 
					
						
							| 
									
										
										
										
											2014-01-23 12:58:29 +01:00
										 |  |  |  |  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Author: Ryan Lortie <desrt@desrt.ca> | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  | #include "config.h"
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | #include "gpermission.h"
 | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "gioerror.h"
 | 
					
						
							|  |  |  |  | #include "gioenums.h"
 | 
					
						
							|  |  |  |  | #include "gasyncresult.h"
 | 
					
						
							| 
									
										
										
										
											2015-08-07 09:48:27 -04:00
										 |  |  |  | #include "gtask.h"
 | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  | #include "glibintl.h"
 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2023-10-24 10:54:31 +01:00
										 |  |  |  |  * GPermission: | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-10-24 10:54:31 +01:00
										 |  |  |  |  * A `GPermission` represents the status of the caller’s permission to | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * perform a certain action. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * You can query if the action is currently allowed and if it is | 
					
						
							|  |  |  |  |  * possible to acquire the permission so that the action will be allowed | 
					
						
							|  |  |  |  |  * in the future. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * There is also an API to actually acquire the permission and one to | 
					
						
							|  |  |  |  |  * release it. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-10-24 10:54:31 +01:00
										 |  |  |  |  * As an example, a `GPermission` might represent the ability for the | 
					
						
							|  |  |  |  |  * user to write to a [class@Gio.Settings] object.  This `GPermission` object | 
					
						
							|  |  |  |  |  * could then be used to decide if it is appropriate to show a “Click here to | 
					
						
							|  |  |  |  |  * unlock” button in a dialog and to provide the mechanism to invoke | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * when that button is clicked. | 
					
						
							|  |  |  |  |  **/ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | struct _GPermissionPrivate | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   gboolean allowed; | 
					
						
							|  |  |  |  |   gboolean can_acquire; | 
					
						
							|  |  |  |  |   gboolean can_release; | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | enum  { | 
					
						
							|  |  |  |  |   PROP_NONE, | 
					
						
							|  |  |  |  |   PROP_ALLOWED, | 
					
						
							|  |  |  |  |   PROP_CAN_ACQUIRE, | 
					
						
							|  |  |  |  |   PROP_CAN_RELEASE | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-11 00:29:58 +01:00
										 |  |  |  | G_DEFINE_ABSTRACT_TYPE_WITH_PRIVATE (GPermission, g_permission, G_TYPE_OBJECT) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_acquire: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * @error: a pointer to a %NULL #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Attempts to acquire the permission represented by @permission. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * The precise method by which this happens depends on the permission | 
					
						
							|  |  |  |  |  * and the underlying authentication mechanism.  A simple example is | 
					
						
							|  |  |  |  |  * that a dialog may appear asking the user to enter their password. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * You should check with g_permission_get_can_acquire() before calling | 
					
						
							|  |  |  |  |  * this function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the permission is acquired then %TRUE is returned.  Otherwise, | 
					
						
							|  |  |  |  |  * %FALSE is returned and @error is set appropriately. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This call is blocking, likely for a very long time (in the case that | 
					
						
							|  |  |  |  |  * user interaction is required).  See g_permission_acquire_async() for | 
					
						
							|  |  |  |  |  * the non-blocking version. | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: %TRUE if the permission was successfully acquired | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_acquire (GPermission   *permission, | 
					
						
							|  |  |  |  |                       GCancellable  *cancellable, | 
					
						
							|  |  |  |  |                       GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return G_PERMISSION_GET_CLASS (permission) | 
					
						
							|  |  |  |  |     ->acquire (permission, cancellable, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_acquire_async: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * @callback: the #GAsyncReadyCallback to call when done | 
					
						
							|  |  |  |  |  * @user_data: the user data to pass to @callback | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Attempts to acquire the permission represented by @permission. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is the first half of the asynchronous version of | 
					
						
							|  |  |  |  |  * g_permission_acquire(). | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_permission_acquire_async (GPermission         *permission, | 
					
						
							|  |  |  |  |                             GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                             GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                             gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_if_fail (G_IS_PERMISSION (permission)); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   G_PERMISSION_GET_CLASS (permission) | 
					
						
							|  |  |  |  |     ->acquire_async (permission, cancellable, callback, user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_acquire_finish: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							|  |  |  |  |  * @result: the #GAsyncResult given to the #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: a pointer to a %NULL #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Collects the result of attempting to acquire the permission | 
					
						
							|  |  |  |  |  * represented by @permission. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is the second half of the asynchronous version of | 
					
						
							|  |  |  |  |  * g_permission_acquire(). | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: %TRUE if the permission was successfully acquired | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_acquire_finish (GPermission   *permission, | 
					
						
							|  |  |  |  |                              GAsyncResult  *result, | 
					
						
							|  |  |  |  |                              GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return G_PERMISSION_GET_CLASS (permission) | 
					
						
							|  |  |  |  |     ->acquire_finish (permission, result, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_release: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * @error: a pointer to a %NULL #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Attempts to release the permission represented by @permission. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * The precise method by which this happens depends on the permission | 
					
						
							|  |  |  |  |  * and the underlying authentication mechanism.  In most cases the | 
					
						
							|  |  |  |  |  * permission will be dropped immediately without further action. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * You should check with g_permission_get_can_release() before calling | 
					
						
							|  |  |  |  |  * this function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the permission is released then %TRUE is returned.  Otherwise, | 
					
						
							|  |  |  |  |  * %FALSE is returned and @error is set appropriately. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This call is blocking, likely for a very long time (in the case that | 
					
						
							|  |  |  |  |  * user interaction is required).  See g_permission_release_async() for | 
					
						
							|  |  |  |  |  * the non-blocking version. | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: %TRUE if the permission was successfully released | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_release (GPermission   *permission, | 
					
						
							|  |  |  |  |                       GCancellable  *cancellable, | 
					
						
							|  |  |  |  |                       GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return G_PERMISSION_GET_CLASS (permission) | 
					
						
							|  |  |  |  |     ->release (permission, cancellable, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_release_async: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  * @callback: the #GAsyncReadyCallback to call when done | 
					
						
							|  |  |  |  |  * @user_data: the user data to pass to @callback | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Attempts to release the permission represented by @permission. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is the first half of the asynchronous version of | 
					
						
							|  |  |  |  |  * g_permission_release(). | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_permission_release_async (GPermission         *permission, | 
					
						
							|  |  |  |  |                             GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                             GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                             gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_if_fail (G_IS_PERMISSION (permission)); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   G_PERMISSION_GET_CLASS (permission) | 
					
						
							|  |  |  |  |     ->release_async (permission, cancellable, callback, user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_release_finish: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							|  |  |  |  |  * @result: the #GAsyncResult given to the #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: a pointer to a %NULL #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Collects the result of attempting to release the permission | 
					
						
							|  |  |  |  |  * represented by @permission. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is the second half of the asynchronous version of | 
					
						
							|  |  |  |  |  * g_permission_release(). | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: %TRUE if the permission was successfully released | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_release_finish (GPermission   *permission, | 
					
						
							|  |  |  |  |                              GAsyncResult  *result, | 
					
						
							|  |  |  |  |                              GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return G_PERMISSION_GET_CLASS (permission) | 
					
						
							|  |  |  |  |     ->release_finish (permission, result, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_get_allowed: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Gets the value of the 'allowed' property.  This property is %TRUE if | 
					
						
							|  |  |  |  |  * the caller currently has permission to perform the action that | 
					
						
							|  |  |  |  |  * @permission represents the permission to perform. | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: the value of the 'allowed' property | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_get_allowed (GPermission *permission) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return permission->priv->allowed; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_get_can_acquire: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Gets the value of the 'can-acquire' property.  This property is %TRUE | 
					
						
							|  |  |  |  |  * if it is generally possible to acquire the permission by calling | 
					
						
							|  |  |  |  |  * g_permission_acquire(). | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: the value of the 'can-acquire' property | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_get_can_acquire (GPermission *permission) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return permission->priv->can_acquire; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_get_can_release: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Gets the value of the 'can-release' property.  This property is %TRUE | 
					
						
							|  |  |  |  |  * if it is generally possible to release the permission by calling | 
					
						
							|  |  |  |  |  * g_permission_release(). | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-11-21 11:01:16 -05:00
										 |  |  |  |  * Returns: the value of the 'can-release' property | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_permission_get_can_release (GPermission *permission) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_val_if_fail (G_IS_PERMISSION (permission), FALSE); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   return permission->priv->can_release; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_permission_impl_update: | 
					
						
							|  |  |  |  |  * @permission: a #GPermission instance | 
					
						
							|  |  |  |  |  * @allowed: the new value for the 'allowed' property | 
					
						
							|  |  |  |  |  * @can_acquire: the new value for the 'can-acquire' property | 
					
						
							|  |  |  |  |  * @can_release: the new value for the 'can-release' property | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function is called by the #GPermission implementation to update | 
					
						
							|  |  |  |  |  * the properties of the permission.  You should never call this | 
					
						
							|  |  |  |  |  * function except from a #GPermission implementation. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * GObject notify signals are generated, as appropriate. | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.26 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |  **/ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_permission_impl_update (GPermission *permission, | 
					
						
							|  |  |  |  |                           gboolean     allowed, | 
					
						
							|  |  |  |  |                           gboolean     can_acquire, | 
					
						
							|  |  |  |  |                           gboolean     can_release) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   GObject *object; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-25 19:35:58 -03:00
										 |  |  |  |   g_return_if_fail (G_IS_PERMISSION (permission)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   object = G_OBJECT (permission); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   g_object_freeze_notify (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |   allowed = allowed != FALSE; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   if (allowed != permission->priv->allowed) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |       permission->priv->allowed = allowed; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |       g_object_notify (object, "allowed"); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |   can_acquire = can_acquire != FALSE; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   if (can_acquire != permission->priv->can_acquire) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |       permission->priv->can_acquire = can_acquire; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |       g_object_notify (object, "can-acquire"); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |   can_release = can_release != FALSE; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   if (can_release != permission->priv->can_release) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |       permission->priv->can_release = can_release; | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |       g_object_notify (object, "can-release"); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_thaw_notify (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_permission_get_property (GObject *object, guint prop_id, | 
					
						
							|  |  |  |  |                            GValue *value, GParamSpec *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GPermission *permission = G_PERMISSION (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   switch (prop_id) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |     case PROP_ALLOWED: | 
					
						
							|  |  |  |  |       g_value_set_boolean (value, permission->priv->allowed); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     case PROP_CAN_ACQUIRE: | 
					
						
							|  |  |  |  |       g_value_set_boolean (value, permission->priv->can_acquire); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     case PROP_CAN_RELEASE: | 
					
						
							|  |  |  |  |       g_value_set_boolean (value, permission->priv->can_release); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     default: | 
					
						
							|  |  |  |  |       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_permission_init (GPermission *permission) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-06-24 15:43:04 +01:00
										 |  |  |  |   permission->priv = g_permission_get_instance_private (permission); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  | static gboolean | 
					
						
							|  |  |  |  | acquire_or_release (GPermission   *permission, | 
					
						
							|  |  |  |  |                     GCancellable  *cancellable, | 
					
						
							|  |  |  |  |                     GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_set_error_literal  (error, | 
					
						
							|  |  |  |  |                         G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, | 
					
						
							|  |  |  |  |                         "Can't acquire or release permission"); | 
					
						
							|  |  |  |  |   return FALSE; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | acquire_or_release_async (GPermission         *permission, | 
					
						
							|  |  |  |  |                           GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                           GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                           gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-07 09:48:27 -04:00
										 |  |  |  |   g_task_report_new_error (permission, | 
					
						
							|  |  |  |  |                            callback, user_data, | 
					
						
							|  |  |  |  |                            NULL, | 
					
						
							|  |  |  |  |                            G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, | 
					
						
							|  |  |  |  |                            "Can't acquire or release permission"); | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static gboolean | 
					
						
							|  |  |  |  | acquire_or_release_finish (GPermission   *permission, | 
					
						
							|  |  |  |  |                            GAsyncResult  *result, | 
					
						
							|  |  |  |  |                            GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-19 15:45:11 -04:00
										 |  |  |  |   return g_task_propagate_boolean (G_TASK (result), error); | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_permission_class_init (GPermissionClass *class) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObjectClass *object_class = G_OBJECT_CLASS (class); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   object_class->get_property = g_permission_get_property; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-19 02:19:27 -04:00
										 |  |  |  |   class->acquire = acquire_or_release; | 
					
						
							|  |  |  |  |   class->release = acquire_or_release; | 
					
						
							|  |  |  |  |   class->acquire_async = acquire_or_release_async; | 
					
						
							|  |  |  |  |   class->release_async = acquire_or_release_async; | 
					
						
							|  |  |  |  |   class->acquire_finish = acquire_or_release_finish; | 
					
						
							|  |  |  |  |   class->release_finish = acquire_or_release_finish; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  |   /**
 | 
					
						
							|  |  |  |  |    * GPermission:allowed: | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * %TRUE if the caller currently has permission to perform the action that | 
					
						
							|  |  |  |  |    * @permission represents the permission to perform. | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |    g_object_class_install_property (object_class, PROP_ALLOWED, | 
					
						
							| 
									
										
										
										
											2023-04-28 01:59:26 +02:00
										 |  |  |  |      g_param_spec_boolean ("allowed", NULL, NULL, | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |                            FALSE, | 
					
						
							|  |  |  |  |                            G_PARAM_STATIC_STRINGS | G_PARAM_READABLE)); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /**
 | 
					
						
							|  |  |  |  |    * GPermission:can-acquire: | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * %TRUE if it is generally possible to acquire the permission by calling | 
					
						
							|  |  |  |  |    * g_permission_acquire(). | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |    g_object_class_install_property (object_class, PROP_CAN_ACQUIRE, | 
					
						
							| 
									
										
										
										
											2023-04-28 01:59:26 +02:00
										 |  |  |  |      g_param_spec_boolean ("can-acquire", NULL, NULL, | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |                            FALSE, | 
					
						
							|  |  |  |  |                            G_PARAM_STATIC_STRINGS | G_PARAM_READABLE)); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /**
 | 
					
						
							|  |  |  |  |    * GPermission:can-release: | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * %TRUE if it is generally possible to release the permission by calling | 
					
						
							|  |  |  |  |    * g_permission_release(). | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |    g_object_class_install_property (object_class, PROP_CAN_RELEASE, | 
					
						
							| 
									
										
										
										
											2023-04-28 01:59:26 +02:00
										 |  |  |  |      g_param_spec_boolean ("can-release", NULL, NULL, | 
					
						
							| 
									
										
										
										
											2010-06-06 14:22:48 -04:00
										 |  |  |  |                            FALSE, | 
					
						
							|  |  |  |  |                            G_PARAM_STATIC_STRINGS | G_PARAM_READABLE)); | 
					
						
							| 
									
										
										
										
											2010-06-03 22:58:52 +02:00
										 |  |  |  | } |