2
0

🐛 Add subscription handler in api folder

This commit is contained in:
Baptiste Arnaud
2024-04-16 15:13:44 +02:00
parent faa8d42b04
commit 5a99493ced
5 changed files with 81 additions and 36 deletions

View File

@ -15,7 +15,8 @@
"DATABASE_URL": "postgresql://postgres:typebot@127.0.0.1:5432/typebot",
"NEXT_PUBLIC_VIEWER_URL": "http://localhost:3001",
"NEXTAUTH_URL": "http://localhost:3000",
"ENCRYPTION_SECRET": "H+KbL/OFrqbEuDy/1zX8bsPG+spXri3S"
"ENCRYPTION_SECRET": "H+KbL/OFrqbEuDy/1zX8bsPG+spXri3S",
"S3_ENDPOINT": "http://localhost:9000"
},
"[prisma]": {
"editor.defaultFormatter": "Prisma.prisma"

View File

@ -3,6 +3,7 @@ import { TRPCError } from '@trpc/server'
import { env } from '@typebot.io/env'
import { z } from 'zod'
// TODO: Delete in favor of /api
export const subscribePreviewWebhook = publicProcedure
.meta({
openapi: {

View File

@ -6,27 +6,40 @@ import { resumeWhatsAppFlow } from '@typebot.io/bot-engine/whatsapp/resumeWhatsA
import { isNotDefined } from '@typebot.io/lib'
import { env } from '@typebot.io/env'
import { NextApiRequest, NextApiResponse } from 'next'
import { methodNotAllowed } from '@typebot.io/lib/api'
export default async function handler(
req: NextApiRequest,
res: NextApiResponse
) {
if (!env.WHATSAPP_PREVIEW_FROM_PHONE_NUMBER_ID)
return res
.status(500)
.send('WHATSAPP_PREVIEW_FROM_PHONE_NUMBER_ID is not defined')
const body = typeof req.body === 'string' ? JSON.parse(req.body) : req.body
const { entry } = whatsAppWebhookRequestBodySchema.parse(body)
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const ctx = globalThis[Symbol.for('@vercel/request-context')]
if (ctx?.get?.().waitUntil) {
ctx.get().waitUntil(() => processWhatsAppReply(entry))
return res.status(200).json({ message: 'Message is being processed.' })
if (req.method === 'GET') {
const token = req.query['hub.verify_token'] as string | undefined
const challenge = req.query['hub.challenge'] as string | undefined
if (token !== env.ENCRYPTION_SECRET)
return res.status(401).json({
error: 'Unauthorized',
})
return Number(challenge)
}
console.log('Processing message')
const { message } = await processWhatsAppReply(entry)
return res.status(200).json({ message })
if (req.method === 'POST') {
if (!env.WHATSAPP_PREVIEW_FROM_PHONE_NUMBER_ID)
return res
.status(500)
.send('WHATSAPP_PREVIEW_FROM_PHONE_NUMBER_ID is not defined')
const body = typeof req.body === 'string' ? JSON.parse(req.body) : req.body
const { entry } = whatsAppWebhookRequestBodySchema.parse(body)
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const ctx = globalThis[Symbol.for('@vercel/request-context')]
if (ctx?.get?.().waitUntil) {
ctx.get().waitUntil(() => processWhatsAppReply(entry))
return res.status(200).json({ message: 'Message is being processed.' })
}
console.log('Processing message')
const { message } = await processWhatsAppReply(entry)
return res.status(200).json({ message })
}
return methodNotAllowed(res)
}
const processWhatsAppReply = async (

View File

@ -3,6 +3,8 @@ import prisma from '@typebot.io/lib/prisma'
import { TRPCError } from '@trpc/server'
import { z } from 'zod'
// TODO: Delete in favor of /api
export const subscribeWebhook = publicProcedure
.meta({
openapi: {

View File

@ -5,6 +5,8 @@ import {
import { resumeWhatsAppFlow } from '@typebot.io/bot-engine/whatsapp/resumeWhatsAppFlow'
import { isNotDefined } from '@typebot.io/lib'
import { NextApiRequest, NextApiResponse } from 'next'
import prisma from '@typebot.io/lib/prisma'
import { methodNotAllowed } from '@typebot.io/lib/api/utils'
type Props = {
entry: WhatsAppWebhookRequestBody['entry']
@ -20,27 +22,53 @@ export default async function handler(
req: NextApiRequest,
res: NextApiResponse
) {
const workspaceId = req.query.workspaceId as string
const credentialsId = req.query.credentialsId as string
const body = typeof req.body === 'string' ? JSON.parse(req.body) : req.body
const { entry } = whatsAppWebhookRequestBodySchema.parse(body)
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const ctx = globalThis[Symbol.for('@vercel/request-context')]
if (ctx?.get?.().waitUntil) {
ctx
.get()
.waitUntil(() =>
processWhatsAppReply({ entry, workspaceId, credentialsId })
)
return res.status(200).json({ message: 'Message is being processed.' })
if (req.method === 'GET') {
const token = req.query['hub.verify_token'] as string | undefined
const challenge = req.query['hub.challenge'] as string | undefined
if (!token || !challenge)
return res.status(400).json({
error: 'hub.verify_token and hub.challenge are required',
})
const verificationToken = await prisma.verificationToken.findUnique({
where: {
token,
},
})
if (!verificationToken)
return res.status(401).json({
error: 'Unauthorized',
})
await prisma.verificationToken.delete({
where: {
token,
},
})
return Number(challenge)
}
const { message } = await processWhatsAppReply({
entry,
workspaceId,
credentialsId,
})
return res.status(200).json({ message })
if (req.method === 'POST') {
const workspaceId = req.query.workspaceId as string
const credentialsId = req.query.credentialsId as string
const body = typeof req.body === 'string' ? JSON.parse(req.body) : req.body
const { entry } = whatsAppWebhookRequestBodySchema.parse(body)
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const ctx = globalThis[Symbol.for('@vercel/request-context')]
if (ctx?.get?.().waitUntil) {
ctx
.get()
.waitUntil(() =>
processWhatsAppReply({ entry, workspaceId, credentialsId })
)
return res.status(200).json({ message: 'Message is being processed.' })
}
const { message } = await processWhatsAppReply({
entry,
workspaceId,
credentialsId,
})
return res.status(200).json({ message })
}
return methodNotAllowed(res)
}
const processWhatsAppReply = async ({