Skip to main content

Ultra-fast Rust-powered Python async web framework

Project description

Cello

Ultra-Fast Python Web Framework
Rust-powered performance with Python simplicity

CI PyPI Python License

InstallationQuick StartFeaturesExamplesDocumentation


Why Cello?

Cello is an enterprise-grade Python web framework that combines Python's developer experience with Rust's raw performance. All HTTP handling, routing, JSON serialization, and middleware execute in native Rust while Python handles your business logic.

┌─────────────────────────────────────────────────────────────────┐
│  Request → Rust HTTP Engine → Python Handler → Rust Response   │
│                  │                    │                         │
│                  ├─ SIMD JSON         ├─ Return dict            │
│                  ├─ Radix routing     └─ Return Response        │
│                  └─ Middleware (Rust)                           │
└─────────────────────────────────────────────────────────────────┘

⚡ Performance

Cello is the fastest Python web framework — benchmarked with wrk on the same machine, same worker count, same settings.

Benchmark Results (4 workers, 5 processes each, wrk -t12 -c400 -d10s)

Framework Server Req/sec Avg Latency p99 Latency Relative
Cello Built-in (Rust/Tokio) 170,000+ 2.76ms 15.34ms 1.0x (fastest)
BlackSheep + Granian Granian (Rust) ~92,000 4.31ms 12.63ms 1.9x slower
FastAPI + Granian Granian (Rust) ~55,000 7.14ms 16.86ms 3.1x slower
Robyn Built-in (Rust) ~29,000 14.21ms 37.91ms 5.9x slower

How to reproduce: See benchmarks/compare/ for the automated comparison runner. All frameworks use the same JSON endpoint, same process count, and same wrk settings for a fair comparison.


📦 Installation

pip install cello-framework

From source:

git clone https://github.com/jagadeesh32/cello.git
cd cello
pip install maturin
maturin develop

Requirements: Python 3.12+


🚀 Quick Start

from cello import App, Response

app = App()

@app.get("/")
def home(request):
    return {"message": "Hello, Cello! 🎸"}

@app.get("/users/{id}")
def get_user(request):
    return {"id": request.params["id"], "name": "John Doe"}

@app.post("/users")
def create_user(request):
    data = request.json()
    return Response.json({"id": 1, **data}, status=201)

if __name__ == "__main__":
    app.run()
python app.py
# 🐍 Cello v1.2.0 server starting at http://127.0.0.1:8000

✨ Features

Core Features

Feature Description
🚀 Blazing Fast Tokio + Hyper async HTTP engine in pure Rust
📦 SIMD JSON SIMD-accelerated JSON parsing with simd-json
🛤️ Radix Routing Ultra-fast route matching with matchit
🔄 Async/Sync Support for both async def and regular def handlers
🛡️ Middleware Built-in CORS, logging, compression, rate limiting
📐 Blueprints Flask-like route grouping and modular apps
🌐 WebSocket Real-time bidirectional communication
📡 SSE Server-Sent Events for streaming
📁 Multipart File uploads and form data handling

Security Features

Feature Description
🔐 JWT Authentication JSON Web Token with constant-time validation
🛡️ CSRF Protection Double-submit cookie and signed token patterns
⏱️ Rate Limiting Token bucket, sliding window, and adaptive algorithms
🍪 Sessions Secure cookie-based session management
🔒 Security Headers CSP, HSTS, X-Frame-Options, Referrer-Policy
🔑 API Key Auth Header and query parameter authentication

v1.2.0 — Bug Fixes & Rust-Native AsyncClient

Feature Description
🐛 Shutdown coroutine fix async def shutdown hooks are now properly awaited via Tokio
🐛 KeyboardInterrupt fix CTRL+C no longer leaks into shutdown handlers
🐛 request.redis fix AttributeError on request.redis resolved when Redis is enabled
🦀 Rust AsyncClient AsyncClient rewritten in Rust (reqwest + Tokio) — GIL never held during HTTP I/O
📜 Redis Lua scripting eval, evalsha, script_load for atomic server-side operations

Template Engine (v1.1.0)

Feature Description
🎨 MiniJinja Full Jinja2-compatible templates rendered entirely in Rust
Zero Python overhead Template rendering stays on the Rust side via minijinja 2
🔒 Auto HTML-escaping XSS-safe output for .html/.htm/.xml by default
🧱 Template inheritance {% extends %} / {% block %} for base + child layouts
🔁 Includes & macros {% include %}, {% macro %}, {% import %} for reuse
🌍 Global variables add_global() for site-wide values (app name, year, etc.)
📦 Standalone engine MiniJinjaEngine usable independently from App (emails, CLI)

