Skip to main content

MagAgent โ€” CLI AI coding agent with persistent MagGraph memory. Like the Magpie: intelligent, tool-using, and never forgets.

Project description

๐Ÿฆโ€โฌ› MagAgent

A terminal-native AI coding agent with persistent memory, built for developers who want an assistant that genuinely learns them.

PyPI version Python License: Apache 2.0 Tests

Quick Start ยท Providers ยท Tools ยท Skills ยท Memory ยท Gateway ยท Docs


Why "Mag"?

Mag is short for Magpie โ€” a member of the Corvidae (Corvid) family.

Corvids โ€” crows, ravens, magpies, jays โ€” are among the most cognitively sophisticated animals on Earth. They are renowned for three traits that define what MagAgent aspires to be:

  • ๐Ÿง  Memory โ€” Corvids remember individual human faces for years and recall the locations of thousands of cached food items. MagAgent remembers your projects, preferences, patterns, and workflows across every session.
  • ๐Ÿ”ง Tool Use โ€” Corvids are some of the only non-primate animals that manufacture and use tools. MagAgent wields a rich toolkit: web search, file operations, databases, document generation, HTTP clients, code execution, and more.
  • ๐Ÿ’ก Intelligence โ€” Corvids pass mirror self-recognition tests and demonstrate future planning. MagAgent plans multi-step tasks, spawns sub-agents for parallel work, and self-improves its knowledge graph over time.

The name also nods to MagGraph โ€” the Rust-powered graph database that backs MagAgent's memory system, storing knowledge as plain Markdown files in Git.


What is MagAgent?

MagAgent is a CLI-first AI coding agent that:

  • Runs entirely in your terminal โ€” no IDE plugin, no web UI required
  • Maintains a persistent memory graph per user that grows smarter over time
  • Connects to 11+ AI providers (local and cloud) via a single config
  • Has 31 built-in tools out of the box โ€” no plugins or configuration required
  • Includes 10 pre-built skill libraries for docs, spreadsheets, PDFs, images, video, data analysis, REST APIs, databases, desktop automation, and Git
  • Uses token-efficient context management: conversation compaction, repo-map slices, memory/skill budgets, and compressed tool results
  • Supports a remote gateway so you can send it tasks from Slack, Discord, or Telegram while you're away from your terminal

Every session, MagAgent extracts facts, preferences, and patterns from your conversation and writes them into a MagGraph knowledge graph. Next session, it reads that graph to understand your tech stack, coding style, project context, and recurring patterns โ€” without you having to repeat yourself.


Quick Start

Install

pip install mag-agent

# With gateway support (Slack/Discord/Telegram):
pip install "mag-agent[gateway]"

# Recommended: isolate with pipx
pipx install mag-agent

First-time setup

magent setup

The wizard will:

  1. Create a named user profile with an isolated memory graph
  2. Walk you through selecting an AI provider and model
  3. Test the connection live

Start a session

magent

Quick one-shot task

magent "Refactor the auth module to use JWTs and add tests"

Providers

MagAgent uses LiteLLM under the hood, supporting any OpenAI-compatible endpoint.

Provider Config ID Notes
Ollama ollama Local inference, free, default
Nous Portal nous-portal Hermes 4, 200+ curated models
OpenCode Zen opencode-zen Coding-optimized models
OpenCode Go opencode-go Fast, cost-efficient coding models
OpenAI openai GPT-4o, GPT-4.1, o3
Anthropic anthropic Claude 3.5 Sonnet / Claude 4
Google google Gemini 2.0 / 2.5 Pro
Groq groq Ultra-fast inference
OpenRouter openrouter 200+ model aggregator
LM Studio lmstudio Local GUI-managed models
AWS Bedrock bedrock Enterprise / VPC
Custom custom Any OpenAI-compatible endpoint

Configure multiple providers and switch mid-session: /model anthropic/claude-3-5-sonnet


Tools

MagAgent ships with 31 built-in tools the agent can call without any setup.

File & Code Tools

Tool Description Permission
read_file Read file preview, with truncation for large files Silent in project, confirm outside
read_file_range Read exact line ranges from a file Silent in project, confirm outside
outline_file Compact source outline with symbols and line numbers Silent in project, confirm outside
write_file Write/create a file Auto in project dir
edit_file Replace exact string in file Auto in project dir
delete_file Delete file or directory Confirm
list_dir List directory contents Silent in project, confirm outside
diff_files Unified diff between two files Silent in project, confirm outside
compress Zip or tar.gz a file/directory Auto
extract Unzip/untar an archive Auto
run_shell Execute a shell command Tiered by command risk
run_python Run Python code in isolated subprocess Confirm
install_package pip install with user permission Confirm
search_codebase Ripgrep pattern search Silent
git_op Any git subcommand Tiered

Web & Network Tools

