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.2.19

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 qwen/qwen3-coder-next

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.2.19.tar.gz (1.1 MB 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.2.19-py3-none-any.whl (1.6 MB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for github_agent-0.2.19.tar.gz
Algorithm Hash digest
SHA256 514bcd057d0f4eac32f30401350e2f037cc6fcfe5df222a3d9505e7e7ad78ede
MD5 2038814712a4e72cef28ea2085b2969b
BLAKE2b-256 1a8637d47fe438cb0f0dc3825e372239b9a99b1767645b2ab24669804d7b44c4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: github_agent-0.2.19-py3-none-any.whl
  • Upload date:
  • Size: 1.6 MB
  • 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.2.19-py3-none-any.whl
Algorithm Hash digest
SHA256 50f9d4df15e850d9a74cb766bb33055842a18c6d4f448d695f65b4ccb20d351b
MD5 d05204a85411d38d74e9318a1b534b4e
BLAKE2b-256 723a18bc283ff19dd10e697613b0129a3791127d6d5bddf8c10926aeef824c04

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