Subconductor
A persistent state machine and notification system for AI agents to manage complex, multi-step workflows via the Model Context Protocol, preventing context drift by maintaining structured checklists and sending desktop alerts.
README
Subconductor
A persistent state machine and notification system for AI agents to manage complex, multi-step workflows via the Model Context Protocol (MCP).
Subconductor prevents "context drift" by maintaining a single source of truth for project progress across multiple independent checklists. It stores these in a structured .subconductor/checklists/ directory along with a global .subconductor/checklists.md index file. It keeps the user informed through a robust notification system that triggers during long-running tasks or checklist completion. This allows agents to "remember" their exact state, completed milestones, and remaining blockers across multiple sessions and parallel workflows.
Quick Start
Add Subconductor to your MCP-compatible host (e.g., Claude Desktop or Gemini) using npx:
"subconductor": {
"command": "npx",
"args": ["-y", "@psno/subconductor"]
}
Configuration Flags
You can customize the server behavior using the following flags:
--disable-batch(or-b): Disable batch operation tools (get_pending_tasks,mark_tasks_done,unmark_tasks,add_tasks,remove_tasks).--disable-alerts(or-a): Disable all desktop notifications and thealerttool.
Tools Included
init_checklist
Initialize a new task checklist. This automatically creates a dedicated folder and registers the checklist in the central index.
- Arguments:
tasks(array): List of tasks to perform. Can be strings or objects withnameand an optionalnote.goal(string): The high-level objective of the workflow.columns(string[], optional): Custom columns for the task table.Status,ID, andNameare always included.
- Effect: Creates a nested
.subconductor/checklists/<goal-slug>/checklist.mdfile and updates the active pointer in.subconductor/checklists.md.
activate_checklist
Switch the active context to a different, previously initialized checklist.
- Arguments:
checklistName(string): The numeric ID from the index, or a partial string match of the checklist's goal name.
- Effect: Updates
.subconductor/checklists.mdto mark the targeted checklist asActiveand all others asIdle.
archive_checklist
Moves a checklist to the archive directory to keep the active index clean.
- Arguments:
checklistIdentifier(string): The numeric ID from the index, or a partial string match of the checklist's goal name.
- Effect: Moves the checklist folder to
.subconductor/archive/checklists/and updates its status toArchivedin the index table.
get_pending_task
Retrieves the next uncompleted task from the active checklist.
- Effect: Returns the first task with an ID prefix (e.g.,
(#1) Task Name). ReturnsDONEif all tasks are completed.
get_pending_tasks
Retrieves a batch of uncompleted tasks from the active checklist (requires batch tools enabled).
- Arguments:
count(number): The number of pending tasks to retrieve (default: 5).
- Effect: Returns a list of tasks with ID prefixes or
DONE.
add_task
Appends a new task to the active checklist dynamically.
- Arguments:
name(string): The name of the task.note(string, optional): An optional note.
- Effect: Appends the task, automatically assigns a monotonic immutable ID, and updates the completion header.
add_tasks
Appends multiple new tasks to the active checklist dynamically.
- Arguments:
tasks(array): List of tasks to add (objects withnameand optionalnote).
- Effect: Appends all tasks sequentially, automatically assigning immutable IDs.
remove_task
Deletes a task from the active checklist.
- Arguments:
task(string): The task ID (e.g., "1") or the full task name.
- Effect: Removes the task row and updates the completion header. Note: Existing task IDs remain immutable and are not shifted.
remove_tasks
Deletes multiple tasks from the active checklist in a single batch operation.
- Arguments:
tasks(array): List of task IDs or names to remove.
- Effect: Removes all specified task rows safely.
mark_task_done
Updates a specific task's status to completed in the active checklist.
- Arguments:
task(string): The task ID (e.g., "1") or the full task name.note(string, optional): An additional note or status message.
- Effect: Updates the status to
Doneand records the note in theNotescolumn. Automatically triggers a notification upon completion of the final task in the active checklist.
mark_tasks_done
Updates multiple tasks' statuses to completed in the active checklist.
- Arguments:
tasks(array): List of objects containingname(ID or task name) and an optionalnote.
- Effect: Marks all specified tasks as
Doneand evaluates overall checklist completion.
unmark_task
Reverts a completed task back to pending status.
- Arguments:
task(string): The task ID (e.g., "1") or the full task name.
- Effect: Reverts status to
Pending(Idle), clears associated notes, and rolls back the completion goal header.
unmark_tasks
Reverts multiple completed tasks back to pending status in a single batch operation.
- Arguments:
tasks(array): List of task IDs or names to unmark.
- Effect: Reverts all specified tasks to
Pending(Idle).
alert
Sends a system-level notification with sound and icon support.
- Arguments:
title(string): The title of the notification.message(string): The message body.status('info' | 'warn' | 'error'): The severity level (default: 'info').
- Effect: Triggers a desktop notification with status-specific icons and sounds.
Resources
Changelog - Check out the latest changes.
License & Attribution
This project is licensed under the Apache License 2.0.
Important Attribution Requirement: In accordance with Section 4(d) of the Apache License, if you modify this software or build new features based on this codebase, you must retain the attribution to Paul Benchea as the original author. Please refer to the NOTICE file for specific details.
Built with the Model Context Protocol.
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.