Framework-agnostic agent fabric orchestration for CrewAI, LangGraph, Strands, local CLI runners, and vendor-fabric tools
Project description
agentic-fabric
Framework-agnostic agent fabric orchestration. Declare fabric agents once in YAML, then run them on CrewAI, LangGraph, Strands, or local CLI runners without changing a single fabric agent definition. Runtime frameworks are optional and are detected lazily from what is installed.
Documentation | Source | Issues
Installation
# Core discovery, loading, runner selection, local CLI, and neutral file tools
pip install agentic-fabric
# With a specific framework
pip install "agentic-fabric[langgraph]"
pip install "agentic-fabric[strands]"
# Non-framework optional surfaces
pip install "agentic-fabric[mcp]"
pip install "agentic-fabric[scraping]"
Local CLI runners do not require a Python extra. Install the external CLI
(aider, claude, codex, ollama, or a custom executable) and inspect
profiles with agentic-fabric list-runners --json.
Vendor-backed passthrough extras will be added after the upstream
vendor-fabric optional-extra contract is published and stable. Until then,
vendor references stay lazy and report install guidance at use time.
There is no aggregate AI extra. Install exactly the framework or provider path
you use. The CrewAI adapter remains lazy, but agentic-fabric does not publish
a CrewAI extra while CrewAI depends on ChromaDB releases covered by an upstream
critical advisory with no patched version. Install CrewAI separately only after
reviewing that advisory state. Core, local-CLI, and first-party scraping
installs are unaffected.
Quick Start
1. Define a Fabric Agent (YAML)
# .fabric/fabric_agents/analyzer/agents.yaml
code_reviewer:
role: Senior Code Reviewer
goal: Find bugs and improvements
backstory: Expert at code analysis
# .fabric/fabric_agents/analyzer/tasks.yaml
review_code:
description: Review the provided code for issues
expected_output: List of findings with severity
agent: code_reviewer
2. Run It
from pathlib import Path
from agentic_fabric import detect_framework, get_fabric_agent_config, run_fabric_agent_auto
# See what framework is available
framework = detect_framework()
# Load a fabric agent manifest discovered in a package or workspace
config = get_fabric_agent_config(Path(".fabric"), "analyzer")
# Auto-detect best framework and run
result = run_fabric_agent_auto(config, inputs={"code": "..."})
Or from the CLI:
agentic-fabric run my-package analyzer --input "Review this code: ..."
3. Use a Specific Runner
from agentic_fabric import get_runner
runner = get_runner("langgraph") # Force LangGraph
fabric_agent = runner.build_fabric_agent(config)
result = runner.run(fabric_agent, inputs)
4. Carry Runtime Context with Data
from agentic_fabric import AgenticData, get_framework_info
print(get_framework_info())
session = AgenticData({"repo": "jbcom/agentic-fabric"})
session.register_fabric_agent("reviewer", config)
result = session.run_fabric_agent("reviewer", runtime="crewai")
Key Features
- Framework agnostic: one fabric agent definition, multiple runtime backends.
- Lazy imports: core package import does not require CrewAI, LangGraph, Strands, or vendor SDKs.
- Framework-neutral file tools: built-in filesystem tools can be resolved without installing CrewAI or Pydantic; framework adapters add schema wrappers only when their optional dependencies are present.
- Focused extras:
langgraph,strands,mcp,scraping,tests,typing,docs, anddev. AgenticData: carries data, registered fabric agents, active runtime selection, and vendor-layer context together.- Capability decorators: runners and tools expose declared capabilities through read-only metadata and deterministic dispatch.
- Tool resolution: built-in, vendor URI, and registered factories are preferred;
external dynamic imports require
AGENTIC_FABRIC_TOOL_IMPORT_ALLOWLIST. - Vendor tool catalogs:
AgenticData.vendor_tools()adapts inheritedVendorDatacapability metadata into agent-facing tools without importing provider SDKs directly. - YAML-first: fabric agent configuration in YAML, not Python boilerplate.
- Hierarchical orchestration:
ManagerAgentdelegates across fabric agents. - Package discovery: finds
.fabric/,.crewai/,.langgraph/, and.strands/directories. - Vendor passthrough extras are deferred until
vendor-fabricis published with a stable optional-extra contract. - CLI and library: use from the command line or import as a module.
Framework Priority
- CrewAI, if installed.
- LangGraph, if CrewAI is unavailable.
- Strands, if neither CrewAI nor LangGraph is available.
You can always force a specific runner with get_runner("langgraph") or
agentic-fabric run --framework langgraph.
If the selected runtime is not installed, errors point to the matching
agentic-fabric[...] extra. Framework-specific config directories also enforce
their runtime: a fabric agent in .langgraph/ will not silently run on CrewAI.
Local CLI Runners
For single-agent coding tools, use the --runner CLI path:
agentic-fabric list-runners --json
agentic-fabric run --runner aider --input "Add validation to auth.py"
agentic-fabric run --runner ollama --model deepseek-coder --input "Explain this module"
Profiles are loaded from the packaged local_cli_profiles.yaml, validated
before use, and rejected on POSIX systems if the profiles file is group- or
world-writable.
MCP Adapters
The mcp extra installs the MCP transport dependency and enables two console
entry points:
agentic-fabric-vendor-mcp
agentic-fabric-meshy-mcp
agentic-fabric-vendor-mcp exposes credential-free vendor catalog tools and
public vendor-fabric data methods. agentic-fabric-meshy-mcp converts
Meshy capability metadata from vendor-fabric[meshy] into MCP tools. Both
servers import provider code lazily; install the matching vendor-fabric
package/extras in the same environment before running provider-backed tools.
If provider startup fails, the adapter error includes the agentic-fabric[mcp]
or vendor-fabric[...] install guidance plus the original import failure so
missing provider extras are visible.
Repository Boundary
extended-dataowns base data containers, logging, input handling, files, redaction, and generic workflows.vendor-fabricowns vendor connectors, provider-backed sync, the SecretSync Python facade/capability surfaces, provider capability metadata, and provider dispatch.agentic-fabricowns fabric agent discovery, runner selection, framework adapters, agent-facing tool wrappers, and orchestration.
Full guides and API documentation are published at
jonbogaty.com/agentic-fabric.
AGENTS.md contains durable repository guidance for Codex sessions.
Documentation
The docs are built with Sphinx, Furo, and sphinx-autodoc2:
tox -e docs
Local validation:
uv sync --all-packages --all-extras --dev
tox -e lint
tox -e typecheck
tox -e audit
tox -e py311
tox -e py312
tox -e py313
tox -e py314
tox -e coverage
tox -e plugin
tox -e examples
tox -e build
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agentic_fabric-1.2.0.tar.gz.
File metadata
- Download URL: agentic_fabric-1.2.0.tar.gz
- Upload date:
- Size: 126.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3e38d2a25b4384071eb75e809a4017f716a1d8e4d6ee14034ac7aafb3c36694e
|
|
| MD5 |
b515737430b2b0b93b1393f76d710c39
|
|
| BLAKE2b-256 |
ffbb86b4b8dfb63a577bfc9fc2004fd787dbbcd2f2cc0daffb935e13cdc35613
|
File details
Details for the file agentic_fabric-1.2.0-py3-none-any.whl.
File metadata
- Download URL: agentic_fabric-1.2.0-py3-none-any.whl
- Upload date:
- Size: 82.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
508d2fa32c6acda161fae35ab24b8ea04b165ea2caf213348c9e65565f2e7343
|
|
| MD5 |
37fcf37f029b3bf1a703aa1be750113d
|
|
| BLAKE2b-256 |
2bea995668e2b9bc31b60602d52696347f0ebe441f98a93a85c005f39ecaf187
|