Metadata-Version: 2.4
Name: task-crusader-mcp
Version: 0.1.3
Summary: Your AI coding assistant's quest companion - campaign and task management via MCP
Author-email: Task Crusade Contributors <contributors@task-crusade.dev>
Maintainer-email: Michael Crescenzo <michaelcrescenzo@gmail.com>
License-Expression: MIT
Project-URL: Homepage, https://github.com/mcrescenzo/task-crusader-mcp
Project-URL: Documentation, https://task-crusader-mcp.readthedocs.io
Project-URL: Repository, https://github.com/mcrescenzo/task-crusader-mcp
Project-URL: Issues, https://github.com/mcrescenzo/task-crusader-mcp/issues
Keywords: mcp,task-management,campaign,ai-assistant,claude,cursor,crusader
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: mcp<2.0.0,>=1.0.0
Requires-Dist: sqlalchemy<3.0.0,>=2.0.0
Requires-Dist: pydantic<2.12.0,>=2.6.0
Requires-Dist: pydantic-settings<3.0.0,>=2.0.0
Requires-Dist: alembic<2.0.0,>=1.13.0
Requires-Dist: anyio<5.0.0,>=4.0.0
Requires-Dist: PyYAML<7.0.0,>=6.0.0
Requires-Dist: textual>=0.50.0
Requires-Dist: typer>=0.16.0
Requires-Dist: rich>=14.0.0
Provides-Extra: tui
Provides-Extra: cli
Provides-Extra: all
Provides-Extra: dev
Requires-Dist: pytest>=7.0.0; extra == "dev"
Requires-Dist: pytest-cov>=4.0.0; extra == "dev"
Requires-Dist: pytest-asyncio>=0.21.0; extra == "dev"
Requires-Dist: pytest-mock>=3.10.0; extra == "dev"
Requires-Dist: mypy>=1.0.0; extra == "dev"
Requires-Dist: ruff>=0.1.0; extra == "dev"
Requires-Dist: black>=24.0.0; extra == "dev"
Requires-Dist: isort>=5.0.0; extra == "dev"
Requires-Dist: types-PyYAML>=6.0.0; extra == "dev"
Dynamic: license-file

# Task Crusader MCP

Your AI coding assistant's quest companion - campaign and task management via MCP.

## Overview

Task Crusader is a campaign and task management system designed for AI coding assistants. It provides a Model Context Protocol (MCP) server that enables AI agents like Claude, Cursor, and others to organize work into campaigns (projects) and tasks with:

- **Dependency tracking**: Tasks can depend on other tasks
- **Acceptance criteria**: Define completion requirements for each task
- **Testing strategy**: Document verification approaches for tasks
- **Research & notes**: Capture findings and implementation details
- **Progress monitoring**: Track campaign progress and find actionable tasks
- **Quality hints**: Context-aware guidance for campaign setup and execution
- **Sequential & parallel execution**: Support for both single-agent and multi-agent workflows

## Installation

```bash
pip install task-crusader-mcp
```

Task Crusader installs with all features by default:
- **MCP Server**: Core campaign/task management for AI assistants (63 tools)
- **CLI**: Command-line interface (`crusader` command)
- **TUI**: Terminal user interface (`crusader-tui` command)

Advanced users needing minimal installs can use `pip install --no-deps task-crusader-mcp` and manually specify dependencies.

## Quick Start

### 1. Configure Your AI Assistant

Add to your MCP client configuration (e.g., Claude Desktop `claude_desktop_config.json`):

```json
{
  "mcpServers": {
    "task-crusade": {
      "command": "crusader-mcp"
    }
  }
}
```

Or for Cursor (`.cursor/mcp.json`):

```json
{
  "mcpServers": {
    "task-crusade": {
      "command": "crusader-mcp"
    }
  }
}
```

### 2. Basic Workflow

1. **Create a campaign:**
   ```
   campaign_create(name="My Project")
   ```

2. **Add tasks:**
   ```
   task_create(title="Implement feature", campaign_id="...")
   ```

3. **Add acceptance criteria:**
   ```
   task_acceptance_criteria_add(task_id="...", content="Unit tests pass")
   ```

4. **Add testing strategy:**
   ```
   task_testing_strategy_add(task_id="...", content="Run pytest with coverage")
   ```

5. **Execute the task loop:**
   ```
   while campaign not complete:
       1. campaign_get_next_actionable_task(campaign_id) -> get next task
       2. task_update(task_id, status="in-progress") -> claim task
       3. [Implement the task]
       4. task_acceptance_criteria_mark_met(criteria_id) -> mark criteria met
       5. task_complete(task_id) -> complete task
   ```

