agentrem

agentrem

MCP server for managing structured reminders for AI agents, with persistent storage, full-text search, and cross-session support.

Category
Visit Server

README

๐Ÿ”” agentrem

npm version CI License: MIT Node.js MCP

Structured reminders for AI agents. Persistent, searchable, works across sessions.

Instant Start

npx agentrem add "Deploy to prod" --due tomorrow --priority 2
npx agentrem check
npx agentrem list

For AI Agents

Copy this into your CLAUDE.md / AGENTS.md (or run agentrem setup to generate it):

## Reminders
You have access to `agentrem` CLI for persistent reminders across sessions.

### On every session start, run:
agentrem check --type time,session --budget 800

### When the user says "remind me", "don't forget", "follow up", or "next time":
agentrem add "<content>" --due "<when>" --priority <1-5> --tags "<tags>"

### Key commands:
- `agentrem add` โ€” create a reminder
- `agentrem check` โ€” see what's triggered/due
- `agentrem check --watch` โ€” block until next reminder fires
- `agentrem list` โ€” list all active reminders
- `agentrem search <query>` โ€” full-text search
- `agentrem complete <id>` โ€” mark done
- `agentrem snooze <id> --for 2h` โ€” snooze
- `agentrem --help` โ€” full reference

MCP Server

For Claude Desktop and any MCP client โ€” add to ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "agentrem": {
      "command": "agentrem-mcp",
      "args": []
    }
  }
}

No global install? Use npx:

{
  "mcpServers": {
    "agentrem": {
      "command": "npx",
      "args": ["-y", "agentrem", "mcp"]
    }
  }
}

Run agentrem setup --mcp to print this config. MCP tools: add_reminder ยท check_reminders ยท list_reminders ยท search_reminders ยท complete_reminder ยท snooze_reminder ยท edit_reminder ยท delete_reminder ยท get_stats ยท get_history ยท undo_change ยท garbage_collect ยท export_reminders ยท import_reminders


All Commands

Command Key Flags Example
add <content> --due --priority --tags --trigger --recur --agent --context --category --depends-on --dry-run agentrem add "PR review" --due "+4h" --priority 2
check --type --text --budget --format --json --escalate --agent --dry-run agentrem check --type time,session --budget 800 --json
check --watch --timeout --json --type --agent agentrem check --watch --timeout 300 --json
list --status --priority --tag --due --limit --json --all --agent --category --trigger --format agentrem list --priority 1,2 --json
search <query> --status --limit --json agentrem search "deploy staging" --json
complete <id> --notes agentrem complete abc12345
snooze <id> --until --for agentrem snooze abc12345 --for 2h
edit <id> --content --due --priority --tags --add-tags --remove-tags --context --category --agent agentrem edit abc12345 --priority 1
delete [id] --permanent --status --older-than agentrem delete abc12345 --permanent
stats --json agentrem stats --json
history [id] --limit --json agentrem history --limit 20 --json
undo <history_id> โ€” agentrem undo 42
gc --older-than --dry-run agentrem gc --older-than 30
export --out --status agentrem export --out backup.json
import <file> --merge --replace --dry-run agentrem import backup.json --merge
watch --interval --once --verbose --on-fire --on-fire-preset --on-fire-timeout --install --uninstall --status --agent agentrem watch --on-fire-preset openclaw
setup --mcp agentrem setup / agentrem setup --mcp
doctor --json agentrem doctor
init --force agentrem init
quickstart โ€” agentrem quickstart
schema โ€” agentrem schema

--json is available on check, list, search, stats, history, doctor โ€” use it for structured output in your agent.

Trigger Types

Type Fires when... Key flags
time Due datetime is reached --due (notifies once by default; stays active until explicitly completed)
keyword Message text matches --keywords, --match any|all|regex
condition Shell command output matches --check, --expect
session Every session start check โ€”
heartbeat Every heartbeat check โ€”
manual Explicit check only โ€”

Priority Levels

Level Label Behavior
1 ๐Ÿ”ด Critical Always surfaced
2 ๐ŸŸก High Surfaced within 60% budget
3 ๐Ÿ”ต Normal Surfaced within 85% budget
4 โšช Low Counted but not surfaced
5 ๐Ÿ’ค Someday Skipped entirely

Natural Language Dates

--due, --until, and --decay all accept natural language:

--due "now"                   # Immediately
--due "today"                 # Today at 23:59
--due "tomorrow"              # Tomorrow at 09:00
--due "in 5 minutes"
--due "in 2 hours"
--due "in 3 days"
--due "in 1 week"
--due "+5m"                   # Short relative
--due "+2h"
--due "+3d"
--due "+1w"
--due "2026-04-01T09:00:00"   # ISO datetime
--due "2026-04-01"            # ISO date

check --watch: Blocking Mode

agentrem check --watch blocks until the next due reminder fires. Useful for scripting, pipelines, or pausing an agent until something needs attention.

# Wait indefinitely for next reminder
agentrem check --watch

# Exit 1 if nothing fires within 5 minutes
agentrem check --watch --timeout 300

# Get the full reminder as JSON when it fires
agentrem check --watch --json

# Filter by trigger type and agent
agentrem check --watch --type time,heartbeat --agent jarvis --timeout 60

