Soul-driven AI agent with permission-hardened tools, token budgets, and multi-channel access. Runs 24/7 from CLI or Telegram.
Soul-driven AI agent with permission-hardened tools, token budgets, and multi-channel access.
Runs 24/7 from CLI or Telegram. 21 built-in tools. Extensible skills. Asks before it acts.
npx @cosmicstack/mercury-agent
Or install globally:
npm i -g @cosmicstack/mercury-agent
mercury
First run triggers the setup wizard — enter your name, an API key, and optionally a Telegram bot token. Takes 30 seconds.
To reconfigure later (change keys, name, settings):
mercury doctor
Every AI agent can read files, run commands, and fetch URLs. Most do it silently. Mercury asks first.undefined
sudo, rm -rf /, etc. never execute). Folder-level read/write scoping. Pending approval flow. Skill elevation with granular allowed-tools. No surprises.soul.md, persona.md, taste.md, heartbeat.md). No corporate wrapper./budget command to check, reset, or override.undefinedOne command to make Mercury persistent:undefined
mercury up
This installs the system service (if not installed), starts the background daemon, and ensures Mercury is running. Use this as your go-to command.
If Mercury is already running, mercury up just confirms it and shows the PID.
mercury restart # Restart the background process
mercury stop # Stop the background process
mercury start -d # Start in background (without service install)
mercury logs # View recent daemon logs
mercury status # Show if daemon is running
Daemon mode includes built-in crash recovery — if the process crashes, it restarts automatically with exponential backoff (up to 10 restarts per minute).
mercury up installs this automatically. You can also manage it directly:
mercury service install
| Platform | Method | Requires Admin |
|---|---|---|
| undefinedmacOSundefined | LaunchAgent (~/Library/LaunchAgents/) |
No |
| undefinedLinuxundefined | systemd user unit (~/.config/systemd/user/) |
No (linger for boot) |
| undefinedWindowsundefined | Task Scheduler (schtasks) |
No |
mercury service status # Check if service is running
mercury service uninstall # Remove the system service
In daemon mode, Telegram becomes your primary channel — CLI is log-only since there’s no terminal for input.
| Command | Description |
|---|---|
mercury up |
undefinedRecommended. Install service + start daemon + ensure running |
mercury |
Start the agent (same as mercury start) |
mercury start |
Start in foreground |
mercury start -d |
Start in background (daemon mode) |
mercury restart |
Restart the background process |
mercury stop |
Stop a background process |
mercury logs |
View recent daemon logs |
mercury doctor |
Reconfigure (Enter to keep current values) |
mercury setup |
Re-run the setup wizard |
mercury status |
Show config and daemon status |
mercury help |
Show full manual |
mercury service install |
Install as system service (auto-start on boot) |
mercury service uninstall |
Uninstall system service |
mercury service status |
Show system service status |
mercury --verbose |
Start with debug logging |
Type these during a conversation — they don’t consume API tokens. Work on both CLI and Telegram.
| Command | Description |
|---|---|
/help |
Show the full manual |
/status |
Show agent config, budget, and usage |
/tools |
List all loaded tools |
/skills |
List installed skills |
/stream |
Toggle Telegram text streaming |
/stream off |
Disable streaming (single message) |
/budget |
Show token budget status |
/budget override |
Override budget for one request |
/budget reset |
Reset usage to zero |
/budget set <n> |
Change daily token budget |
| Category | Tools |
|---|---|
| undefinedFilesystemundefined | read_file, write_file, create_file, edit_file, list_dir, delete_file, send_file |
| undefinedShellundefined | run_command, approve_command |
| undefinedGitundefined | git_status, git_diff, git_log, git_add, git_commit, git_push |
| undefinedWebundefined | fetch_url |
| undefinedSkillsundefined | install_skill, list_skills, use_skill |
| undefinedSchedulerundefined | schedule_task, list_scheduled_tasks, cancel_scheduled_task |
| undefinedSystemundefined | budget_status |
| Channel | Features |
|---|---|
| undefinedCLIundefined | Readline prompt, real-time text streaming, markdown rendering, file display |
| undefinedTelegramundefined | HTML formatting, file uploads (photos, audio, video, documents), typing indicators, /budget commands |
schedule_task with cron expressions (0 9 * * * for daily at 9am)schedule_task with delay_seconds (e.g. 15 seconds)~/.mercury/schedules.yaml and restore on restartAll runtime data lives in ~/.mercury/ — not in your project directory.
| Path | Purpose |
|---|---|
~/.mercury/mercury.yaml |
Main config (providers, channels, budget) |
~/.mercury/soul/*.md |
Agent personality (soul, persona, taste, heartbeat) |
~/.mercury/permissions.yaml |
Capabilities and approval rules |
~/.mercury/skills/ |
Installed skills |
~/.mercury/schedules.yaml |
Scheduled tasks |
~/.mercury/token-usage.json |
Daily token usage tracking |
~/.mercury/memory/ |
Short-term, long-term, episodic memory |
~/.mercury/daemon.pid |
Background process PID |
~/.mercury/daemon.log |
Daemon mode logs |
Configure multiple LLM providers. Mercury tries them in order and falls back automatically:
generateText + streamText, 10-step agentic loop, provider fallback~/.mercury/MIT © Cosmic Stack
undefinedThis is AI - it can break sometimes, please use this at your own risk.undefined
For suggestions, contributions, or any inquiries, please reach out to us at support@cosmicstack.org.