Tool Description Permission
web_search DuckDuckGo search (real results, no API key) Auto
web_fetch Fetch URL, clean article extraction via trafilatura Auto
http_request Full HTTP client: GET/POST/PUT/PATCH/DELETE Auto

Data Tools

Tool Description Permission
json_query JMESPath query over JSON file or string Silent
db_query SELECT from a named SQLite database Silent
db_execute INSERT/UPDATE/DELETE/CREATE TABLE Auto
db_list_tables List tables + row counts Silent
db_schema Show column definitions for a table Silent
db_list_databases List all user databases Silent

System & Desktop Tools

Tool Description Permission
system_info CPU, RAM, disk, OS, Python version Silent
notify Desktop notification (plyer / notify-send) Silent
clipboard_read Read system clipboard Silent
clipboard_write Write to clipboard Auto
open_file Open file in default application (xdg-open) Auto
read_image Image metadata + base64 for vision models Silent in project, confirm outside

Permission Modes

MagAgent uses a 4-tier risk system to auto-approve safe operations and only ask when it matters.

Mode Behaviour
balanced (default) Project reads run; outside-project reads confirm; low-risk writes auto-run; medium needs Enter; high needs typed "yes"
silent Only destructive or high-risk ops prompt
paranoid Everything except file reads requires confirmation
yolo Fully autonomous โ€” no prompts
magent mode balanced   # Set globally
/mode paranoid         # Change in-session

Pre-approve patterns in your config (e.g. trust all git and pytest commands):

[permissions]
allowed_shell_patterns = ["git *", "npm *", "pytest *", "cargo *"]

Memory Graph

MagAgent's memory is powered by MagGraph โ€” a Rust-backed in-process graph database that stores nodes as plain Markdown files in a Git repository.

~/.config/magent/users/<username>/memory/
โ”œโ”€โ”€ preference_uses_typescript.md
โ”œโ”€โ”€ project_ecommerce_backend.md
โ”œโ”€โ”€ pattern_prefers_async_await.md
โ””โ”€โ”€ ...

Node types:

Type What it stores
preference Coding style, tool choices, formatting preferences
project Projects you work on, their tech stack and structure
pattern Recurring problems and solutions MagAgent has learned
skill_learned Techniques and APIs you've used together
fact Domain knowledge extracted from conversations
session_summary High-level summaries of past sessions
error_pattern Bugs and their resolutions
bookmark URLs and references the agent saved for you

Memory is extracted and written every N turns (configurable, default 5) and always at session end.

magent memory stats                     # Node/edge counts, disk usage
magent memory search "JWT"              # Keyword/full-text search
magent memory show project_myapp        # View a node
magent memory traverse project_myapp    # BFS from a node
magent memory ui                        # Open MagGraph dashboard
magent memory sync status               # Run MagGraph sync status
magent memory export --out backup.json  # Export all nodes as JSON
magent memory reset                     # Wipe all memory (with confirmation)

Token-Efficient Context

MagAgent keeps context lean while preserving useful state:

  • Conversation compaction summarizes older turns and keeps recent turns verbatim.
  • Repository map slices inject relevant file/symbol maps instead of whole files.
  • Memory recall budgets inject compact matches first, then a few excerpts.
  • Skill budgets truncate long skill guidance before it crowds out the task.
  • Tool result compression trims large outputs and points the agent to targeted follow-ups.
  • Large file reads return previews; use outline_file and read_file_range for exact context.

SQLite Local Databases

The agent can create and manage structured local databases โ€” per user, per project, or user-specified.

~/.config/magent/users/<username>/databases/
โ”œโ”€โ”€ default.db       # General-purpose
โ”œโ”€โ”€ myproject.db     # Project-specific
โ””โ”€โ”€ analytics.db     # Purpose-specific

Inside a session, the agent automatically uses these tools to store structured data โ€” task lists, research caches, API test logs, contacts โ€” without any setup required.

/db    # In-session: list your databases

Skills

Skills are Markdown files that teach the agent how to perform specific tasks โ€” code patterns, library usage, common pitfalls, and decision guides. They are injected into context automatically when relevant.

Locations

  • Global: ~/.config/magent/skills/<skill-name>/SKILL.md
  • Project-local: .magent/skills/<skill-name>/SKILL.md

Built-in Skills Library

MagAgent ships with 10 pre-built skills in docs/skills/:

Skill Triggers On Guide
Create Word Docs docx, word document, report python-docx + docxtpl
Create Spreadsheets excel, xlsx, spreadsheet openpyxl with charts/formulas
Create PDFs pdf, html to pdf fpdf2 + WeasyPrint + pypdf
Create Images image, chart, plot, PNG Pillow + matplotlib
Create Video/Audio video, audio, mp4, Remotion Remotion (React) + moviepy + ffmpeg
Data Analysis pandas, csv, dataframe pandas + SQLite integration
REST API Testing api, http, endpoint, curl http_request patterns + auth
SQLite Database sql, database, sqlite Named DBs, common schemas
Desktop Automation notify, clipboard, open file notify + clipboard + system info
Git Workflow git, branch, commit, merge, rebase Git best practices & conflict resolution

