Skip to main content

Alpha is intended to be the first dependency you need to add to your Python application. It is a Python library which contains standard building blocks that can be used in applications that are used as APIs and/or make use of database interaction.

Project description

Alpha

Alpha is intended to be the first dependency you need to add to your Python application. It is a Python library which contains standard building blocks that can be used in applications that are used as APIs and/or make use of database interaction.

Badges

PyPI version PyPI Downloads Build Status Supported Python versions Coverage Status uv mypy Pytest PEP8 Ruff Documentation Status MIT License Sponsor

TL;DR

Alpha provides a comprehensive set of tools for building Python applications that interact with APIs and databases, including API code generation, authentication and authorization, database access layers, error handling, logging, and more. It is designed to be the first dependency you add to your project, providing a solid foundation for your application's architecture.

Documentation

Full documentation is available at alpha-python.readthedocs.io.

Installation

The library is still in development, but you can already install it using pip:

pip install alpha-python

If you want to use the alpha cli for generating API code, you can install it using pip as well:

pip install alpha-python[api-generator]

If you want to add the library to your API project, you can add it to your pyproject.toml file:

# Poetry example
poetry add alpha-python --extras "flask, postgresql"
poetry add --dev alpha-python --extras "api-generator"

# UV example
uv add alpha-python --extra flask --extra postgresql
uv add --dev alpha-python --extra api-generator

Features

  • API code generation
  • Authentication and authorization
  • Database interaction
  • Logging
  • Error handling
  • And much more!

Usage

The library contains many components. Below are a few practical examples that map to the guides in the documentation.

1) API code generation using OpenAPI spec

alpha api gen --spec-file specification/openapi.yaml --service-package my_app

alpha api run --port 8080

2) Authenticate with Keycloak (OIDC)

from alpha import KeyCloakOIDCConnector, KeyCloakProvider, PasswordCredentials

keycloak_connector = KeyCloakOIDCConnector(
	base_url="https://keycloak.example.com",
	realm="myrealm",
	client_id="myclient",
	client_secret="myclientsecret",
)

keycloak_provider = KeyCloakProvider(connector=keycloak_connector)

credentials = PasswordCredentials(username="user1", password="user1_password")
identity = keycloak_provider.authenticate(credentials)

3) Query data using SqlAlchemyDatabase + SqlAlchemyRepository

from alpha import SqlAlchemyDatabase, SqlAlchemyRepository
from my_app import User

db = SqlAlchemyDatabase(conn_str="postgresql://user:password@localhost:5432/mydatabase")

with db.get_session() as session:
	users = SqlAlchemyRepository[User](session=session, default_model=User)
	user = users.get_by_id(1)

4) Use Unit of Work for transactional operations

from alpha import (
	RepositoryModel,
	SqlAlchemyDatabase,
	SqlAlchemyRepository,
	SqlAlchemyUnitOfWork,
)
from my_app import User, OrmMapper

db = SqlAlchemyDatabase(..., mapper=OrmMapper)
repositories = [
	RepositoryModel(
		name="users",
		repository=SqlAlchemyRepository[User],
		default_model=User,
	)
]

uow = SqlAlchemyUnitOfWork(db=db, repos=repositories)

with uow:
	user = uow.users.get_by_id(1)

See also:

Contributing

If you want to contribute to the development of this library, you can fork the repository and create a pull request with your changes.

Support

If Alpha saves you time in production, consider supporting development by buying me a coffee! Your support helps me to continue improving the library and adding new features. Thank you!

License

This library is licensed under the MIT License. See the LICENSE file for more information.

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

alpha_python-0.6.3.tar.gz (116.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

alpha_python-0.6.3-py3-none-any.whl (153.2 kB view details)

Uploaded Python 3

File details

Details for the file alpha_python-0.6.3.tar.gz.

File metadata

  • Download URL: alpha_python-0.6.3.tar.gz
  • Upload date:
  • Size: 116.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for alpha_python-0.6.3.tar.gz
Algorithm Hash digest
SHA256 0afb02a2a3930176a1f1d3201a84277738d42bd01182c78f80d6c9433098b6bf
MD5 7804f069b991ed3e735bc73a118b4a70
BLAKE2b-256 6f1d642c73dcd7b8cd605675e7d2c9a835c018beaec501b4d87e2457c1991567

See more details on using hashes here.

Provenance

The following attestation bundles were made for alpha_python-0.6.3.tar.gz:

Publisher: python-publish.yml on BReijling/alpha

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file alpha_python-0.6.3-py3-none-any.whl.

File metadata

  • Download URL: alpha_python-0.6.3-py3-none-any.whl
  • Upload date:
  • Size: 153.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for alpha_python-0.6.3-py3-none-any.whl
Algorithm Hash digest
SHA256 852fe669761eb07da2f918751f149ad9c8d6c131b8b45b1968a3e96cb99cb60d
MD5 f3fe35b63d504884888389de506c6c53
BLAKE2b-256 79c67d997853ac0ef6ff5744df45c7966b5d06a48d86973c8415ce99d9edf21d

See more details on using hashes here.

Provenance

The following attestation bundles were made for alpha_python-0.6.3-py3-none-any.whl:

Publisher: python-publish.yml on BReijling/alpha

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page