pinafore/src/routes/_api/oauth.js

38 lines
1.1 KiB
JavaScript
Raw Normal View History

import { post, paramsString, WRITE_TIMEOUT } from '../_utils/ajax'
2018-02-09 07:29:29 +01:00
import { basename } from './utils'
2018-01-13 23:19:51 +01:00
const WEBSITE = 'https://pinafore.social'
const SCOPES = 'read write follow push'
2018-01-13 23:19:51 +01:00
const CLIENT_NAME = 'Pinafore'
2018-02-09 07:29:29 +01:00
export function registerApplication (instanceName, redirectUri) {
const url = `${basename(instanceName)}/api/v1/apps`
return post(url, {
2018-02-09 07:29:29 +01:00
client_name: CLIENT_NAME,
redirect_uris: redirectUri,
scopes: SCOPES,
website: WEBSITE
}, null, { timeout: WRITE_TIMEOUT })
2018-01-13 23:19:51 +01:00
}
2018-02-09 07:29:29 +01:00
export function generateAuthLink (instanceName, clientId, redirectUri) {
2018-01-13 23:19:51 +01:00
let params = paramsString({
'client_id': clientId,
2018-01-14 04:23:05 +01:00
'redirect_uri': redirectUri,
2018-01-13 23:19:51 +01:00
'response_type': 'code',
'scope': SCOPES
})
return `${basename(instanceName)}/oauth/authorize?${params}`
2018-01-13 23:19:51 +01:00
}
2018-02-09 07:29:29 +01:00
export function getAccessTokenFromAuthCode (instanceName, clientId, clientSecret, code, redirectUri) {
let url = `${basename(instanceName)}/oauth/token`
return post(url, {
2018-01-13 23:19:51 +01:00
client_id: clientId,
client_secret: clientSecret,
2018-01-14 04:23:05 +01:00
redirect_uri: redirectUri,
2018-01-13 23:19:51 +01:00
grant_type: 'authorization_code',
code: code
}, null, { timeout: WRITE_TIMEOUT })
2018-02-09 07:29:29 +01:00
}