An application framework promoting consistency and centralising common tasks
Project description
alx-common
A comprehensive Python framework for infrastructure automation, monitoring, and reporting. Designed to standardize common development tasks and eliminate code duplication in dev, test and production environments.
Preamble
On first invocation, if the directory $HOME/.config/alx
(or %APPDATA%\alx on Windows) is not found, then it is created
along with the following files:
alx.ini: The module configuration file which should be used to override settings in the defaults found inalx.iniin the installed module directoryenv: This file contains the path to the virtual environment in use and is set to the current python used to execute a script usingalx-common. The file is used in a standardised start script that should be used to make best use of the module.key: An encryption key used to encrypt and decrypt strings. If there are multiple developers, then it is wise to share the key so the configuration file can remain consistent. This file must be stored readable only by the user and not shared. The command to create a key is:
python -c "from cryptography.fernet import Fernet; print(Fernet.generate_key().decode())"
These files can (and should) be modified to suit your needs. For example,
changing alx.ini and adding
[mail]
from: Application User <valid@email.address>
server: your.mailhost.org
would be a good idea.
Summary
alx-common provides a consistent foundation for building reliable internal applications that deal with:
- ✅ Configuration management
- ✅ Argument parsing
- ✅ Different environment handling: dev, test, prod
- ✅ Secure password, etc. handling with encryption
- ✅ Logging (including file rotation, maximum size and console output)
- ✅ Database utilities (MySQL, MariaDB, SQLite, PostgreSQL)
- ✅ HTML report generation
- ✅ Email notifications (plain, HTML, attachments, inline images)
- ✅ Monitoring integrations (ITRS Geneos support)
- ✅ Lightweight internal automation tools
Originally designed to simplify and standardize automation scripts,
reporting jobs, monitoring pipelines, and operational tooling across
real-world production environments. The aim of alx-common is to
reduce hard coding and duplication of snippets.
Too many times, I have seen developers share code to 'send an email'.
Then the mailhost changes and there are 200 scripts to fix. Or
a shell script is copied and something edited to create a wrapper
to start a python script. Or the same code is used over and over to
set up logging or read a configuration file coupled with a lot of hard
coding and inconsistencies.
Bad practice is endemic in the developer community as there are too many coders adopting a cut-and-paste mentality.
The name comes from my company, ALX Solutions which is no longer in operation but now lives on in PyPI and GitHub!
Features
-
Application Framework (
alx.app.ALXapp)- Simplified argparse-based CLI definition
- Config-driven parameter management (
alx.ini) - Environment separation (dev/test/prod)
- Secure password storage (Fernet encryption)
- Dynamic path management (logs, data, config)
- Application configuration automatically parsed
and stored in
alx.app.ALXappobject - Centralized logger management handled providing automatic house-keeping based on configuration
-
Database Utilities (
alx.db_util.ALXdatabase)- Simplifies open source database access
- Auto-formatted SQL logging
- Centralized connection lifecycle
- Transaction management
- Simplified execution mechanism
-
Reporting (
alx.html.ALXhtml)- Easy HTML generation
- Promotes tidy and consistent code
-
Email creation (
alx.mail.ALXmail)- Supports plaintext and html formats
- Easy email formatting and sending
- Flexible
- Integrated with SMTP servers, attachments, and inline images
-
String manipulation (
strings.py)- Commonly used string manipulation routines
-
ITRS Geneos Utilities (
alx.itrs)- Provides a consistent way to parse the environment on an event
(
alx.itrs.environment.Environment) - A standard alert in html / table format (
alx.itrs.alert.HtmlAlert) - A class to create a Geneos toolkit sampler without the
need to know internal details (
alx.itrs.toolkit.Toolkit) - Standardised environment parsing
- Provides a consistent way to parse the environment on an event
(
Documentation
Documentation exists inline in pdoc format. Once the
module is installed pdoc alx will display the fully formatted
documaentation in a browser window. It is also generated in html
format at https://andrewapac.github.io/alx-common
Quick Start
from alx.app import ALXapp
import sys
args = [
['string'],
['-d', '--decrypt', {'action': 'store_true', 'default': False}]
]
app = ALXapp("Password encryption tool", args=args)
string = app.arguments.string
if not app.arguments.decrypt:
string = app.encrypt(string)
print("Encrypted: " + string)
print("Decrypted: " + app.decrypt(string))
sys.exit(0)
Examples
Please refer to the files in the examples directory
Changelog
See CHANGELOG for details of public releases.
Stats for nerds
More at https://pepy.tech/projects/alx-common
Resources
- PyPI: https://pypi.org/project/alx-common/
- GitHub: https://github.com/AndrewAPAC/alx-common
- Documentation: https://andrewapac.github.io/alx-common/
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file alx_common-2.8.8.tar.gz.
File metadata
- Download URL: alx_common-2.8.8.tar.gz
- Upload date:
- Size: 39.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
75c478817dd41bf0f555b0f264823e205efa80991d3a448137600284cd1bf6fa
|
|
| MD5 |
ab2ea0f9157ecc76eea4d8fc0e3eda3c
|
|
| BLAKE2b-256 |
1ab539b5b5546a7ed0e2f108b355e8e581d5d85928b74b7ee368675427115067
|
Provenance
The following attestation bundles were made for alx_common-2.8.8.tar.gz:
Publisher:
publish.yml on AndrewAPAC/alx-common
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
alx_common-2.8.8.tar.gz -
Subject digest:
75c478817dd41bf0f555b0f264823e205efa80991d3a448137600284cd1bf6fa - Sigstore transparency entry: 786799575
- Sigstore integration time:
-
Permalink:
AndrewAPAC/alx-common@ec6ea1e4e550e762853f9b4b56fa04f4f4fe20d0 -
Branch / Tag:
refs/tags/v2.8.8 - Owner: https://github.com/AndrewAPAC
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ec6ea1e4e550e762853f9b4b56fa04f4f4fe20d0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file alx_common-2.8.8-py3-none-any.whl.
File metadata
- Download URL: alx_common-2.8.8-py3-none-any.whl
- Upload date:
- Size: 40.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4eb4626cc35bfba5b5d7ee31f580aaa0e3f7fe68df3dac2d7f88b1d95103177f
|
|
| MD5 |
a650fba232128c8b50b85c154bafae3b
|
|
| BLAKE2b-256 |
83c5c85789fae817d746013cad8452793750573151cfb46889c249c1496800b6
|
Provenance
The following attestation bundles were made for alx_common-2.8.8-py3-none-any.whl:
Publisher:
publish.yml on AndrewAPAC/alx-common
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
alx_common-2.8.8-py3-none-any.whl -
Subject digest:
4eb4626cc35bfba5b5d7ee31f580aaa0e3f7fe68df3dac2d7f88b1d95103177f - Sigstore transparency entry: 786799577
- Sigstore integration time:
-
Permalink:
AndrewAPAC/alx-common@ec6ea1e4e550e762853f9b4b56fa04f4f4fe20d0 -
Branch / Tag:
refs/tags/v2.8.8 - Owner: https://github.com/AndrewAPAC
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ec6ea1e4e550e762853f9b4b56fa04f4f4fe20d0 -
Trigger Event:
push
-
Statement type: