FluentBoards MCP Server

FluentBoards MCP Server

Enables AI assistants to manage FluentBoards project management through WordPress REST API, supporting board operations, task management, comments, and labels with advanced safety controls and board focus mode.

Category
Visit Server

README

FluentBoards MCP Server

A comprehensive Model Context Protocol (MCP) server for FluentBoards project management system with advanced safety features and board focus mode.

Overview

This MCP server provides AI agents with full access to FluentBoards functionality through a secure, modular architecture. It enables AI assistants to manage boards, tasks, comments, and labels programmatically while offering advanced safety controls and focused workflows.

Key Features

✨ Board Focus Mode - Streamline operations for a specific board
šŸ›”ļø Delete Safety Controls - Granular control over destructive operations
šŸ”§ Modular Architecture - Clean, maintainable code structure
šŸ“Š Comprehensive API Coverage - Full FluentBoards functionality
šŸŽÆ Dynamic Tool Registration - Context-aware tool availability

Architecture

src/
ā”œā”€ā”€ config/           # Configuration management with safety controls
ā”œā”€ā”€ utils/            # Utilities (formatting, validation, safety)
ā”œā”€ā”€ api/              # API client and HTTP handling
ā”œā”€ā”€ types/            # TypeScript types and Zod schemas
ā”œā”€ā”€ tools/            # MCP tool implementations
│   ā”œā”€ā”€ boards.ts     # Board management (conditional registration)
│   ā”œā”€ā”€ tasks.ts      # Task management tools
│   ā”œā”€ā”€ comments.ts   # Comment management tools
│   ā”œā”€ā”€ labels.ts     # Label management tools
│   └── debug.ts      # Debug and testing tools
└── index.ts          # Main server entry point

Configuration Modes

1. All Boards Mode (Default)

Access to all boards and full board management capabilities.

WORDPRESS_URL=https://your-site.local
WORDPRESS_USERNAME=your-username
WORDPRESS_APP_PASSWORD=your-app-password
# No BOARD_ID set

2. Board Focus Mode šŸŽÆ

Streamlined operations focused on a specific board. Automatically disables board manipulation tools.

WORDPRESS_URL=https://your-site.local
WORDPRESS_USERNAME=your-username
WORDPRESS_APP_PASSWORD=your-app-password
BOARD_ID=14  # Focus on board 14

Available Tools

Tool availability depends on your configuration mode:

Debug Tools (Always Available)

  • debug_test - Test server connectivity and API status

Board Management (All Boards Mode Only)

  • list_boards - List all boards with pagination
  • create_board - Create new boards with type validation
  • delete_board - Delete boards permanently (safety controlled)

Board Operations (Always Available, Scoped by Focus)

  • get_board - Get specific board details
  • create_stage - Create new stages in boards

Task Management (Always Available, Scoped by Focus)

  • list_tasks - List tasks in a board
  • get_task - Get detailed task information with comments/attachments
  • create_task - Create new tasks with rich formatting
  • update_task - Update existing tasks
  • change_task_status - Move tasks between stages
  • delete_task - Delete tasks permanently (safety controlled)

Comment Management (Always Available, Scoped by Focus)

  • add_comment - Add comments/replies to tasks with notifications

Label Management (Always Available, Scoped by Focus)

  • add_label - Add labels to tasks
  • remove_label - Remove labels from tasks
  • edit_label - Edit label properties (title, colors)
  • create_label - Create new labels with custom colors
  • delete_label - Delete labels permanently (safety controlled)

Board Focus Mode šŸŽÆ

When BOARD_ID is configured, the server enters Board Focus Mode:

What Changes:

  • Board manipulation tools are removed (list_boards, create_board, delete_board)
  • All operations are scoped to the focused board only
  • Tool count reduces from ~14 to ~11 tools
  • Safety from accidental cross-board operations

Example Usage:

# Set focus to board 14
export BOARD_ID=14

# Available operations (all scoped to board 14):
get_board(board_id: 14)           # āœ… Works
get_board(board_id: 15)           # āŒ Blocked
create_task(board_id: 14, ...)    # āœ… Works  
create_task(board_id: 15, ...)    # āŒ Blocked

