Python library for requesting root privileges
Project description
Elevate is a small Python library that re-launches the current process with root/admin privileges using one of the following mechanisms:
UAC (Windows)
AppleScript (macOS)
pkexec, gksudo or kdesudo (Linux)
sudo (Linux, macOS)
Usage
To use, call elevate.elevate() early in your script. When run as root this function does nothing. When not run as root, this function replaces the current process (Linux, macOS) or creates a new process, waits, and exits (Windows). Consider the following example:
import os
from elevate import elevate
def is_root():
return os.getuid() == 0
print("before ", is_root())
elevate()
print("after ", is_root())
This prints:
before False before True after True
On Windows, the new process’s standard streams are not attached to the parent, which is an inherent limitation of UAC. By default the new process runs in a new console window. To suppress this window, use elevate(show_console=False).
On Linux and macOS, graphical prompts are tried before sudo by default. To prevent graphical prompts, use elevate(graphical=False).
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file elevate-0.1.3.tar.gz
.
File metadata
- Download URL: elevate-0.1.3.tar.gz
- Upload date:
- Size: 2.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 53ad19fa1de301fb1de3f8768fb3a5894215716fd96a475690c4d0ff3b1de209 |
|
MD5 | 33d07ae9cc2f280415179d1075e3e9e2 |
|
BLAKE2b-256 | 813229ba61063ac124632754e26c65e71217f48ce682fbf8762ee9a0bb0d32de |