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.2.tar.gz (115.2 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.2-py3-none-any.whl (152.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: alpha_python-0.6.2.tar.gz
  • Upload date:
  • Size: 115.2 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.2.tar.gz
Algorithm Hash digest
SHA256 b4937199471d9ee8554841009725794405b298135cae5aab51e4e6810b015aa2
MD5 cbbe273d2d413ae91b1098bf33493137
BLAKE2b-256 fed6b8fa7f4bb510d13b77c091dbf499006181bc29e23789855815f3c675311c

See more details on using hashes here.

Provenance

The following attestation bundles were made for alpha_python-0.6.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: alpha_python-0.6.2-py3-none-any.whl
  • Upload date:
  • Size: 152.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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6162f7e9d73d6b341247b0b90f5d77cc27286fc69c64ad51e55848ad4e6e1ed2
MD5 71a2d5f686e506bc18c5b41067071e3d
BLAKE2b-256 7d63e972b5bc3841f99eeeec2701bb84f7c4e8fd3c687ac338559ff248ea0c1c

See more details on using hashes here.

Provenance

The following attestation bundles were made for alpha_python-0.6.2-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