EnQuotaModule » Cronologia » Versione 5
Simone Piccardi, 22-12-2010 19:10
| 1 | 5 | Simone Piccardi | h1. Module quota |
|---|---|---|---|
| 2 | 1 | Amministratore Truelite | |
| 3 | 5 | Simone Piccardi | This is a simple wrapper for the @quotactl@ system call, allowing getting and setting _quota_ directly from _Python_ (no need to call an external program and parse its output). |
| 4 | 4 | Amministratore Truelite | |
| 5 | It's still extremely primordial, providing limited functionality and working only with Linux quota version 2. It has been tested on Debian Etch and Lenny. As my first attempt to write a module it is also very far from elegance (and no pythonic at all). |
||
| 6 | 1 | Amministratore Truelite | |
| 7 | 5 | Simone Piccardi | h2. Installation |
| 8 | 4 | Amministratore Truelite | |
| 9 | To install the module you need the following steps (provided you have standard development tools installed): |
||
| 10 | 5 | Simone Piccardi | |
| 11 | 1 | Amministratore Truelite | <pre> |
| 12 | 4 | Amministratore Truelite | svn co https://labs.truelite.it/svn/cyrcus/quotamodule |
| 13 | 1 | Amministratore Truelite | cd quotamodule/ |
| 14 | python setup.py build |
||
| 15 | </pre> |
||
| 16 | |||
| 17 | 5 | Simone Piccardi | then you can copy the @quota.so@ module (look inside the created build directory) to its destination (if you want to just check it with @python@ you can use your current working directory). |
| 18 | 4 | Amministratore Truelite | |
| 19 | 5 | Simone Piccardi | h2. Use |
| 20 | 1 | Amministratore Truelite | |
| 21 | The module provides the following functions (interface is preliminar, it will be probably changed in future releases): |
||
| 22 | |||
| 23 | 5 | Simone Piccardi | |_.Function |_.Arguments |._Description| |
| 24 | |@get_user_quota@|@uid@ (integer), @device@ (string)| get user quota| |
||
| 25 | |@get_group_quota@|@gid@ (integer), @device@ (string)| get group quota| |
||
| 26 | |@set_user_block_quota@|@uid@ (integer), @device@ (string), @(soft,hard)@ *tuple of two int | set block user quota| |
||
| 27 | |@set_user_inode_quota@|@uid@ (integer), @device@ (string), @(soft,hard)@ *tuple of two int | set inode user quota| |
||
| 28 | |@set_group_block_quota@|@gid@ (integer), @device@ (string), @(soft,hard)@ *tuple of two int | set block group quota| |
||
| 29 | |@set_group_inode_quota@|@gid@ (integer), @device@ (string), @(soft,hard)@ *tuple of two int | set inode group quota| |
||
| 30 | 4 | Amministratore Truelite | |
| 31 | 5 | Simone Piccardi | User or group can be only specified by numeric ID (uid or gid). The device string must be the device pathname for the filesystem on which we want to operate. |
| 32 | 1 | Amministratore Truelite | |
| 33 | When setting quotas they must be provided as a tuple of two integer values (first for soft limit, second for hard limit). They will be applied to inode/block, user/group according to the chosen function. |
||
| 34 | |||
| 35 | Reading quota will give back a tuple of two dictionaries. First dictionary is for block quota data, second for inode quota data. Both dictionaries will have the same string keys according to the following table: |
||
| 36 | 4 | Amministratore Truelite | |
| 37 | 5 | Simone Piccardi | |_.Key|_.Desctiption| |
| 38 | |used| integer with the actual usage of the resource (blocks or inodes number)|| |
||
| 39 | |quota| a two integers tuple with the current value of the quota (soft limit, hard limit) || |
||
| 40 | |grace| an integer with the @time_t@ value of the grace expiration (if active)|| |
||
| 41 | 1 | Amministratore Truelite | |
| 42 | 4 | Amministratore Truelite | |
| 43 | 5 | Simone Piccardi | h2. Error handling |
| 44 | 4 | Amministratore Truelite | |
| 45 | 5 | Simone Piccardi | All error in calling the @quotactl@ function will raise an @OSError@ exception passing the error value in @errno@. |