mirror of
https://github.com/documenso/documenso.git
synced 2025-11-24 21:51:40 +10:00
fix: optimize webhook routing
This commit is contained in:
@ -1,3 +1,4 @@
|
|||||||
|
// Todo: [Webhooks] delete file after deployment.
|
||||||
import { handlerTriggerWebhooks } from '@documenso/lib/server-only/webhooks/trigger/handler';
|
import { handlerTriggerWebhooks } from '@documenso/lib/server-only/webhooks/trigger/handler';
|
||||||
|
|
||||||
import type { Route } from './+types/webhook.trigger';
|
import type { Route } from './+types/webhook.trigger';
|
||||||
|
|||||||
@ -13,6 +13,7 @@ export type HandlerTriggerWebhooksResponse =
|
|||||||
error: string;
|
error: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Todo: [Webhooks] delete after deployment.
|
||||||
export const handlerTriggerWebhooks = async (req: Request) => {
|
export const handlerTriggerWebhooks = async (req: Request) => {
|
||||||
const signature = req.headers.get('x-webhook-signature');
|
const signature = req.headers.get('x-webhook-signature');
|
||||||
|
|
||||||
|
|||||||
@ -1,7 +1,6 @@
|
|||||||
import type { WebhookTriggerEvents } from '@prisma/client';
|
import type { WebhookTriggerEvents } from '@prisma/client';
|
||||||
|
|
||||||
import { NEXT_PRIVATE_INTERNAL_WEBAPP_URL } from '../../../constants/app';
|
import { jobs } from '../../../jobs/client';
|
||||||
import { sign } from '../../crypto/sign';
|
|
||||||
import { getAllWebhooksByEventTrigger } from '../get-all-webhooks-by-event-trigger';
|
import { getAllWebhooksByEventTrigger } from '../get-all-webhooks-by-event-trigger';
|
||||||
|
|
||||||
export type TriggerWebhookOptions = {
|
export type TriggerWebhookOptions = {
|
||||||
@ -13,35 +12,26 @@ export type TriggerWebhookOptions = {
|
|||||||
|
|
||||||
export const triggerWebhook = async ({ event, data, userId, teamId }: TriggerWebhookOptions) => {
|
export const triggerWebhook = async ({ event, data, userId, teamId }: TriggerWebhookOptions) => {
|
||||||
try {
|
try {
|
||||||
const body = {
|
|
||||||
event,
|
|
||||||
data,
|
|
||||||
userId,
|
|
||||||
teamId,
|
|
||||||
};
|
|
||||||
|
|
||||||
const registeredWebhooks = await getAllWebhooksByEventTrigger({ event, userId, teamId });
|
const registeredWebhooks = await getAllWebhooksByEventTrigger({ event, userId, teamId });
|
||||||
|
|
||||||
if (registeredWebhooks.length === 0) {
|
if (registeredWebhooks.length === 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const signature = sign(body);
|
await Promise.allSettled(
|
||||||
|
registeredWebhooks.map(async (webhook) => {
|
||||||
await Promise.race([
|
await jobs.triggerJob({
|
||||||
fetch(`${NEXT_PRIVATE_INTERNAL_WEBAPP_URL()}/api/webhook/trigger`, {
|
name: 'internal.execute-webhook',
|
||||||
method: 'POST',
|
payload: {
|
||||||
headers: {
|
event,
|
||||||
'content-type': 'application/json',
|
webhookId: webhook.id,
|
||||||
'x-webhook-signature': signature,
|
data,
|
||||||
},
|
},
|
||||||
body: JSON.stringify(body),
|
});
|
||||||
}),
|
}),
|
||||||
new Promise((_, reject) => {
|
);
|
||||||
setTimeout(() => reject(new Error('Request timeout')), 500);
|
|
||||||
}),
|
|
||||||
]).catch(() => null);
|
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
|
console.error(err);
|
||||||
throw new Error(`Failed to trigger webhook`);
|
throw new Error(`Failed to trigger webhook`);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user