Segreto client e ID da deprecare nei prossimi mesi [duplicato]
Aug 20 2020
Il mio codice funziona ma il formato della richiesta sarà deprecato nei prossimi mesi.
Nuovo formato suggerito da Github
curl -u my_client_id:my_client_secret https://api.github.com/users/user
Qualcuno può mostrarmi il modo corretto per riformattarlo per quando sarà deprecato nei prossimi mesi. Ho provato di tutto. Ecco un esempio di quello che ho provato:
Il mio tentativo che non funziona
`-u ${this.client_id}:${this.client_secret} https://api.github.com/users/${user}`
Il mio codice attuale
class Github {
constructor() {
// THESE ARE FAKE!!!
this.client_id = 'a71344259aec03d0cea3';
this.client_secret = 'a28202377336e199cb554bd099e6e5fe672788db';
this.repos_count = 7;
this.repos_sort = 'created: asc';
}
async getUser(user) {
const profileResponse = await fetch(
`https://api.github.com/users/${user}?client_id=${this.client_id}&client_secret=${this.client_secret}`
);
const repoResponse = await fetch(
`https://api.github.com/users/${user}/repos?per_page=${this.repos_count}&sort=${this.repos_sort}&client_id=${this.client_id}&client_secret=${this.client_secret}`
);
console.log(user);
const profile = await profileResponse.json();
const repos = await repoResponse.json();
return {
profile,
repos,
};
}
}
Risposte
2 Phil Aug 20 2020 at 06:54
L' -u
opzione in curl
utilizza l'autenticazione HTTP di base .
Ciò che fa è prendere la user:password
stringa, codificarla in base64 (ad esempio user:password
=> dXNlcjpwYXNzd29yZA==
) e aggiungerla all'intestazione della Authorization
richiesta in questo modo
Authorization: Basic dXNlcjpwYXNzd29yZA==
Quando usi fetch
, devi farlo manualmente usando qualcosa di similebtoa()
const auth = btoa(`${this.client_id}:${this.client_secret}`)
fetch(`https://api.github.com/users/${encodeURIComponent(user)}`, {
headers: {
Authorization: `Basic ${auth}`
}
})