Writing Your Own Skill

---
name: my-skill
description: Brief description โ€” used for matching
version: "1.0"
trigger_keywords:
  - keyword1
  - keyword2
tools_required:
  - run_shell
  - write_file
---

# Skill Title

Guidance for the agent here โ€” code patterns, library usage, pitfalls...

Sub-Agents

Spawn a parallel agent to work on a focused sub-task while you continue the main conversation:

/spawn Write unit tests for all functions in src/auth.py

The sub-agent runs an isolated session sharing your memory graph, completes the task, and returns a summary. Use this for long-running tasks that shouldn't interrupt the main flow.


Remote Gateway

Send tasks to MagAgent from Slack, Discord, or Telegram while you're away from your terminal.

# Install gateway dependencies
pip install "mag-agent[gateway]"

# Generate config template
magent gateway init

# Start (background daemon)
magent gateway start

# Platform-specific
magent gateway start slack
magent gateway start discord telegram

# Monitoring
magent gateway status
magent gateway logs --follow
magent gateway stop

How it works

When you message the bot:

  1. It immediately replies "โณ Working on it..."
  2. Runs your task through the full agent (tools, memory, etc.)
  3. Edits that message with the result when done
  4. Sessions are persistent per channel โ€” it remembers conversation context

Security

  • Allowlist โ€” only users in allowed_user_ids can send instructions
  • Channel restriction โ€” optionally limit to specific channels
  • Rate limiting โ€” configurable per-user request limit (default 10/min)
  • Task timeout โ€” configurable max execution time (default 5 min)

Setup Guides

Platform Guide Notes
Slack setup-slack.md Socket Mode โ€” no public URL needed
Discord setup-discord.md Bot token โ€” free, 2-minute setup
Telegram setup-telegram.md @BotFather โ€” simplest of the three

All Commands

User Management

magent user create <name>   # Create a user profile
magent user switch <name>   # Switch active user
magent user list            # List all users
magent user delete <name>   # Delete user + memory (with confirmation)
magent user current         # Show active user

Memory

magent memory stats                      # Node/edge counts, disk usage
magent memory search "<query>"           # Search memory graph
magent memory show <node-id>             # View a memory node
magent memory traverse <node-id>         # BFS traversal from a node
magent memory delete <node-id>           # Delete a node
magent memory export --out backup.json   # Export all nodes as JSON
magent memory reset                      # Wipe all memory (prompts "yes")
magent memory log                        # View recent session logs
magent memory ui                         # Open embedded MagGraph UI
magent memory sync status                # Git sync status via MagGraph
magent memory sync pull                  # Pull memory graph updates
magent memory sync push -m "message"     # Commit/push memory graph updates

Gateway

magent gateway init              # Print example config
magent gateway start             # Start all configured platforms (daemon)
magent gateway start slack -f    # Single platform, foreground mode
magent gateway stop              # Stop daemon (SIGTERM)
magent gateway status            # Is daemon running? PID?
magent gateway logs [-n N] [-f]  # View / follow gateway log

Other

magent setup           # First-run setup wizard
magent mode <mode>     # Set permission mode globally
magent doctor          # Health check: providers, memory, deps
magent --version       # Show version

In-Session Slash Commands

Command Description
/help All slash commands
/memory Memory graph stats
/skills Loaded skills list
/model Current model / change model
/user Active user
/mode <mode> Change permission mode
/spawn <task> Spawn a sub-agent
/db List your SQLite databases
/clear Clear conversation history
/exit End session

Configuration

Full config at ~/.config/magent/config.toml:

[defaults]
provider = "ollama"
model = "qwen2.5-coder:32b"
permission_mode = "balanced"
context_window_tokens = 32000
memory_budget_tokens = 4000
repo_map_budget_tokens = 1200
skill_budget_tokens = 2000

[memory]
write_every_n_turns = 5
extraction_provider = "ollama"
extraction_model = "qwen2.5:7b"
encrypt = false
recall_body_tokens = 220

[context]
compact_every_n_turns = 10
keep_recent_turns = 6
max_history_tokens = 6000

[permissions]
mode = "balanced"
allowed_shell_patterns = ["git *", "npm *", "pytest *"]

[providers.ollama]
base_url = "http://localhost:11434"
default_model = "qwen2.5-coder:32b"

[providers.nous-portal]
base_url = "https://inference-api.nousresearch.com/v1"
api_key_env = "NOUS_API_KEY"
default_model = "nous-hermes-4"

