Skip to content

Commit 8b8bf00

Browse files
committed
docs: add installation guides for Zed and OpenCode
Adds two new installation guides under docs/installation-guides/ covering MCP host applications that are not yet documented: - install-zed.md: covers Zed's 'context_servers' settings key (command + args shape), the official GitHub MCP extension as an easier alternative, remote/local setup, the 'mcp:<server>:<tool>' permission key format introduced in Zed v0.224.0, and OAuth-vs-PAT trade-offs. - install-opencode.md: covers OpenCode's 'mcp' config block (type-discriminated local/remote, command-as-array, 'environment' instead of 'env'), the 'oauth: false' opt-out needed when using a PAT, the '{env:VAR}' interpolation pattern, and the per-agent tool-gating pattern recommended for token-heavy servers like GitHub. Also adds both hosts to: - docs/installation-guides/README.md installation-guides index and the support-by-host-application table. - README.md 'Install in other MCP hosts' and 'Install in Other MCP Hosts' lists. Closes #2531.
1 parent 1add5fe commit 8b8bf00

4 files changed

Lines changed: 265 additions & 0 deletions

File tree

README.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -86,7 +86,9 @@ Alternatively, to manually configure VS Code, choose the appropriate JSON block
8686
- **[Claude Applications](/docs/installation-guides/install-claude.md)** - Installation guide for Claude Desktop and Claude Code CLI
8787
- **[Codex](/docs/installation-guides/install-codex.md)** - Installation guide for OpenAI Codex
8888
- **[Cursor](/docs/installation-guides/install-cursor.md)** - Installation guide for Cursor IDE
89+
- **[OpenCode](/docs/installation-guides/install-opencode.md)** - Installation guide for the OpenCode terminal agent
8990
- **[Windsurf](/docs/installation-guides/install-windsurf.md)** - Installation guide for Windsurf IDE
91+
- **[Zed](/docs/installation-guides/install-zed.md)** - Installation guide for Zed editor
9092
- **[Rovo Dev CLI](/docs/installation-guides/install-rovo-dev-cli.md)** - Installation guide for Rovo Dev CLI
9193

9294
> **Note:** Each MCP host application needs to configure a GitHub App or OAuth App to support remote access via OAuth. Any host application that supports remote MCP servers should support the remote GitHub server with PAT authentication. Configuration details and support levels vary by host. Make sure to refer to the host application's documentation for more info.
@@ -356,7 +358,9 @@ For other MCP host applications, please refer to our installation guides:
356358
- **[Claude Code & Claude Desktop](docs/installation-guides/install-claude.md)** - Installation guide for Claude Code and Claude Desktop
357359
- **[Cursor](docs/installation-guides/install-cursor.md)** - Installation guide for Cursor IDE
358360
- **[Google Gemini CLI](docs/installation-guides/install-gemini-cli.md)** - Installation guide for Google Gemini CLI
361+
- **[OpenCode](docs/installation-guides/install-opencode.md)** - Installation guide for the OpenCode terminal agent
359362
- **[Windsurf](docs/installation-guides/install-windsurf.md)** - Installation guide for Windsurf IDE
363+
- **[Zed](docs/installation-guides/install-zed.md)** - Installation guide for Zed editor
360364

361365
For a complete overview of all installation options, see our **[Installation Guides Index](docs/installation-guides)**.
362366

docs/installation-guides/README.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,9 +11,11 @@ This directory contains detailed installation instructions for the GitHub MCP Se
1111
- **[Cursor](install-cursor.md)** - Installation guide for Cursor IDE
1212
- **[Google Gemini CLI](install-gemini-cli.md)** - Installation guide for Google Gemini CLI
1313
- **[OpenAI Codex](install-codex.md)** - Installation guide for OpenAI Codex
14+
- **[OpenCode](install-opencode.md)** - Installation guide for the OpenCode terminal agent
1415
- **[Roo Code](install-roo-code.md)** - Installation guide for Roo Code
1516
- **[Windsurf](install-windsurf.md)** - Installation guide for Windsurf IDE
1617
- **[Xcode (Codex & Claude Agent)](install-xcode.md)** - Installation guide for Codex and Claude Agent within Xcode
18+
- **[Zed](install-zed.md)** - Installation guide for Zed editor
1719

1820
## Support by Host Application
1921