# Not available in focus mode:
list_boards()                     # āŒ Tool not registered
create_board(...)                 # āŒ Tool not registered
delete_board(...)                 # āŒ Tool not registered

Delete Operation Safety šŸ›”ļø

āš ļø IMPORTANT: Delete operations are disabled by default for safety.

Safety Configuration

# Core safety settings
ENABLE_DELETES=false                    # Master switch (default: false)
REQUIRE_DELETE_CONFIRMATION=true       # Require confirmation (default: true)
ALLOWED_DELETE_TYPES=task,label        # Allowed types (default: none)

Safety Levels

Level 1: No Deletes (Default - Safest)

ENABLE_DELETES=false

All delete tools return safety errors.

Level 2: Selective Deletes with Confirmation

ENABLE_DELETES=true
REQUIRE_DELETE_CONFIRMATION=true
ALLOWED_DELETE_TYPES=task,label

Only task and label deletions allowed, confirmation required.

Level 3: Full Deletes with Confirmation

ENABLE_DELETES=true
REQUIRE_DELETE_CONFIRMATION=true
ALLOWED_DELETE_TYPES=board,task,label

All deletions allowed, confirmation required.

Level 4: Unrestricted (Not Recommended)

ENABLE_DELETES=true
REQUIRE_DELETE_CONFIRMATION=false
ALLOWED_DELETE_TYPES=board,task,label

Using Delete Operations

When enabled, delete operations require confirmation:

// Valid confirmation formats:
delete_task(board_id: 1, task_id: 5, confirm_delete: true)
delete_task(board_id: 1, task_id: 5, confirm_delete: "yes") 
delete_task(board_id: 1, task_id: 5, confirm_delete: "confirm")

// Without confirmation (when required):
delete_task(board_id: 1, task_id: 5)  // āŒ Safety error

Installation & Setup

Prerequisites

  • FluentBoards WordPress Plugin - The MCP server connects directly to FluentBoards REST API
  • WordPress Application Password - For secure authentication
  • No additional WordPress plugins required

1. Install Dependencies

npm install

2. Build the Server

npm run build

3. Configure Environment

All Boards Mode:

WORDPRESS_URL=https://your-site.local
WORDPRESS_USERNAME=your-username
WORDPRESS_APP_PASSWORD=your-app-password

Board Focus Mode:

WORDPRESS_URL=https://your-site.local
WORDPRESS_USERNAME=your-username
WORDPRESS_APP_PASSWORD=your-app-password
BOARD_ID=14

4. Configure MCP Client

Cursor (~/.cursor/mcp.json):

{
  "mcpServers": {
    "fluent-boards": {
      "command": "node",
      "args": ["/path/to/mcp-server-app/dist/index.js"],
      "env": {
        "WORDPRESS_URL": "https://your-site.local",
        "WORDPRESS_USERNAME": "your-username", 
        "WORDPRESS_APP_PASSWORD": "your-app-password",
        "BOARD_ID": "14"
      }
    }
  }
}

Claude Desktop:

{
  "mcpServers": {
    "fluent-boards": {
      "command": "node",
      "args": ["/path/to/mcp-server-app/dist/index.js"],
      "env": {
        "WORDPRESS_URL": "https://your-site.local",
        "WORDPRESS_USERNAME": "your-username",
        "WORDPRESS_APP_PASSWORD": "your-app-password"
      }
    }
  }
}

Complete Configuration Reference

# Required: WordPress connection
WORDPRESS_URL=https://your-site.local
WORDPRESS_USERNAME=your-username
WORDPRESS_APP_PASSWORD=your-app-password

# Optional: Board focus mode
BOARD_ID=14                             # Enable board focus mode

# Optional: Delete operation safety
ENABLE_DELETES=false                    # Enable delete operations
REQUIRE_DELETE_CONFIRMATION=true       # Require confirmation parameter
ALLOWED_DELETE_TYPES=task,label         # Comma-separated: board,task,label

Development

Building

npm run build

Testing

# Run integration tests
npm test

# Run specific integration test
npx ts-node tests/integration.test.ts