[providers.opencode-go]
base_url = "https://opencode.ai/go/v1"
api_key_env = "OPENCODE_GO_API_KEY"
default_model = "deepseek-v4-flash"

[gateway]
username = "alex"
allowed_user_ids = ["YOUR_SLACK_USER_ID"]
rate_limit_per_minute = 10
max_task_duration_seconds = 300

[gateway.slack]
bot_token = "xoxb-..."
app_token = "xapp-..."

[gateway.discord]
bot_token = "..."

[gateway.telegram]
bot_token = "..."

Documentation

Document Description
docs/skills/create-word-docs/SKILL.md Word document generation (python-docx, docxtpl)
docs/skills/create-spreadsheets/SKILL.md Excel spreadsheet generation (openpyxl)
docs/skills/create-pdfs/SKILL.md PDF generation (fpdf2, WeasyPrint, pypdf)
docs/skills/create-images/SKILL.md Image manipulation (Pillow, matplotlib)
docs/skills/create-video-audio/SKILL.md Video/audio (Remotion, moviepy, ffmpeg)
docs/skills/data-analysis/SKILL.md Data analysis (pandas, SQLite)
docs/skills/rest-api/SKILL.md REST API testing and integration
docs/skills/sqlite-database/SKILL.md SQLite database patterns
docs/skills/desktop-automation/SKILL.md Desktop notifications, clipboard, system info
docs/skills/git-workflow/SKILL.md Git workflows & conflict resolution
docs/gateway/setup-slack.md Slack gateway setup (Socket Mode)
docs/gateway/setup-discord.md Discord gateway setup
docs/gateway/setup-telegram.md Telegram gateway setup

Development

git clone https://github.com/AlexMercedCoder/MagAgent.git
cd MagAgent
pip install -e ".[dev]"

# Run tests
pytest

# Run with coverage
pytest --cov=src/magent --cov-report=term-missing

# Lint
ruff check src/

# Type check
mypy src/magent

Project Structure

src/magent/
โ”œโ”€โ”€ agent.py          # AgentSession โ€” tool loop, streaming, sub-agents
โ”œโ”€โ”€ cli/main.py       # Typer CLI entry point
โ”œโ”€โ”€ config/           # TOML config, user profiles
โ”œโ”€โ”€ gateway/          # Remote gateway (Slack, Discord, Telegram)
โ”‚   โ””โ”€โ”€ adapters/     # Platform-specific adapters
โ”œโ”€โ”€ memory/           # MagGraph integration โ€” read, write, search
โ”œโ”€โ”€ permissions/      # Risk tiers, auto-approve logic
โ”œโ”€โ”€ providers/        # LiteLLM provider registry
โ”œโ”€โ”€ repo_map.py       # Token-efficient repository map cache
โ”œโ”€โ”€ skills/           # SKILL.md discovery, matching, lockfile
โ”œโ”€โ”€ subagents/        # Sub-agent runner
โ”œโ”€โ”€ tokens.py         # Lightweight token budgeting helpers
โ”œโ”€โ”€ tools/            # 31 built-in tools (file, web, db, system)
โ”‚   โ””โ”€โ”€ db.py         # SQLite named database tools
โ”œโ”€โ”€ logging.py        # JSONL session event logging
โ”œโ”€โ”€ setup.py          # First-run wizard
โ””โ”€โ”€ tui.py            # Rich terminal UI, streaming renderer
docs/
โ”œโ”€โ”€ gateway/          # Gateway setup guides
โ””โ”€โ”€ skills/           # Built-in skill SKILL.md files
tests/
โ””โ”€โ”€ unit/             # 78 unit tests (all mocked, no credentials needed)

License

Apache 2.0 โ€” see LICENSE


Built with ๐Ÿฆโ€โฌ› by Alex Merced ยท Powered by MagGraph

Like the Magpie โ€” intelligent, tool-using, and never forgets.

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

mag_agent-0.3.0.tar.gz (118.4 kB view details)

Uploaded Source

Built Distribution

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

mag_agent-0.3.0-py3-none-any.whl (84.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for mag_agent-0.3.0.tar.gz
Algorithm Hash digest
SHA256 9220fe271d89f8ffa67f515b22adae7b68b842f0cef18698648ae5972a65e307
MD5 547c76ead15ee4551f3a18ffc707a59f
BLAKE2b-256 52023e63c0040eab5b45b11279ac59726579dfcb940f86e18fe6b1f721aaa98e

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for mag_agent-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1f33df972dfb9debe260ea3bdc30b13650517948584212e7ce9901d1d85da1e4
MD5 95b4d958560988a5cc0627d3439da2bb
BLAKE2b-256 60c9540947a491b1e78b3298ae191ec3cd0ce93c038eb41e62aa9128802f451a

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