mirror of
https://github.com/dograh-hq/dograh.git
synced 2026-06-07 07:55:16 +02:00
91 lines
2.9 KiB
Python
91 lines
2.9 KiB
Python
|
|
from __future__ import annotations
|
|||
|
|
|
|||
|
|
from typing import Any, Dict, List
|
|||
|
|
|
|||
|
|
from google.genai.types import (
|
|||
|
|
Content,
|
|||
|
|
Part,
|
|||
|
|
)
|
|||
|
|
from pipecat.adapters.schemas.function_schema import FunctionSchema
|
|||
|
|
from pipecat.adapters.schemas.tools_schema import ToolsSchema
|
|||
|
|
from pipecat.services.google.llm import GoogleLLMContext
|
|||
|
|
from pipecat.services.openai.llm import OpenAILLMContext
|
|||
|
|
|
|||
|
|
from api.utils.template_renderer import render_template
|
|||
|
|
|
|||
|
|
__all__ = [
|
|||
|
|
"get_function_schema",
|
|||
|
|
"update_llm_context",
|
|||
|
|
"render_template",
|
|||
|
|
]
|
|||
|
|
|
|||
|
|
|
|||
|
|
def get_function_schema(
|
|||
|
|
function_name: str,
|
|||
|
|
description: str,
|
|||
|
|
*,
|
|||
|
|
properties: Dict[str, Any] | None = None,
|
|||
|
|
required: List[str] | None = None,
|
|||
|
|
) -> FunctionSchema:
|
|||
|
|
"""Create a FunctionSchema definition that can later be transformed into
|
|||
|
|
the provider-specific format (OpenAI, Gemini, etc.).
|
|||
|
|
|
|||
|
|
The helper keeps the public signature backward-compatible – callers that
|
|||
|
|
only pass ``function_name`` and ``description`` continue to work and will
|
|||
|
|
define a parameter-less function.
|
|||
|
|
"""
|
|||
|
|
|
|||
|
|
return FunctionSchema(
|
|||
|
|
name=function_name,
|
|||
|
|
description=description,
|
|||
|
|
properties=properties or {},
|
|||
|
|
required=required or [],
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
|
|||
|
|
def update_llm_context(
|
|||
|
|
context: OpenAILLMContext,
|
|||
|
|
system_message: Dict[str, Any],
|
|||
|
|
functions: List[FunctionSchema],
|
|||
|
|
) -> None:
|
|||
|
|
"""Update *context* with an up-to-date system message and tool list.
|
|||
|
|
|
|||
|
|
This helper removes any previous system messages before inserting the new
|
|||
|
|
*system_message* at the top of the conversation history and then instructs
|
|||
|
|
the LLM which *functions* (a.k.a. tools) are currently available.
|
|||
|
|
"""
|
|||
|
|
|
|||
|
|
# Wrap the provided function schemas in a ToolsSchema so that the adapter
|
|||
|
|
# associated with the current LLM service can convert them to the correct
|
|||
|
|
# provider-specific representation when required.
|
|||
|
|
tools_schema = ToolsSchema(standard_tools=functions)
|
|||
|
|
|
|||
|
|
if isinstance(context, GoogleLLMContext):
|
|||
|
|
context.system_message = system_message["content"]
|
|||
|
|
|
|||
|
|
if functions:
|
|||
|
|
# Lets only call set_tools if we have functions, else Gemini will
|
|||
|
|
# throw an exception
|
|||
|
|
context.set_tools(tools_schema)
|
|||
|
|
|
|||
|
|
if context.messages[-1].role != "user":
|
|||
|
|
# Google expects the last message should end with user message
|
|||
|
|
context.add_message(Content(role="user", parts=[Part(text="...")]))
|
|||
|
|
return
|
|||
|
|
|
|||
|
|
# In case of OpenAILLMContext, replace the system message with incoming system message
|
|||
|
|
previous_interactions = context.messages
|
|||
|
|
|
|||
|
|
# Filter out old system messages but keep user/assistant/function content.
|
|||
|
|
messages: List[Dict[str, Any]] = [system_message]
|
|||
|
|
messages.extend(
|
|||
|
|
interaction
|
|||
|
|
for interaction in previous_interactions
|
|||
|
|
if interaction["role"] != "system"
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
context.set_messages(messages)
|
|||
|
|
|
|||
|
|
if functions:
|
|||
|
|
context.set_tools(tools_schema)
|