Enterprise Features (v0.7.0+)

Feature Description
📊 OpenTelemetry Distributed tracing with W3C Trace Context
🏥 Health Checks Kubernetes-compatible liveness/readiness probes
🗄️ Database Pooling Connection pool management with metrics
🔷 GraphQL GraphQL endpoint with Playground UI
💉 Dependency Injection Type-safe DI with Singleton/Request/Transient scopes
🛡️ Guards (RBAC) Role & permission-based access control
📈 Prometheus Metrics Production-ready metrics at /metrics
🔌 Circuit Breaker Fault tolerance with automatic recovery

Data Layer Features (v0.8.0)

Feature Description
🗄️ Enhanced DB Pooling Async connection pool with health monitoring & reconnection
🔴 Redis Integration Async Redis client with pool, Pub/Sub, cluster mode
🔄 Transactions Automatic transaction management with decorator support

API Protocol Features (v0.9.0)

Feature Description
🔷 GraphQL Query, Mutation, Subscription decorators with Schema builder
📊 DataLoader N+1 prevention with automatic batching and caching
🔌 gRPC Service-based gRPC with unary, streaming, and bidirectional support
📨 Kafka Consumer/producer decorators with automatic message routing
🐰 RabbitMQ AMQP messaging with topic exchanges and prefetch control
☁️ SQS/SNS AWS message queue integration with LocalStack support

Protocol Support

Feature Description
🔒 TLS/SSL Native HTTPS with rustls
HTTP/2 Multiplexed connections with h2
🚀 HTTP/3 QUIC protocol support with quinn
🏭 Cluster Mode Multi-worker process deployment

📘 Examples

Data Layer Features (v0.8.0)

from cello import App, DatabaseConfig, RedisConfig
from cello.database import transactional

app = App()

# Enable database connection pooling
app.enable_database(DatabaseConfig(
    url="postgresql://user:pass@localhost/mydb",
    pool_size=20,
    max_lifetime_secs=1800
))

# Enable Redis connection
app.enable_redis(RedisConfig(
    url="redis://localhost:6379",
    pool_size=10
))

@app.post("/transfer")
@transactional
async def transfer(request):
    # Automatic transaction management
    return {"success": True}

@app.get("/")
def home(request):
    return {"status": "ok", "version": "1.2.0"}

app.run()

API Protocol Features (v0.9.0)

from cello import App, GrpcConfig, KafkaConfig, RabbitMQConfig
from cello.graphql import Query, Mutation, Schema, DataLoader, GraphQL
from cello.grpc import GrpcService, grpc_method, GrpcServer
from cello.messaging import kafka_consumer, kafka_producer, Producer, Consumer

app = App()

# --- GraphQL ---
@Query
def users(info):
    return [{"id": 1, "name": "Alice"}, {"id": 2, "name": "Bob"}]

@Mutation
def create_user(info, name: str, email: str):
    return {"id": 3, "name": name, "email": email}

schema = Schema().query(users).mutation(create_user).build()

# --- gRPC ---
class UserService(GrpcService):
    @grpc_method
    async def get_user(self, request):
        return {"id": request.data.get("id"), "name": "Alice"}

app.enable_grpc(GrpcConfig(port=50051, reflection=True))
app.add_grpc_service("UserService", ["GetUser", "ListUsers"])

# --- Kafka ---
app.enable_messaging(KafkaConfig(brokers="localhost:9092", group_id="my-app"))

@kafka_consumer(topic="user-events", group="processors")
async def handle_user_event(message):
    print(f"Received: {message.text}")

@app.post("/users")
@kafka_producer(topic="user-events")
def create_user_api(request):
    return {"id": 1, "name": request.json().get("name")}

# --- RabbitMQ ---
app.enable_rabbitmq(RabbitMQConfig(url="amqp://localhost:5672"))

@app.get("/")
def home(request):
    return {"status": "ok", "version": "1.0.1", "protocols": ["graphql", "grpc", "kafka", "rabbitmq"]}

app.run()

Enterprise Features (v0.7.0+)

from cello import App, OpenTelemetryConfig, HealthCheckConfig, GraphQLConfig

app = App()

