Baserow MCP Server
MCP server enabling AI-powered Baserow database operations through natural language, with workspace, table, and row management.
README
Baserow MCP Server
An MCP (Model Context Protocol) server that provides seamless integration between MCP-compatible clients (Claude Desktop, Cursor, Windsurf, etc.) and Baserow, enabling AI-powered database operations through natural language.
๐ Features
- ๐ Smart Authentication: Automatic token refresh with credentials or manual JWT/database tokens
- ๐ข Workspace Management: List, create, and manage Baserow workspaces
- ๐๏ธ Database Operations: Full control over databases within workspaces
- ๐ Table Management: Create, list, and manage tables with field definitions
- ๐ Row CRUD Operations: Complete Create, Read, Update, Delete functionality
- โก Batch Operations: Efficient bulk operations for creating, updating, and deleting rows
- ๐ Advanced Queries: Pagination, filtering, and sorting support
- ๐ก Natural Language: Use plain English to interact with your databases
๐ Prerequisites
- Node.js v22+ (install via nvm)
- An MCP-compatible client:
- Claude Desktop
- Cursor
- Windsurf
- Any other MCP-compatible AI editor
- Baserow account (self-hosted or cloud)
๐ ๏ธ Installation
-
Clone the repository:
git clone https://github.com/ayyazzafar/mcp-baserow.git cd mcp-baserow -
Install dependencies:
npm install -
Configure authentication:
cp .env.example .envEdit
.envand add your credentials:# Recommended: Use credentials for automatic token refresh BASEROW_USERNAME=your@email.com BASEROW_PASSWORD=your_password # Optional: Override default API URL for self-hosted instances # BASEROW_API_URL=https://your-baserow-instance.com -
Build the project:
npm run build
๐ Authentication Options
Option 1: Username/Password (Recommended)
Provides automatic token refresh and full API access:
BASEROW_USERNAME=your@email.com
BASEROW_PASSWORD=your_password
Option 2: JWT Token
For manual token management (expires after 60 minutes):
BASEROW_API_TOKEN=JWT_your_jwt_token_here
Option 3: Database Token
For database-specific operations (limited scope, never expires):
BASEROW_API_TOKEN=Token_your_database_token_here
โ๏ธ Configuration
MCP Client Setup
<details> <summary>Claude Desktop</summary>
-
Open configuration:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
- macOS:
-
Add the Baserow server:
{ "mcpServers": { "baserow": { "command": "/path/to/mcp-baserow/start.sh" } } }
</details>
<details> <summary>Cursor</summary>
- Open Cursor settings
- Navigate to MCP Servers section
- Add:
{ "baserow": { "command": "/path/to/mcp-baserow/start.sh" } }
</details>
<details> <summary>Windsurf</summary>
- Open Windsurf configuration
- Add to MCP servers:
{ "baserow": { "command": "/path/to/mcp-baserow/start.sh" } }
</details>
- Restart your MCP client
๐ Usage Examples
Natural Language Commands
Once configured, you can use natural language in your MCP client:
- "Show me all my Baserow workspaces"
- "Create a new database called 'Project Tracker' in my workspace"
- "List all tables in the Project Tracker database"
- "Add a new row to the Tasks table with title 'Review PR' and status 'In Progress'"
- "Update row 5 in the Tasks table to mark it as completed"
- "Delete all rows in the Archive table that are older than 30 days"
Available MCP Tools
<details> <summary>Authentication Tools (3)</summary>
baserow_auth_status- Check authentication status and capabilitiesbaserow_auth_login- Login with credentialsbaserow_auth_set_token- Manually set JWT or database token </details>
<details> <summary>Workspace Tools (4)</summary>
baserow_list_workspaces- List all workspacesbaserow_get_workspace- Get workspace detailsbaserow_create_workspace- Create new workspacebaserow_set_workspace- Set active workspace for operations </details>
<details> <summary>Database Tools (3)</summary>
baserow_list_databases- List databases in workspacebaserow_get_database- Get database detailsbaserow_create_database- Create new database </details>
<details> <summary>Table Tools (3)</summary>
baserow_list_tables- List tables in databasebaserow_get_table- Get table with field definitionsbaserow_create_table- Create new table </details>
<details> <summary>Row Operations (8)</summary>
baserow_list_rows- List rows with pagination/filteringbaserow_get_row- Get single row by IDbaserow_create_row- Create new rowbaserow_update_row- Update existing rowbaserow_delete_row- Delete rowbaserow_batch_create_rows- Create multiple rowsbaserow_batch_update_rows- Update multiple rowsbaserow_batch_delete_rows- Delete multiple rows </details>
๐งช Development
Setup Development Environment
# Install dependencies
npm install
# Run TypeScript compiler in watch mode
npm run dev
# Run tests (when available)
npm test
Project Structure
mcp-baserow/
โโโ src/
โ โโโ index.ts # MCP server entry point
โ โโโ auth-manager.ts # Authentication handling
โ โโโ baserow-client.ts # Baserow API client
โ โโโ tools/ # MCP tool implementations
โ โ โโโ auth.ts # Authentication tools
โ โ โโโ workspace.ts # Workspace operations
โ โ โโโ database.ts # Database operations
โ โ โโโ table.ts # Table operations
โ โ โโโ row.ts # Row CRUD operations
โ โโโ types/ # TypeScript type definitions
โโโ dist/ # Compiled JavaScript
โโโ examples/ # Usage examples
โโโ tests/ # Test files
๐ค Contributing
We welcome contributions! Please see our Contributing Guidelines for details.
Quick Start for Contributors
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
๐ Changelog
See CHANGELOG.md for a list of changes in each version.
๐ Troubleshooting
Common Issues
-
"Authentication failed"
- Verify your credentials in
.env - Ensure your Baserow account is active
- Check if you're using the correct API URL
- Verify your credentials in
-
"No workspace_id provided"
- Use
baserow_set_workspaceto set an active workspace - Or provide
workspace_idparameter in database operations
- Use
-
"Server disconnected"
- Check your MCP client's logs:
- Claude Desktop:
~/Library/Logs/Claude/mcp-server-baserow.log - Other clients: Check their respective log locations
- Claude Desktop:
- Ensure Node.js v22+ is installed
- Verify all dependencies are installed
- Check your MCP client's logs:
Debug Mode
Enable debug logging by setting:
export DEBUG=baserow:*
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- Anthropic for the MCP specification
- Baserow for the excellent open-source database platform
- The MCP community for examples and best practices
๐ Links
Made with โค๏ธ by the open-source community
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.