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 3 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.4.tar.gz (8.6 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.4-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: adk_chatkit-0.0.4.tar.gz
  • Upload date:
  • Size: 8.6 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.4.tar.gz
Algorithm Hash digest
SHA256 8d1faabcfeffcc7c9795b14e8290f7394436856cc9c184707806b1818fae4399
MD5 0a4286de04d599968e19beb2b5f70571
BLAKE2b-256 10b758d7f456c7800e6afb6dd1d4a4ffdf97b2477031cda9b455ff575f230ab0

See more details on using hashes here.

Provenance

The following attestation bundles were made for adk_chatkit-0.0.4.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.4-py3-none-any.whl.

File metadata

  • Download URL: adk_chatkit-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 10.0 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 6f2f3dc1238999a9c285bdcf4a4bf613235a686c0d9ca5ecfcf3f774a7ce4b2b
MD5 6476331c393d2b409f83e8085209d03b
BLAKE2b-256 4e96caae89720fbc03b34f30dfc4aad3a8be2ed0650b08a6ac1f3032984202d3

See more details on using hashes here.

Provenance

The following attestation bundles were made for adk_chatkit-0.0.4-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