Skip to main content

Microsoft Agent Framework extensions for mainstream open-source LLMs

Project description

agent-framework-ep

CI

Microsoft Agent Framework extensions for mainstream open-source LLMs, including structured output support for GLM, Kimi, Qwen, and DeepSeek, along with reasoning_content support. Plus a local containerized code interpreter environment. 'ep' stands for enterprise-level applications.

Features

  • OpenAI-like Client Extensions (openai_like)

    • Structured output parsing with JSON fallback (dirtyjson, json-repair)
    • Reasoning content support for DeepSeek-R1 style models
    • Uses Chat Completions API, compatible with domestic LLMs (DeepSeek, Kimi, Qwen)
    • Requires: agent-framework>=1.0.0rc6 and agent-framework-openai>=1.0.0rc6
  • Code Executor (code_executor)

    • Docker-based code execution environment
    • Supports Python, bash, and shell scripts
    • Timeout and cancellation support
    • Isolated execution for security
  • Dynamic Skills Provider (skills_provider)

    • Async skill updates before each agent run
    • Extendable skills from external sources

Installation

pip install agent-framework-ep

Or with uv:

uv add agent-framework-ep

Prerequisites

  • Python 3.12+
  • Docker (for code execution features)

Quick Start

OpenAI-like Client with Structured Output

from pydantic import BaseModel
from agent_framework import Agent
from agent_framework_ep import OpenAILikeChatClient

class Response(BaseModel):
    answer: str
    confidence: float

# Create client with structured output support
client = OpenAILikeChatClient(
    model="deepseek-chat",
    api_key="your-api-key"
)

# Use with Agent framework
agent = Agent(client=client)
response = await agent.run(
    "What is the capital of France?",
    response_format=Response
)
print(response)  # Parsed Response object

Code Execution

import asyncio
import os
from agent_framework_ep import DockerCommandLineCodeExecutor
from agent_framework_ep import OpenAILikeChatClient, CodeExecutionTool

chat_client = OpenAILikeChatClient(
    model_id="kimi/kimi-k2.5",
)

code_executor = DockerCommandLineCodeExecutor(
    image="python-code-sandbox",
    work_dir="some_of_your_working_directory",
    delete_tmp_files=True,
    environment={
        "TAVILY_API_KEY": os.environ.get("TAVILY_API_KEY"),
    }
)

code_tool = CodeExecutionTool(code_executor).execute_code

agent = chat_client.as_agent(
    name="SkillsAssistant",
    instructions="You're a helpful assistant.",
    tools=[code_tool],
)

Dynamic Skills Provider

from agent_framework_ep import UpdatableSkillsProvider
from agent_framework import Skill

async def fetch_dynamic_skills():
    # Fetch skills from external source
    return [
        Skill(name="web-search", description="Search the web", content="..."),
    ]

provider = UpdatableSkillsProvider(
    skill_paths="./skills",
    skills_updater=fetch_dynamic_skills
)

Development

# Clone the repository
git clone https://github.com/qianpeng/agent-framework-ep.git
cd agent-framework-ep

# Install dependencies
uv sync

# Run tests
uv run pytest

# Run tests with Docker (requires Docker)
uv run pytest -m docker

# Lint and format
uv run ruff check --fix .
uv run ruff format .

# Type check
uv run mypy src/agent_framework_ep

License

MIT License - see LICENSE for details.

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

agent_framework_ep-0.2.0.tar.gz (74.8 kB view details)

Uploaded Source

Built Distribution

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

agent_framework_ep-0.2.0-py3-none-any.whl (28.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for agent_framework_ep-0.2.0.tar.gz
Algorithm Hash digest
SHA256 df87ba482792e321a28e0e3b107b02c9c1aac396245850aad07b8f0422c85e1f
MD5 e9992ef2a4201645db694e3035cf9e34
BLAKE2b-256 f0d59b3c1d268e7bd48d8fd309055db71c4e010ca0c36f78bd01d7fab158d35f

See more details on using hashes here.

Provenance

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

Publisher: release.yml on qtalen/agent-framework-ep

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

File details

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

File metadata

File hashes

Hashes for agent_framework_ep-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c6e067fb5efc1702efba4d465badfbd0a44a4b3f7a0b39abbb5ffd894e47558d
MD5 5c4006fba56059c5dcacf7e36431e938
BLAKE2b-256 9de7dd01070b41a09a007cf38a8e89fbb92198546c874da635509a22cba706f2

See more details on using hashes here.

Provenance

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

Publisher: release.yml on qtalen/agent-framework-ep

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