UNPKG

inngest

Version:

Official SDK for Inngest.com. Inngest is the reliability layer for modern applications. Inngest combines durable execution, events, and queues into a zero-infra platform with built-in observability.

66 lines (64 loc) 1.58 kB
const require_InngestCommHandler = require('./components/InngestCommHandler.cjs'); //#region src/astro.ts /** * An adapter for Astro to serve and register any declared functions with * Inngest, making them available to be triggered by events. * * @example * ```ts * export const { GET, POST, PUT } = serve({ * client: inngest, * functions: [fn1, fn2], * }); * ``` * * @module */ /** * The name of the framework, used to identify the framework in Inngest * dashboards and during testing. */ const frameworkName = "astro"; /** * In Astro, serve and register any declared functions with Inngest, making them * available to be triggered by events. * * @example * ```ts * export const { GET, POST, PUT } = serve({ * client: inngest, * functions: [fn1, fn2], * }); * ``` * * @public */ const serve = (options) => { const requestHandler = new require_InngestCommHandler.InngestCommHandler({ frameworkName, ...options, handler: ({ request: req }) => { return { body: () => req.text(), headers: (key) => req.headers.get(key), method: () => req.method, url: () => new URL(req.url, `https://${req.headers.get("host") || ""}`), transformResponse: ({ body, status, headers }) => { return new Response(body, { status, headers }); } }; } }).createHandler(); return Object.defineProperties(requestHandler, { GET: { value: requestHandler }, POST: { value: requestHandler }, PUT: { value: requestHandler } }); }; //#endregion exports.frameworkName = frameworkName; exports.serve = serve; //# sourceMappingURL=astro.cjs.map