opencode serve コマンドは、OpenCode クライアントが使用できる OpenAPI エンドポイントを公開するヘッドレス HTTP サーバーを実行します。
opencode serve [--port <number>] [--hostname <string>] [--cors <origin>]
| フラグ | 説明 | デフォルト |
|---|
--port | リッスンするポート | 4096 |
--hostname | リッスンするホスト名 | 127.0.0.1 |
--mdns | mDNS 検出を有効にする | false |
--mdns-domain | mDNS サービスのカスタムドメイン名 | opencode.local |
--cors | 許可する追加のブラウザーオリジン | [] |
--cors は複数回渡すことができます。
opencode serve --cors http://localhost:5173 --cors https://app.example.com
HTTP 基本認証でサーバーを保護するには、OPENCODE_SERVER_PASSWORD を設定します。ユーザー名はデフォルトで opencode になるか、OPENCODE_SERVER_USERNAME を設定してオーバーライドします。これは、opencode serve と opencode web の両方に当てはまります。
OPENCODE_SERVER_PASSWORD=your-password opencode serve
opencode を実行すると、TUI とサーバーが起動します。 TUI はサーバーと通信するクライアントです。サーバーは OpenAPI 3.1 仕様のエンドポイントを公開します。このエンドポイントは、SDK を使用してアクセスできます。
opencode serve を実行してスタンドアロンサーバーを起動できます。すでに OpenCode TUI を実行している場合でも、opencode serve は新しいサーバーを起動します。
TUI を起動すると、ポートとホスト名がランダムに割り当てられます。代わりに、--hostname と --port フラグ を使用して固定できます。次に、これを使用してサーバーに接続します。
/tui エンドポイントは、サーバー経由で TUI を駆動するために使用できます。たとえば、プロンプトを事前入力したり、実行したりできます。この設定は、OpenCode IDE プラグインによって使用されます。
サーバーは、次の場所で閲覧できる OpenAPI 3.1 仕様を公開しています。
http://<hostname>:<port>/doc
たとえば、http://localhost:4096/doc。この仕様を使用して、クライアントを生成したり、要求と応答のタイプを検査したりできます。または、Swagger エクスプローラーで表示します。
OpenCode サーバーは次の API を公開します。
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /global/health | サーバーの健全性とバージョンを取得する | { healthy: true, version: string } |
GET | /global/event | グローバルイベントの取得 (SSE ストリーム) | イベントストリーム |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /project | すべてのプロジェクトをリストする | Project[] |
GET | /project/current | 現在のプロジェクトを取得 | Project |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /path | 現在のパスを取得する | Path |
GET | /vcs | 現在のプロジェクトの VCS 情報を取得する | VcsInfo |
| メソッド | パス | 説明 | レスポンス |
|---|
POST | /instance/dispose | 現在のインスタンスを破棄する | void |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /config | 設定情報を取得する | Config |
PATCH | /config | 設定を更新する | Config |
GET | /config/providers | プロバイダーとデフォルトのモデルをリストする | { providers: Provider[], default: { [key: string]: string } } |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /provider | すべてのプロバイダーをリストする | { all: Provider[], default: {...}, connected: string[] } |
GET | /provider/auth | プロバイダーの認証方法を取得する | { [providerID: string]: ProviderAuthMethod[] } |
POST | /provider/{id}/oauth/authorize | OAuth を使用してプロバイダーを認証する | ProviderAuthAuthorization |
POST | /provider/{id}/oauth/callback | プロバイダーの OAuth コールバックを処理する | void |
| メソッド | パス | 説明 | 詳細 |
|---|
GET | /session | すべてのセッションをリストする | 戻り値 Session[] |
POST | /session | 新しいセッションを作成する | 本文: { parentID?, title? }、Session を返します。 |
GET | /session/status | すべてのセッションのセッションステータスを取得する | 戻り値 { [sessionID: string]: SessionStatus } |
GET | /session/:id | セッションの詳細を取得する | 戻り値 Session |
DELETE | /session/:id | セッションとそのすべてのデータを削除する | 戻り値 boolean |
PATCH | /session/:id | セッションのプロパティを更新する | 本文: { title? }、Session を返します。 |
GET | /session/:id/children | セッションの子セッションを取得する | 戻り値 Session[] |
GET | /session/:id/todo | セッションの ToDo リストを取得する | 戻り値 Todo[] |
POST | /session/:id/init | アプリを分析して AGENTS.md を作成する | 本文: { messageID, providerID, modelID }、boolean を返します。 |
POST | /session/:id/fork | メッセージで既存のセッションをフォークする | 本文: { messageID? }、Session を返します。 |
POST | /session/:id/abort | 実行中のセッションを中止する | 戻り値 boolean |
POST | /session/:id/share | セッションを共有する | 戻り値 Session |
DELETE | /session/:id/share | セッションの共有を解除する | 戻り値 Session |
GET | /session/:id/diff | このセッションの差分を取得する | クエリ: messageID?、FileDiff[] を返します。 |
POST | /session/:id/summarize | セッションを要約する | 本文: { providerID, modelID }、boolean を返します。 |
POST | /session/:id/revert | メッセージを元に戻す | 本文: { messageID, partID? }、boolean を返します。 |
POST | /session/:id/unrevert | 元に戻したすべてのメッセージを復元する | 戻り値 boolean |
POST | /session/:id/permissions/:permissionID | 許可リクエストに応答する | 本文: { response, remember? }、boolean を返します。 |
| メソッド | パス | 説明 | 詳細 |
|---|
GET | /session/:id/message | セッション内のメッセージをリストする | クエリ: limit?、{ info: Message, parts: Part[]}[] を返します。 |
POST | /session/:id/message | メッセージを送信して応答を待ちます | 本文: { messageID?, model?, agent?, noReply?, system?, tools?, parts }、{ info: Message, parts: Part[]} を返します |
GET | /session/:id/message/:messageID | メッセージの詳細を取得する | 戻り値 { info: Message, parts: Part[]} |
POST | /session/:id/prompt_async | メッセージを非同期に送信する (待機なし) | body: /session/:id/message と同じ、204 No Content を返します。 |
POST | /session/:id/command | スラッシュコマンドを実行します | 本文: { messageID?, agent?, model?, command, arguments }、{ info: Message, parts: Part[]} を返します |
POST | /session/:id/shell | シェルコマンドを実行する | 本文: { agent, model?, command }、{ info: Message, parts: Part[]} を返します |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /command | すべてのコマンドをリストする | Command[] |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /find?pattern=<pat> | ファイル内のテキストを検索 | path、lines、line_number、absolute_offset、submatches と一致するオブジェクトの配列 |
GET | /find/file?query=<q> | ファイルとディレクトリを名前で検索する | string[] (パス) |
GET | /find/symbol?query=<q> | ワークスペースのシンボルを検索する | Symbol[] |
GET | /file?path=<path> | ファイルとディレクトリをリストする | FileNode[] |
GET | /file/content?path=<p> | ファイルを読む | FileContent |
GET | /file/status | 追跡されたファイルのステータスを取得する | File[] |
query (必須) — 検索文字列 (あいまい一致)
type (オプション) — 結果を "file" または "directory" に制限します
directory (オプション) — 検索用のプロジェクトルートをオーバーライドします。
limit (オプション) — 最大結果 (1 ~ 200)
dirs (オプション) — 従来のフラグ ("false" はファイルのみを返します)
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /experimental/tool/ids | すべてのツール ID をリストする | ToolIDs |
GET | /experimental/tool?provider=<p>&model=<m> | モデルの JSON スキーマを含むツールをリストする | ToolList |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /lsp | LSP サーバーのステータスを取得 | LSPStatus[] |
GET | /formatter | フォーマッタのステータスを取得する | FormatterStatus[] |
GET | /mcp | MCP サーバーのステータスを取得する | { [name: string]: MCPStatus } |
POST | /mcp | MCP サーバーを動的に追加する | 本文: { name, config }、MCP ステータスオブジェクトを返します。 |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /agent | 利用可能なすべてのエージェントをリストする | Agent[] |
| メソッド | パス | 説明 | レスポンス |
|---|
POST | /log | ログエントリを書き込みます。本体:{ service, level, message, extra? } | void |
| メソッド | パス | 説明 | レスポンス |
|---|
POST | /tui/append-prompt | プロンプトにテキストを追加します | void |
POST | /tui/open-help | ヘルプダイアログを開く | void |
POST | /tui/open-sessions | セッションセレクターを開く | void |
POST | /tui/open-themes | テーマセレクターを開く | void |
POST | /tui/open-models | モデルセレクターを開く | void |
POST | /tui/submit-prompt | 現在のプロンプトを送信します | void |
POST | /tui/clear-prompt | プロンプトをクリア | void |
POST | /tui/execute-command | コマンドを実行する ({ command }) | void |
POST | /tui/show-toast | トーストを表示 ({ title?, message, variant }) | void |
GET | /tui/control/next | 次の制御リクエストを待ちます | 制御リクエストオブジェクト |
POST | /tui/control/response | 制御リクエストに応答する ({ body }) | void |
| メソッド | パス | 説明 | レスポンス |
|---|
PUT | /auth/:id | 認証資格情報を設定します。本文はプロバイダーのスキーマと一致する必要があります | void |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /event | サーバー送信イベントストリーム。最初のイベントは server.connected、次にバスイベント | サーバー送信イベントストリーム |
| メソッド | パス | 説明 | レスポンス |
|---|
GET | /doc | OpenAPI 3.1 仕様 | OpenAPI 仕様を備えた HTML ページ |