Labsco
renezander030 logo

Agentic Task System (ats)

β˜… 5

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

πŸ”₯πŸ”₯πŸ”₯βœ“ VerifiedFreeQuick setup

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.

Copy & paste β€” that's it
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 / supersedes link; a later agent in a fresh context receives it via ats context. The handoff lives in the task app, not a chat log.

  • Execution context. ats intent captures outcome/why/done-when; ats lifecycle keeps stale context from steering current work; ats security scopes actions and audits allow/deny; ats ledger records what an agent did and whether the task advanced; ats promote turns exploration into a committed goal; ats hierarchy evaluate checks local work still supports its parent.

  • Bounded events. ats events watch --json emits deterministic task.created/updated/completed/... NDJSON, spooled 0600 with 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 ready pick 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:

Copy & paste β€” that's it
ats adapter new linear # writes ats-adapter-linear/ (six stubs)
ats adapter test ./ats-adapter-linear # pass/fail/skip per contract check

CLI surface

Copy & paste β€” that's it
# 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.

Copy & paste β€” that's it
# Claude Code
claude mcp add ats -e ATS_ADAPTER=@reneza/ats-adapter-ticktick -- ats-mcp
Copy & paste β€” that's it
// 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 via ats 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.