phanpy/src/utils/auth.js

65 lines
1.8 KiB
JavaScript
Raw Normal View History

2022-12-10 17:14:48 +08:00
const { VITE_CLIENT_NAME: CLIENT_NAME, VITE_WEBSITE: WEBSITE } = import.meta
.env;
const SCOPES = 'read write follow push';
2022-12-10 17:14:48 +08:00
export async function registerApplication({ instanceURL }) {
const registrationParams = new URLSearchParams({
client_name: CLIENT_NAME,
2023-08-30 17:46:22 +08:00
redirect_uris: location.origin + location.pathname,
scopes: SCOPES,
2022-12-10 17:14:48 +08:00
website: WEBSITE,
});
const registrationResponse = await fetch(
`https://${instanceURL}/api/v1/apps`,
{
method: 'POST',
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
},
body: registrationParams.toString(),
},
);
const registrationJSON = await registrationResponse.json();
console.log({ registrationJSON });
return registrationJSON;
}
export async function getAuthorizationURL({ instanceURL, client_id }) {
const authorizationParams = new URLSearchParams({
client_id,
scope: SCOPES,
2023-08-30 17:46:22 +08:00
redirect_uri: location.origin + location.pathname,
2022-12-10 17:14:48 +08:00
// redirect_uri: 'urn:ietf:wg:oauth:2.0:oob',
response_type: 'code',
});
const authorizationURL = `https://${instanceURL}/oauth/authorize?${authorizationParams.toString()}`;
return authorizationURL;
}
export async function getAccessToken({
instanceURL,
client_id,
client_secret,
code,
}) {
const params = new URLSearchParams({
client_id,
client_secret,
2023-08-30 17:46:22 +08:00
redirect_uri: location.origin + location.pathname,
2022-12-10 17:14:48 +08:00
grant_type: 'authorization_code',
code,
scope: SCOPES,
2022-12-10 17:14:48 +08:00
});
const tokenResponse = await fetch(`https://${instanceURL}/oauth/token`, {
method: 'POST',
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
},
body: params.toString(),
});
const tokenJSON = await tokenResponse.json();
console.log({ tokenJSON });
return tokenJSON;
}