data:image/s3,"s3://crabby-images/206c8/206c8f20ef6313e28cce16c5ec9ecf05dc41503a" alt="logo"
🤖 Fabric Agent Action is a GitHub Action that leverages Fabric Patterns to automate complex workflows using an agent-based approach. Built with LangGraph, it intelligently selects and executes patterns using Large Language Models (LLMs).
🎥 Demo:
data:image/s3,"s3://crabby-images/c6fcf/c6fcf3a5392842cab3af559e138da489d032f693" alt="demo"
- Features
- Quick Start
- Security
- Configuration
- Usage Examples
- Agent Types
- Debugging
- Running Anywhere
- Contributing
- License
✨ Key Capabilities:
- Seamless Integration: Easily incorporate the action into your existing workflows without additional setup.
- Multi-Provider Support: Choose between OpenAI, OpenRouter, or Anthropic based on your preference and availability.
- Configurable Agent Behavior: Select agent types (
router
,react
,react_issue
, orreact_pr
) and customize their behavior to suit your workflow needs. - Flexible Pattern Management: Include or exclude specific Fabric Patterns to optimize performance and comply with model limitations.
To add the Fabric Agent Action to your workflow, reference it in your workflow .yaml
file:
- name: Execute Fabric Agent Action
uses: xvnpw/fabric-agent-action@v1 # or docker://ghcr.io/xvnpw/fabric-agent-action:v1 to avoid action rebuild on each run
with:
input_file: path/to/input.md
output_file: path/to/output.md
env:
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
Set Environment Variables: Ensure you set the required API keys in your repository's secrets.
Use these workflow conditions to protect your action:
Context | Risk | Protection |
---|---|---|
Pull Requests | Fork-based PRs can run workflows | if: github.event.pull_request.head.repo.full_name == github.repository |
PR Comments | Public repositories allow anyone to comment | if: github.event.comment.user.login == github.event.repository.owner.login and if (pr.data.head.repo.owner.login !== context.repo.owner) |
Issue Comments | Public repositories allow anyone to comment | if: github.event.comment.user.login == github.event.repository.owner.login |
All Events | General access control | if: github.actor == 'authorized-username' |
Input | Description | Default |
---|---|---|
input_file |
Required Source file containing input and agent instructions | |
output_file |
Required Destination file for pattern results | |
verbose |
Enable INFO level logging | false |
debug |
Enable DEBUG level logging | false |
agent_type |
Agent behavior model (router /react /react_issue /react_pr ) |
router |
agent_provider |
LLM provider for agent (openai /openrouter /anthropic ) |
openai |
agent_model |
Model name for agent | gpt-4o |
agent_temperature |
Model creativity (0-1) for agent | 0 |
agent_preamble_enabled |
Enable preamble in output | false |
agent_preamble |
Preamble added to the beginning of output | ##### (🤖 AI Generated) |
fabric_provider |
Pattern execution LLM provider | openai |
fabric_model |
Pattern execution LLM model | gpt-4o |
fabric_temperature |
Pattern execution creativity (0-1) | 0 |
fabric-patterns-included |
Patterns to include (comma-separated). Required for models with pattern limits (e.g., gpt-4o ). |
|
fabric-patterns-excluded |
Patterns to exclude (comma-separated) | |
fabric_max_num_turns |
Maximum number of turns to LLM when running fabric patterns | 10 |
Note: Models like
gpt-4o
have a limit on the number of tools (128), while Fabric currently includes 175 patterns (as of November 2024). Usefabric_patterns_included
orfabric_patterns_excluded
to tailor the patterns used. For access to all patterns without tool limits, consider usingclaude-3-5-sonnet-20240620
.
Find the list of available Fabric Patterns here.
Set one of the following API keys:
OPENAI_API_KEY
OPENROUTER_API_KEY
ANTHROPIC_API_KEY
This action is flexible in workflow integration and can be used on issues, pushes, pull requests, etc.
Below is an example of how to integrate the Fabric Agent Action into a GitHub Actions workflow that reacts to issue comments.
Flowchart:
flowchart TD
Start([GitHub Issue Created]) --> Command["/fabric Command Detected"]
subgraph Process["AI Agent Processing"]
Command --> ReadContext["Read Issue Context<br/>(title, body, comments)"]
ReadContext --> Analyze["AI Analyzes Request"]
Analyze --> PatternCheck{"Needs Patterns?"}
PatternCheck -->|Yes| UsePattern["Use Pattern<br/>(e.g., clean_text)"]
UsePattern --> CheckResult{"Check Result"}
CheckResult -->|"Need More"| Analyze
CheckResult -->|"Done"| PrepareResponse["Prepare Response"]
end
PrepareResponse --> Comment["Post GitHub Comment"]
Comment --> End([Done])
style Start fill:#90EE90
style End fill:#FFB6C1
style Process fill:#F0F8FF
style PatternCheck fill:#FFE4B5
style CheckResult fill:#FFE4B5
Sequence Diagram:
sequenceDiagram
participant U as User
participant GI as GitHub Issue
participant WF as GitHub Workflow
participant A as AI Agent
participant T as Patterns
U->>GI: Creates/Updates Issue
U->>GI: Adds Command (/fabric)
GI->>WF: Triggers Workflow
rect rgb(240, 240, 255)
Note over WF,A: fabric-agent-action
WF->>A: Passes Issue Context
loop Until Task Complete
A->>A: Processes Current State
A->>T: Requests Pattern Action #1
T-->>A: Returns Pattern Result #1
opt May Need Additional Patterns
A->>T: Requests Pattern Action #2
T-->>A: Returns Pattern Result #2
Note over A,T: Can continue based on results
end
end
A->>WF: Returns Final Response
end
WF->>GI: Posts Comment
GI-->>U: Notifies User
Github Workflow:
name: Fabric Pattern Processing using ReAct Issue Agent
on:
issue_comment:
types: [created, edited]
jobs:
process_fabric:
if: >
github.event.comment.user.login == github.event.repository.owner.login &&
startsWith(github.event.comment.body, '/fabric') &&
!github.event.issue.pull_request
runs-on: ubuntu-latest
permissions:
issues: write
contents: read
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Prepare Input
uses: actions/github-script@v7
id: prepare-input
with:
script: |
const issue = await github.rest.issues.get({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo
});
const comment = await github.rest.issues.getComment({
comment_id: context.payload.comment.id,
owner: context.repo.owner,
repo: context.repo.repo
});
// Get all comments for this issue to include in the output
const comments = await github.rest.issues.listComments({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo
});
// Extract command from the triggering comment
const command = comment.data.body;
let output = `INSTRUCTION:\n${command}\n\n`;
// Add issue information
output += `GITHUB ISSUE, NR: ${issue.data.number}, AUTHOR: ${issue.data.user.login}, TITLE: ${issue.data.title}\n`;
output += `${issue.data.body}\n\n`;
// Add all comments
for (const c of comments.data) {
if (c.id === comment.data.id) {
break;
}
output += `ISSUE COMMENT, ID: ${c.id}, AUTHOR: ${c.user.login}\n`;
output += `${c.body}\n\n`;
}
require('fs').writeFileSync('fabric_input.md', output);
return output;
- name: Execute Fabric Patterns
uses: docker://ghcr.io/xvnpw/fabric-agent-action:v1
with:
input_file: "fabric_input.md"
output_file: "fabric_output.md"
agent_type: "react_issue"
fabric_temperature: 0.2
fabric_patterns_included: "clean_text,create_stride_threat_model,create_design_document,review_design,refine_design_document,create_threat_scenarios,improve_writing,create_quiz,create_summary"
debug: true
env:
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}
- name: Post Results
uses: peter-evans/create-or-update-comment@v4
with:
issue-number: ${{ github.event.issue.number }}
body-path: fabric_output.md
In this workflow:
- The job runs only when:
- The comment starts with
/fabric
. - The comment author is the repository owner.
- The issue is not a pull request.
- The comment starts with
- This prevents unauthorized users from triggering the action, avoiding excessive API usage or costs.
Example | Links |
---|---|
Create a pull request on changes in README.md to run the improve_writing pattern |
Pull request, workflow |
Create a pull request on changes in the docs/ directory to run the improve_writing pattern |
Pull request, workflow |
Run fabric patterns from issue comments using the router agent | Issue, workflow |
Run fabric patterns from issue comments using the react agent | Issue, workflow |
Automatically run the fabric write_pull_request pattern on pull requests | Pull request, workflow |
Run fabric patterns from issue comments using specialized react issue agent | Issue, workflow |
Run fabric patterns from pull request comments using specialized react pr agent | Pull request, workflow |
The action supports different types of agents that process Fabric patterns. Each agent has specific capabilities and use cases.
quadrantChart
title Agents: Autonomy vs. Reliability
x-axis Low Autonomy --> High Autonomy
y-axis Low Reliability --> High Reliability
Router Agent: [0.25, 0.75]
ReAct Agent: [0.6, 0.4]
ReAct Issue/PR Agents: [0.7, 0.3]
In practice, there's often a trade-off between autonomy and reliability. Increasing LLM autonomy can sometimes reduce reliability due to factors like non-determinism or errors in tool selection.
The simplest agent that makes a single pattern selection and returns direct output. It follows a straightforward flow:
- Receives input.
- Selects appropriate tool (pattern).
- Returns tool output.
%%{init: {'flowchart': {'curve': 'linear'}}}%%
graph TD;
__start__([<p>__start__</p>]):::first
assistant(assistant)
tools(tools)
__end__([<p>__end__</p>]):::last
__start__ --> assistant;
tools --> __end__;
assistant -.-> tools;
assistant -.-> __end__;
classDef default fill:#f2f0ff,line-height:1.2
classDef first fill-opacity:0
classDef last fill:#bfb6fc
Input Example:
INSTRUCTION:
/fabric improve writing
INPUT:
I encountered a challenge in creating high-quality design documents [...]
A more sophisticated agent that implements the ReAct pattern (Reason-Act-Observe). Features:
- Can make multiple tool calls in sequence.
- Reasons about tool outputs.
- Configurable maximum turns via
fabric_max_num_turns
.
%%{init: {'flowchart': {'curve': 'linear'}}}%%
graph TD;
__start__([<p>__start__</p>]):::first
assistant(assistant)
tools(tools)
__end__([<p>__end__</p>]):::last
__start__ --> assistant;
tools --> assistant;
assistant -.-> tools;
assistant -.-> __end__;
classDef default fill:#f2f0ff,line-height:1.2
classDef first fill-opacity:0
classDef last fill:#bfb6fc
Input Example:
INSTRUCTION:
/fabric clean text and improve writing
INPUT:
I encountered a challenge in creating high-quality design documents [...]
Two variants of ReAct agent optimized for GitHub interactions:
-
ReAct Issue Agent: Processes GitHub Issues.
- Handles structured input with
INSTRUCTION
,GITHUB ISSUE
, andISSUE COMMENTS
. - Maintains context from previous interactions.
- Preserves exact tool outputs.
- Handles structured input with
-
ReAct Pull Request Agent: Processes Pull Requests.
- Similar to Issue agent but includes
GIT DIFF
analysis. - Processes
INSTRUCTION
, PR description, and comments. - Can analyze code changes through diff.
- Similar to Issue agent but includes
Example Input:
INSTRUCTION:
/fabric improve writing of cleaned text
GITHUB ISSUE, NR: 1233, AUTHOR: xvnpw, TITLE: Text improvements
I encountered a challenge in creating high-quality design documents for my threat modeling research..... About a year and a half ago, I created AI Nutrition-Pro architecture and have been using it since then. What if it's already in LLMs' training data? Testing threat modeling capabilities could give me false results.
ISSUE COMMENT, ID: 12321434, AUTHOR: xvnpw
/fabric clean text
ISSUE COMMENT, ID: 12313245, AUTHOR: github-action[bot]
I encountered a challenge in creating high-quality design documents for my threat modeling research. About a year and a half ago, I created AI Nutrition-Pro architecture and have been using it since then. What if it's already in LLMs' training data? Testing threat modeling capabilities could give me false results.
ISSUE COMMENT, ID: 32425444, AUTHOR: pedro
I think writing about training data is inrelevent. We don't really know what is in those data.
Example Input:
INSTRUCTION:
/fabric improve writing of cleaned text
GITHUB PULL REQUEST, NR: 1233, AUTHOR: xvnpw, TITLE: Text improvements
I encountered a challenge in creating high-quality design documents for my threat modeling research..... About a year and a half ago, I created AI Nutrition-Pro architecture and have been using it since then. What if it's already in LLMs' training data? Testing threat modeling capabilities could give me false results.
GIT DIFF:
diff --git a/.github/workflows/fabric-docs-pr.yml b/.github/workflows/fabric-docs-pr.yml
index 996a93a..ba7d121 100644
--- a/.github/workflows/fabric-docs-pr.yml
+++ b/.github/workflows/fabric-docs-pr.yml
@@ -58,7 +58,7 @@ jobs:
CHANGED_FILES: ${{ steps.changed_files.outputs.changed_files }}
- name: Execute Fabric patterns
- uses: docker://ghcr.io/xvnpw/fabric-agent-action:v0.0.26
+ uses: docker://ghcr.io/xvnpw/fabric-agent-action:v0.0.27^M
with:
input_file: "fabric_input.md"
output_file: "fabric_output.md"
PULL REQUEST COMMENT, ID: 12321434, AUTHOR: xvnpw
/fabric clean text
PULL REQUEST COMMENT, ID: 12313245, AUYTHOR: github-action[bot]
I encountered a challenge in creating high-quality design documents for my threat modeling research. About a year and a half ago, I created AI Nutrition-Pro architecture and have been using it since then. What if it's already in LLMs' training data? Testing threat modeling capabilities could give me false results.
PULL REQUEST COMMENT, ID: 32425444, AUTHOR: pedro
I think writing about training data is inrelevent. We don't really know what is in those data.
All agents will return "no fabric pattern for this request" if they cannot match the input to an appropriate pattern.
You have two ways to gain insights into the internal workings of the system.
Enable the debug
mode by setting the debug
argument to true
. This will provide more detailed information about the process.
LangSmith offers a free tier that lets you visually track interactions between agents and LLMs, making debugging easier.
To use LangSmith, set the following environment variables:
LANGCHAIN_API_KEY
:${{ secrets.LANGCHAIN_API_KEY }}
LANGCHAIN_TRACING_V2
:true
The application can be run anywhere from source or using Docker.
Using Docker:
docker run --rm -it -v $(pwd):/data -e INPUT_INPUT_FILE=/data/fabric_input.md -e INPUT_OUTPUT_FILE=/data/fabric_output.md ghcr.io/xvnpw/fabric-agent-action:v1
From Source:
# Ensure you have poetry installed
git clone [email protected]:xvnpw/fabric-agent-action.git
cd fabric-agent-action/
poetry install
poetry run python fabric_agent_action/app.py --input-file fabric_input.md --output-file fabric_output.md
- OpenAI - Industry standard.
- OpenRouter - Multi-model gateway.
- Anthropic - Claude models.
Contributions are welcome! Please open issues and pull requests. Ensure that you follow the existing code style and include tests for new features.
This project is licensed under the MIT License.