# Enable distributed tracing
app.enable_telemetry(OpenTelemetryConfig(
    service_name="my-api",
    otlp_endpoint="http://collector:4317",
    sampling_rate=0.1
))

# Enable Kubernetes health checks
app.enable_health_checks(HealthCheckConfig(
    base_path="/health",
    include_details=True,
    include_system_info=True
))

# Enable GraphQL with Playground
app.enable_graphql(GraphQLConfig(
    path="/graphql",
    playground=True,
    introspection=True
))

# Enable Prometheus metrics
app.enable_prometheus(endpoint="/metrics")

@app.get("/")
def home(request):
    return {"status": "ok", "version": "1.2.0"}

app.run()

Blueprints (Route Grouping)

from cello import App, Blueprint

api_v1 = Blueprint("/api/v1")

@api_v1.get("/users")
def list_users(request):
    return {"users": [{"id": 1, "name": "Alice"}]}

@api_v1.post("/users")
def create_user(request):
    return Response.json(request.json(), status=201)

app = App()
app.register_blueprint(api_v1)
app.run()

Guards (RBAC)

from cello import App, RateLimitConfig

app = App()

# Role-based access control
@app.add_guard
def require_auth(request):
    return request.headers.get("Authorization") is not None

@app.add_guard
def require_admin(request):
    token = request.headers.get("Authorization", "")
    return "admin" in token

# Rate limiting
app.enable_rate_limit(RateLimitConfig.token_bucket(
    capacity=100,
    refill_rate=10
))

@app.get("/admin")
def admin_panel(request):
    return {"message": "Welcome, Admin!"}

WebSocket

@app.websocket("/ws/chat")
def chat_handler(ws):
    ws.send_text("Welcome to the chat!")

    while True:
        message = ws.recv()
        if message is None:
            break
        ws.send_json({"type": "echo", "content": message.text})

Server-Sent Events

from cello import SseStream

@app.get("/events")
def event_stream(request):
    stream = SseStream()
    stream.add_event("update", '{"count": 42}')
    stream.add_event("notification", '{"message": "New data"}')
    return stream

MiniJinja Templates (v1.1.0)

from cello import App, MiniJinjaEngine, Response

app = App()

# Attach once at startup — optional auto_escape and global variables
app.enable_templates(
    template_dir="templates",   # directory containing .html files
    auto_escape=True,           # HTML-escape {{ }} output (XSS safe)
    globals={"site_name": "My App", "year": 2026},
)

@app.get("/")
def home(request):
    html = app.render("index.html", {"title": "Home", "items": ["a", "b", "c"]})
    return Response.html(html)

# Inline rendering — no file needed
@app.get("/greet/{name}")
def greet(request):
    msg = app.render_string(
        "Hello, {{ name | title }}! Welcome to {{ site_name }}.",
        {"name": request.params["name"]},
    )
    return Response.html(msg)

# Standalone engine (outside of App — useful for emails, CLI, background tasks)
email_engine = MiniJinjaEngine(template_dir="templates/emails", auto_escape=False)
html = email_engine.render("welcome.html", {"user": "Alice"})

templates/base.html — base layout:

<!DOCTYPE html>
<html>
<head><title>{% block title %}{{ site_name }}{% endblock %}</title></head>
<body>
  <nav>{% block nav %}{% endblock %}</nav>
  <main>{% block content %}{% endblock %}</main>
  <footer>© {{ year }} {{ site_name }}</footer>
</body>
</html>

templates/index.html — child template:

{% extends "base.html" %}

{% block title %}Home — {{ site_name }}{% endblock %}

{% block content %}
<h1>{{ title }}</h1>
{% for item in items %}
<p>{{ loop.index }}. {{ item | upper }}</p>
{% endfor %}
{% endblock %}

Rust-Native AsyncClient (v1.2.0)

from cello import AsyncClient

client = AsyncClient(timeout=10.0)

# GET
resp = await client.get("https://api.example.com/data")
print(resp.status)    # int
print(resp.json())    # dict

# POST with JSON
resp = await client.post("https://api.example.com/items", json={"name": "widget"})

# PUT / PATCH / DELETE
resp = await client.put("https://api.example.com/items/1", json={"name": "updated"})
resp = await client.delete("https://api.example.com/items/1")

# Async context manager
async with AsyncClient() as c:
    resp = await c.get("https://example.com")

GIL is never held during network I/O. HTTP/2, gzip, and rustls TLS are included.

