Skip to main content

Python SDK for interacting with the Project David Platform Assistant API.

Project description

projectdavid — Python SDK

PyPI Downloads License: PolyForm Noncommercial Python 3.10+ Lint, Test, Tag, Publish Status


The Python SDK for Project David — the open source, GDPR compliant successor to the OpenAI Assistants API.

Same primitives. Every model. Your infrastructure.


What is Project David?

Project David is a full-scale, containerized LLM orchestration platform built around the same primitives as the OpenAI Assistants API — Assistants, Threads, Messages, Runs, and Tools — but without the lock-in.

  • Provider agnostic — Hyperbolic, TogetherAI, Ollama, or any OpenAI-compatible endpoint. Point at any inference provider and the platform normalizes the stream.
  • Every model — hosted APIs today, raw local weights tomorrow. Bring your own model.
  • Your infrastructure — fully self-hostable, open source, GDPR compliant, security audited.
  • Production grade — sandboxed code execution (FireJail), multi-agent delegation, file serving with signed URLs, real-time streaming frontend.

Project Uni5 — the next milestone. transformers, GGUF, and vLLM adapters that mean a model straight off a training run has a full orchestration platform in minutes. From the lab to enterprise grade orchestration — instantly.


Project Activity & Reach

Metric Status
Total Downloads Total Downloads
Monthly Reach Monthly
Open Source Activity GitHub last commit
Analytics View Live Download Trends on ClickPy →

Installation

pip install projectdavid

Requirements: Python 3.10+ · A running Project David platform instance


Quick Start

import os
from dotenv import load_dotenv
from projectdavid import Entity

load_dotenv()

client = Entity(
    base_url=os.getenv("BASE_URL"),        # default: http://localhost:80
    api_key=os.getenv("ENTITIES_API_KEY"),
)

# Create an assistant
assistant = client.assistants.create_assistant(
    name="my_assistant",
    instructions="You are a helpful AI assistant.",
)

# Create a thread and send a message
thread = client.threads.create_thread()

message = client.messages.create_message(
    thread_id=thread.id,
    role="user",
    content="Tell me about the latest trends in AI.",
    assistant_id=assistant.id,
)

# Create a run
run = client.runs.create_run(
    assistant_id=assistant.id,
    thread_id=thread.id,
)

# Stream the response
stream = client.synchronous_inference_stream
stream.setup(
    user_id=os.getenv("ENTITIES_USER_ID"),
    thread_id=thread.id,
    assistant_id=assistant.id,
    message_id=message.id,
    run_id=run.id,
    api_key=os.getenv("PROVIDER_API_KEY"),
)

for chunk in stream.stream_chunks(
    model="hyperbolic/deepseek-ai/DeepSeek-V3-0324",
    timeout_per_chunk=15.0,
):
    content = chunk.get("content", "")
    if content:
        print(content, end="", flush=True)

See the Quick Start guide for the event-driven interface, tool calling, and advanced usage.


Why Project David?

OpenAI Assistants API LangChain Project David
Assistants / Threads / Runs primitives
Provider agnostic Partial
Local model support Partial
Raw weights → orchestration (Uni5)
Sandboxed code execution ✅ Black box ✅ FireJail PTY
Multi-agent delegation Limited
Self-hostable
GDPR compliant N/A
Security audited N/A N/A
Open source
Community Adoption Proprietary High Total Downloads

Supported Inference Providers

Full list of supported providers and endpoints →

Works with any OpenAI-compatible endpoint out of the box — including Ollama for fully local inference.


Environment Variables

Variable Description
ENTITIES_API_KEY Your Entities API key
ENTITIES_USER_ID Your user ID
BASE_URL Platform base URL (default: http://localhost:80)
PROVIDER_API_KEY Your inference provider API key

Documentation

Documentation

Topic Link
Full Documentation docs.projectdavid.co.uk
Quick Start docs.projectdavid.co.uk/docs/sdk-quick-start
Assistants docs.projectdavid.co.uk/docs/sdk-assistants
Threads docs.projectdavid.co.uk/docs/sdk-threads
Messages docs.projectdavid.co.uk/docs/sdk-messages
Runs docs.projectdavid.co.uk/docs/sdk-runs
Inference docs.projectdavid.co.uk/docs/sdk-inference
Tools docs.projectdavid.co.uk/docs/sdk-tools
Function Calls docs.projectdavid.co.uk/docs/sdk-function-calls
Code Interpreter docs.projectdavid.co.uk/docs/sdk-code-interpreter
Files docs.projectdavid.co.uk/docs/sdk-files
Vector Store docs.projectdavid.co.uk/docs/sdk-vector-store
Stream Contract docs.projectdavid.co.uk/docs/sdk-stream-contract
Providers docs.projectdavid.co.uk/docs/providers

Full SDK documentation →

Full hosted docs coming at docs.projectdavid.co.uk


Related Repositories

Repo Description
projectdavid-core Runtime API engine
projectdavid-platform Docker orchestration layer
projectdavid-common Shared utilities and validation
projectdavid-docs Documentation site
entities_cook_book Minimal tested examples


License

PolyForm Noncommercial 1.0.0

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 Distribution

projectdavid-1.97.0.tar.gz (98.2 kB view details)

Uploaded Source

Built Distribution

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

projectdavid-1.97.0-py3-none-any.whl (79.2 kB view details)

Uploaded Python 3

File details

Details for the file projectdavid-1.97.0.tar.gz.

File metadata

  • Download URL: projectdavid-1.97.0.tar.gz
  • Upload date:
  • Size: 98.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for projectdavid-1.97.0.tar.gz
Algorithm Hash digest
SHA256 8bcb31ad37a454662974d18644848f49a461dbd6cc001a1f4ac34f68c889427c
MD5 ca0c7f863fcbea1561426fb5fd49e3c8
BLAKE2b-256 9c7d844221e0386588219f811ffa80d5530f49aaf8c70c31ca9acf2814aacc8e

See more details on using hashes here.

File details

Details for the file projectdavid-1.97.0-py3-none-any.whl.

File metadata

  • Download URL: projectdavid-1.97.0-py3-none-any.whl
  • Upload date:
  • Size: 79.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for projectdavid-1.97.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b47a1bcb6aa2734865bb772c93e9798384c0bfab2703138392c5ce12fa1cd985
MD5 6b7f54b0f7e0b949181b958ff9e35ae4
BLAKE2b-256 5b83ae6551f7aa845609c9b2652872896960e993d4f5a459e7155c37f7cd47b6

See more details on using hashes here.

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