Skip to main content

Gemini-first and OpenAI provider helpers for Codex

Project description

codex-ai

PyPI version Python CI License

Gemini-first and OpenAI provider helpers for the Codex ecosystem. The library keeps the legacy prompt router for text generation, and exposes direct provider methods for practical Gemini workflows.

Install

pip install codex-ai
pip install "codex-ai[gemini]"
pip install "codex-ai[openai]"
pip install "codex-ai[openai,gemini]"

Requires Python 3.12 or newer.

Gemini Direct API

from pydantic import BaseModel

from codex_ai import GeminiProvider


class LootItem(BaseModel):
    name: str
    power: int


gemini = GeminiProvider(api_key="AIza...")

text = await gemini.generate_text("Write one short tavern rumor.")
loot = await gemini.generate_json("Create one loot item.", schema=LootItem)
image_bytes, content_type = await gemini.generate_image_bytes(
    "A fantasy clan banner, game icon style.",
    response_mime_type="image/webp",
)

answer(prompt) remains available as a compatibility wrapper for text generation.

Router Pipeline

from codex_ai import GeminiProvider, LLMDispatcher, LLMMessage, LLMRouter, PromptResult

router = LLMRouter()


@router.prompt("chat")
async def build_chat(text: str, **kw) -> PromptResult:
    return PromptResult(
        messages=[LLMMessage(role="user", content=text)],
        system="You are a helpful assistant.",
    )


dispatcher = LLMDispatcher(provider=GeminiProvider(api_key="AIza..."))
dispatcher.include_router(router)

response = await dispatcher.process("chat", text="Hello!")

Modules

Module Extra Description
codex_ai.core - Dispatcher, router, protocol types, sync wrapper, and shared exception contract
codex_ai.providers.gemini [gemini] Google Gemini text, JSON, and image generation via google-genai
codex_ai.providers.openai [openai] OpenAI Chat Completions text provider

Development

uv sync --extra dev
uv run pytest
uv run mypy src/
uv run pre-commit run --all-files
uv build --no-sources

Documentation

Full docs with architecture, API reference, and data flow diagrams:

codexdlc.github.io/codex-ai

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

codex_ai-0.2.0.tar.gz (128.9 kB view details)

Uploaded Source

Built Distribution

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

codex_ai-0.2.0-py3-none-any.whl (18.0 kB view details)

Uploaded Python 3

File details

Details for the file codex_ai-0.2.0.tar.gz.

File metadata

  • Download URL: codex_ai-0.2.0.tar.gz
  • Upload date:
  • Size: 128.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for codex_ai-0.2.0.tar.gz
Algorithm Hash digest
SHA256 b2a3ce1faeefdd506002a0097782f98b38cf3d9f7151e2fa91d7f382ff614724
MD5 c6eb318c5de3151207583faae9238418
BLAKE2b-256 a5a1c8befd8d1000a49643729a12868facbb923dbfafe79dc888323847f97e02

See more details on using hashes here.

Provenance

The following attestation bundles were made for codex_ai-0.2.0.tar.gz:

Publisher: publish.yml on CodexDLC/codex-ai

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

File details

Details for the file codex_ai-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: codex_ai-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 18.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for codex_ai-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 38a4a4324edf8bfd1968faab752f172759b47692729857260fdc26f36b6cddc2
MD5 fd0cfcc96901f112504728d47b9178c1
BLAKE2b-256 5c3d54d9d648709663244f9362672c2e8c747759599ff244ab7656acbd6176bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for codex_ai-0.2.0-py3-none-any.whl:

Publisher: publish.yml on CodexDLC/codex-ai

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