Google Sheets Kanban MCP Server

$claude mcp add --transport stdio kanban-sheets -- uv run -- --directory "path\to\project" python main.py
README.md

Enables task management and Kanban board tracking using Google Sheets as a database

MCP Server - Google Sheets Kanban

Servidor MCP (Model Context Protocol) para gerenciamento de tarefas em um quadro Kanban utilizando Google Sheets como backend.

Características

  • Integração com Google Sheets: Usa Google Sheets API v4 para armazenamento de dados
  • Modelos Pydantic: Validação de dados com Pydantic v2
  • Operações em Lote: Suporte para adicionar e atualizar múltiplas tarefas de uma vez
  • Busca Avançada: Filtros por prioridade, status, contexto, projeto e texto
  • Paginação: Suporte completo para navegação paginada de resultados
  • Protocolo MCP: Compatível com clientes MCP via STDIO

Configuração

Claude

Executar o seguinte comando na pasta do projeto:

claude mcp add --transport stdio kanban-sheets -- uv run -- --directory "caminho\projeto\sua\maquina" python main.py

Ferramentas Disponíveis

1. `get_one_task` - Buscar Tarefa Específica

Busca uma tarefa específica pelo ID da tarefa e nome do projeto.

Parâmetros:

  • project (obrigatório): Nome do projeto
  • task_id (obrigatório): ID único da tarefa

Exemplo:

{
  "project": "MCP Server Sheets",
  "task_id": "TASK-001"
}

Retorno (sucesso):

{
  "Projeto": "MCP Server Sheets",
  "Task ID": "TASK-001",
  "Task ID Root": "TASK-001",
  "Sprint": "Sprint 1",
  "Contexto": "Backend",
  "Descrição": "Implementar busca avançada",
  "Detalhado": "Adicionar filtros por prioridade, status e contexto",
  "Prioridade": "Alta",
  "Status": "Em Desenvolvimento",
  "Data Criação": "2025-10-24 10:30:00",
  "Data Solução": ""
}

Retorno (não encontrada):

{
  "error": "Tarefa 'TASK-999' não encontrada no projeto 'MCP Server'"
}

2. `list_tasks` - Listar e Buscar Tarefas

Lista e busca tarefas da planilha com filtros avançados e paginação opcional.

Parâmetros:

  • filters (opcional): Objeto com critérios de busca
    • prioridade: Lista de prioridades (Baixa, Normal, Alta, Urgente)
    • status: Lista de status para filtrar
    • contexto: Filtro por contexto (busca parcial, case-insensitive)
    • projeto: Filtro por projeto (busca parcial, case-insensitive)
    • texto_busca: Busca em Descrição e Detalhado (case-insensitive)
    • task_id: Busca por Task ID específico
    • sprint: Filtro por Sprint
  • pagination (opcional): Objeto com page (número da página) e page_size (itens por página)

Exemplos:

// 1. Listar todas as tarefas (comportamento legado)
{}

// 2. Com paginação
{
  "pagination": {
    "page": 1,
    "page_size": 20
  }
}

// 3. Buscar tarefas de alta prioridade
{
  "filters": {
    "prioridade": ["Alta", "Urgente"]
  }
}

// 4. Buscar tarefas em desenvolvimento com paginação
{
  "filters": {
    "status": ["Em Desenvolvimento"]
  },
  "pagination": {
    "page": 1,
    "page_size": 10
  }
}

// 5. Buscar por texto na descrição
{
  "filters": {
    "texto_busca": "implementar API"
  }
}

// 6. Combinar múltiplos filtros
{
  "filters": {
    "prioridade": ["Alta"],
    "status": ["Todo", "Em Desenvolvimento"],
    "contexto": "Backend",
    "projeto": "MCP Server"
  },
  "pagination": {
    "page": 1,
    "page_size": 25
  }
}

Retorno (sem paginação):

[
  {
    "Task ID": "TASK-001",
    "Contexto": "Backend",
    "Descrição": "...",
    ...
  },
  ...
]