# Run development/debugging scripts (see scripts/README.md)
npx ts-node scripts/testing/test-connection.ts
npx ts-node scripts/testing/test-admin-create.ts

Adding New Tools

  1. Create tool in appropriate module:
// src/tools/example.ts
export function registerExampleTools(server: McpServer) {
  server.tool(
    "example_tool",
    "Description of the tool",
    {
      board_id: z.number().int().positive().describe("Board ID"),
      param1: z.string().describe("Parameter description"),
    },
    async (args) => {
      const { board_id, param1 } = args;
      
      // Validate board access in focus mode
      const accessCheck = validateBoardAccess(board_id);
      if (!accessCheck.allowed) {
        return formatResponse(createBoardFocusError(accessCheck));
      }
      
      // Implementation
      const response = await api.get(`/endpoint/${board_id}`);
      return formatResponse(response.data);
    }
  );
}
  1. Register in main server:
// src/index.ts
import { registerExampleTools } from './tools/example.js';

registerExampleTools(server);

API Integration

The MCP server connects directly to the FluentBoards WordPress REST API:

  • Base URL: {WORDPRESS_URL}/wp-json/fluent-boards/v2
  • Authentication: WordPress Application Password (secure, built-in)
  • Connection: Direct HTTPS (no proxy required)
  • Format: JSON requests/responses
  • Rate Limiting: Handled by WordPress

No Proxy Plugin Required

The MCP server uses WordPress's native REST API and Application Password authentication. No additional WordPress plugins are needed for the MCP server to function.

Response Format

All tools return standardized MCP responses:

{
  "content": [
    {
      "type": "text", 
      "text": "{\n  \"board\": {\n    \"id\": 14,\n    \"title\": \"My Board\"\n  }\n}"
    }
  ]
}

Text Formatting Features

The server automatically formats text content:

  • āœ… Proper line breaks for markdown
  • āœ… Header formatting (##)
  • āœ… List formatting (- and numbered)
  • āœ… Checkbox formatting ([ ] and [x])
  • āœ… Status indicators (āœ…, āŒ)
  • āœ… HTML entity decoding

Error Handling

Comprehensive error handling with specific error types:

API Errors

{
  "error": "API request failed",
  "status": 404,
  "message": "Board not found"
}

Safety Errors

{
  "error": "Delete operation not allowed",
  "reason": "Delete operations are disabled",
  "code": "DELETES_DISABLED"
}

Board Focus Errors

{
  "error": "Operation outside board focus scope", 
  "reason": "Operations are focused on board 14",
  "code": "OUT_OF_FOCUS"
}

Troubleshooting

Tool Count Changes

  • Expected: Tool count changes when switching between focus modes
  • All Boards: ~14 tools available
  • Board Focus: ~11 tools available (board manipulation tools removed)

Connection Issues

# Test server connectivity
npm run test

# Test direct FluentBoards API access
curl -u "username:app-password" "https://your-site.local/wp-json/fluent-boards/v2/projects/list-of-boards"

# Test WordPress REST API is working
curl "https://your-site.local/wp-json/"

Permission Issues

  • Ensure WordPress user has FluentBoards access
  • Verify Application Password is correctly generated
  • Check WordPress REST API is enabled
  • Ensure FluentBoards plugin is active
  • No proxy plugin installation required

Future Enhancements

  • šŸ“Š Performance monitoring and metrics
  • šŸ”„ Caching layer for frequently accessed data
  • šŸŖ Webhook support for real-time updates
  • šŸ“¦ Bulk operations for efficiency
  • šŸ“Ž File upload and attachment management
  • šŸ” Advanced search and filtering
  • šŸ“ˆ Reporting and analytics tools
  • šŸ” Enhanced authentication methods

Contributing

  1. Follow architecture patterns - Use modular tool organization
  2. Implement safety controls - Add validation and access checks
  3. Add comprehensive error handling - Include specific error codes
  4. Use input validation - Zod schemas for all parameters
  5. Format responses consistently - Use utility functions
  6. Add tests - Cover new functionality thoroughly
  7. Update documentation - Keep README current

License

This project is part of the FluentBoards ecosystem.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
E2B

E2B

Using MCP to run code via e2b.

Official
Featured