Note
GitHub Copilot Extensions se encuentra en versión preliminar pública y está sujeto a cambios.
Requisitos previos
Antes de configurar Copilot agent para comunicarse con GitHub, debe comprender cómo se comunica su Copilot agent con la plataforma de Copilot. Consulta Configuración del agente de Copilot para comunicarse con la plataforma de Copilot.
Comprobación de que las cargas proceden de GitHub
Antes de que Copilot agent comience a procesar una solicitud, debe comprobar que la solicitud procede de GitHub y que está pensada para su agente. Todas las solicitudes del agente contienen los encabezados X-GitHub-Public-Key-Identifier
y X-GitHub-Public-Key-Signature
. Para comprobar la firma de una solicitud determinada, compare la firma en el encabezado X-GitHub-Public-Key-Signature
con una copia firmada del cuerpo de la solicitud mediante la clave pública actual que se muestra en https://api.github.com/meta/public_keys/copilot_api.
Para obtener más detalles y ejemplos de comprobación de firmas en idiomas específicos, consulte el repositorio github-technology-partners/signature-verification
.
⚠️ Nota: Actualmente enviamos pares duplicados de estos encabezados. Un conjunto tiene el prefijo
Github-Public-...
y el otro tieneX-GitHub-Public...
. El primero se cerrar el 31 de marzo. Actualiza las comprobaciones pertinentes al prefijo correcto (X-GitHub-Public...
) antes de esa fecha.
Captura de recursos de la API de GitHub
Las solicitudes a Copilot agent tendrán un encabezado X-GitHub-Token
. Este encabezado contiene un token de API que se puede usar para capturar recursos de la API de GitHub en nombre del usuario que interactúa con el agente. Los permisos de este token son la superposición de los propios permisos del usuario y los permisos concedidos a la instalación de GitHub App.
Para obtener un ejemplo de cómo puede usar X-GitHub-Token
, vea el ejemplo de código siguiente:
async function whoami(req) {
const response = await fetch(
// The GitHub API endpoint for the authenticated user
"https://api.github.com/user",
{
headers: {
"Authorization": `Bearer ${req.headers.get("x-github-token")}`
}
}
)
const user = await response.json()
return user
}
Para obtener más información sobre cómo trabajar con la API de GitHub y explorar kits de desarrollo de software (SDK) oficiales), consulte la organización octokit
.