import { NextApiRequest, NextApiResponse } from 'next' import { drive } from '@googleapis/drive' import { getAuthenticatedGoogleClient } from 'libs/google-sheets' import { methodNotAllowed, notAuthenticated } from 'utils' import { setUser, withSentry } from '@sentry/nextjs' import { getAuthenticatedUser } from 'services/api/utils' 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.toString() 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', // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore auth: auth, }).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)