Pure-Python gRPC client for a remote Jammi engine — the deploy half of jammi-ai
Project description
jammi-client
Pure-Python gRPC client for a remote Jammi engine — the deploy half of the develop→deploy journey.
jammi-ai runs an embedded engine in-process and bundles this client for its
remote targets. jammi-client is the lean variant: a universal
py3-none-any wheel that links no candle/ML stack — just grpcio + protobuf
pyarrow— for production where the engine runs behind a server.
One front door
import jammi_client
db = jammi_client.connect("https://engine.example.com")
db.add_source("patents", url="s3://corpus/patents.parquet", format="parquet")
db.generate_embeddings(source="patents", model="local:tiny_bert",
columns=["abstract"], key="id", modality="text")
q = db.encode_query(model="local:tiny_bert", query="quantum computing")
hits = db.search("patents", query=q, k=5) # -> pyarrow.Table
connect(target) is the Python mirror of the Rust Jammi::open(Target):
transport is config, not a code path.
Authenticated channels
A bearer-protected endpoint is reached by attaching credentials to the channel — the bearer rides the channel (attached once at connect), not threaded through every call:
from jammi_client import connect, BearerCredentials
db = connect("https://engine.example.com", credentials=BearerCredentials(token))
The same works on a plaintext grpc:// target for local development. The
channel-level bearer covers the typed gRPC verbs; db.sql() (the Flight SQL
lane) does not yet carry it — tracked at
issue #96.
| target | transport |
|---|---|
https://host / grpcs://host:8081 |
secure remote |
http://host / grpc://host:8081 |
plaintext remote |
file:///data |
local engine — not in this build; raises NoEmbeddedEngineError pointing at pip install jammi-ai |
Scaling local→remote is an env flip (connect(os.environ["JAMMI_TARGET"]))
with no code change. Productionising from the embed wheel to this lean client is
a one-line import swap (import jammi_ai → import jammi_client), connect
unchanged.
Generated from the canonical proto
The wire stubs under jammi_client/_generated/ are generated from the same
jammi.v1 proto the engine, npm client, and embed wheel speak — one source, no
parallel schema. Regenerate after a proto change:
pip install -e '.[dev]'
make generate
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
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 jammi_client-0.26.1-py3-none-any.whl.
File metadata
- Download URL: jammi_client-0.26.1-py3-none-any.whl
- Upload date:
- Size: 93.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6c083eaaa0da3ebb2e4d336364ae1af0d8c76ea3a107d8696ae785e2ac5d473
|
|
| MD5 |
9367face5d8369a007f4578c1b08db45
|
|
| BLAKE2b-256 |
3259ed74a975e9ed2d93cff09e1ad34b18c4871fab5bc8e04b23dbd28e73534f
|
Provenance
The following attestation bundles were made for jammi_client-0.26.1-py3-none-any.whl:
Publisher:
pypi-client.yml on f-inverse/jammi-ai
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
jammi_client-0.26.1-py3-none-any.whl -
Subject digest:
f6c083eaaa0da3ebb2e4d336364ae1af0d8c76ea3a107d8696ae785e2ac5d473 - Sigstore transparency entry: 1788035626
- Sigstore integration time:
-
Permalink:
f-inverse/jammi-ai@1f6ab1f4a643276f2e4b52445c9e78504a4bffd7 -
Branch / Tag:
refs/tags/py-v0.26.1 - Owner: https://github.com/f-inverse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-client.yml@1f6ab1f4a643276f2e4b52445c9e78504a4bffd7 -
Trigger Event:
push
-
Statement type: