先决条件
- 必须对用户进行身份验证(GitHub令牌或登录用户)
- 会话的工作目录必须是GitHub存储库
启用远程会话
始终开启(客户端级别)
创建客户端时设置 remote: true 。 GitHub存储库中的每个会话都会自动获取远程 URL。
TypeScript
import { CopilotClient } from "@github/copilot-sdk";
const client = new CopilotClient({ remote: true });
const session = await client.createSession({
workingDirectory: "/path/to/github-repo",
onPermissionRequest: async () => ({ allowed: true }),
});
session.on("session.info", (event) => {
if (event.data.infoType === "remote") {
console.log("Remote URL:", event.data.url);
}
});
Python
from copilot import CopilotClient
client = CopilotClient(enable_remote_sessions=True)
session = await client.create_session(
working_directory="/path/to/github-repo",
on_permission_request=lambda req: {"allowed": True},
)
def on_event(event):
if event.type == "session.info" and event.data.info_type == "remote":
print(f"Remote URL: {event.data.url}")
session.on(on_event)
Go
client, _ := copilot.NewClient(&copilot.ClientOptions{Remote: true})
session, _ := client.CreateSession(ctx, &copilot.SessionConfig{
WorkingDirectory: "/path/to/github-repo",
OnPermissionRequest: func(req copilot.PermissionRequest, inv copilot.PermissionInvocation) (rpc.PermissionDecision, error) {
return &rpc.PermissionDecisionApproveOnce{}, nil
},
})
session.On(func(event copilot.SessionEvent) {
if event.Type == "session.info" {
// Check infoType and extract URL
}
})
C#
var client = new CopilotClient(new CopilotClientOptions { Remote = true });
var session = await client.CreateSessionAsync(new SessionConfig
{
WorkingDirectory = "/path/to/github-repo",
OnPermissionRequest = (req, inv) =>
Task.FromResult(PermissionDecision.ApproveOnce()),
});
session.On((SessionEvent e) =>
{
if (e is SessionInfoEvent info && info.Data.InfoType == "remote")
{
Console.WriteLine($"Remote URL: {info.Data.Url}");
}
});
Rust
use github_copilot_sdk::{Client, ClientOptions, SessionConfig};
use github_copilot_sdk::handler::PermissionResult;
let client = Client::start(
ClientOptions::new().with_enable_remote_sessions(true)
).await?;
let session = client.create_session(
SessionConfig::new("/path/to/github-repo")
.with_permission_handler(|_req, _inv| async {
Ok(PermissionResult::approve_once())
}),
).await?;
let mut events = session.subscribe();
while let Ok(event) = events.recv().await {
if event.event_type == "session.info" {
// Check info_type and extract URL
}
}
云会话
设置创建会话 cloud 选项以在云中创建远程会话,而不是本地会话。 可以包含存储库元数据,以便将云会话与GitHub存储库相关联。
TypeScript
const session = await client.createSession({
onPermissionRequest: async () => ({ allowed: true }),
cloud: {
repository: { owner: "github", name: "copilot-sdk", branch: "main" },
},
});
Python
from copilot import CloudSessionOptions, CloudSessionRepository
session = await client.create_session(
on_permission_request=PermissionHandler.approve_all,
cloud=CloudSessionOptions(
repository=CloudSessionRepository(
owner="github",
name="copilot-sdk",
branch="main",
)
),
)
Go
session, err := client.CreateSession(ctx, &copilot.SessionConfig{
Cloud: &copilot.CloudSessionOptions{
Repository: &copilot.CloudSessionRepository{
Owner: "github",
Name: "copilot-sdk",
Branch: "main",
},
},
})
C#
var session = await client.CreateSessionAsync(new SessionConfig
{
Cloud = new CloudSessionOptions
{
Repository = new CloudSessionRepository
{
Owner = "github",
Name = "copilot-sdk",
Branch = "main"
}
}
});
Rust
use github_copilot_sdk::{CloudSessionOptions, CloudSessionRepository, SessionConfig};
let session = client.create_session(
SessionConfig::default().with_cloud(
CloudSessionOptions::with_repository(
CloudSessionRepository::new("github", "copilot-sdk").with_branch("main"),
),
),
).await?;
按需(每会话切换)
使用 session.rpc.remote.enable() 在会话进行中启动远程访问,并使用 session.rpc.remote.disable() 停止远程访问。 这相当于 CLI 的 /remote on 和 /remote off 命令。
TypeScript
const result = await session.rpc.remote.enable();
console.log("Remote URL:", result.url);
// Later: stop sharing
await session.rpc.remote.disable();
Python
result = await session.rpc.remote.enable()
print(f"Remote URL: {result.url}")
# Later: stop sharing
await session.rpc.remote.disable()
Go
result, err := session.RPC.Remote.Enable(ctx)
if result.URL != nil {
fmt.Println("Remote URL:", *result.URL)
}
// Later: stop sharing
err = session.RPC.Remote.Disable(ctx)
C#
var result = await session.Rpc.Remote.EnableAsync();
Console.WriteLine($"Remote URL: {result.Url}");
// Later: stop sharing
await session.Rpc.Remote.DisableAsync();
Rust
let result = session.rpc().remote().enable().await?;
if let Some(url) = &result.url {
println!("Remote URL: {url}");
}
// Later: stop sharing
session.rpc().remote().disable().await?;
QR 码生成
远程 URL 可以呈现为 QR 码,以便轻松进行移动访问。 SDK 提供 URL - 使用首选 QR 码库:
笔记
- 客户端
remote选项仅适用于 SDK 生成 CLI 进程时。 通过cliUrl连接外部服务器时,会忽略它。 - 会话
cloud选项仅适用于使用session.create创建的新会话;在恢复现有会话时不使用该选项。 - 如果工作目录不是 GitHub 仓库,则会静默跳过远程配置(始终启用模式),或返回错误(按需模式)。
- 远程会话需要身份验证。 确保
gitHubToken或useLoggedInUser已配置。