Skip to main content

GitHub Agent for MCP

Project description

GitHub Agent - A2A | AG-UI | MCP

PyPI - Version MCP Server PyPI - Downloads GitHub Repo stars GitHub forks GitHub contributors PyPI - License GitHub

GitHub last commit (by committer) GitHub pull requests GitHub closed pull requests GitHub issues

GitHub top language GitHub language count GitHub repo size GitHub repo file count (file type) PyPI - Wheel PyPI - Implementation

Version: 0.3.0

Overview

GitHub Agent is a powerful Model Context Protocol (MCP) server and Agent-to-Agent (A2A) system designed to interact with GitHub.

It acts as a Supervisor Agent, delegating tasks to a suite of specialized Child Agents, each focused on a specific domain of the GitHub API (e.g., Issues, Pull Requests, Repositories, Actions). This architecture allows for precise and efficient handling of complex GitHub operations.

This repository is actively maintained - Contributions are welcome!

Capabilities:

  • Supervisor-Worker Architecture: Orchestrates specialized agents for optimal task execution.
  • Comprehensive GitHub Coverage: specialized agents for Issues, PRs, Repos, Actions, Organizations, and more.
  • MCP Support: Fully compatible with the Model Context Protocol.
  • A2A Integration: Ready for Agent-to-Agent communication.
  • Flexible Deployment: Run via Docker, Docker Compose, or locally.

Architecture

System components

---
config:
  layout: dagre
---
flowchart TB
 subgraph subGraph0["Agent Capabilities"]
        Supervisor["Supervisor Agent"]
        Server["A2A Server - Uvicorn/FastAPI"]
        ChildAgents["Child Agents (Specialists)"]
        MCP["GitHub MCP Tools"]
  end
    Supervisor --> ChildAgents
    ChildAgents --> MCP
    User["User Query"] --> Server
    Server --> Supervisor
    MCP --> GitHubAPI["GitHub API"]

     Supervisor:::agent
     ChildAgents:::agent
     Server:::server
     User:::server
    classDef server fill:#f9f,stroke:#333
    classDef agent fill:#bbf,stroke:#333,stroke-width:2px
    style Server stroke:#000000,fill:#FFD600
    style MCP stroke:#000000,fill:#BBDEFB
    style GitHubAPI fill:#E6E6FA
    style User fill:#C8E6C9
    style subGraph0 fill:#FFF9C4

Component Interaction

sequenceDiagram
    participant User
    participant Server as A2A Server
    participant Supervisor as Supervisor Agent
    participant Child as Child Agent (e.g. Issues)
    participant MCP as GitHub MCP Tools
    participant GitHub as GitHub API

    User->>Server: "Create an issue in repo X"
    Server->>Supervisor: Invoke Supervisor
    Supervisor->>Supervisor: Analyze Request & Select Specialist
    Supervisor->>Child: Delegate to Issues Agent
    Child->>MCP: Call create_issue Tool
    MCP->>GitHub: POST /repos/user/repo/issues
    GitHub-->>MCP: Issue Created JSON
    MCP-->>Child: Tool Response
    Child-->>Supervisor: Task Complete
    Supervisor-->>Server: Final Response
    Server-->>User: "Issue #123 created successfully"

Specialized Agents

The Supervisor delegates tasks to these specialized agents:

Agent Name Description
GitHub_Context_Agent Provides context about the current user and GitHub status.
GitHub_Actions_Agent Manages GitHub Actions workflows and runs.
GitHub_Code_Security_Agent Handles code security scanning and alerts.
GitHub_Dependabot_Agent Manages Dependabot alerts and configurations.
GitHub_Discussions_Agent Manages repository discussions.
GitHub_Gists_Agent Manages GitHub Gists.
GitHub_Git_Agent Performs low-level Git operations (refs, trees, blobs).
GitHub_Issues_Agent Manages Issues (create, list, update, comment).
GitHub_Labels_Agent Manages repository labels.
GitHub_Notifications_Agent Checks and manages notifications.
GitHub_Organizations_Agent Manages Organization memberships and settings.
GitHub_Projects_Agent Manages GitHub Projects (V2).
GitHub_Pull_Requests_Agent Manages Pull Requests (create, review, merge).
GitHub_Repos_Agent Manages Repositories (create, list, delete, settings).
GitHub_Secret_Protection_Agent Manages secret scanning protection.
GitHub_Security_Advisories_Agent Accesses security advisories.
GitHub_Stargazers_Agent Views repository stargazers.
GitHub_Users_Agent Accesses public user information.
GitHub_Copilot_Agent Assists with coding tasks via Copilot.
GitHub_Support_Docs_Agent Searches GitHub Support documentation.

Usage

Prerequisites

  • Python 3.10+
  • A valid GitHub Personal Access Token (PAT) with appropriate permissions.

Installation

pip install github-agent

Or using UV:

uv pip install github-agent

CLI

The github-agent command starts the server.

Argument Description Default
--host Host to bind the server to 0.0.0.0
--port Port to bind the server to 9000
--mcp-config Path to MCP configuration file mcp_config.json
--provider LLM Provider (openai, anthropic, google, etc.) openai
--model-id LLM Model ID nvidia/nemotron-3-super

Running the Agent Server

github-agent --provider openai --model-id gpt-4o --api-key sk-...

Docker

Build

docker build -t github-agent .

Run using Docker

docker run -d \
  -p 9000:9000 \
  -e LLM_API_KEY=sk-... \
  -e MCP_CONFIG=/app/mcp_config.json \
  knucklessg1/github-agent:latest

Run using Docker Compose

Create a docker-compose.yml:

services:
  github-agent:
    image: knucklessg1/github-agent:latest
    ports:
      - "9000:9000"
    environment:
      - PROVIDER=openai
      - MODEL_ID=gpt-4o
      - LLM_API_KEY=${LLM_API_KEY}
    volumes:
      - ./mcp_config.json:/app/mcp_config.json

Then run:

docker-compose up -d

Repository Owners

GitHub followers GitHub User's stars

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

github_agent-0.3.0.tar.gz (19.2 kB view details)

Uploaded Source

Built Distribution

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

github_agent-0.3.0-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file github_agent-0.3.0.tar.gz.

File metadata

  • Download URL: github_agent-0.3.0.tar.gz
  • Upload date:
  • Size: 19.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for github_agent-0.3.0.tar.gz
Algorithm Hash digest
SHA256 af5f683b09bc278aa307d67fde5e79429af318486b7eb2663756eb0c199b351f
MD5 e2e5c72c382283ff8dd33a10c65fafd8
BLAKE2b-256 00366b060ebfcc7cbf585db7dccb38c0ad8114bf3067d7fdc87f5ee1d21ec025

See more details on using hashes here.

File details

Details for the file github_agent-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: github_agent-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 20.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for github_agent-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 352cd0321c16fdc2112f6add909f219140b9c2d8b459836b7233a62906e7be97
MD5 1777c99851e35235e1be0a780607e798
BLAKE2b-256 88ad7eec422815ad51533333e76297c64c0581d0d2b5de440e140494648728f8

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