2022-12-10 17:14:48 +08:00
|
|
|
const { VITE_CLIENT_NAME: CLIENT_NAME, VITE_WEBSITE: WEBSITE } = import.meta
|
|
|
|
.env;
|
|
|
|
|
2023-09-01 15:40:00 +08:00
|
|
|
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,
|
2023-09-01 15:40:00 +08:00
|
|
|
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,
|
2023-09-01 15:40:00 +08:00
|
|
|
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,
|
2023-09-01 15:40:00 +08:00
|
|
|
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;
|
|
|
|
}
|