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

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.2.54.tar.gz (21.7 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.2.54-py3-none-any.whl (24.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: github_agent-0.2.54.tar.gz
  • Upload date:
  • Size: 21.7 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.2.54.tar.gz
Algorithm Hash digest
SHA256 d57e440bb5c6e584e725ab3cc33b10f047b9494481905b4e52013a0bd52be019
MD5 f2015b8809ffcf5deb3fea32d1298134
BLAKE2b-256 dc19d1360fdba1faaedd4543baba5fcd62dced6a46988eb3591bec9f5e54a327

See more details on using hashes here.

File details

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

File metadata

  • Download URL: github_agent-0.2.54-py3-none-any.whl
  • Upload date:
  • Size: 24.8 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.2.54-py3-none-any.whl
Algorithm Hash digest
SHA256 48e431a4bc200469255ed410cbef4cfc816002be1e23f6eab8b1d3ee0896cf4d
MD5 eb3d7d9e73b2d1caf7157b60d8881ab5
BLAKE2b-256 2480cbf441f6316335cf88fac3312242f7fb0e87867394af30592e97fca8a845

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