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(
    "Square tactical dark fantasy ruined capital city map, no labels.",
    model="gemini-3-pro-image-preview",
    response_mime_type="image/png",
    image_config={"aspect_ratio": "1:1", "image_size": "4K"},
)

imagen_bytes, imagen_content_type = await gemini.generate_imagen_bytes(
    "A fantasy clan banner, game icon style.",
    response_mime_type="image/jpeg",
)

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

generate_image_bytes() targets Gemini image models through generate_content and treats response_mime_type as a preferred/fallback MIME type. It does not pass image MIME values to Gemini's text response_mime_type config field. Pass Gemini image controls such as aspect_ratio and image_size with image_config; if a 4K request is rejected, the Gemini provider retries once with 2K. Use generate_imagen_bytes() for Imagen models; that path uses generate_images and passes the requested MIME as output_mime_type.

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, Gemini image, and Imagen generation via pinned 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.3.tar.gz (132.1 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.3-py3-none-any.whl (19.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: codex_ai-0.2.3.tar.gz
  • Upload date:
  • Size: 132.1 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.3.tar.gz
Algorithm Hash digest
SHA256 21721e625a5a815478e7939bfa75890fe0acbcaee3661b1a22cbd3c78417441c
MD5 08823c200e81218a94526af0f681c6b6
BLAKE2b-256 7639cb5a25f35bef84c78ad2982dffc4bc25ff4da984edcd2e91b2d3f9d67c1a

See more details on using hashes here.

Provenance

The following attestation bundles were made for codex_ai-0.2.3.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.3-py3-none-any.whl.

File metadata

  • Download URL: codex_ai-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 19.5 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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ab8a42ec6c57f5a03bfb1984d033c2c872721fac294f61dad14daa0a77e4e3aa
MD5 d037d4faaee27191e4f1182fd9faf05a
BLAKE2b-256 a39a27b6f80b07769883592952398dc227f7d6a4c705d3b8167d37741bfdd264

See more details on using hashes here.

Provenance

The following attestation bundles were made for codex_ai-0.2.3-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