39 lines
1.3 KiB
TypeScript
39 lines
1.3 KiB
TypeScript
import type {NextApiRequest, NextApiResponse} from 'next';
|
|
import {getSession} from "next-auth/client";
|
|
import prisma from "../../../../lib/prisma";
|
|
|
|
const client_id = process.env.ZOOM_CLIENT_ID;
|
|
const client_secret = process.env.ZOOM_CLIENT_SECRET;
|
|
|
|
export default async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|
const { code } = req.query;
|
|
|
|
// Check that user is authenticated
|
|
const session = await getSession({req: req});
|
|
|
|
if (!session) { res.status(401).json({message: 'You must be logged in to do this'}); return; }
|
|
|
|
const redirectUri = encodeURI(process.env.BASE_URL + '/api/integrations/zoomvideo/callback');
|
|
const authHeader = 'Basic ' + Buffer.from(client_id + ':' + client_secret).toString('base64');
|
|
|
|
return new Promise( async (resolve, reject) => {
|
|
const result = await fetch('https://zoom.us/oauth/token?grant_type=authorization_code&code=' + code + '&redirect_uri=' + redirectUri, {
|
|
method: 'POST',
|
|
headers: {
|
|
Authorization: authHeader
|
|
}
|
|
})
|
|
.then(res => res.json());
|
|
|
|
await prisma.credential.create({
|
|
data: {
|
|
type: 'zoom_video',
|
|
key: result,
|
|
userId: session.user.id
|
|
}
|
|
});
|
|
|
|
res.redirect('/integrations');
|
|
resolve();
|
|
});
|
|
} |