|
1 | 1 | from datetime import timedelta |
2 | | - |
3 | 2 | from ext_api.proxmox_api import ProxmoxAPI |
4 | 3 |
|
5 | 4 |
|
6 | 5 | class BaseTasks: |
7 | | - TIMEOUT = 60 |
8 | | - LOOP_SLEEP = 2 |
| 6 | + """ |
| 7 | + BaseTasks class that provides common functionality for tasks interacting |
| 8 | + with the Proxmox API. It manages timeouts, loop sleeps, and provides utility |
| 9 | + methods for formatting durations. |
| 10 | +
|
| 11 | + Attributes: |
| 12 | + timeout (int): The default timeout in seconds for tasks. |
| 13 | + loop_sleep (int): The default sleep duration between task loops in seconds. |
| 14 | + _api (ProxmoxAPI): The Proxmox API instance used for interacting with Proxmox. |
| 15 | + """ |
| 16 | + |
| 17 | + timeout = 60 |
| 18 | + loop_sleep = 2 |
| 19 | + |
| 20 | + def __init__( |
| 21 | + self, api: ProxmoxAPI, timeout: int = timeout, loop_sleep: int = loop_sleep |
| 22 | + ): |
| 23 | + """ |
| 24 | + Initializes the BaseTasks class with the given Proxmox API instance and optional |
| 25 | + timeout and loop sleep values. |
9 | 26 |
|
10 | | - def __init__(self, api: ProxmoxAPI): |
| 27 | + Args: |
| 28 | + api (ProxmoxAPI): The Proxmox API instance for making API calls. |
| 29 | + timeout (int, optional): The timeout value for tasks (default is 60). |
| 30 | + loop_sleep (int, optional): The sleep time between loops in seconds (default is 2). |
| 31 | + """ |
11 | 32 | self._api: ProxmoxAPI = api |
| 33 | + self.timeout = timeout |
| 34 | + self.loop_sleep = loop_sleep |
12 | 35 |
|
13 | 36 | @property |
14 | 37 | def api(self): |
| 38 | + """ |
| 39 | + Gets the Proxmox API instance. |
| 40 | +
|
| 41 | + Returns: |
| 42 | + ProxmoxAPI: The Proxmox API instance. |
| 43 | + """ |
15 | 44 | return self._api |
16 | 45 |
|
17 | 46 | @api.setter |
18 | 47 | def api(self, value): |
| 48 | + """ |
| 49 | + Sets a new Proxmox API instance. |
| 50 | +
|
| 51 | + Args: |
| 52 | + value (ProxmoxAPI): The new Proxmox API instance to set. |
| 53 | + """ |
19 | 54 | self._api = value |
20 | 55 |
|
21 | 56 | @staticmethod |
22 | 57 | def format_duration(seconds: float | int) -> str: |
23 | | - """Format a duration (in seconds) as HH:MM:SS.""" |
| 58 | + """ |
| 59 | + Formats a duration (in seconds) as a string in the format HH:MM:SS. |
| 60 | +
|
| 61 | + Args: |
| 62 | + seconds (float or int): The duration in seconds to format. |
| 63 | +
|
| 64 | + Returns: |
| 65 | + str: The formatted duration as HH:MM:SS. |
| 66 | + """ |
24 | 67 | return str(timedelta(seconds=seconds)).split(".")[0] |
0 commit comments