Polarcraft/web/server/api/auth/index.js

53 lines
1.6 KiB
JavaScript
Raw Normal View History

2023-04-23 10:15:25 +02:00
export default defineEventHandler(async (event) => {
const { code } = getQuery(event)
const config = useRuntimeConfig()
2023-04-25 15:51:20 +02:00
if (!code) return sendRedirect(event, '/', 302)
2023-04-23 10:15:25 +02:00
try {
const tokenResponseData = await $fetch('https://discord.com/api/oauth2/token', {
method: 'POST',
body: new URLSearchParams({
client_id: config.discordId,
client_secret: config.discordSecret,
code: code,
grant_type: 'authorization_code',
2023-05-11 19:46:18 +02:00
redirect_uri: config.redirectURI,
2023-04-23 10:15:25 +02:00
scope: 'identify',
}).toString(),
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
})
2023-04-23 17:16:53 +02:00
const userResult = await $fetch('https://discord.com/api/users/@me', {
headers: {
authorization: `Bearer ${tokenResponseData.access_token}`
}
})
const coll = db.collection('users')
const doc = {
discord: {
id: userResult.id,
username: userResult.username,
avatarHash: userResult.avatar || null
},
}
2023-05-09 13:57:01 +02:00
await coll.updateOne({ 'discord.id': userResult.id }, { $set: doc, $setOnInsert: { minecraft: { uuid: null, username: null }, teamInvites: [] } }, { upsert: true })
2023-04-23 10:15:25 +02:00
2023-04-25 15:51:20 +02:00
const token = createToken(tokenResponseData.access_token, tokenResponseData.refresh_token, tokenResponseData.expires_in, userResult.id )
2023-04-23 10:15:25 +02:00
setCookie(event, 'jwt', token, { httpOnly: true, maxAge: tokenResponseData.expires_in * 1000 })
} catch (e) {
console.log(e)
2023-05-09 16:01:19 +02:00
throw createError({ statusCode: 500, statusMessage: 'Error tijdens het genereren van JWT token'})
2023-04-23 10:15:25 +02:00
}
return sendRedirect(event, '/', 302)
});