AppFlowy MCP server for workspace, space, page, database, and row operations
Project description
AppFlowy MCP
An MCP server for AppFlowy with 68 tools covering workspaces, spaces, pages, page content, Markdown import, databases, rows, search, members and invitations, publishing, quick notes, file upload, and AI chat.
Requirements
- Python 3.14
- uv
- AppFlowy account credentials
Configure In Codex
codex mcp add appflowy -- uvx appflowy-mcp --env APPFLOWY_EMAIL="your-email" --env APPFLOWY_PASSWORD="your-password"
Option 1: PyPI / uvx
Use this after the package is published to PyPI. This is the simplest setup for daily use.
Use uvx as the command:
uvx
Use these arguments:
appflowy-mcp
Option 2: Local Source / uv
Use this when developing the MCP locally or running directly from a cloned repository.
Use uv as the command:
uv
Use these arguments:
run
--project
D:\codes\MCP\Appflowy-MCP
D:\codes\MCP\Appflowy-MCP\main.py
Configure In Claude-code
claude mcp add appflowy -- uvx appflowy -e APPFLOWY_EMAIL=your-email -e APPFLOWY_PASSWORD=your-password
Environment Variables
Set these environment variables:
APPFLOWY_EMAIL=your-email@example.com
APPFLOWY_PASSWORD=your-password
With these variables set, tools automatically log in on first use. appflowy_login is still available when you want to provide credentials explicitly.
For self-hosted AppFlowy, also set the base URL:
APPFLOWY_BASE_URL=http://localhost:8000
If omitted, APPFLOWY_BASE_URL defaults to https://beta.appflowy.cloud.
AppFlowy Structure
Most write operations need both a workspace and a parent view:
workspace -> space -> page/database
To create a page inside a space, pass the workspace ID and use the space view_id as parent_view_id.
Tools
Authentication
appflowy_loginappflowy_refresh_token
Workspaces And Spaces
appflowy_list_workspacesappflowy_get_workspace_folderappflowy_list_spacesappflowy_create_spaceappflowy_update_space
Workspace Management
appflowy_create_workspaceappflowy_update_workspaceappflowy_delete_workspaceappflowy_leave_workspaceappflowy_get_workspace_settingsappflowy_update_workspace_settingsappflowy_get_workspace_usage
Note: creating extra workspaces requires a paid AppFlowy Cloud plan; the free plan returns a workspace-limit error.
Members And Invitations
appflowy_list_membersappflowy_update_memberappflowy_remove_membersappflowy_invite_membersappflowy_list_invitationsappflowy_accept_invitation
Member roles are Owner, Member, or Guest.
Pages
appflowy_create_pageappflowy_get_pageappflowy_update_pageappflowy_move_pageappflowy_duplicate_pageappflowy_move_page_to_trashappflowy_restore_page_from_trashappflowy_delete_page_from_trashappflowy_restore_all_from_trashappflowy_empty_trashappflowy_favorite_pageappflowy_list_trashappflowy_list_favoritesappflowy_list_recent
Page Content
appflowy_save_pageappflowy_append_page_contentappflowy_append_text_to_pageappflowy_append_blocks_to_pageappflowy_create_markdown_pageappflowy_append_markdown_to_pageappflowy_import_markdown_fileappflowy_import_markdown_directory
Page-content support covers appending new document blocks, creating pages from Markdown, and appending Markdown to existing pages. AppFlowy exposes a high-level append-block endpoint, but not a matching high-level REST endpoint for deleting or editing arbitrary existing blocks. Page-level deletion through trash is supported.
When saving AI answers, notes, summaries, or generated content into AppFlowy, use appflowy_save_page by default. Its content_format field defaults to markdown, so agents do not need to ask users to say "save as Markdown" every time. Set content_format to plain_text only when the user explicitly wants the content preserved as literal plain text.
Use appflowy_append_page_content by default when adding AI-generated content to an existing page. It also treats content as Markdown unless content_format is set to plain_text.
Example paragraph block:
{
"type": "paragraph",
"data": {
"delta": [
{
"insert": "Hello from MCP"
}
]
}
}
Example Markdown page:
{
"parent_view_id": "space-or-page-view-id",
"title": "Meeting Notes",
"content": "# Meeting Notes\n\n- [ ] Follow up\n- **Important** decision\n\n```python\nprint(\"hello\")\n```",
"content_format": "markdown"
}
Markdown conversion supports headings, paragraphs, dividers, bullet lists, numbered lists, todo lists, quotes, code blocks, image links, and inline bold, italic, strikethrough, code, and links.
Markdown Import
Use appflowy_import_markdown_file to import one local Markdown file as an AppFlowy page. Use appflowy_import_markdown_directory to recursively import a local folder tree.
Directory import maps local structure directly to AppFlowy:
local folder -> AppFlowy page
local subfolder -> AppFlowy subpage
local .md/.markdown file -> AppFlowy page
README.md or index.md becomes the content of its folder page instead of a separate child page. Other Markdown files in the same folder become child pages. Hidden folders plus .git, .hg, .svn, .idea, .vscode, node_modules, and __pycache__ are skipped.
Local image references are resolved relative to the Markdown file, uploaded to AppFlowy file storage, and replaced with AppFlowy file URLs:


