Lightweight OS-agnostic service monitoring API
Platform Supported
Deployments
Recommendations
- Install
python3.11 or above - Use a dedicated virtual environment
Install PyNinja
python -m pip install pyninjaInitiate - IDE
import pyninja
if __name__ == '__main__':
pyninja.start()Initiate - CLI
pyninja startUse
pyninja --helpfor usage instructions.
Sourcing environment variables from an env file
By default,
PyNinjawill look for a.envfile in the current working directory.
Basic API
- APIKEY - API Key for authentication.
- SWAGGER_UI_PARAMETERS - Dictionary of parameters to be included in the Swagger UI.
- NINJA_HOST - Hostname for the API server.
- NINJA_PORT - Port number for the API server.
Functional improvements
- RATE_LIMIT - List of dictionaries with
max_requestsandsecondsto apply as rate limit. - LOG_CONFIG - Logging configuration file path.
Remote execution and FileIO
- REMOTE_EXECUTION - Boolean flag to enable remote execution.
- API_SECRET - Secret access key for running commands on server remotely.
- DATABASE - FilePath to store the auth database that handles the authentication errors.
Multifactor Authentication (MFA)
-
MFA_TIMEOUT - Timeout duration for MFA in seconds.
-
MFA_RESEND_DELAY - Resend duration for MFA in seconds. Cool off period before a new MFA can be requested.
-
Email
- GMAIL_USER - Gmail username for MFA.
- GMAIL_PASS - Gmail password for MFA.
- RECIPIENT - Recipient email address for MFA. Defaults to GMAIL_USER
-
Ntfy
- NTFY_URL - Ntfy server URL.
- NTFY_TOPIC - Subscribed ntfy topic.
Include NTFY_USERNAME and NTFY_PASSWORD if the topic is protected.
-
Telegram
- TELEGRAM_TOKEN - Telegram bot token.
- TELEGRAM_CHAT_ID - Telegram chat ID to send MFA.
-
Authenticator
- AUTHENTICATOR_TOKEN - MFA Authenticator token.
To generate a QR code for any authenticator application:
Code
import pyninja pyninja.otp.generate_qr(show_qr=True)
CLI
pyninja --mfa
📓 Generating an authenticator token using PyNinja is the simplest ways to set up MFA authentication. However, the trade-off is that the token is short-lived. Each MFA passcode is only valid for 30 seconds.
Monitoring UI
- MONITOR_USERNAME - Username to authenticate the monitoring page.
- MONITOR_PASSWORD - Password to authenticate the monitoring page.
- MONITOR_SESSION - Session timeout for the monitoring page.
- DISK_REPORT - Boolean flag to enable disk report feature using PyUdisk.
- MAX_CONNECTIONS - Maximum number of monitoring sessions allowed in parallel.
- PROCESSES - List of process names to include in the monitor page.
- SERVICES - List of service names to include in the monitor page.
- SERVICE_LIB - Library path to retrieve service info.
- SMART_LIB - Library path for S.M.A.R.T metrics using PyUdisk.
- GPU_LIB - Library path to retrieve GPU names using PyArchitecture.
- DISK_LIB - Library path to retrieve disk info using PyArchitecture.
- PROCESSOR_LIB - Library path to retrieve processor name using PyArchitecture.
macOS Specific Binaries
- OSASCRIPT - Path to the
osascriptbinary for macOS. Defaults to/usr/bin/osascript - MDLS - Path to the
mdlsbinary for macOS. Defaults to/usr/bin/mdls - OPEN - Path to the
openbinary for macOS. Defaults to/usr/bin/open
📓 Certain environment variables like
SERVICESandPROCESSSare case-sensitive
Refer samples directory for examples.
Docstring format: Google
Styling conventions: PEP 8 and isort
Requirement
python -m pip install gitverseUsage
gitverse-release reverse -f release_notes.rst -t 'Release Notes'pre-commit will ensure linting, run pytest, generate runbook & release notes, and validate hyperlinks in ALL
markdown files (including Wiki pages)
Requirement
python -m pip install sphinx==5.1.1 pre-commit recommonmarkUsage
pre-commit run --all-fileshttps://pypi.org/project/PyNinja/
https://thevickypedia.github.io/PyNinja/
© Vignesh Rao
Licensed under the MIT License