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
JavaScript
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