Skip to main content

Microsoft Agent Framework extensions for mainstream open-source LLMs

Project description

agent-framework-ep

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
    • Compatible with Microsoft Agent Framework's OpenAIChatClient
  • 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.1.3.tar.gz (35.5 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.1.3-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: agent_framework_ep-0.1.3.tar.gz
  • Upload date:
  • Size: 35.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for agent_framework_ep-0.1.3.tar.gz
Algorithm Hash digest
SHA256 7ea42daf9ebab8832067c7ac5953768a06de7884362e1762ff37e52897837761
MD5 c1d65458c00f13543e18b65bd382802c
BLAKE2b-256 6961dbba57638fe1f4409301151019078e43a9cf7e34bcb093c8a2606a87ecf4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for agent_framework_ep-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 30d70f30c0bb4fdf9e0b21ad2b63ab14c036693fb67e6b41aa98c3a6d7acf5d1
MD5 35dbc992ab92563bf72f06e08ded960f
BLAKE2b-256 dad0a087c35753004f986486ef873ff2deb034b24b381659267ffb6386a9239d

See more details on using hashes here.

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