MCP ExplorerExplorer

Mcp Google Tasks

@mstfeon 9 months ago
5 MIT
FreeCommunity
AI Systems
Node.js server implementing Model Context Protocol (MCP) for Google Tasks

Overview

What is Mcp Google Tasks

mcp-google-tasks is a Node.js server that implements the Model Context Protocol (MCP) for managing Google Tasks. It is built using TypeScript and integrates with the Google Tasks API to provide a structured way to manage tasks.

Use cases

Use cases include managing personal to-do lists, tracking project tasks, integrating task management into larger applications, and automating task updates and completions through API calls.

How to use

To use mcp-google-tasks, start the server by running node build/index.js. You can then utilize various commands such as create_task, list_tasks, delete_task, update_task, and complete_task to manage tasks in the default Google Tasks list.

Key features

Key features include the ability to create, list, delete, update, and toggle the completion status of tasks. It supports a JSON Mime Type for task representation and provides easy integration with Large Language Models (LLMs) or other applications via MCP.

Where to use

mcp-google-tasks can be used in project management, personal task management, and any application that requires structured task handling and integration with Google Tasks.

Content

Google Tasks MCP Server

A Model Context Protocol (MCP) server for managing Google Tasks.

This TypeScript-based MCP server demonstrates core MCP concepts by integrating with the Google Tasks API. It allows managing tasks in a structured and efficient way.


Features

Resources

  • Default Task List: Access tasks in the default Google Tasks list via the URI tasks://default.
  • Task Details: Provides metadata about tasks such as title, notes, and completion status.
  • JSON Mime Type: Tasks are represented in a machine-readable JSON format.

Tools

  • create_task: Create a new task in the default task list.
    • Parameters:
      • title (string, optional): Title of the task.
      • notes (string, optional): Additional notes for the task.
      • taskId (string, optional): Unique ID for the task.
      • status (string, optional): Status of the task (e.g., “needsAction” or “completed”).
    • Response: Returns the details of the created task.
  • list_tasks: List all tasks in the default task list.
    • Parameters: None.
    • Response: Returns a JSON array of all tasks in the default task list.
  • delete_task: Delete a task from the default task list.
    • Parameters:
      • taskId (string, required): ID of the task to delete.
    • Response: Confirms successful deletion of the task.
  • update_task: Update an existing task in the default task list.
    • Parameters:
      • taskId (string, required): ID of the task to update.
      • title (string, optional): New title for the task.
      • notes (string, optional): New notes for the task.
    • Response: Returns the updated details of the task.
  • complete_task: Toggle the completion status of a task.
    • Parameters:
      • taskId (string, required): ID of the task to toggle completion status.
    • Response: Returns the updated task details, including the new status.

Functionality

  • Provides easy integration with Large Language Models (LLMs) or other applications via MCP.
  • Structured tool definitions make task management intuitive and accessible.
  • Full support for creating, listing, deleting, updating, and toggling the completion status of tasks.

Usage

Running the Server

To start the server:

node build/index.js

Available Commands

  • create_task:
    Create a new task with optional parameters.
    {
      "title": "Complete project",
      "notes": "Finalize module 3",
      "status": "needsAction"
    }
  • list_tasks:
    Retrieve all tasks in the default task list.
    • No parameters required.
    • Returns an array of tasks.
  • delete_task:
    Delete a task by its ID.
    {
      "taskId": "unique-task-id"
    }
  • update_task:
    Update a task’s title, notes, or other details by its ID.
    {
      "taskId": "unique-task-id",
      "title": "Updated task title",
      "notes": "Updated task notes"
    }
  • complete_task:
    Toggle the completion status of a task.
    {
      "taskId": "unique-task-id"
    }

Example Response for complete_task

Before Completion

{
  "taskId": "unique-task-id",
  "title": "Finish the report",
  "status": "needsAction"
}

After Completion

{
  "taskId": "unique-task-id",
  "title": "Finish the report",
  "status": "completed"
}

Debugging

Since MCP servers communicate over stdio, debugging requires additional tools. We recommend using the MCP Inspector.

To start the inspector:

npm run inspector

The Inspector will provide a URL to access debugging tools in your browser, making it easier to test and debug the server.

License

This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License.

Tools

No tools

Comments

Recommend MCP Servers

View All MCP Servers