@@ -29,8 +31,10 @@ This directory contains detailed installation instructions for the GitHub MCP Se
2931
| Cline || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
3032
| Cursor || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
3133
| Google Gemini CLI || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
34+
| OpenCode || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
3235
| Roo Code || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
3336
| Windsurf || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
37+
| Zed || ✅ PAT + ❌ No OAuth | Docker or Go build, GitHub PAT | Easy |
3438
| Copilot in Xcode || ✅ Full (OAuth + PAT) | Local: Docker or Go build, GitHub PAT<br>Remote: Copilot for Xcode 0.41.0+ | Easy |
3539
| Copilot in Eclipse || ✅ Full (OAuth + PAT) | Local: Docker or Go build, GitHub PAT<br>Remote: Eclipse Plug-in for Copilot 0.10.0+ | Easy |
3640
| Xcode (Codex) || ✅ PAT + ❌ No OAuth | Local: Docker (full path required), GitHub PAT<br>Remote: GitHub PAT via `GITHUB_PAT_TOKEN` env var (`bearer_token_env_var`) | Easy |
Lines changed: 154 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,154 @@
1+
# Install GitHub MCP Server in OpenCode
2+
3+
[OpenCode](https://opencode.ai) is a terminal-based AI coding agent that exposes MCP servers under the `mcp` key in `opencode.json` (or `opencode.jsonc`). For general setup information (prerequisites, Docker installation, security best practices), see the [Installation Guides README](./README.md).
4+
5+
## Prerequisites
6+
7+
1. OpenCode installed (`brew install sst/tap/opencode` or see [OpenCode install docs](https://opencode.ai/docs/))
8+
2. [GitHub Personal Access Token](https://github.com/settings/personal-access-tokens/new) with appropriate scopes
9+
3. For local installation: [Docker](https://www.docker.com/) installed and running
10+
11+
> [!IMPORTANT]
12+
> The OpenCode docs note that the GitHub MCP server can add a lot of tokens to your context. Consider limiting toolsets — for example, by setting `X-MCP-Toolsets` on the remote server or `--toolsets` on the local server — to keep prompts within your model's context window. See the [Server Configuration Guide](../server-configuration.md) and the [main README's toolsets section](../../README.md#available-toolsets).
13+
14+
## Remote Server (Recommended)
15+
16+
Uses GitHub's hosted server at `https://api.githubcopilot.com/mcp/`. Edit your [OpenCode config](https://opencode.ai/docs/config/) (typically `~/.config/opencode/opencode.json`, or `opencode.json` in your project root) and add the following under `mcp`:
17+
18+
```json
19+
{
20+
"$schema": "https://opencode.ai/config.json",
21+
"mcp": {
22+
"github": {
23+
"type": "remote",
24+
"url": "https://api.githubcopilot.com/mcp/",
25+
"enabled": true,
26+
"oauth": false,
27+
"headers": {
28+
"Authorization": "Bearer YOUR_GITHUB_PAT"
29+
}
30+
}
31+
}
32+
}
33+
```
34+
35+
Replace `YOUR_GITHUB_PAT` with your [GitHub Personal Access Token](https://github.com/settings/tokens). The `oauth: false` setting disables OpenCode's automatic OAuth discovery and tells it to use the PAT in `Authorization` instead — without this, OpenCode may try the OAuth flow first.
36+
37+
### Using an environment variable for the PAT
38+
39+
OpenCode supports environment-variable interpolation in config values via `{env:VAR_NAME}`. To avoid putting your PAT directly in `opencode.json`:
40+
41+
```json
42+
{
43+
"$schema": "https://opencode.ai/config.json",
44+
"mcp": {
45+
"github": {
46+
"type": "remote",
47+
"url": "https://api.githubcopilot.com/mcp/",
48+
"enabled": true,
49+
"oauth": false,
50+
"headers": {
51+
"Authorization": "Bearer {env:GITHUB_PERSONAL_ACCESS_TOKEN}"
52+
}
53+
}
54+
}
55+
}
56+
```
57+
58+
Set `GITHUB_PERSONAL_ACCESS_TOKEN` in your shell environment before starting OpenCode.
59+
60+
## Local Server (Docker)
61+
62+
The local GitHub MCP server runs via Docker and requires Docker Desktop (or another Docker runtime) to be installed and running.
63+
64+
```json
65+
{
66+
"$schema": "https://opencode.ai/config.json",
67+
"mcp": {
68+
"github": {
69+
"type": "local",
70+
"command": [
71+
"docker", "run", "-i", "--rm",
72+
"-e", "GITHUB_PERSONAL_ACCESS_TOKEN",
73+
"ghcr.io/github/github-mcp-server"
74+
],
75+
"enabled": true,
76+
"environment": {
77+
"GITHUB_PERSONAL_ACCESS_TOKEN": "YOUR_GITHUB_PAT"
78+
}
79+
}
80+
}
81+
}
82+
```
83+
84+
> [!IMPORTANT]
85+
> OpenCode expects `command` as a **single array** combining the executable and its arguments (e.g. `["docker", "run", "-i", ...]`), and the env-var key is `environment` (not `env`). This differs from hosts like Zed and Cursor.
86+
87+
## Verify Installation
88+
89+
1. Restart OpenCode (or start a new session).
90+
2. Check that the server is discovered:
91+
```sh
92+
opencode mcp list
93+
```
94+
3. Try a prompt that references the server by name to bias the model toward its tools:
95+
```
96+
Use the github tool to list my recently merged pull requests.
97+
```
98+
99+
## Managing the Server
100+
101+
OpenCode exposes a few useful subcommands for MCP servers:
102+
103+
| Command | Purpose |
104+
| --- | --- |
105+
| `opencode mcp list` | List configured MCP servers and their auth/connection status. |
106+
| `opencode mcp debug github` | Show auth status, test HTTP connectivity, and walk through OAuth discovery for the `github` server. |
107+
| `opencode mcp auth github` | Trigger an OAuth flow manually (only relevant if `oauth` is not set to `false`). |
108+
| `opencode mcp logout github` | Clear stored OAuth tokens for the server. |
109+
110+
## Disabling Tools Per-Agent
111+
112+
Because the GitHub MCP server can register a large number of tools, you may want to **disable them globally** and **re-enable them only for specific agents**. OpenCode uses the `<server-name>_*` glob pattern to match all tools from a server:
113+
114+
```json
115+
{
116+
"$schema": "https://opencode.ai/config.json",
117+
"mcp": {
118+
"github": {
119+
"type": "remote",
120+
"url": "https://api.githubcopilot.com/mcp/",
121+
"enabled": true,
122+
"oauth": false,
123+
"headers": { "Authorization": "Bearer {env:GITHUB_PERSONAL_ACCESS_TOKEN}" }
124+
}
125+
},
126+
"tools": {
127+
"github_*": false
128+
},
129+
"agent": {
130+
"github-helper": {
131+
"tools": { "github_*": true }
132+
}
133+
}
134+
}
135+
```
136+
137+
This pattern is recommended by the [OpenCode MCP docs](https://opencode.ai/docs/mcp-servers/) for servers with many tools.
138+
139+
## Troubleshooting
140+
141+
- **`401 Unauthorized` from the remote server**: confirm your PAT is valid and not expired. If you set `oauth: false`, OpenCode will not attempt an OAuth fallback — the `Authorization` header must be correct.
142+
- **Server marked failed in `opencode mcp list`**: run `opencode mcp debug github` to see the exact connectivity and auth diagnostics.
143+
- **Tools missing from prompts**: check that `enabled: true` is set on the server and that you have not disabled `github_*` in your `tools` block without re-enabling it for the current agent.
144+
- **Context window exceeded**: the GitHub MCP server can register many tools. Use server-side toolset filtering (`X-MCP-Toolsets` header) to register only the toolsets you need.
145+
- **Docker errors on the local server**: ensure Docker Desktop is running and the `ghcr.io/github/github-mcp-server` image has been pulled (`docker pull ghcr.io/github/github-mcp-server`).
146+
147+
## Important Notes
148+
149+
- **Configuration key**: OpenCode uses `mcp` (not `mcpServers` or `context_servers`).
150+
- **Type discriminator**: every entry must include `"type": "local"` or `"type": "remote"`.
151+
- **Command shape**: `command` is a single array combining the executable and its arguments.
152+
- **Environment variable key**: `environment` (not `env`).
153+
- **OAuth**: enabled by default for remote servers. Set `"oauth": false` when using PAT-in-`Authorization`, otherwise OpenCode may try OAuth first.
154+
- **Env interpolation**: use `{env:VAR_NAME}` in string values to read from the shell environment instead of hard-coding secrets.
Lines changed: 103 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,103 @@
1+
# Install GitHub MCP Server in Zed
2+
3+
[Zed](https://zed.dev) is a high-performance multiplayer code editor with native MCP support. Zed exposes MCP servers under the `context_servers` settings key. For general setup information (prerequisites, Docker installation, security best practices), see the [Installation Guides README](./README.md).
4+
5+
## Prerequisites
6+
7+
1. Zed installed (latest version — Zed v0.224.0+ recommended for the modern `agent.tool_permissions` settings shape)
8+
2. [GitHub Personal Access Token](https://github.com/settings/personal-access-tokens/new) with appropriate scopes
9+
3. For local installation: [Docker](https://www.docker.com/) installed and running
10+
11+
## Installation Methods
12+
13+
There are two ways to install the GitHub MCP server in Zed:
14+
15+
- **Option A — Zed Extension (easiest):** a community-maintained [GitHub MCP extension](https://zed.dev/extensions/mcp-server-github) is available in the Zed extension gallery. Install it from the Agent Panel's top-right menu → "View Server Extensions", or from the command palette via the `zed: extensions` action. After installation, Zed pops up a modal asking for your GitHub Personal Access Token.
16+
- **Option B — Custom Server (recommended for the official remote endpoint):** add the configuration manually to `settings.json` to use either GitHub's hosted remote server or the official Docker image directly. The rest of this guide covers Option B.
17+
18+
## Remote Server (Recommended)
19+
20+
Uses GitHub's hosted server at `https://api.githubcopilot.com/mcp/`. Open your Zed [settings file](https://zed.dev/docs/configuring-zed.html#settings-files) (Command Palette → `zed: open settings`) and add the configuration below under `context_servers`.
21+
22+
```json
23+
{
24+
"context_servers": {
25+
"github": {
26+
"url": "https://api.githubcopilot.com/mcp/",
27+
"headers": {
28+
"Authorization": "Bearer YOUR_GITHUB_PAT"
29+
}
30+
}
31+
}
32+
}
33+
```
34+
35+
Replace `YOUR_GITHUB_PAT` with your [GitHub Personal Access Token](https://github.com/settings/tokens). To customize toolsets, add server-side headers like `X-MCP-Toolsets` or `X-MCP-Readonly` to the `headers` object — see the [Server Configuration Guide](../server-configuration.md).
36+
37+
> [!NOTE]
38+
> If you omit the `Authorization` header, Zed will attempt the standard MCP OAuth flow on first use. The GitHub MCP server does not currently advertise OAuth for non-Copilot hosts, so a Personal Access Token in the `Authorization` header is the supported path.
39+
40+
## Local Server (Docker)
41+
42+
The local GitHub MCP server runs via Docker and requires Docker Desktop (or another Docker runtime) to be installed and running.
43+
44+
```json
45+
{
46+
"context_servers": {
47+
"github": {
48+
"command": "docker",
49+
"args": [
50+
"run", "-i", "--rm",
51+
"-e", "GITHUB_PERSONAL_ACCESS_TOKEN",
52+
"ghcr.io/github/github-mcp-server"
53+
],
54+
"env": {
55+
"GITHUB_PERSONAL_ACCESS_TOKEN": "YOUR_GITHUB_PAT"
56+
}
57+
}
58+
}
59+
}
60+
```
61+
62+
> [!IMPORTANT]
63+
> Zed expects `command` as a **string** plus a separate `args` array, not a single array combining both. This differs from hosts like OpenCode and Claude Desktop.
64+
65+
## Verify Installation
66+
67+
1. Open the Agent Panel and click into its Settings view (or run `agent: open settings`).
68+
2. Find `github` in the context servers list. A green indicator dot with the tooltip "Server is active" confirms a working configuration. Other colors and tooltip messages indicate startup or auth errors.
69+
3. Try a prompt that should invoke a tool — for example, `List my recent GitHub pull requests`. Zed will prompt for tool approval before the first call unless your `agent.tool_permissions.default` is set to `"allow"`.
70+
71+
## Tool Permissions (Optional)
72+
73+
Zed v0.224.0+ controls tool approval via `agent.tool_permissions`. Approve a specific GitHub MCP tool without per-call prompts by using the `mcp:<server>:<tool_name>` key format:
74+
75+
```json
76+
{
77+
"agent": {
78+
"tool_permissions": {
79+
"default": "confirm",
80+
"rules": [
81+
{ "tool": "mcp:github:list_pull_requests", "permission": "allow" },
82+
{ "tool": "mcp:github:list_issues", "permission": "allow" }
83+
]
84+
}
85+
}
86+
}
87+
```
88+
89+
See the [Zed tool permissions docs](https://zed.dev/docs/ai/tool-permissions.html) for the full schema.
90+
91+
## Troubleshooting
92+
93+
- **Server indicator stays red / "Server is not running"**: check the Agent Panel's settings view for the per-server error string. Most common cause is invalid JSON in `settings.json` — Zed surfaces JSON parse errors in the editor itself.
94+
- **`401 Unauthorized`**: verify your PAT has not expired and includes the scopes for the tools you intend to call. The remote endpoint will reject requests with no `Authorization` header (no anonymous access).
95+
- **Tools missing from prompts**: confirm the Agent profile in use has not disabled the server. If you're using a [custom profile](https://zed.dev/docs/ai/agent-panel.html#custom-profiles), make sure `enable_all_context_servers` is `true` or that `github` is explicitly listed.
96+
- **Docker errors on the local server**: ensure Docker Desktop is running and the `ghcr.io/github/github-mcp-server` image has been pulled at least once. Try `docker pull ghcr.io/github/github-mcp-server` from a terminal.
97+
98+
## Important Notes
99+
100+
- **Configuration key**: Zed uses `context_servers` (not `mcpServers`).
101+
- **Command shape**: `command` is a string + separate `args` array.
102+
- **OAuth**: omitting `Authorization` triggers Zed's MCP OAuth flow, but the GitHub MCP server's PAT-based auth is the supported path today.
103+
- **External agents**: MCP servers configured in `context_servers` are forwarded to [external agents](https://zed.dev/docs/ai/external-agents.html) via the Agent Client Protocol.

0 commit comments

Comments
 (0)