Skip to main content

Microsoft Agent Framework integration for the Agent Skills format (https://agentskills.io)

Project description

agentskills-agentframework

PyPI Python 3.12+ License: MIT

Microsoft Agent Framework integration for the Agent Skills SDK — turn a skill registry into Agent Framework tools.

Generates a set of Microsoft Agent Framework FunctionTool instances from a SkillRegistry, ready to be passed to any Agent Framework agent.

Installation

pip install agentskills-agentframework

Requires Python 3.12+. Installs agentskills-core and agent-framework as dependencies.

Note: agent-framework is currently a pre-release dependency (>=1.0.0b1). The constraint will be updated once a stable release is published.

Usage

from agentskills_core import SkillRegistry
from agentskills_fs import LocalFileSystemSkillProvider
from agentskills_agentframework import get_tools, get_tools_usage_instructions

# Set up registry
provider = LocalFileSystemSkillProvider(Path("./skills"))
registry = SkillRegistry()
await registry.register("incident-response", provider)

# Build tools + system prompt
tools = get_tools(registry)
catalog = await registry.get_skills_catalog(format="xml")
instructions = get_tools_usage_instructions()
system_prompt = f"{catalog}\n\n{instructions}"

Pass tools to your Agent Framework agent and inject system_prompt into the instructions. The catalog tells the agent what skills exist; the usage instructions tell it how to use the tools.

Generated Tools

Tool Parameters Description
get_skill_metadata skill_id Get structured metadata (name, description, etc.)
get_skill_body skill_id Load the full markdown instructions
get_skill_reference skill_id, name Read a reference document
get_skill_script skill_id, name Read a script
get_skill_asset skill_id, name Read an asset

All tools are async-compatible (FunctionTool with @tool decorator).

API

get_tools(registry: SkillRegistry) -> list[FunctionTool]

Returns a list of Agent Framework function tools bound to the given registry.

get_tools_usage_instructions() -> str

Returns a markdown string explaining the progressive-disclosure workflow — read metadata, then body, then fetch resources on demand. Designed for system-prompt injection alongside the skill catalog.

Example

See examples/agent-framework/ for full working demos.

Error Handling

Scenario Exception
Skill not found in registry SkillNotFoundError
Resource not found in skill ResourceNotFoundError
Provider errors (HTTP, filesystem) AgentSkillsError

All exceptions inherit from AgentSkillsError (from agentskills-core).

Note: Binary content (scripts, assets, references) is decoded as UTF-8 with errors="replace". Non-decodable bytes are replaced with the Unicode replacement character (�).

License

MIT

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

agentskills_agentframework-0.2.1.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

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

agentskills_agentframework-0.2.1-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file agentskills_agentframework-0.2.1.tar.gz.

File metadata

  • Download URL: agentskills_agentframework-0.2.1.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.1 CPython/3.13.9 Windows/11

File hashes

Hashes for agentskills_agentframework-0.2.1.tar.gz
Algorithm Hash digest
SHA256 90d25ca4c1bbb6f7328fd3bdfb9de037cce5e62f14d75011d99457b62084fcb7
MD5 c3bc7b904cf10bc1a9a02e8dc32f85cb
BLAKE2b-256 7dd7df5213060d120428de5f688beba7af53c2c160af4d7ec915ab7ebd49aadc

See more details on using hashes here.

File details

Details for the file agentskills_agentframework-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for agentskills_agentframework-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 866e93f4449334e047bdd597f8f6c0c33670958b54fbf8e7aaa78e86673513d3
MD5 b15b0fd9211db7bcd49d314f18000543
BLAKE2b-256 48633201fad61975fceb5e2799f62e02ae7a27849e50f79f49b9fcc1e9ea541b

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