Exit codes: 0 = reminder found (or SIGINT/SIGTERM), 1 = timeout elapsed with no reminder.

Note: --watch does not update fire counts. Use a regular agentrem check after to actually mark reminders as fired.

Poll-then-act pattern:

if agentrem check --watch --timeout 120 --json > /tmp/due.json; then
  echo "Reminder fired:"
  cat /tmp/due.json
  agentrem check   # mark as fired
fi

watch --on-fire: Hooks

โš ๏ธ Security: The --on-fire command runs with your user's permissions. Only use trusted commands. Reminder data is passed via environment variables (never shell-interpolated) to prevent injection.

Execute a shell command whenever a reminder fires:

agentrem watch --on-fire "curl -X POST https://hooks.example.com/reminder"

Reminder data is passed as environment variables (no shell injection โ€” data never interpolated into the command):

Variable Description
AGENTREM_ID Reminder ID
AGENTREM_CONTENT Reminder text
AGENTREM_PRIORITY Priority (1-5)
AGENTREM_TAGS Comma-separated tags
AGENTREM_CONTEXT Context string
AGENTREM_DUE Due datetime
AGENTREM_FIRE_COUNT Number of times fired
  • Fire-and-forget โ€” failures are logged to ~/.agentrem/logs/on-fire.log, never crash the watcher
  • Sequential โ€” multiple reminders process one at a time
  • Timeout: 5 seconds default, configurable with --on-fire-timeout <ms>

Built-in presets โ€” skip the shell command entirely:

agentrem watch --on-fire-preset openclaw   # auto-delivers to your OpenClaw agent

Or craft your own:

agentrem watch --on-fire 'curl -X POST https://hooks.example.com/reminder -d "text=$AGENTREM_CONTENT"'

Background Watcher

agentrem watch polls for due reminders and fires native OS notifications.

agentrem watch                           # Poll every 30s (foreground)
agentrem watch --interval 60             # Custom interval
agentrem watch --once                    # Single check and exit
agentrem watch --agent jarvis            # Watch for a specific agent
agentrem watch --verbose                 # Show poll log

# Install as OS service (auto-start on boot)
agentrem watch --install
agentrem watch --install --interval 60
agentrem watch --status
agentrem watch --uninstall

Service files: macOS โ†’ ~/Library/LaunchAgents/com.agentrem.watch.plist ยท Linux โ†’ ~/.config/systemd/user/agentrem-watch.service ยท Logs โ†’ ~/.agentrem/logs/watch.log


Native Notifications ๐Ÿ””

On macOS, agentrem ships a bundled Swift app (Agentrem.app) that runs as a singleton process โ€” notifications appear under "agentrem" with a bell icon.

Priority Sound
P1 ๐Ÿ”ด Critical Hero
P2 ๐ŸŸก High Ping
P3 ๐Ÿ”ต Normal Pop

Notification behavior:

  • Click body โ†’ notification re-appears (won't dismiss until you act on it)
  • Complete โœ… โ†’ marks reminder complete and dismisses (the only way to complete a fired reminder)
  • Multiple reminders โ†’ single process handles all via IPC
  • Fallback chain: Agentrem.app โ†’ terminal-notifier โ†’ osascript โ†’ console

To rebuild the Swift app: npm run build:notify


Programmatic API

Use agentrem directly from JavaScript/TypeScript โ€” no CLI subprocess needed.

npm install agentrem
import { add, check, list, complete, snooze, search, stats } from 'agentrem';
import type { Reminder } from 'agentrem';

// Add a reminder
const rem = await add('Review PR #42', { due: 'tomorrow', priority: 2, tags: 'pr,review' });

// Check for triggered reminders (session start pattern)
const { included, totalTriggered } = await check({ type: 'time,session', budget: 800 });
for (const r of included) {
  console.log(`[P${r.priority}] ${r.content}`);
}

// List active reminders
const reminders = await list({ limit: 20 });

// Complete a reminder
const done = await complete(rem.id, 'Reviewed and merged');

// Snooze a reminder
const snoozed = await snooze(rem.id, { for: '2h' });

// Full-text search
const results = await search('deploy staging');

// Get statistics
const s = await stats();
console.log(`${s.totalActive} active, ${s.overdue} overdue`);

All API functions are async and return full Reminder objects. The database is auto-initialized on first call (no manual init needed).

See llms-full.txt for complete type signatures and all options.


Why agentrem?

# vs flat files / memory.md
agentrem check --json   # structured output your agent can parse; memory.md can't do that
  • Persistent across sessions โ€” SQLite-backed, survives restarts, not just in-context notes
  • Priority-aware + token budgets โ€” check --budget 800 fits within any context window without overflow
  • Triggerable โ€” time, keyword, condition, session, heartbeat triggers; not just static lists
  • Blocking watch mode โ€” check --watch lets agents pause until something needs attention
  • Agent-native โ€” --json everywhere, --agent namespacing, MCP server for chat clients

Install

npm install -g agentrem

The database auto-initializes on first use. Run agentrem setup to get your CLAUDE.md snippet, or agentrem setup --mcp for Claude Desktop.

MIT License

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured