
Agentic Task System (ats)
β 5from renezander030
Turns your task manager into agent memory: hybrid (RRF) retrieval over TickTick or an Obsidian vault via an adapter contract. MCP server + CLI, no vector DB to maintain.
Your task manager is the best agent memory you're not using.
ats is an MCP server and CLI that gives your AI agent memory from the task system you already use β TickTick, Taskmaster, Beads, Obsidian, Notion, GitHub, Airtable, Google, or all at once via the composite adapter. It fuses retrieval across adapters with Reciprocal Rank Fusion (RRF) and layers on portable intent, typed task links, lifecycle validity, scoped access, an action ledger, and bounded task events. Works with Claude Code, Claude Desktop, Cursor, and any MCP client.
Adapter, not migration. Most "agent memory" projects build a new store that drifts the moment you stop feeding it. But you already curate a knowledge base by hand every day β your task app. ATS makes that context agent-native without re-homing a single note. It's task-first: the task is the spine; supporting docs (GitHub issues, Notion specs) fuse in as context behind it β not a second-brain/PKM tool.
npm install -g @reneza/ats-cli @reneza/ats-adapter-ticktick
ats config use ticktick
ats auth login
ats find "deployment runbook"
One ats find across GitHub + Notion + TickTick, ranked by RRF. Your connectors give the agent access; this is the semantic layer that lands the first query on the right answer.
How it compares
Approach Where memory lives Upkeep Retrieval
CLAUDE.md / memory files markdown you re-edit by hand manual, drifts none β whole file injected every session
Vector-DB memory (mem0-style) a new store only the agent sees rots unless you keep feeding it dense-only
Plain TickTick / Obsidian MCP your task app none keyword or the app's native search
ATS your task app none β you curate it daily hybrid retrieval + typed context, validity, provenance, audit
Andrej Karpathy's LLM Wiki idea is right about the destination, wrong about the starting line: almost nobody's knowledge lives in clean markdown β it lives in the task app they've used for years. ATS closes that gap with pluggable storage adapters.
What you get
-
A two-way bus. The agent reads a task's title, body, tags, dates, and checklist; it writes results back where you'll see them.
-
First-fetch relevance. Parallel hybrid retrieval (dense + sparse + keyword, RRF-fused, with provenance) collapses "search β refine β search again" into one fetch.
-
Durable typed links. One agent attaches a
decision/depends-on/output/supersedeslink; a later agent in a fresh context receives it viaats context. The handoff lives in the task app, not a chat log. -
Execution context.
ats intentcaptures outcome/why/done-when;ats lifecyclekeeps stale context from steering current work;ats securityscopes actions and audits allow/deny;ats ledgerrecords what an agent did and whether the task advanced;ats promoteturns exploration into a committed goal;ats hierarchy evaluatechecks local work still supports its parent. -
Bounded events.
ats events watch --jsonemits deterministictask.created/updated/completed/...NDJSON, spooled0600with pending/ack recovery and stable dedup IDs. ATS only emits observations β a consumer still evaluates intent, validity, and security before acting. -
Curated at write time. Every item is hung on a "trunk" (a theme like
writing,client-work) the moment it's captured, so retrieval has structure to grab.
Metadata lives in flat YAML frontmatter on the task body, typed links in ## Related, consulted sources in ## References. Writes are add-only β ATS never drops a row or link a human added. npm run prove:intent runs a deterministic synthetic proof of the full path.
Walkthrough: from a task pile to the next action
Three tags steer everything β do: (agent or you), type: (build/research/review), effort: (S/M/L):
-
Capture into the system you already use.
-
Tag each task
do:/type:/effort:. -
Link dependencies:
ats link add <task> <blocker> --type depends-on. -
Let
bd readypick the unblocked frontier β you never scan the backlog. -
Do it, then close. Closing recomputes the frontier; the next right thing surfaces on its own.
Available adapters
Every vendor ships an MCP connector now, so your agent can reach Notion, GitHub, and your task app β but not retrieve ("what do I know about the auth migration?", ranked across all of them). That's the layer ATS adds: hybrid RRF ranking, one query across every source (the composite adapter fuses them into one deduped list), top-k instead of token dumps, and the credential stays scoped inside the adapter.
Adapter Storage
ticktick TickTick OpenAPI v1 + qdrant + ollama
obsidian local markdown vault
okf Open Knowledge Format markdown bundle
taskmaster local .taskmaster/tasks/tasks.json
beads repository-local Beads via bd --json
airtable Airtable REST API (table = project)
google Google Sheets / Docs / Slides (read-only)
notion Notion databases + pages
github GitHub issues + discussions
composite many adapters fused as one corpus
things / apple-notes / google-tasks wishlist
Per-adapter auth and mapping live in each package's README. PRs welcome β scaffold and verify against the contract:
ats adapter new linear # writes ats-adapter-linear/ (six stubs)
ats adapter test ./ats-adapter-linear # pass/fail/skip per contract check
CLI surface
# Lifecycle
ats init|config use|auth login|doctor # setup, switch, auth, health check
# Retrieval (any read command takes --json for piping to jq / agents)
ats find [--explain] # parallel + RRF + provenance β DEFAULT
ats open|url # deep link / paste-ready cross-reference
ats get [--extract raw|json|yaml]
ats links # resolve deep-links in a task body
ats hybrid | ats similar # when embeddings exist
# Authoring
ats create " " [--content ..][--project ]
ats update [--content ..][--title ..]
# Agent execution context (portable across adapters)
ats intent set --outcome ".." --done-when "a,b"
ats promote --outcome ".." --done-when "a,b"
ats hierarchy set|evaluate
ats lifecycle set --status active --valid-until 2026-12-31
ats link add|remove --type decision
ats graph|context
ats ledger record --action release.verified --advanced true
ats security set|check
ats events snapshot|watch|pending|ack # NDJSON observations; never launches agents
# Ops
ats bench run|score|progress|analyze-usage
npm run prove:intent|prove:taskmaster|prove:beads|prove:progress
Use it from Claude Code, Claude Desktop, Cursor (MCP)
@reneza/ats-mcp exposes the active adapter as a tool set spanning retrieval, CRUD, and execution context (find, get_task, create_task, set_task_intent, add_task_link, context_for_task, record_action, poll_task_events, and more). For Claude Code this is persistent memory between sessions with no new database β the agent recalls runbooks, decisions, and project state from the task app you already keep current.
# Claude Code
claude mcp add ats -e ATS_ADAPTER=@reneza/ats-adapter-ticktick -- ats-mcp
// Claude Desktop / Cursor
{
"mcpServers": {
"ats": { "command": "ats-mcp", "env": { "ATS_ADAPTER": "@reneza/ats-adapter-ticktick" } }
}
}
Conventions
-
Wiki project. A designated project (default
Permanent Notes) holds durable knowledge; others hold ephemeral tasks. -
Agent-data notes = a note whose body has a fenced
json /yaml block, extracted viaats get <title> --extract json. -
Cross-references = adapter-native deep links β generate with
ats url <title>, don't hand-write. -
Full pattern:
docs/wiki-conventions.md.
State integrity
ATS holds the line where agent systems fail: writes round-trip without lossy re-encoding, the store β Task mapping is contract-tested, and every result carries its provenance (sources, find --explain). A publish-safety gate (check-no-pii.mjs) fails the build if personal data could leak into a package. Full note: docs/state-integrity.md.
Versioning & license
v0.6 β portable intent, exploration promotion, goal hierarchy + conflict evaluation, bounded task events, workflow-progress evaluation, Taskmaster and Beads adapters. See CHANGELOG.md. MIT.
If ATS is useful, consider a β β it helps others find it.
npm install -g @reneza/ats-cli @reneza/ats-adapter-ticktick
ats config use ticktick
ats auth login
ats find "deployment runbook"Before it works, you'll need: ATS_ADAPTER
Deploy it yourself
The operator deck (phone app) runs free on Cloudflare Pages; the backend runs on Render β one click builds the MCP server plus a private search memory (Qdrant) and embedding engine (Ollama).
After deploy, copy the auto-generated ATS_MCP_TOKEN from the ats-mcp service's Environment tab, point your MCP client at https://<your-mcp-url>/mcp with header Authorization: Bearer <ATS_MCP_TOKEN>, and set TICKTICK_ACCESS_TOKEN to read your real tasks. Prefer your own machine or a VPS? Same pieces as plain Docker containers β see the deploy guide.
No common issues documented yet. If you hit a problem, the repository's GitHub Issues page is the best place to look.