Skip to main content

OpenAI chatkit backend support for Google ADK

Project description

OpenAI chatkit support for Google ADK

This repository provides the backend support for openai/chatkit-js (https://github.com/openai/chatkit-js) for Google ADK based agentic applications.

It uses and extends openai/chatkit-python (https://github.com/openai/chatkit-python) by providing

  • ADKStore that wraps BaseSessionService
  • A function (stream_agent_response) that translate ADK events into chatkit events
  • Provides support to render widgets
    • See examples/backend/src/backend/agents/facts/_tools.py::get_weather
  • Provides support for making calls to client tools.
    • Client tools typically run in browser
    • See examples/backend/src/backend/agents/facts/_tools.py::switch_theme

TODO:

  • Support for attachments / artifacts

Install

uv add adk-chatkit

Running examples

Make sure you open this repository in vscode devcontainer and all dependencies will be setup for you

# At the root of the repository
# fill in your configuration / settings
cp .env.example .env

There is one backend and one frontend that hosts 4 agents (chatkit servers) and their corresponding user interface.

# Run the backend
uv run poe run-example-backend
# Run the frontend
uv run poe run-example-frontend

Usage

See examples for full usage

from adk_chatkit import ADKAgentContext, ADKContext, ADKStore, ChatkitRunConfig, stream_agent_response

class FactsChatkitServer(ChatKitServer[ADKContext]):
    def __init__(
        self,
        store: ADKStore,
        runner_manager: RunnerManager,
        settings: Settings,
    ) -> None:
        super().__init__(store)
        agent = _make_facts_agent(settings)
        self._runner = runner_manager.add_runner(settings.FACTS_APP_NAME, agent)

    async def respond(
        self,
        thread: ThreadMetadata,
        item: UserMessageItem | None,
        context: ADKContext,
    ) -> AsyncIterator[ThreadStreamEvent]:
        if item is None:
            return

        if _is_tool_completion_item(item):
            return

        message_text = _user_message_text(item)
        if not message_text:
            return

        agent_context = ADKAgentContext(
            app_name=context.app_name,
            user_id=context.user_id,
            thread=thread,
        )

        event_stream = self._runner.run_async(
            user_id=context.user_id,
            session_id=thread.id,
            new_message=content,
            run_config=ChatkitRunConfig(streaming_mode=StreamingMode.SSE, context=agent_context),
        )

        async for event in stream_agent_response(agent_context, event_stream):
            yield event

Examples applications

There are 4 example applications (3 are ported from https://github.com/openai/openai-chatkit-advanced-samples)

Facts & Guide

  • Shows Fact Recording
  • Displays Weather using Widget
  • Theme Switching

http://localhost:5173/guide

Weather widget preview

Customer Support

  • Airline Reservation Management
  • Change Seat
  • Add bags

http://localhost:5171/customer-support

Customer Support preview

Knowledge Assistant

  • Answers questions based on files and vector store
  • Shows files and citations

http://localhost:5171/knowledge

Knowledge preview

Widget Gallery

  • Shows various widgets and how to process actions

Knowledge preview

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

adk_chatkit-0.0.5.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

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

adk_chatkit-0.0.5-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file adk_chatkit-0.0.5.tar.gz.

File metadata

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

File hashes

Hashes for adk_chatkit-0.0.5.tar.gz
Algorithm Hash digest
SHA256 ca2e1864b4db9fd056e2e527813fe1dd704052ded8d9bfa84dadba1135fd7edc
MD5 c266b86e08e9944c40b749091f920c9c
BLAKE2b-256 5ed232e2eacb355bf85bb7aac1fb73a18b31c7b155600524a3231954b9dc5b8a

See more details on using hashes here.

Provenance

The following attestation bundles were made for adk_chatkit-0.0.5.tar.gz:

Publisher: publish.yaml on ksachdeva/adk-chatkit

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

File details

Details for the file adk_chatkit-0.0.5-py3-none-any.whl.

File metadata

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

File hashes

Hashes for adk_chatkit-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 6fab895cd9cfd537b3499eac564106bd52deec1f9857fb83660ce9ddaa4d10d2
MD5 1997955bb0a2e489a83a2827fc5beba2
BLAKE2b-256 aad9dca9076769cebe3bf717a521849bf95fae471e0bd1d3f2e009db9ed37149

See more details on using hashes here.

Provenance

The following attestation bundles were made for adk_chatkit-0.0.5-py3-none-any.whl:

Publisher: publish.yaml on ksachdeva/adk-chatkit

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