forked from ericc-ch/copilot-api
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapi-config.ts
More file actions
73 lines (63 loc) · 2.97 KB
/
api-config.ts
File metadata and controls
73 lines (63 loc) · 2.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import { randomUUID } from "node:crypto"
import { FALLBACK as COPILOT_CHAT_VERSION_FALLBACK } from "~/services/get-copilot-chat-version"
import { FALLBACK as VSCODE_VERSION_FALLBACK } from "~/services/get-vscode-version"
import type { State } from "./state"
export const standardHeaders = () => ({
"content-type": "application/json",
accept: "application/json",
})
const API_VERSION = "2025-04-01"
export const copilotBaseUrl = (state: State) =>
state.accountType === "individual" ?
"https://api.githubcopilot.com"
: `https://api.${state.accountType}.githubcopilot.com`
/**
* Headers sent with every upstream request to mimic VS Code Copilot Chat traffic.
*
* Header sources:
* - Authorization — Copilot token from GitHub OAuth flow
* - editor-version — Auto-detected VS Code stable release (update.code.visualstudio.com)
* - editor-plugin-version — Auto-detected GitHub.copilot-chat Marketplace version
* - user-agent — Same as editor-plugin-version, GitHubCopilotChat/<version>
* - copilot-integration-id — Fixed "vscode-chat"
* - openai-intent — Fixed "conversation-panel"
* - x-github-api-version — Fixed "2025-04-01" (verify periodically against VS Code source)
* - x-request-id — Per-request UUID via crypto.randomUUID()
* - x-vscode-user-agent-library-version — Fixed "electron-fetch"
* - copilot-vision-request — Added when request includes image content
*/
export const copilotHeaders = (state: State, vision: boolean = false) => {
const copilotVersion =
state.copilotChatVersion ?? COPILOT_CHAT_VERSION_FALLBACK
const headers: Record<string, string> = {
Authorization: `Bearer ${state.copilotToken}`,
"content-type": standardHeaders()["content-type"],
"copilot-integration-id": "vscode-chat",
"editor-version": `vscode/${state.vsCodeVersion ?? VSCODE_VERSION_FALLBACK}`,
"editor-plugin-version": `copilot-chat/${copilotVersion}`,
"user-agent": `GitHubCopilotChat/${copilotVersion}`,
"openai-intent": "conversation-panel",
"x-github-api-version": API_VERSION,
"x-request-id": randomUUID(),
"x-vscode-user-agent-library-version": "electron-fetch",
}
if (vision) headers["copilot-vision-request"] = "true"
return headers
}
export const GITHUB_API_BASE_URL = "https://api.github.com"
export const githubHeaders = (state: State) => {
const copilotVersion =
state.copilotChatVersion ?? COPILOT_CHAT_VERSION_FALLBACK
return {
...standardHeaders(),
authorization: `token ${state.githubToken}`,
"editor-version": `vscode/${state.vsCodeVersion ?? VSCODE_VERSION_FALLBACK}`,
"editor-plugin-version": `copilot-chat/${copilotVersion}`,
"user-agent": `GitHubCopilotChat/${copilotVersion}`,
"x-github-api-version": API_VERSION,
"x-vscode-user-agent-library-version": "electron-fetch",
}
}
export const GITHUB_BASE_URL = "https://github.com"
export const GITHUB_CLIENT_ID = "Iv1.b507a08c87ecfe98"
export const GITHUB_APP_SCOPES = ["read:user"].join(" ")