Retorno (com paginação):

{
  "tasks": [...],
  "total_count": 45,
  "page": 1,
  "page_size": 25,
  "total_pages": 2,
  "has_next": true,
  "has_previous": false
}

3. `add_task` - Adicionar Tarefa

Adiciona uma nova tarefa na planilha.

Parâmetros:

  • task: Objeto Task com todos os campos

Exemplo:

{
  "task": {
    "project": "MCP Server Sheets",
    "task_id": "TASK-001",
    "contexto": "Backend",
    "descricao": "Implementar busca avançada",
    "prioridade": "Alta",
    "status": "Todo",
    "task_id_root": "",
    "sprint": "Sprint 1",
    "detalhado": "Adicionar filtros por prioridade, status e contexto",
    "data_criacao": "2025-10-24",
    "data_solucao": ""
  }
}

4. `update_task` - Atualizar Tarefa

Atualiza uma tarefa existente pelo Task ID.

Parâmetros:

  • task_id: ID da tarefa a ser atualizada
  • updates: Dicionário com campos a atualizar

Exemplo:

{
  "task_id": "TASK-001",
  "updates": {
    "Status": "Concluído",
    "Data Solução": "2025-10-24"
  }
}

5. `batch_add_tasks` - Adicionar Múltiplas Tarefas

Adiciona múltiplas tarefas em uma única operação.

Parâmetros:

  • batch: Objeto BatchTaskAdd contendo lista de tarefas

Exemplo:

{
  "batch": {
    "tasks": [
      {
        "project": "MCP Server",
        "task_id": "TASK-001",
        "contexto": "Backend",
        "descricao": "Tarefa 1",
        "prioridade": "Alta",
        "status": "Todo"
      },
      {
        "project": "MCP Server",
        "task_id": "TASK-002",
        "contexto": "Frontend",
        "descricao": "Tarefa 2",
        "prioridade": "Normal",

Tools (5)

get_one_taskBusca uma tarefa específica pelo ID da tarefa e nome do projeto.
list_tasksLista e busca tarefas da planilha com filtros avançados e paginação opcional.
add_taskAdiciona uma nova tarefa na planilha.
update_taskAtualiza uma tarefa existente pelo Task ID.
batch_add_tasksAdiciona múltiplas tarefas em uma única operação.

Configuration

claude_desktop_config.json
{
  "mcpServers": {
    "kanban-sheets": {
      "command": "uv",
      "args": [
        "run",
        "--",
        "--directory",
        "C:\\path\\to\\your\\project",
        "python",
        "main.py"
      ]
    }
  }
}

Try it

List all tasks in the 'MCP Server' project that have 'Alta' priority.
Add a new task to the 'Backend' context with the description 'Implement API' and status 'Todo'.
Update the status of task 'TASK-001' to 'Concluído' and set today's date as the solution date.
Search for all tasks that contain the text 'implementar' in their description.
Show me the first 10 tasks for the current sprint.

Frequently Asked Questions

What are the key features of Google Sheets Kanban?

Google Sheets API v4 integration for data storage. Advanced search with filters for priority, status, context, and project. Batch operations for adding and updating multiple tasks simultaneously. Full pagination support for navigating large result sets. Data validation using Pydantic v2 models.

What can I use Google Sheets Kanban for?

Managing a project Kanban board directly from a chat interface. Automating task creation and updates within a Google Spreadsheet. Filtering and reporting on project progress using natural language. Synchronizing local project tasks with a shared Google Sheets backend.

How do I install Google Sheets Kanban?

Install Google Sheets Kanban by running: claude mcp add --transport stdio kanban-sheets -- uv run -- --directory "path\to\project" python main.py

What MCP clients work with Google Sheets Kanban?

Google Sheets Kanban works with any MCP-compatible client including Claude Desktop, Claude Code, Cursor, and other editors with MCP support.

Use Google Sheets Kanban with Conare

Manage MCP servers visually, upload persistent context, and never start from zero with Claude Code & Codex.

Try Free