:right-sidebar: True Permission =================================================================== .. currentmodule:: gi.repository.Gio .. class:: Permission(**properties: ~typing.Any) :no-contents-entry: Superclasses: :class:`~gi.repository.GObject.Object` Subclasses: :class:`~gi.repository.Gio.SimplePermission` A ``GPermission`` represents the status of the caller’s permission to 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. As an example, a ``GPermission`` might represent the ability for the user to write to a :obj:`~gi.repository.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 when that button is clicked. Methods ------- .. rst-class:: interim-class .. class:: Permission :no-index: .. method:: acquire(cancellable: ~gi.repository.Gio.Cancellable | None = None) -> bool 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 :func:`~gi.repository.Gio.Permission.get_can_acquire` before calling this function. If the permission is acquired then :const:`True` is returned. Otherwise, :const:`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 :func:`~gi.repository.Gio.Permission.acquire_async` for the non-blocking version. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` .. method:: acquire_async(cancellable: ~gi.repository.Gio.Cancellable | None = None, callback: ~typing.Callable[[...], None] | None = None, *user_data: ~typing.Any) -> None Attempts to acquire the permission represented by ``permission``. This is the first half of the asynchronous version of :func:`~gi.repository.Gio.Permission.acquire`. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` :param callback: the :obj:`~gi.repository.Gio.AsyncReadyCallback` to call when done :param user_data: the user data to pass to ``callback`` .. method:: acquire_finish(result: ~gi.repository.Gio.AsyncResult) -> bool Collects the result of attempting to acquire the permission represented by ``permission``. This is the second half of the asynchronous version of :func:`~gi.repository.Gio.Permission.acquire`. .. versionadded:: 2.26 :param result: the :obj:`~gi.repository.Gio.AsyncResult` given to the :obj:`~gi.repository.Gio.AsyncReadyCallback` .. method:: get_allowed() -> bool Gets the value of the 'allowed' property. This property is :const:`True` if the caller currently has permission to perform the action that ``permission`` represents the permission to perform. .. versionadded:: 2.26 .. method:: get_can_acquire() -> bool Gets the value of the 'can-acquire' property. This property is :const:`True` if it is generally possible to acquire the permission by calling :func:`~gi.repository.Gio.Permission.acquire`. .. versionadded:: 2.26 .. method:: get_can_release() -> bool Gets the value of the 'can-release' property. This property is :const:`True` if it is generally possible to release the permission by calling :func:`~gi.repository.Gio.Permission.release`. .. versionadded:: 2.26 .. method:: impl_update(allowed: bool, can_acquire: bool, can_release: bool) -> None This function is called by the :obj:`~gi.repository.Gio.Permission` implementation to update the properties of the permission. You should never call this function except from a :obj:`~gi.repository.Gio.Permission` implementation. GObject notify signals are generated, as appropriate. .. versionadded:: 2.26 :param allowed: the new value for the 'allowed' property :param can_acquire: the new value for the 'can-acquire' property :param can_release: the new value for the 'can-release' property .. method:: release(cancellable: ~gi.repository.Gio.Cancellable | None = None) -> bool 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 :func:`~gi.repository.Gio.Permission.get_can_release` before calling this function. If the permission is released then :const:`True` is returned. Otherwise, :const:`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 :func:`~gi.repository.Gio.Permission.release_async` for the non-blocking version. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` .. method:: release_async(cancellable: ~gi.repository.Gio.Cancellable | None = None, callback: ~typing.Callable[[...], None] | None = None, *user_data: ~typing.Any) -> None Attempts to release the permission represented by ``permission``. This is the first half of the asynchronous version of :func:`~gi.repository.Gio.Permission.release`. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` :param callback: the :obj:`~gi.repository.Gio.AsyncReadyCallback` to call when done :param user_data: the user data to pass to ``callback`` .. method:: release_finish(result: ~gi.repository.Gio.AsyncResult) -> bool Collects the result of attempting to release the permission represented by ``permission``. This is the second half of the asynchronous version of :func:`~gi.repository.Gio.Permission.release`. .. versionadded:: 2.26 :param result: the :obj:`~gi.repository.Gio.AsyncResult` given to the :obj:`~gi.repository.Gio.AsyncReadyCallback` Properties ---------- .. rst-class:: interim-class .. class:: Permission :no-index: .. attribute:: props.allowed :type: bool The type of the None singleton. .. attribute:: props.can_acquire :type: bool The type of the None singleton. .. attribute:: props.can_release :type: bool The type of the None singleton. Virtual Methods --------------- .. rst-class:: interim-class .. class:: Permission :no-index: .. method:: do_acquire(cancellable: ~gi.repository.Gio.Cancellable | None = None) -> bool 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 :func:`~gi.repository.Gio.Permission.get_can_acquire` before calling this function. If the permission is acquired then :const:`True` is returned. Otherwise, :const:`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 :func:`~gi.repository.Gio.Permission.acquire_async` for the non-blocking version. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` .. method:: do_acquire_async(cancellable: ~gi.repository.Gio.Cancellable | None = None, callback: ~typing.Callable[[...], None] | None = None, *user_data: ~typing.Any) -> None Attempts to acquire the permission represented by ``permission``. This is the first half of the asynchronous version of :func:`~gi.repository.Gio.Permission.acquire`. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` :param callback: the :obj:`~gi.repository.Gio.AsyncReadyCallback` to call when done :param user_data: the user data to pass to ``callback`` .. method:: do_acquire_finish(result: ~gi.repository.Gio.AsyncResult) -> bool Collects the result of attempting to acquire the permission represented by ``permission``. This is the second half of the asynchronous version of :func:`~gi.repository.Gio.Permission.acquire`. .. versionadded:: 2.26 :param result: the :obj:`~gi.repository.Gio.AsyncResult` given to the :obj:`~gi.repository.Gio.AsyncReadyCallback` .. method:: do_release(cancellable: ~gi.repository.Gio.Cancellable | None = None) -> bool 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 :func:`~gi.repository.Gio.Permission.get_can_release` before calling this function. If the permission is released then :const:`True` is returned. Otherwise, :const:`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 :func:`~gi.repository.Gio.Permission.release_async` for the non-blocking version. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` .. method:: do_release_async(cancellable: ~gi.repository.Gio.Cancellable | None = None, callback: ~typing.Callable[[...], None] | None = None, *user_data: ~typing.Any) -> None Attempts to release the permission represented by ``permission``. This is the first half of the asynchronous version of :func:`~gi.repository.Gio.Permission.release`. .. versionadded:: 2.26 :param cancellable: a :obj:`~gi.repository.Gio.Cancellable`, or :const:`None` :param callback: the :obj:`~gi.repository.Gio.AsyncReadyCallback` to call when done :param user_data: the user data to pass to ``callback`` .. method:: do_release_finish(result: ~gi.repository.Gio.AsyncResult) -> bool Collects the result of attempting to release the permission represented by ``permission``. This is the second half of the asynchronous version of :func:`~gi.repository.Gio.Permission.release`. .. versionadded:: 2.26 :param result: the :obj:`~gi.repository.Gio.AsyncResult` given to the :obj:`~gi.repository.Gio.AsyncReadyCallback` Fields ------ .. rst-class:: interim-class .. class:: Permission :no-index: .. attribute:: parent_instance .. attribute:: priv