2022-11-15 23:48:23 +08:00
|
|
|
import { stringifyQuery } from 'vue-router'
|
2022-12-22 02:12:37 +00:00
|
|
|
import { createError, defineEventHandler, getQuery, getRouterParams, sendRedirect } from 'h3'
|
2022-11-29 22:55:53 +00:00
|
|
|
import { getApp, getRedirectURI } from '~/server/shared'
|
2022-11-15 19:54:07 +08:00
|
|
|
|
2022-11-26 17:56:35 +00:00
|
|
|
export default defineEventHandler(async (event) => {
|
2023-01-02 03:30:39 +08:00
|
|
|
const { origin } = getQuery(event) as { origin: string }
|
2022-12-24 01:51:45 +01:00
|
|
|
let { server } = getRouterParams(event)
|
|
|
|
server = server.toLocaleLowerCase().trim()
|
2023-01-02 03:30:39 +08:00
|
|
|
const app = await getApp(origin, server)
|
2022-11-15 22:29:46 +08:00
|
|
|
|
|
|
|
if (!app) {
|
2022-11-29 22:55:53 +00:00
|
|
|
throw createError({
|
|
|
|
statusCode: 400,
|
|
|
|
statusMessage: `App not registered for server: ${server}`,
|
|
|
|
})
|
2022-11-15 22:29:46 +08:00
|
|
|
}
|
|
|
|
|
2022-11-26 17:56:35 +00:00
|
|
|
const { code } = getQuery(event)
|
2022-11-29 22:55:53 +00:00
|
|
|
if (!code) {
|
|
|
|
throw createError({
|
|
|
|
statusCode: 422,
|
|
|
|
statusMessage: 'Missing authentication code.',
|
|
|
|
})
|
|
|
|
}
|
2022-11-15 19:54:07 +08:00
|
|
|
|
2022-11-15 23:48:23 +08:00
|
|
|
const result: any = await $fetch(`https://${server}/oauth/token`, {
|
2022-11-15 19:54:07 +08:00
|
|
|
method: 'POST',
|
|
|
|
body: {
|
2022-11-15 22:29:46 +08:00
|
|
|
client_id: app.client_id,
|
|
|
|
client_secret: app.client_secret,
|
2023-01-02 03:30:39 +08:00
|
|
|
redirect_uri: getRedirectURI(origin, server),
|
2022-11-15 19:54:07 +08:00
|
|
|
grant_type: 'authorization_code',
|
|
|
|
code,
|
|
|
|
scope: 'read write follow push',
|
|
|
|
},
|
|
|
|
})
|
2022-11-15 22:29:46 +08:00
|
|
|
|
2022-12-18 00:29:16 +01:00
|
|
|
const url = `/signin/callback?${stringifyQuery({ server, token: result.access_token, vapid_key: app.vapid_key })}`
|
2022-11-26 17:56:35 +00:00
|
|
|
await sendRedirect(event, url, 302)
|
2022-11-15 19:54:07 +08:00
|
|
|
})
|