maestral.utils.integration
This module provides functions for platform integration. Most of the functionality here could also be achieved with psutils but we want to avoid the large dependency.
Module Contents
- maestral.utils.integration.get_ac_state()[source]
Checks if the current device has AC power or is running on battery.
- Returns
True
if the device has AC power,False
otherwise.- Return type
- maestral.utils.integration.get_inotify_limits()[source]
Returns the current inotify limit settings as tuple.
- maestral.utils.integration.cpu_usage_percent(interval=0.1)[source]
Returns a float representing the CPU utilization of the current process as a percentage. This duplicates the similar method from psutil to avoid the psutil dependency.
Compares process times to system CPU times elapsed before and after the interval (blocking). It is recommended for accuracy that this function be called with an interval of at least 0.1 sec.
A value > 100.0 can be returned in case of processes running multiple threads on different CPU cores. The returned value is explicitly NOT split evenly between all available logical CPUs. This means that a busy loop process running on a system with 2 logical CPUs will be reported as having 100% CPU utilization instead of 50%.
- maestral.utils.integration.check_connection(hostname, timeout=2, logger=None)[source]
A low latency check for an internet connection.
- Parameters
hostname (str) – Hostname to use for connection check.
timeout (int) – Timeout in seconds for connection check.
logger (Optional[logging.Logger]) – If provided, log output for connection failures will be logged to this logger with the level DEBUG.
- Returns
Connection availability.
- Return type