Skip to main content

Secure MCP server for WorkBoard OKR and strategy execution platform

Project description

MCP WorkBoard CrunchTools

A secure MCP (Model Context Protocol) server for WorkBoard OKR and strategy execution platform.

Overview

This MCP server is designed to be:

  • Secure by default - Comprehensive threat modeling, input validation, and token protection
  • No third-party services - Runs locally via stdio, your API token never leaves your machine
  • Cross-platform - Works on Linux, macOS, and Windows
  • Automatically updated - GitHub Actions monitor for CVEs and update dependencies
  • Containerized - Available at quay.io/crunchtools/mcp-workboard built on Hummingbird Python base image

Naming Convention

Component Name
GitHub repo crunchtools/mcp-workboard
Container quay.io/crunchtools/mcp-workboard
Python package (PyPI) mcp-workboard-crunchtools
CLI command mcp-workboard-crunchtools
Module import mcp_workboard_crunchtools

Why Hummingbird?

The container image is built on the Hummingbird Python base image from Project Hummingbird, which provides:

  • Minimal CVE exposure - Built with a minimal package set, dramatically reducing attack surface
  • Regular updates - Security patches applied promptly
  • Optimized for Python - Pre-configured with uv package manager
  • Production-ready - Proper signal handling and non-root user defaults

Features

User Management (4 tools)

  • workboard_get_user - Get a user by ID or the current authenticated user
  • workboard_list_users - List all users (Data-Admin role required)
  • workboard_create_user - Create a new user (Data-Admin role required)
  • workboard_update_user - Update an existing user

Objective Management (4 tools)

  • workboard_get_objectives - Get objectives associated with a user (API capped at 15)
  • workboard_get_objective_details - Get details for a specific objective with key results
  • workboard_get_my_objectives - Get the current user's owned objectives by ID (recommended)
  • workboard_create_objective - Create a new objective with key results (Data-Admin required)

Key Result Management (2 tools)

  • workboard_get_my_key_results - List current user's key results with metric IDs and progress
  • workboard_update_key_result - Update key result progress for weekly OKR check-ins

Workstream Management (5 tools)

  • workboard_get_workstreams - Get team workstreams accessible to the authenticated user
  • workboard_get_workstream_activities - Get workstream details with all action items
  • workboard_get_team_workstreams - Get all workstreams belonging to a specific team
  • workboard_create_workstream - Create a new workstream for a team
  • workboard_update_workstream - Update workstream properties (name, dates, pace, health, priority)

Installation

With uvx (Recommended)

uvx mcp-workboard-crunchtools

With pip

pip install mcp-workboard-crunchtools

With Container

podman run -e WORKBOARD_API_TOKEN=your_token \
    quay.io/crunchtools/mcp-workboard

Configuration

Getting a WorkBoard API Token

  1. Log in to your WorkBoard instance
  2. Navigate to Admin Settings > API Configuration
  3. Generate a JWT API token
  4. Copy the token immediately - store it securely

Add to Claude Code

claude mcp add mcp-workboard \
    --env WORKBOARD_API_TOKEN=your_token_here \
    -- uvx mcp-workboard-crunchtools

Or for the container version:

claude mcp add mcp-workboard \
    --env WORKBOARD_API_TOKEN=your_token_here \
    -- podman run -i --rm -e WORKBOARD_API_TOKEN quay.io/crunchtools/mcp-workboard

Usage Examples

Get Current User

User: Who am I in WorkBoard?
Assistant: [calls workboard_get_user with no args]

List All Users

User: List all WorkBoard users
Assistant: [calls workboard_list_users]

Get User Objectives

User: Show me objectives for user 12345
Assistant: [calls workboard_get_objectives with user_id=12345]

Get Objective Details

User: Get details on objective 67890 for user 12345
Assistant: [calls workboard_get_objective_details with user_id=12345, objective_id=67890]

Get My Objectives

User: Show me my objectives (IDs: 2900058, 2900075, 2901770)
Assistant: [calls workboard_get_my_objectives with objective_ids=[2900058, 2900075, 2901770]]

List My Key Results

User: Show me my key results
Assistant: [calls workboard_get_my_key_results]

Update Key Result Progress

User: Update key result 12345 to 75
Assistant: [calls workboard_update_key_result with metric_id=12345, value="75"]

Create an Objective

User: Create an objective called "Increase retention" owned by user@example.com
Assistant: [calls workboard_create_objective with name, owner, dates, and optional key_results]

List Workstreams

User: Show me my workstreams
Assistant: [calls workboard_get_workstreams]

Get Workstream Action Items

User: Show me the agenda for workstream 4130463
Assistant: [calls workboard_get_workstream_activities with ws_id=4130463]

Security

This server was designed with security as a primary concern. See SECURITY.md for:

  • Threat model and attack vectors
  • Defense in depth architecture
  • Token handling best practices
  • Input validation rules

Key Security Features

  1. Token Protection

    • Stored as SecretStr (never accidentally logged)
    • Environment variable only (never in files or args)
    • Sanitized from all error messages
  2. Input Validation

    • Pydantic models for all inputs
    • Positive integer validation for IDs
    • Email validation for user creation
  3. API Hardening

    • Hardcoded API base URL (prevents SSRF)
    • TLS certificate validation
    • Request timeouts
    • Response size limits
  4. Automated CVE Scanning

    • GitHub Actions scan dependencies weekly
    • Automatic issues for security updates
    • Dependabot alerts enabled

Development

Setup

git clone https://github.com/crunchtools/mcp-workboard.git
cd mcp-workboard
uv sync

Run Tests

uv run pytest

Lint and Type Check

uv run ruff check src tests
uv run mypy src

Build Container

podman build -t mcp-workboard .

License

AGPL-3.0-or-later

Contributing

Contributions welcome! Please read SECURITY.md before submitting security-related changes.

Links

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_workboard_crunchtools-0.7.0.tar.gz (52.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_workboard_crunchtools-0.7.0-py3-none-any.whl (37.3 kB view details)

Uploaded Python 3

File details

Details for the file mcp_workboard_crunchtools-0.7.0.tar.gz.

File metadata

File hashes

Hashes for mcp_workboard_crunchtools-0.7.0.tar.gz
Algorithm Hash digest
SHA256 f55dde5d2c1b882579d10b11fcd759a147b3afeaf948728337c6bcc785819dd5
MD5 1bc9b33a98bf857536361e4cd7390bb3
BLAKE2b-256 79498d717b3ca523c17822438b6384cfe130ca825146141da6f026f3b4e31fbf

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_workboard_crunchtools-0.7.0.tar.gz:

Publisher: publish.yml on crunchtools/mcp-workboard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_workboard_crunchtools-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_workboard_crunchtools-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3ceed48185da9ae106d535ae1a1d8bb203976055826d2c9aa8f3a3198c914ad4
MD5 b875e754b8b498f0a436fa6bc9e31b6c
BLAKE2b-256 0725f4a7dae508b001cbb8b93184afeb7b77ee9a52790fe9648ae8922de7d311

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_workboard_crunchtools-0.7.0-py3-none-any.whl:

Publisher: publish.yml on crunchtools/mcp-workboard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page