Gio.MountOperation¶
class — extends GObject.Object
GMountOperation provides a mechanism for interacting with the user.
It can be used for authenticating mountable operations, such as loop
mounting files, hard drive partitions or server locations. It can
also be used to ask the user questions or show a list of applications
preventing unmount or eject operations from completing.
Note that GMountOperation is used for more than just Mount
objects – for example it is also used in Drive.start and
Drive.stop.
Users should instantiate a subclass of this that implements all the
various callbacks to show the required dialogs, such as
GtkMountOperation.
If no user interaction is desired (for example when automounting
filesystems at login time), usually NULL can be passed, see each method
taking a GMountOperation for details.
Throughout the API, the term ‘TCRYPT’ is used to mean ‘compatible with TrueCrypt and VeraCrypt’. TrueCrypt is a discontinued system for encrypting file containers, partitions or whole disks, typically used with Windows. VeraCrypt is a maintained fork of TrueCrypt with various improvements and auditing fixes.
Constructors¶
new¶
Creates a new mount operation.
Methods¶
get_anonymous¶
Check to see whether the mount operation is being used for an anonymous user.
get_choice¶
Gets a choice from the mount operation.
get_domain¶
Gets the domain of the mount operation.
get_is_tcrypt_hidden_volume¶
Check to see whether the mount operation is being used for a TCRYPT hidden volume.
get_is_tcrypt_system_volume¶
Check to see whether the mount operation is being used for a TCRYPT system volume.
get_password¶
Gets a password from the mount operation.
get_password_save¶
Gets the state of saving passwords for the mount operation.
get_pim¶
Gets a PIM from the mount operation.
get_username¶
Get the user name from the mount operation.
reply¶
Emits the MountOperation::reply signal.
Parameters:
result— aMountOperationResult
set_anonymous¶
Sets the mount operation to use an anonymous user if anonymous is True.
Parameters:
anonymous— boolean value.
set_choice¶
Sets a default choice for the mount operation.
Parameters:
choice— an integer.
set_domain¶
Sets the mount operation's domain.
Parameters:
domain— the domain to set.
set_is_tcrypt_hidden_volume¶
Sets the mount operation to use a hidden volume if hidden_volume is True.
Parameters:
hidden_volume— boolean value.
set_is_tcrypt_system_volume¶
Sets the mount operation to use a system volume if system_volume is True.
Parameters:
system_volume— boolean value.
set_password¶
Sets the mount operation's password to password.
Parameters:
password— password to set.
set_password_save¶
Sets the state of saving passwords for the mount operation.
Parameters:
save— a set ofPasswordSaveflags.
set_pim¶
Sets the mount operation's PIM to pim.
Parameters:
pim— an unsigned integer.
set_username¶
Sets the user name within op to username.
Parameters:
username— input username.
Virtual methods¶
do_aborted¶
do_ask_password¶
def do_ask_password(self, message: str, default_user: str, default_domain: str, flags: AskPasswordFlags | int) -> None
do_ask_question¶
Virtual implementation of MountOperation::ask-question.
Parameters:
message— string containing a message to display to the userchoices— an array of strings for each possible choice
do_reply¶
Emits the MountOperation::reply signal.
Parameters:
result— aMountOperationResult
do_show_processes¶
Virtual implementation of MountOperation::show-processes.
Parameters:
message— string containing a message to display to the userprocesses— an array ofGPidfor processes blocking the operationchoices— an array of strings for each possible choice
do_show_unmount_progress¶
Properties¶
anonymous¶
Whether to use an anonymous user when authenticating.
choice¶
The index of the user's choice when a question is asked during the
mount operation. See the MountOperation::ask-question signal.
domain¶
The domain to use for the mount operation.
is_tcrypt_hidden_volume¶
Whether the device to be unlocked is a TCRYPT hidden volume. See the VeraCrypt documentation.
is_tcrypt_system_volume¶
Whether the device to be unlocked is a TCRYPT system volume. In this context, a system volume is a volume with a bootloader and operating system installed. This is only supported for Windows operating systems. For further documentation, see the VeraCrypt documentation.
password¶
The password that is used for authentication when carrying out the mount operation.
password_save¶
Determines if and how the password information should be saved.
pim¶
The VeraCrypt PIM value, when unlocking a VeraCrypt volume. See the VeraCrypt documentation.
username¶
The user name that is used for authentication when carrying out the mount operation.
Signals¶
aborted¶
Emitted by the backend when e.g. a device becomes unavailable while a mount operation is in progress.
Implementations of GMountOperation should handle this signal by dismissing open password dialogs.
ask-password¶
def on_ask_password(self, message: str, default_user: str, default_domain: str, flags: AskPasswordFlags) -> None: ...
Emitted when a mount operation asks the user for a password.
If the message contains a line break, the first line should be
presented as a heading. For example, it may be used as the
primary text in a Gtk.MessageDialog.
ask-question¶
Emitted when asking the user a question and gives a list of choices for the user to choose from.
If the message contains a line break, the first line should be
presented as a heading. For example, it may be used as the
primary text in a Gtk.MessageDialog.
reply¶
Emitted when the user has replied to the mount operation.
show-processes¶
def on_show_processes(self, message: str, processes: list[GLib.Pid], choices: list[str]) -> None: ...
Emitted when one or more processes are blocking an operation
e.g. unmounting/ejecting a Mount or stopping a Drive.
Note that this signal may be emitted several times to update the
list of blocking processes as processes close files. The
application should only respond with MountOperation.reply to
the latest signal (setting MountOperation:choice to the choice
the user made).
If the message contains a line break, the first line should be
presented as a heading. For example, it may be used as the
primary text in a Gtk.MessageDialog.
show-unmount-progress¶
Emitted when an unmount operation has been busy for more than some time (typically 1.5 seconds).
When unmounting or ejecting a volume, the kernel might need to flush
pending data in its buffers to the volume stable storage, and this operation
can take a considerable amount of time. This signal may be emitted several
times as long as the unmount operation is outstanding, and then one
last time when the operation is completed, with bytes_left set to zero.
Implementations of GMountOperation should handle this signal by
showing an UI notification, and then dismiss it, or show another notification
of completion, when bytes_left reaches zero.
If the message contains a line break, the first line should be
presented as a heading. For example, it may be used as the
primary text in a Gtk.MessageDialog.