Simple file-based task tracker for git repos
Project description
Tasker
A simple file-based task tracker for git repositories. Tasks are stored as plain Markdown files inside a tasker/ directory, tracked alongside your code with git.
Installation
Install with pipx (recommended — installs in an isolated environment):
pipx install mcp-tasker
Or with pip:
pip install mcp-tasker
For development (requires Poetry):
git clone https://github.com/greendwin/mcp-tasker.git
cd mcp-tasker
poetry install --with dev
Quick Start
# Initialize tasker (or let it auto-detect from any subdirectory)
tasker init
# Create a story
tasker new "Build authentication"
# Add subtasks
tasker add s01 "Design login flow"
tasker add s01 "Implement JWT tokens" --details "Use RS256 signing"
# Work on a task
tasker start s01t01
# View what's on your plate
tasker list
# Mark tasks done
tasker done s01t01
# Edit a task in your editor
tasker edit s01t02
Tasks are stored as Markdown in tasker/ and committed with your code:
tasker/
s01-build-authentication/
README.md
s01t01-design-login-flow.md
s01t02-implement-jwt-tokens.md
Usage
Create tasks
tasker new <title> # new root story
tasker new <title> --details "..." --slug <slug> # with description and slug
tasker new <title> --editor # create and open in editor
tasker add <parent-id> <title> # inline subtask
tasker add <parent-id> <title> --details "..." # subtask with description
tasker add <parent-id> <title> --editor # create and open in editor
tasker add-many <parent-id> # add multiple subtasks interactively
Update status
tasker start <task-id>... # mark in-progress
tasker done <task-id>... # mark done
tasker cancel <task-id>... # cancel
tasker reset <task-id>... # reset to pending
tasker reset <task-id> --force # force reset non-pending subtasks
# Force-close a parent with open subtasks
tasker done <task-id> --force
View tasks
tasker list # all open root tasks
tasker list -a # include closed tasks
tasker list --archived # list archived tasks
tasker list <task-id> # subtasks of a specific task
tasker view <task-id> # full task details
Edit tasks
tasker edit <task-id> # open in $EDITOR
tasker edit <task-id> --title "New title"
tasker edit <task-id> --details "New description"
tasker edit <task-id> --slug new-slug
Organize
tasker move <task-id> --parent <new-parent> # reparent
tasker move <task-id> --root # promote to story
tasker move <task-id> --delete # delete a task
tasker archive <task-id> # archive completed story
tasker archive --closed # archive all closed stories
tasker unarchive <task-id> # restore from archive
Shortcuts
Reference recent tasks without typing full IDs:
| Shortcut | Meaning |
|---|---|
q |
Last referenced task |
q01 |
Subtask 01 of recent |
p |
Parent of recent |
p03 |
Sibling 03 via parent |
tasker view s01t02 # sets recent = s01t02
tasker start q # starts s01t02
tasker view p # views s01 (parent)
tasker done q01 # marks s01t0201 done
MCP Server
tasker can run as a Model Context Protocol server, allowing AI agents to manage your tasks directly.
Configure in Claude Code
claude mcp add tasker -- tasker mcp
Configure per-project (.mcp.json)
{
"mcpServers": {
"tasker": {
"command": "tasker",
"args": ["mcp"]
}
}
}
If running from a Poetry project:
{
"mcpServers": {
"tasker": {
"command": "poetry",
"args": ["run", "tasker", "mcp"]
}
}
}
HTTP transport
For network-accessible clients, start with --port:
tasker mcp --port 8080
Available tools
Once connected, the MCP server exposes:
| Tool | Description |
|---|---|
create_task |
Create a root task or subtask |
list_tasks |
List all root tasks |
view_tasks |
View detailed info for multiple tasks |
edit_task |
Update a task's title, description, or slug |
start_task |
Mark task in-progress |
reset_task |
Reset task to pending |
finish_task |
Mark task done |
Development
poetry install --with dev
# Run all checks (lint + tests)
poetry run tox
# Run tests only
poetry run tox -e test
# Lint (black, isort, flake8, mypy)
poetry run tox -e lint
# Format code
black src tests
isort src tests
Requirements
- Python >= 3.10
Release Notes
1.2.0
initcommand and automatictasker/directory discovery (walks up to git root)move --deleteoption to delete tasksreset --forceto force-reset non-pending subtasks(q)/(p)recent-task markers shown inviewandeditcommands- Subtask count shown in
viewcommand - Tab autocompletion for task ID arguments
- Slug validation
- Bug fixes: recent task override, auto-unarchive logic
1.1.0
--editor(-e) option onnewandaddcommands to open the task in an editor after creationlist --archivedto browse archived taskslisthighlights the most recently referenced task- Editing an archived task auto-unarchives it
- Task preview shown after
start,reset,done,cancel,move,new,add, andeditcommands - MCP: added
edit_tasktool for updating title, description, and slug - MCP:
view_tasksaccepts multiple task IDs in a single call - MCP: task subtasks grouped by status in response
--versionflag- Bug fixes: editor slug path, directory cleanup on
move, multi-task preview onstart
1.0.0
piprelease
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcp_tasker-1.2.0.tar.gz.
File metadata
- Download URL: mcp_tasker-1.2.0.tar.gz
- Upload date:
- Size: 28.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ae05dcd622b32c1627a8dc69b3e21928bc9d20ff1ae2b367eeaa15bdf4459eb7
|
|
| MD5 |
c6543bc6105aaa4bdb9a1756293773a8
|
|
| BLAKE2b-256 |
2c4123808aac8c003d8c78d00a586f795f835996be3e4d27752b779d18072094
|
Provenance
The following attestation bundles were made for mcp_tasker-1.2.0.tar.gz:
Publisher:
release.yml on greendwin/mcp-tasker
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_tasker-1.2.0.tar.gz -
Subject digest:
ae05dcd622b32c1627a8dc69b3e21928bc9d20ff1ae2b367eeaa15bdf4459eb7 - Sigstore transparency entry: 1242102887
- Sigstore integration time:
-
Permalink:
greendwin/mcp-tasker@9cd73a64a3df5fff1341542961dd9a72c7df596f -
Branch / Tag:
refs/tags/v1.2.0 - Owner: https://github.com/greendwin
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9cd73a64a3df5fff1341542961dd9a72c7df596f -
Trigger Event:
release
-
Statement type:
File details
Details for the file mcp_tasker-1.2.0-py3-none-any.whl.
File metadata
- Download URL: mcp_tasker-1.2.0-py3-none-any.whl
- Upload date:
- Size: 37.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
76495d706853bc717139797c4baba02b2ed75c569a6d42f1027c36a03a13f61c
|
|
| MD5 |
dc0ef7f3b6c1e1045346437e037d1ce2
|
|
| BLAKE2b-256 |
0e2fb9bf6471474830127b35f94c1fcfee3fa528fdde576ba347d21c9a07148c
|
Provenance
The following attestation bundles were made for mcp_tasker-1.2.0-py3-none-any.whl:
Publisher:
release.yml on greendwin/mcp-tasker
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_tasker-1.2.0-py3-none-any.whl -
Subject digest:
76495d706853bc717139797c4baba02b2ed75c569a6d42f1027c36a03a13f61c - Sigstore transparency entry: 1242102904
- Sigstore integration time:
-
Permalink:
greendwin/mcp-tasker@9cd73a64a3df5fff1341542961dd9a72c7df596f -
Branch / Tag:
refs/tags/v1.2.0 - Owner: https://github.com/greendwin
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9cd73a64a3df5fff1341542961dd9a72c7df596f -
Trigger Event:
release
-
Statement type: