MCP Servers

A collection of Model Context Protocol servers, templates, tools and more.

Canvas LMS MCP server

Created 10/30/2025
Updated 1 day ago
Repository documentation and setup instructions

Canvas MCP Server

A Model Context Protocol server providing comprehensive access to Canvas LMS for AI assistants.

Install MCP Server

Features

Access Canvas LMS functionality through 31 MCP tools:

  • Courses: List and view course information
  • Assignments: Browse, view details, check submissions, and submit work
  • Grades: View grades for individual courses or across all courses
  • Messaging: Send and receive messages, manage conversations (read/unread, star, archive, delete)
  • Calendar: View events and upcoming deadlines
  • To-Do Lists: Track pending tasks and assignments
  • Modules: Navigate course content structure
  • Announcements: Read course and institutional announcements
  • Files: Access and download course materials
  • Quizzes: View quizzes and submissions
  • Users: Search for classmates and instructors

Installation

Prerequisites

  • Bun runtime
  • Canvas LMS account with API access token

Setup

  1. Install dependencies:
bun install
  1. Get your Canvas API token:

    • Log into Canvas
    • Navigate to Account → Settings
    • Scroll to "Approved Integrations"
    • Click "+ New Access Token"
    • Generate and copy the token
  2. Configure environment variables:

export CANVAS_BASE_URL="https://your-institution.instructure.com"
export CANVAS_ACCESS_TOKEN="your_access_token_here"
  1. Configure your MCP client with the following settings:
{
  "mcpServers": {
    "canvas": {
      "command": "bun",
      "args": ["run", "/absolute/path/to/canvas/src/index.ts"],
      "env": {
        "CANVAS_BASE_URL": "https://your-institution.instructure.com",
        "CANVAS_ACCESS_TOKEN": "your_access_token_here"
      }
    }
  }
}

Usage

After setup, interact with Canvas through your MCP client:

Show me all my current courses
What assignments do I have due soon?
What are my grades in all my classes?
Show me my recent Canvas messages

Development

Quality Gates

bun run format      # Format code with Prettier
bun run lint        # Lint code with ESLint
bun run typecheck   # Type check with TypeScript
bun test            # Run tests

Build

bun run build       # Build for production
bun run dev         # Run in development mode

Documentation

Architecture

Built with TypeScript and the MCP SDK, this server provides a type-safe interface to the Canvas LMS REST API. All operations use Bearer token authentication and respect Canvas rate limits.

Project Structure

canvas/
├── src/
│   ├── canvas/
│   │   ├── client.ts        # Canvas API client
│   │   └── client.test.ts   # Client tests
│   └── index.ts             # MCP server implementation
├── docs/                    # Documentation
├── package.json             # Dependencies and scripts
└── tsconfig.json           # TypeScript configuration

Security

  • Store credentials in environment variables
  • Never commit access tokens to version control
  • Use token expiration dates
  • Rotate tokens regularly
  • Follow your institution's API usage policies

API Reference

This server implements the Canvas LMS REST API v1. For detailed API documentation, visit the Instructure Developer Portal.

License

This project uses permissive open-source dependencies with no telemetry or tracking.

Quick Setup
Installation guide for this server

Install Package (if required)

npx @modelcontextprotocol/server-canvas-mcp

Cursor configuration (mcp.json)

{ "mcpServers": { "plyght-canvas-mcp": { "command": "npx", "args": [ "plyght-canvas-mcp" ] } } }