Redis Lua Scripting (v1.2.0)

app.enable_redis(RedisConfig(url="redis://localhost:6379", pool_size=10))

@app.get("/")
async def index(request):
    r = request.redis

    # Upload script once, reuse by SHA1
    sha = await r.script_load("""
        local m = redis.call('SISMEMBER', KEYS[1], ARGV[1])
        if m == 0 then return 0 end
        redis.call('LPUSH', KEYS[2], ARGV[2])
        return 1
    """)

    result = await r.evalsha(sha, 2, "tokens", "queue", "tok", "payload")
    return {"enqueued": result == 1}

Response Types

from cello import Response

# JSON (default)
return {"data": "value"}

# Explicit JSON with status
return Response.json({"created": True}, status=201)

# Other response types
return Response.text("Hello, World!")
return Response.html("<h1>Welcome</h1>")
return Response.file("/path/to/document.pdf")
return Response.redirect("/new-location")
return Response.no_content()

🏗️ Tech Stack

Component Technology
Runtime Tokio (async Rust)
HTTP Server Hyper 1.x
JSON simd-json + serde
Routing matchit (radix tree)
Python Bindings PyO3
TLS/SSL rustls
HTTP/2 h2
HTTP/3 quinn (QUIC)
Tracing OpenTelemetry
Metrics Prometheus
JWT jsonwebtoken
gRPC Custom Rust gRPC engine
GraphQL Python engine with Rust serialization
Messaging Kafka, RabbitMQ, SQS adapters
Templates MiniJinja 2 (Jinja2-compatible, Rust)

🔒 Security

Cello is built with security as a priority:

  • Constant-time comparison for passwords, API keys, and tokens
  • CSRF protection with double-submit cookies and signed tokens
  • Security headers (CSP, HSTS, X-Frame-Options, Referrer-Policy)
  • Rate limiting with multiple algorithms
  • Session security (Secure, HttpOnly, SameSite cookies)
  • Path traversal protection in static file serving
  • JWT blacklisting for token revocation

🛠️ Development

# Setup
git clone https://github.com/jagadeesh32/cello.git
cd cello
python -m venv .venv
source .venv/bin/activate
pip install maturin pytest

# Build
maturin develop

# Test
pytest tests/ -v

# Lint
cargo clippy
cargo fmt

📋 Release History

v1.2.0 — Bug Fixes & Rust-Native AsyncClient (Jun 2026)

  • Fix: async def shutdown handlers (@app.on_event("shutdown")) now correctly awaited via Tokio instead of silently dropped
  • Fix: KeyboardInterrupt during CTRL+C no longer leaks into shutdown handler error output
  • Fix: request.redis no longer raises AttributeError when app.enable_redis() is configured
  • Rust AsyncClient: AsyncClient rewritten from Python stdlib to reqwest + Tokio — GIL is never held during HTTP I/O; HTTP/2, gzip, and rustls TLS included; API unchanged from v1.1.0
  • Redis Lua scripting: eval(script, numkeys, *args), evalsha(sha, numkeys, *args), script_load(script) for atomic server-side operations

v1.1.0 — MiniJinja Template Engine (Apr 2026)

  • MiniJinja integration: full Jinja2-compatible template engine built into Cello via minijinja 2 Rust crate — zero Python overhead on the render path
  • app.enable_templates(): attach the engine as optional middleware in one line
  • app.render(name, context) and app.render_string(source, context): render from file or inline string
  • MiniJinjaEngine: standalone class for use outside of App (emails, CLI scripts, background tasks)
  • HTML auto-escaping: XSS-safe by default for .html/.htm/.xml templates
  • Global template variables: add_global() / add_globals() for site-wide variables
  • Full Jinja2 syntax: {% if %}, {% for %}, {% block %}, {% extends %}, {% include %}, {% macro %}, {% import %}, all built-in filters
  • Python type conversion: str, int, float, bool, None, list, tuple, dict, and objects with __dict__ all convert automatically

v1.0.1 — Cross-Platform & Compatibility Patch (Feb 2026)

  • Windows multi-worker: subprocess re-execution (CELLO_WORKER=1) replaces broken multiprocessing.Process
  • Windows signal handling: SIGTERM wrapped in try/except with platform validation
  • Windows static files: UNC path normalization fix
  • ARM JSON fallback: serde_json for non-SIMD architectures
  • Linux-only CPU affinity: gated with warning on other platforms
  • Async compatibility: wrap_handler_with_validation, _apply_guards, cache() all support async handlers
  • Blueprint guards: Blueprint route decorators now support guards parameter and validation
  • Export completeness: Guards (RoleGuard, PermissionGuard, Authenticated, And, Or, Not, GuardError, ForbiddenError, UnauthorizedError) and database (Database, Redis, Transaction) added to __all__

v1.0.0 — Production-Ready Stable Release (Feb 2026)

  • 170,000+ req/s sustained throughput (fastest Python web framework)
  • Handler metadata caching, lazy query parsing, zero-copy response building
  • TCP_NODELAY, HTTP/1.1 keep-alive and pipeline flush optimization
  • Pre-allocated headers, fast-path skip for empty middleware/guards
  • Optimized release profile: LTO fat, panic abort, symbol stripping
  • API stability guarantee under Semantic Versioning
  • 394 tests passing, comprehensive security hardening

v0.10.0 — Event Sourcing, CQRS & Saga Pattern

  • Event Sourcing: Aggregate root pattern, event store, snapshot support, event versioning
  • CQRS: Command/Query buses, separate read/write models, event-driven sync
  • Saga Pattern: Distributed transaction coordination, compensation logic, persistent state, retry with backoff

v0.9.0 — GraphQL, gRPC & Message Queues

  • GraphQL: Query, Mutation, Subscription decorators, DataLoader for N+1 prevention, schema introspection
  • gRPC: Protocol buffer integration, bidirectional streaming, gRPC-Web, reflection service
  • Kafka: Consumer/producer decorators, consumer group management, dead letter queues
  • RabbitMQ: AMQP messaging with topic exchanges and prefetch control
  • SQS/SNS: AWS message queue integration with LocalStack support

v0.8.0 — Database & Redis Integration

  • Enhanced database connection pooling (PostgreSQL, MySQL, SQLite) with health monitoring
  • Redis async client with connection pooling, Pub/Sub, and cluster mode
  • Query builder with parameterized queries
  • Transaction management with @transactional decorator and nested savepoints
  • Pool metrics exposed via Prometheus

v0.7.0 — Enterprise Observability

  • OpenTelemetry distributed tracing with OTLP export
  • Health check endpoints (/health/live, /health/ready, /health/startup)
  • Structured JSON logging with trace context injection
  • Kubernetes deployment support and Docker multi-stage builds

v0.6.0 — Smart Caching & Validation

  • @cache decorator with TTL and tag-based invalidation
  • Adaptive rate limiting based on server health metrics
  • DTO validation with RFC 7807 Problem Details errors
  • Circuit breaker middleware for fault tolerance
  • 15% faster JSON parsing, 20% lower memory usage

v0.5.0 — Dependency Injection & RBAC

  • Dependency injection via Depends with singleton and transient lifetimes
  • Composable guards: RoleGuard, PermissionGuard, AndGuard, OrGuard, NotGuard
  • Prometheus metrics endpoint (/metrics)
  • OpenAPI 3.0 schema generation with Swagger UI and ReDoc
  • Background tasks and Jinja2 template rendering

v0.4.0 — Security & Cluster Mode

  • JWT authentication (HS256/384/512, RS256/384/512, ES256/384)
  • Rate limiting with token bucket and sliding window algorithms
  • Encrypted cookie sessions with automatic rotation
  • Security headers: CSP, HSTS, X-Frame-Options, X-Content-Type-Options
  • Cluster mode with multi-process workers via SO_REUSEPORT
  • Native TLS via rustls (TLS 1.2 and 1.3)

v0.3.0 — Real-Time Communication

  • WebSocket support via tokio-tungstenite with full-duplex communication
  • Server-Sent Events (SSE) with async generators
  • Multipart form handling and file uploads via multer
  • Blueprints for modular route organization with nesting

v0.2.0 — Middleware System

  • Composable middleware chain execution
  • CORS middleware with configurable origins, methods, and headers
  • Request/response logging middleware
  • Gzip and brotli compression middleware

v0.1.0 — Initial Release

  • Rust-powered HTTP server via Hyper and Tokio
  • Python route registration with decorators (@app.get, @app.post, etc.)
  • Radix tree routing via matchit with path parameters and wildcards
  • SIMD-accelerated JSON parsing via simd-json
  • Async handler support and static file serving
  • PyO3 abi3 bindings for Python 3.12+

📚 Documentation

Full documentation available at: cello.lineupcode.com


🤝 Contributing

Contributions are welcome! Please see CONTRIBUTING.md for guidelines.


📄 License

MIT License - see LICENSE


👤 Author

Jagadeesh Katla - @jagadeesh32


Made with ❤️ using 🐍 Python and 🦀 Rust

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

cello_framework-1.2.3.tar.gz (2.3 MB view details)

Uploaded Source

Built Distributions

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

cello_framework-1.2.3-cp312-abi3-win_amd64.whl (2.8 MB view details)

Uploaded CPython 3.12+Windows x86-64

cello_framework-1.2.3-cp312-abi3-manylinux_2_28_aarch64.whl (2.9 MB view details)

Uploaded CPython 3.12+manylinux: glibc 2.28+ ARM64

cello_framework-1.2.3-cp312-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.1 MB view details)

Uploaded CPython 3.12+manylinux: glibc 2.17+ x86-64

cello_framework-1.2.3-cp312-abi3-macosx_11_0_arm64.whl (2.6 MB view details)

Uploaded CPython 3.12+macOS 11.0+ ARM64

File details

Details for the file cello_framework-1.2.3.tar.gz.

File metadata

  • Download URL: cello_framework-1.2.3.tar.gz
  • Upload date:
  • Size: 2.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cello_framework-1.2.3.tar.gz
Algorithm Hash digest
SHA256 f43fa3bc426e8ec39b54afcde405bc91c41cd4240f4fca5639fe21bcfde89cb7
MD5 9b5e6df7f4ca142a0e54e72491c29922
BLAKE2b-256 7af75b99e069c82d5b35110db436348fde8500b5a6ac898149d71c8060df9af3

See more details on using hashes here.

Provenance

The following attestation bundles were made for cello_framework-1.2.3.tar.gz:

Publisher: publish.yml on jagadeesh32/cello

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

File details

Details for the file cello_framework-1.2.3-cp312-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for cello_framework-1.2.3-cp312-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 e696de62ad420c2eb8c9eb1d21dce8332d3b155e0ffd8e07befd4492de1829d4
MD5 044a09d540e364784c23b8c3e9830f8c
BLAKE2b-256 5ddb7aa9165a0e72ae8c46bfbf74dee8e8240726ce58f2ac4b0879c1755374f2

See more details on using hashes here.

Provenance

The following attestation bundles were made for cello_framework-1.2.3-cp312-abi3-win_amd64.whl:

Publisher: publish.yml on jagadeesh32/cello

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

File details

Details for the file cello_framework-1.2.3-cp312-abi3-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for cello_framework-1.2.3-cp312-abi3-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 3263cb4df751923749373f81d413c3b964b9e2bf9b4c1fb867e532adc1debf6e
MD5 5879c4223966ed895c05a878d1ffdec5
BLAKE2b-256 7f2ebe959c6ee6f8a42520791422eecab16e331afdfd1cf89ea8f6755ff9ac70

See more details on using hashes here.

Provenance

The following attestation bundles were made for cello_framework-1.2.3-cp312-abi3-manylinux_2_28_aarch64.whl:

Publisher: publish.yml on jagadeesh32/cello

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

File details

Details for the file cello_framework-1.2.3-cp312-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for cello_framework-1.2.3-cp312-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 972e769db89e1e8470778de61b11efd1783b03f3015716e5d1448d503b27e9aa
MD5 c809fb084d9c4e8499a2f39b42725eee
BLAKE2b-256 14eb8c5d9690cf4958390d4f1cd784367f6a3875383e2cf6c8c86a342cbe6cfc

See more details on using hashes here.

Provenance

The following attestation bundles were made for cello_framework-1.2.3-cp312-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:

Publisher: publish.yml on jagadeesh32/cello

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

File details

Details for the file cello_framework-1.2.3-cp312-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for cello_framework-1.2.3-cp312-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 2b353fe02ecc39006d6e89d9eb408471cef0fb76d648fea65d133e9c399d1acb
MD5 a48fe70ab4a9f00c4451205de6c2adf4
BLAKE2b-256 56e85eaf5155dbe099d998730a1dc159a9a09a9fd4a3eba36cdd5c72663bcfd0

See more details on using hashes here.

Provenance

The following attestation bundles were made for cello_framework-1.2.3-cp312-abi3-macosx_11_0_arm64.whl:

Publisher: publish.yml on jagadeesh32/cello

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