Remote image URLs such as https://... are kept as-is. Missing local images are reported in the import result warnings, while other files continue importing.
Example directory import:
{
"parent_view_id": "space-or-page-view-id",
"path": "D:\\notes",
"upload_assets": true
}
Example single-file import:
{
"parent_view_id": "space-or-page-view-id",
"path": "D:\\notes\\MCP\\config.md",
"title": "MCP Config",
"upload_assets": true
}
Databases And Rows
appflowy_list_databasesappflowy_get_database_fieldsappflowy_create_database_fieldappflowy_list_rowsappflowy_get_row_detailsappflowy_create_rowappflowy_upsert_rowappflowy_get_updated_rows
appflowy_create_database_field field types: 0=RichText, 1=Number, 2=DateTime, 3=SingleSelect, 4=MultiSelect, 5=Checkbox, 6=URL, 7=Checklist.
Search
appflowy_search
Full-text search across a workspace. Newly written content can take a short while to appear while the server indexes it.
Publishing
appflowy_publish_pageappflowy_unpublish_pageappflowy_get_publish_namespaceappflowy_set_publish_namespaceappflowy_list_published_views
appflowy_publish_page returns the publish info (namespace and publish name) for building the public URL. On older server deployments that lack the list endpoint, appflowy_list_published_views falls back to walking the workspace folder tree.
Quick Notes
appflowy_list_quick_notesappflowy_create_quick_noteappflowy_update_quick_noteappflowy_delete_quick_note
Quick note tools accept plain text (converted to paragraph blocks) or raw data JSON.
AI Chat
appflowy_create_chatappflowy_delete_chatappflowy_get_chat_settingsappflowy_update_chat_settingsappflowy_list_chat_messagesappflowy_chat_ask
Create a chat with appflowy_create_chat (optionally passing rag_ids, page view ids the AI may use as context), then ask questions with appflowy_chat_ask, which posts the question and waits for the complete AI answer (non-streaming).
User And Files
appflowy_get_user_profileappflowy_upload_file
appflowy_upload_file uploads a local file to AppFlowy file storage and returns a URL that image or file blocks can reference. Use the page view_id as parent_dir.
Local Run
uv run appflowy-mcp
Publish To PyPI
Build and check the package:
uv build
uv publish --dry-run --trusted-publishing never
Publish with a PyPI API token:
$env:UV_PUBLISH_TOKEN="pypi-your-token"
uv publish --trusted-publishing never
Do not commit PyPI tokens or write them into project files.
Notes
- Tokens are stored in memory by the MCP server process.
APPFLOWY_EMAIL,APPFLOWY_PASSWORD, andAPPFLOWY_BASE_URLcan also be provided through a local.envfile.- Some page and space endpoints are implemented from AppFlowy source routes that are not present in the public OpenAPI document.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file appflowy_mcp-0.2.0.tar.gz.
File metadata
- Download URL: appflowy_mcp-0.2.0.tar.gz
- Upload date:
- Size: 61.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"26.04","id":"resolute","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
60efefd870cb4b983d0f6978ce3d8dbc58abadf35824ba243e14da5daa7320dd
|
|
| MD5 |
f067550efceadb9330688a196fc77b3d
|
|
| BLAKE2b-256 |
a973d372a4f39c6ec76298575f337eac28ad02edfe5bf483510c44140c3ecaa1
|
File details
Details for the file appflowy_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: appflowy_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"26.04","id":"resolute","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd5c8f9649966d1a58568faa107c04260ef804f2e6a9c0035c5e7948f7d39a32
|
|
| MD5 |
5de43f19d6ac7b9bab8f68ef1cebbf39
|
|
| BLAKE2b-256 |
15b453a329e8242289ea4719914745df3c7d3610055aef2c193325346ba226b2
|