Shared foundation library for TLS-based protocol implementations
Project description
Tlacacoca - Shared Foundation Library for TLS-Based Protocols
A protocol-agnostic foundation library providing shared components for building secure TLS-based network protocol implementations in Python. Tlacacoca (pronounced "tla-ka-KO-ka", from Nahuatl meaning "secure/safe") provides security, middleware, and logging utilities that can be shared across multiple protocol implementations.
Key Features
- Security First - TLS context creation, TOFU certificate validation, certificate utilities
- Middleware System - Rate limiting, IP access control, certificate authentication
- Structured Logging - Privacy-preserving logging with IP hashing
- Protocol Agnostic - Abstract interfaces that any TLS-based protocol can build upon
- Modern Python - Full type hints, async/await support, and modern tooling with
uv
Quick Start
Installation
# As a library
uv add tlacacoca
# From source (for development)
git clone https://github.com/alanbato/tlacacoca.git
cd tlacacoca && uv sync
Basic Usage
import ssl
from tlacacoca import (
create_client_context,
create_server_context,
TOFUDatabase,
RateLimiter,
RateLimitConfig,
AccessControl,
AccessControlConfig,
MiddlewareChain,
)
# Create TLS contexts
client_ctx = create_client_context(verify_mode=ssl.CERT_REQUIRED)
server_ctx = create_server_context("cert.pem", "key.pem")
# Set up TOFU certificate validation
async with TOFUDatabase(app_name="myapp") as tofu:
# First connection - certificate is stored
await tofu.verify_or_trust("example.com", 1965, cert_fingerprint)
# Subsequent connections - certificate is verified
await tofu.verify_or_trust("example.com", 1965, cert_fingerprint)
# Configure middleware chain
rate_config = RateLimitConfig(capacity=10, refill_rate=1.0)
access_config = AccessControlConfig(
allow_list=["192.168.1.0/24"],
default_allow=False
)
chain = MiddlewareChain([
AccessControl(access_config),
RateLimiter(rate_config),
])
# Process requests through middleware
result = await chain.process_request(
request_url="protocol://example.com/path",
client_ip="192.168.1.100"
)
if result.allowed:
# Handle request
pass
else:
# Map denial_reason to protocol-specific response
if result.denial_reason == "rate_limit":
# e.g., Gemini: "44 SLOW DOWN\r\n"
pass
Components
Security
| Component | Description |
|---|---|
create_client_context() |
Create TLS context for client connections |
create_server_context() |
Create TLS context for server connections |
TOFUDatabase |
Trust-On-First-Use certificate validation |
generate_self_signed_cert() |
Generate self-signed certificates |
get_certificate_fingerprint() |
Get SHA-256 fingerprint of certificate |
load_certificate() |
Load certificate from PEM file |
Middleware
| Component | Description |
|---|---|
MiddlewareChain |
Chain multiple middleware components |
RateLimiter |
Token bucket rate limiting per IP |
AccessControl |
IP-based allow/deny lists with CIDR support |
CertificateAuth |
Client certificate authentication |
Logging
| Component | Description |
|---|---|
configure_logging() |
Configure structured logging |
get_logger() |
Get a logger instance |
hash_ip_processor() |
Privacy-preserving IP hashing |
Protocol Implementations Using Tlacacoca
Tlacacoca is designed to be used by protocol-specific implementations:
- nauyaca - Gemini protocol server & client
- amatl - Scroll protocol implementation (planned)
Documentation
Middleware Return Types
Middleware components return MiddlewareResult with protocol-agnostic denial reasons:
from tlacacoca import MiddlewareResult, DenialReason
# Allowed request
result = MiddlewareResult(allowed=True)
# Denied request
result = MiddlewareResult(
allowed=False,
denial_reason=DenialReason.RATE_LIMIT,
retry_after=30
)
Protocol implementations map these to their specific status codes:
| Denial Reason | Gemini Status | Description |
|---|---|---|
RATE_LIMIT |
44 SLOW DOWN | Rate limit exceeded |
ACCESS_DENIED |
53 PROXY REFUSED | IP not allowed |
CERT_REQUIRED |
60 CLIENT CERT REQUIRED | Need client certificate |
CERT_NOT_AUTHORIZED |
61 CERT NOT AUTHORIZED | Certificate not in allowed list |
Contributing
# Setup
git clone https://github.com/alanbato/tlacacoca.git
cd tlacacoca && uv sync
# Test
uv run pytest
# Lint & Type Check
uv run ruff check src/ tests/
uv run ty check src/
See CONTRIBUTING.md for guidelines.
License
MIT License - see LICENSE for details.
Resources
- SECURITY.md - Security documentation
- GitHub Issues - Bug reports
- GitHub Discussions - Questions and ideas
Status: Active development (pre-1.0). Core security and middleware features are stable.
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
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 tlacacoca-0.1.4.tar.gz.
File metadata
- Download URL: tlacacoca-0.1.4.tar.gz
- Upload date:
- Size: 17.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e632c6f810472fa82c818b5fbf1bf22d185926d9a2a820d6e34671cf9e54b9ad
|
|
| MD5 |
969880741f8c884f50cad256df6a8ff3
|
|
| BLAKE2b-256 |
1b8b90d83e3468c2ad144b32a6280445771747d9f13ffcd03ba4801d6d6e4afb
|
Provenance
The following attestation bundles were made for tlacacoca-0.1.4.tar.gz:
Publisher:
release-pypi.yml on alanbato/tlacacoca
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tlacacoca-0.1.4.tar.gz -
Subject digest:
e632c6f810472fa82c818b5fbf1bf22d185926d9a2a820d6e34671cf9e54b9ad - Sigstore transparency entry: 811884530
- Sigstore integration time:
-
Permalink:
alanbato/tlacacoca@3e87e1bea7b384a1cf71310f40346f6a06c9b95c -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/alanbato
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-pypi.yml@3e87e1bea7b384a1cf71310f40346f6a06c9b95c -
Trigger Event:
push
-
Statement type:
File details
Details for the file tlacacoca-0.1.4-py3-none-any.whl.
File metadata
- Download URL: tlacacoca-0.1.4-py3-none-any.whl
- Upload date:
- Size: 23.1 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 |
f8e1ef8ccfa7767bb3c81c09e45c9fad76003630470c530aa87e02cebcd362bb
|
|
| MD5 |
415761db3858d7c2d0fd42f488fd1867
|
|
| BLAKE2b-256 |
e34a80d7951440052db491b6f505a33810e683165ff9dad167cf9f12ef609c93
|
Provenance
The following attestation bundles were made for tlacacoca-0.1.4-py3-none-any.whl:
Publisher:
release-pypi.yml on alanbato/tlacacoca
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tlacacoca-0.1.4-py3-none-any.whl -
Subject digest:
f8e1ef8ccfa7767bb3c81c09e45c9fad76003630470c530aa87e02cebcd362bb - Sigstore transparency entry: 811884539
- Sigstore integration time:
-
Permalink:
alanbato/tlacacoca@3e87e1bea7b384a1cf71310f40346f6a06c9b95c -
Branch / Tag:
refs/tags/v0.1.4 - Owner: https://github.com/alanbato
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-pypi.yml@3e87e1bea7b384a1cf71310f40346f6a06c9b95c -
Trigger Event:
push
-
Statement type: