Skip to main content

Open-RPC API hosting and interactive documentation.

Project description

Tabella

Open-RPC development framework with builtin interactive documentation.

Demo

Live Demo

A live demo is available here.

Install

Tabella is on PyPI and can be installed with:

pip install tabella

Or with Poetry

poetry add tabella

Python OpenRPC Docs

The RPC server hosted and documented by Tabella is powered by Python OpenRPC. Refer to the Python OpenRPC docs hosted here for advanced use.

Getting Started

A basic Tabella app:

from tabella import Tabella

app = Tabella()


@app.method()
def echo(a: str, b: float) -> tuple[str, float]:
    """Echo parameters back in result."""
    return a, b


if __name__ == "__main__":
    app.run()

Run this, then open http://127.0.0.1:8000/ in your browser to use the interactive documentation.

The Open-RPC API will be hosted over HTTP on http://127.0.0.1:8000/api and over WebSockets on ws://127.0.0.1:8000/api.

Further Usage

Routers

An app with many modules can be organized into segments using Method Routers.

Security and Depends Arguments

Tabella passes request headers to the RPCServer process request methods. Details on usage can be found in the Python OpenRPC docs on Depends Arguments.

Set Servers

Set RPC servers manually to specify transport and paths to host the RPC server on, e.g.

from openrpc import Server
from tabella import Tabella

app = Tabella(
    servers=[
        Server(name="HTTP API", url="http://localhost:8000/my/api/path"),
        Server(name="WebSocket API", url="ws://localhost:8000/my/api/path"),
    ]
)

This app will host the RPCServer over HTTP and over WebSockets with the path /my/api/path.

Pydantic

Pydantic is used for request/response deserialization/serialization as well as schema generation. Pydantic should be used for any models as seen here in the Python OpenRPC Docs.

Starlette

Tabella HTTP and WebSocket server hosting uses Starlette. Uvicorn can be used to run the starlette app.

uvicorn main:app.starlette --reload

Monitor

If you are running the app with in debug mode, e.g. app = Tabella(debug=True), then at the path /monitor there is a display that will show requests and responses made to the RPC server as they happen.

This requires websockets

pip install websockets

Monitor

Inspired By

Support The Developer

Buy Me A Coffee

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

tabella-2.3.17.tar.gz (213.3 kB view details)

Uploaded Source

Built Distribution

tabella-2.3.17-py3-none-any.whl (244.8 kB view details)

Uploaded Python 3

File details

Details for the file tabella-2.3.17.tar.gz.

File metadata

  • Download URL: tabella-2.3.17.tar.gz
  • Upload date:
  • Size: 213.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.7 Linux/6.11.4-201.fc40.x86_64

File hashes

Hashes for tabella-2.3.17.tar.gz
Algorithm Hash digest
SHA256 3b11b951c6b65eb998bcd92a4a3c760992c5008e6328810f30a7db21e911f316
MD5 1d0da4a58aa6a28b24d95267ead856ea
BLAKE2b-256 e5a8452a6e412a45d681bac95e65e18555bf19ed01a88f7c8444822cad48a2a7

See more details on using hashes here.

File details

Details for the file tabella-2.3.17-py3-none-any.whl.

File metadata

  • Download URL: tabella-2.3.17-py3-none-any.whl
  • Upload date:
  • Size: 244.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.7 Linux/6.11.4-201.fc40.x86_64

File hashes

Hashes for tabella-2.3.17-py3-none-any.whl
Algorithm Hash digest
SHA256 95abfa0675e6913e81be46055c653ac6d485255e4d72303fe9851f30bff8551e
MD5 ea5c77d0f32cfe50ac88dc6f5ef2a155
BLAKE2b-256 d90e3d88d1deaae6edcb8ae10c6ef172157941b57c4793a9c3d76d1af8dfdcbe

See more details on using hashes here.

Supported by

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