Running your own Appwrite instance? Run the MCP server locally over stdio and
authenticate with a project API key instead of OAuth.
- In your Appwrite Console, create a project API key with the scopes you want the server to use.
- Add the server to your client using the config below, replacing the
placeholders:
<YOUR_PROJECT_ID>— your Appwrite project ID.<YOUR_API_KEY>— the API key you just created.<YOUR_APPWRITE_DOMAIN>— your instance domain, e.g.localhost:9501for a local Docker setup.
Self-hosted runs use uvx, so make sure uv is
installed and on your PATH. stdio is the default transport for the package
command. The server validates the endpoint, project ID, API key, and at least one
supported service at startup, and fails before accepting tool calls if anything is
wrong.
Claude Code
claude mcp add appwrite \
--env APPWRITE_PROJECT_ID=<YOUR_PROJECT_ID> \
--env APPWRITE_API_KEY=<YOUR_API_KEY> \
--env APPWRITE_ENDPOINT=https://<YOUR_APPWRITE_DOMAIN>/v1 \
-- uvx mcp-server-appwriteClaude Desktop
Edit your config via Settings → Developer → Edit Config
(~/Library/Application Support/Claude/claude_desktop_config.json on macOS,
%APPDATA%\Claude\claude_desktop_config.json on Windows), then fully restart the
app.
{
"mcpServers": {
"appwrite": {
"command": "uvx",
"args": ["mcp-server-appwrite"],
"env": {
"APPWRITE_PROJECT_ID": "<YOUR_PROJECT_ID>",
"APPWRITE_API_KEY": "<YOUR_API_KEY>",
"APPWRITE_ENDPOINT": "https://<YOUR_APPWRITE_DOMAIN>/v1"
}
}
}
}Cursor
Edit ~/.cursor/mcp.json (global) or .cursor/mcp.json (project).
{
"mcpServers": {
"appwrite": {
"command": "uvx",
"args": ["mcp-server-appwrite"],
"env": {
"APPWRITE_PROJECT_ID": "<YOUR_PROJECT_ID>",
"APPWRITE_API_KEY": "<YOUR_API_KEY>",
"APPWRITE_ENDPOINT": "https://<YOUR_APPWRITE_DOMAIN>/v1"
}
}
}
}VS Code (GitHub Copilot)
Edit .vscode/mcp.json (workspace) or your user configuration via the Command
Palette → MCP: Open User Configuration.
{
"servers": {
"appwrite": {
"type": "stdio",
"command": "uvx",
"args": ["mcp-server-appwrite"],
"env": {
"APPWRITE_PROJECT_ID": "<YOUR_PROJECT_ID>",
"APPWRITE_API_KEY": "<YOUR_API_KEY>",
"APPWRITE_ENDPOINT": "https://<YOUR_APPWRITE_DOMAIN>/v1"
}
}
}
}Codex
Edit ~/.codex/config.toml.
[mcp_servers.appwrite]
command = "uvx"
args = ["mcp-server-appwrite"]
[mcp_servers.appwrite.env]
APPWRITE_PROJECT_ID = "<YOUR_PROJECT_ID>"
APPWRITE_API_KEY = "<YOUR_API_KEY>"
APPWRITE_ENDPOINT = "https://<YOUR_APPWRITE_DOMAIN>/v1"OpenCode
Edit opencode.json (project) or ~/.config/opencode/opencode.json (global).
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"appwrite": {
"type": "local",
"command": ["uvx", "mcp-server-appwrite"],
"enabled": true,
"environment": {
"APPWRITE_PROJECT_ID": "<YOUR_PROJECT_ID>",
"APPWRITE_API_KEY": "<YOUR_API_KEY>",
"APPWRITE_ENDPOINT": "https://<YOUR_APPWRITE_DOMAIN>/v1"
}
}
}
}Windsurf
Edit ~/.codeium/windsurf/mcp_config.json.
{
"mcpServers": {
"appwrite": {
"command": "uvx",
"args": ["mcp-server-appwrite"],
"env": {
"APPWRITE_PROJECT_ID": "<YOUR_PROJECT_ID>",
"APPWRITE_API_KEY": "<YOUR_API_KEY>",
"APPWRITE_ENDPOINT": "https://<YOUR_APPWRITE_DOMAIN>/v1"
}
}
}
}