Skip to main content

Python SDK for Pendra — UK-based, privacy-first LLM inference

Project description

pendra-python

Official Python SDK for Pendra — UK-based, privacy-first LLM inference.

Your data is processed in the UK, never stored, never shared with US cloud providers.

Installation

pip install pendra

Quick Start

import pendra

client = pendra.Pendra(
    api_key="pdr_sk_...",          # or set PENDRA_API_KEY env var
    base_url="http://localhost",    # your self-hosted instance
)

response = client.chat.completions.create(
    model="llama3.2",
    messages=[
        {"role": "system", "content": "You are a helpful assistant."},
        {"role": "user", "content": "What is the capital of the UK?"},
    ],
)

print(response.choices[0].message.content)
# → London is the capital of the United Kingdom.

Streaming

with client.chat.completions.create(
    model="llama3.2",
    messages=[{"role": "user", "content": "Write me a short poem about London."}],
    stream=True,
) as stream:
    for chunk in stream:
        print(chunk.choices[0].delta.content or "", end="", flush=True)

Async

import asyncio
import pendra

async def main():
    async with pendra.AsyncPendra(api_key="pdr_sk_...") as client:
        # Non-streaming
        response = await client.chat.completions.create(
            model="llama3.2",
            messages=[{"role": "user", "content": "Hello!"}],
        )
        print(response.choices[0].message.content)

        # Streaming
        stream = await client.chat.completions.create(
            model="llama3.2",
            messages=[{"role": "user", "content": "Count to 5"}],
            stream=True,
        )
        async for chunk in stream:
            print(chunk.choices[0].delta.content or "", end="", flush=True)

asyncio.run(main())

List Models

models = client.models.list()
for model in models:
    print(model.id)

Environment Variables

Variable Description
PENDRA_API_KEY Your Pendra API key (pdr_sk_...)

OpenAI Compatibility

The Pendra SDK is fully compatible with the OpenAI Python SDK interface. To migrate:

# Before
from openai import OpenAI
client = OpenAI(api_key="sk-...")

# After
from pendra import Pendra
client = Pendra(api_key="pdr_sk_...", base_url="https://your-pendra-instance.com")

The client.chat.completions.create() interface is identical.

Self-Hosted Workers

Run inference on your own GPUs with a single command. Your prompts and completions never leave your infrastructure.

curl -fsSL https://get.pendra.ai/worker | bash

See the Workers documentation for full setup instructions.

Licence

MIT

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

pendra-0.1.2.tar.gz (11.0 kB view details)

Uploaded Source

Built Distribution

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

pendra-0.1.2-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file pendra-0.1.2.tar.gz.

File metadata

  • Download URL: pendra-0.1.2.tar.gz
  • Upload date:
  • Size: 11.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pendra-0.1.2.tar.gz
Algorithm Hash digest
SHA256 4186554e3ce17133668736f0a153a6755de20928f6e8f2d144a307d94705141e
MD5 55e321b3e2837889d527f2706c96c886
BLAKE2b-256 9410449be8fc4d678b4d475508fc1ac141253042d863d88f90a79f9d9af80698

See more details on using hashes here.

Provenance

The following attestation bundles were made for pendra-0.1.2.tar.gz:

Publisher: publish-sdk-python.yml on Pendra-Cloud/pendra

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

File details

Details for the file pendra-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: pendra-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pendra-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 16406b28a7b4db9e6035eaa456c8a0921f3183aedb0cad7aef804e428c093361
MD5 a5ad401d5e581b16d1f3ba038cd0c475
BLAKE2b-256 829f44a8fe469f7b1bd46ae6f6e8380b169ff1b36da57684fb858bf92025d728

See more details on using hashes here.

Provenance

The following attestation bundles were made for pendra-0.1.2-py3-none-any.whl:

Publisher: publish-sdk-python.yml on Pendra-Cloud/pendra

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