import { NextApiRequest, NextApiResponse } from 'next' import { drive } from '@googleapis/drive' import { getAuthenticatedGoogleClient } from '@/lib/googleSheets' import { badRequest, methodNotAllowed, notAuthenticated } from 'utils/api' import { setUser, withSentry } from '@sentry/nextjs' import { getAuthenticatedUser } from '@/features/auth/api' const handler = async (req: NextApiRequest, res: NextApiResponse) => { const user = await getAuthenticatedUser(req) if (!user) return notAuthenticated(res) setUser({ email: user.email ?? undefined, id: user.id }) if (req.method === 'GET') { const credentialsId = req.query.credentialsId as string | undefined if (!credentialsId) return badRequest(res) const auth = await getAuthenticatedGoogleClient(user.id, credentialsId) if (!auth) return res.status(404).send("Couldn't find credentials in database") const response = await drive({ version: 'v3', auth: auth.client, }).files.list({ q: "mimeType='application/vnd.google-apps.spreadsheet'", fields: 'nextPageToken, files(id, name)', }) return res.send(response.data) } return methodNotAllowed(res) } export default withSentry(handler)