### 3. Bulk Campaign Creation (Recommended)

For new projects, use `campaign_create_with_tasks` to create everything atomically:

```json
campaign_create_with_tasks(campaign_json='{
  "campaign": {"name": "Auth System", "priority": "high"},
  "tasks": [
    {"temp_id": "setup", "title": "Setup environment", "acceptance_criteria": ["Dev server runs"]},
    {"temp_id": "impl", "title": "Implement login", "dependencies": ["setup"]},
    {"temp_id": "test", "title": "Integration tests", "dependencies": ["impl"]}
  ]
}')
```

## Available Tools (63 total)

### Campaign Management (21 tools)

| Category | Tools |
|----------|-------|
| **Core CRUD** | `campaign_create`, `campaign_list`, `campaign_show`, `campaign_update`, `campaign_delete` |
| **Progress & Actions** | `campaign_get_progress_summary`, `campaign_get_next_actionable_task`, `campaign_get_all_actionable_tasks`, `campaign_overview`, `campaign_details` |
| **Bulk & Workflow** | `campaign_create_with_tasks`, `campaign_validate_readiness`, `campaign_workflow_guide`, `campaign_get_state_snapshot`, `campaign_renumber_tasks` |
| **Research** | `campaign_research_add`, `campaign_research_list`, `campaign_research_show`, `campaign_research_update`, `campaign_research_delete`, `campaign_research_reorder` |

### Task Management (42 tools)

| Category | Tools |
|----------|-------|
| **Core CRUD** | `task_create`, `task_list`, `task_show`, `task_update`, `task_delete`, `task_complete` |
| **Acceptance Criteria** | `task_acceptance_criteria_add`, `task_acceptance_criteria_mark_met`, `task_acceptance_criteria_mark_unmet`, `task_acceptance_criteria_list`, `task_acceptance_criteria_show`, `task_acceptance_criteria_update`, `task_acceptance_criteria_delete`, `task_acceptance_criteria_reorder` |
| **Testing Strategy** | `task_testing_strategy_add`, `task_testing_strategy_list`, `task_testing_strategy_show`, `task_testing_strategy_update`, `task_testing_strategy_delete`, `task_testing_strategy_mark_passed`, `task_testing_strategy_mark_failed`, `task_testing_strategy_mark_skipped`, `task_testing_strategy_reorder`, `task_testing_step_add` |
| **Research** | `task_research_add`, `task_research_list`, `task_research_show`, `task_research_update`, `task_research_delete`, `task_research_reorder` |
| **Implementation Notes** | `task_implementation_notes_add`, `task_implementation_notes_list`, `task_implementation_notes_show`, `task_implementation_notes_update`, `task_implementation_notes_delete`, `task_implementation_notes_reorder` |
| **Search & Analytics** | `task_search`, `task_stats`, `task_get_dependency_info` |
| **Bulk & Workflow** | `task_bulk_update`, `task_create_from_template`, `task_complete_with_workflow` |

## CLI Usage

```bash
# Create a campaign
crusader campaign create "My Project" --description "My awesome project"

# List campaigns
crusader campaign list

# Show campaign details
crusader campaign show <campaign-id>

# Create a task
crusader task create "Implement feature" --campaign <campaign-id>

# Show task details
crusader task show <task-id>

# Update task status
crusader task update <task-id> --status in-progress
```

## TUI Usage

```bash
crusader-tui
```

This opens an interactive terminal interface for browsing campaigns and tasks with keyboard navigation, filtering, and bulk operations.

## Database

By default, Task Crusader stores data in `~/.crusader/database.db`. You can configure a custom path by setting the `CRUSADER_DB_PATH` environment variable.

## Architecture

Task Crusader follows a clean hexagonal architecture:

```
MCP Server → Service Layer → Repository Layer → SQLite Database
                  ↓
            Domain Layer (DTOs, Result Types, Hints)
```

Key design decisions:
- **Direct service calls**: MCP tools call services directly (no CLI subprocess overhead)
- **Result pattern**: All operations return `DomainResult` for explicit error handling
- **Context-aware hints**: Operations return guidance hints for next actions
- **Memory system internal**: Acceptance criteria, research, notes, and testing steps use an internal memory system

## Contributing

Contributions are welcome! Before pushing, run the CI checks locally:

```bash
./scripts/check_ci.sh
```

This runs:
1. Linting with `ruff check src/ tests/`
2. Tests with coverage: `pytest --cov --cov-fail-under=65`
3. Optional type checking: `mypy src/`

See [CONTRIBUTING.md](CONTRIBUTING.md) for detailed guidelines.

## License

MIT License - see LICENSE file for details.
