Aktueller Stand

This commit is contained in:
2026-01-23 01:33:35 +01:00
parent 082dc5e110
commit 2766dd12c5
10109 changed files with 1578841 additions and 77685 deletions

View File

@@ -0,0 +1,366 @@
// src/adapter/aws-lambda/handler.ts
import { decodeBase64, encodeBase64 } from "../../utils/encode.js";
function sanitizeHeaderValue(value) {
const hasNonAscii = /[^\x00-\x7F]/.test(value);
if (!hasNonAscii) {
return value;
}
return encodeURIComponent(value);
}
var getRequestContext = (event) => {
return event.requestContext;
};
var streamToNodeStream = async (reader, writer) => {
let readResult = await reader.read();
while (!readResult.done) {
writer.write(readResult.value);
readResult = await reader.read();
}
writer.end();
};
var streamHandle = (app) => {
return awslambda.streamifyResponse(
async (event, responseStream, context) => {
const processor = getProcessor(event);
try {
const req = processor.createRequest(event);
const requestContext = getRequestContext(event);
const res = await app.fetch(req, {
event,
requestContext,
context
});
const headers = {};
const cookies = [];
res.headers.forEach((value, name) => {
if (name === "set-cookie") {
cookies.push(value);
} else {
headers[name] = value;
}
});
const httpResponseMetadata = {
statusCode: res.status,
headers,
cookies
};
responseStream = awslambda.HttpResponseStream.from(responseStream, httpResponseMetadata);
if (res.body) {
await streamToNodeStream(res.body.getReader(), responseStream);
} else {
responseStream.write("");
}
} catch (error) {
console.error("Error processing request:", error);
responseStream.write("Internal Server Error");
} finally {
responseStream.end();
}
}
);
};
var handle = (app, { isContentTypeBinary } = { isContentTypeBinary: void 0 }) => {
return async (event, lambdaContext) => {
const processor = getProcessor(event);
const req = processor.createRequest(event);
const requestContext = getRequestContext(event);
const res = await app.fetch(req, {
event,
requestContext,
lambdaContext
});
return processor.createResult(event, res, { isContentTypeBinary });
};
};
var EventProcessor = class {
getHeaderValue(headers, key) {
const value = headers ? Array.isArray(headers[key]) ? headers[key][0] : headers[key] : void 0;
return value;
}
getDomainName(event) {
if (event.requestContext && "domainName" in event.requestContext) {
return event.requestContext.domainName;
}
const hostFromHeaders = this.getHeaderValue(event.headers, "host");
if (hostFromHeaders) {
return hostFromHeaders;
}
const multiValueHeaders = "multiValueHeaders" in event ? event.multiValueHeaders : {};
const hostFromMultiValueHeaders = this.getHeaderValue(multiValueHeaders, "host");
return hostFromMultiValueHeaders;
}
createRequest(event) {
const queryString = this.getQueryString(event);
const domainName = this.getDomainName(event);
const path = this.getPath(event);
const urlPath = `https://${domainName}${path}`;
const url = queryString ? `${urlPath}?${queryString}` : urlPath;
const headers = this.getHeaders(event);
const method = this.getMethod(event);
const requestInit = {
headers,
method
};
if (event.body) {
requestInit.body = event.isBase64Encoded ? decodeBase64(event.body) : event.body;
}
return new Request(url, requestInit);
}
async createResult(event, res, options) {
const contentType = res.headers.get("content-type");
const isContentTypeBinary = options.isContentTypeBinary ?? defaultIsContentTypeBinary;
let isBase64Encoded = contentType && isContentTypeBinary(contentType) ? true : false;
if (!isBase64Encoded) {
const contentEncoding = res.headers.get("content-encoding");
isBase64Encoded = isContentEncodingBinary(contentEncoding);
}
const body = isBase64Encoded ? encodeBase64(await res.arrayBuffer()) : await res.text();
const result = {
body,
statusCode: res.status,
isBase64Encoded,
..."multiValueHeaders" in event && event.multiValueHeaders ? {
multiValueHeaders: {}
} : {
headers: {}
}
};
this.setCookies(event, res, result);
if (result.multiValueHeaders) {
res.headers.forEach((value, key) => {
result.multiValueHeaders[key] = [value];
});
} else {
res.headers.forEach((value, key) => {
result.headers[key] = value;
});
}
return result;
}
setCookies(event, res, result) {
if (res.headers.has("set-cookie")) {
const cookies = res.headers.getSetCookie ? res.headers.getSetCookie() : Array.from(res.headers.entries()).filter(([k]) => k === "set-cookie").map(([, v]) => v);
if (Array.isArray(cookies)) {
this.setCookiesToResult(result, cookies);
res.headers.delete("set-cookie");
}
}
}
};
var EventV2Processor = class extends EventProcessor {
getPath(event) {
return event.rawPath;
}
getMethod(event) {
return event.requestContext.http.method;
}
getQueryString(event) {
return event.rawQueryString;
}
getCookies(event, headers) {
if (Array.isArray(event.cookies)) {
headers.set("Cookie", event.cookies.join("; "));
}
}
setCookiesToResult(result, cookies) {
result.cookies = cookies;
}
getHeaders(event) {
const headers = new Headers();
this.getCookies(event, headers);
if (event.headers) {
for (const [k, v] of Object.entries(event.headers)) {
if (v) {
headers.set(k, v);
}
}
}
return headers;
}
};
var v2Processor = new EventV2Processor();
var EventV1Processor = class extends EventProcessor {
getPath(event) {
return event.path;
}
getMethod(event) {
return event.httpMethod;
}
getQueryString(event) {
if (event.multiValueQueryStringParameters) {
return Object.entries(event.multiValueQueryStringParameters || {}).filter(([, value]) => value).map(
([key, values]) => values.map((value) => `${encodeURIComponent(key)}=${encodeURIComponent(value)}`).join("&")
).join("&");
} else {
return Object.entries(event.queryStringParameters || {}).filter(([, value]) => value).map(([key, value]) => `${encodeURIComponent(key)}=${encodeURIComponent(value || "")}`).join("&");
}
}
getCookies(event, headers) {
}
getHeaders(event) {
const headers = new Headers();
this.getCookies(event, headers);
if (event.headers) {
for (const [k, v] of Object.entries(event.headers)) {
if (v) {
headers.set(k, sanitizeHeaderValue(v));
}
}
}
if (event.multiValueHeaders) {
for (const [k, values] of Object.entries(event.multiValueHeaders)) {
if (values) {
const foundK = headers.get(k);
values.forEach((v) => {
const sanitizedValue = sanitizeHeaderValue(v);
return (!foundK || !foundK.includes(sanitizedValue)) && headers.append(k, sanitizedValue);
});
}
}
}
return headers;
}
setCookiesToResult(result, cookies) {
result.multiValueHeaders = {
"set-cookie": cookies
};
}
};
var v1Processor = new EventV1Processor();
var ALBProcessor = class extends EventProcessor {
getHeaders(event) {
const headers = new Headers();
if (event.multiValueHeaders) {
for (const [key, values] of Object.entries(event.multiValueHeaders)) {
if (values && Array.isArray(values)) {
const sanitizedValue = sanitizeHeaderValue(values.join("; "));
headers.set(key, sanitizedValue);
}
}
} else {
for (const [key, value] of Object.entries(event.headers ?? {})) {
if (value) {
headers.set(key, sanitizeHeaderValue(value));
}
}
}
return headers;
}
getPath(event) {
return event.path;
}
getMethod(event) {
return event.httpMethod;
}
getQueryString(event) {
if (event.multiValueQueryStringParameters) {
return Object.entries(event.multiValueQueryStringParameters || {}).filter(([, value]) => value).map(([key, value]) => `${key}=${value.join(`&${key}=`)}`).join("&");
} else {
return Object.entries(event.queryStringParameters || {}).filter(([, value]) => value).map(([key, value]) => `${key}=${value}`).join("&");
}
}
getCookies(event, headers) {
let cookie;
if (event.multiValueHeaders) {
cookie = event.multiValueHeaders["cookie"]?.join("; ");
} else {
cookie = event.headers ? event.headers["cookie"] : void 0;
}
if (cookie) {
headers.append("Cookie", cookie);
}
}
setCookiesToResult(result, cookies) {
if (result.multiValueHeaders) {
result.multiValueHeaders["set-cookie"] = cookies;
} else {
result.headers["set-cookie"] = cookies.join(", ");
}
}
};
var albProcessor = new ALBProcessor();
var LatticeV2Processor = class extends EventProcessor {
getPath(event) {
return event.path;
}
getMethod(event) {
return event.method;
}
getQueryString() {
return "";
}
getHeaders(event) {
const headers = new Headers();
if (event.headers) {
for (const [k, values] of Object.entries(event.headers)) {
if (values) {
const foundK = headers.get(k);
values.forEach((v) => {
const sanitizedValue = sanitizeHeaderValue(v);
return (!foundK || !foundK.includes(sanitizedValue)) && headers.append(k, sanitizedValue);
});
}
}
}
return headers;
}
getCookies() {
}
setCookiesToResult(result, cookies) {
result.headers = {
...result.headers,
"set-cookie": cookies.join(", ")
};
}
};
var latticeV2Processor = new LatticeV2Processor();
var getProcessor = (event) => {
if (isProxyEventALB(event)) {
return albProcessor;
}
if (isProxyEventV2(event)) {
return v2Processor;
}
if (isLatticeEventV2(event)) {
return latticeV2Processor;
}
return v1Processor;
};
var isProxyEventALB = (event) => {
if (event.requestContext) {
return Object.hasOwn(event.requestContext, "elb");
}
return false;
};
var isProxyEventV2 = (event) => {
return Object.hasOwn(event, "rawPath");
};
var isLatticeEventV2 = (event) => {
if (event.requestContext) {
return Object.hasOwn(event.requestContext, "serviceArn");
}
return false;
};
var defaultIsContentTypeBinary = (contentType) => {
return !/^text\/(?:plain|html|css|javascript|csv)|(?:\/|\+)(?:json|xml)\s*(?:;|$)/.test(
contentType
);
};
var isContentEncodingBinary = (contentEncoding) => {
if (contentEncoding === null) {
return false;
}
return /^(gzip|deflate|compress|br)/.test(contentEncoding);
};
export {
ALBProcessor,
EventProcessor,
EventV1Processor,
EventV2Processor,
LatticeV2Processor,
defaultIsContentTypeBinary,
getProcessor,
handle,
isContentEncodingBinary,
streamHandle
};

View File

@@ -0,0 +1,7 @@
// src/adapter/aws-lambda/index.ts
import { handle, streamHandle, defaultIsContentTypeBinary } from "./handler.js";
export {
defaultIsContentTypeBinary,
handle,
streamHandle
};

View File

27
backend/node_modules/hono/dist/adapter/bun/conninfo.js generated vendored Normal file
View File

@@ -0,0 +1,27 @@
// src/adapter/bun/conninfo.ts
import { getBunServer } from "./server.js";
var getConnInfo = (c) => {
const server = getBunServer(c);
if (!server) {
throw new TypeError("env has to include the 2nd argument of fetch.");
}
if (typeof server.requestIP !== "function") {
throw new TypeError("server.requestIP is not a function.");
}
const info = server.requestIP(c.req.raw);
if (!info) {
return {
remote: {}
};
}
return {
remote: {
address: info.address,
addressType: info.family === "IPv6" || info.family === "IPv4" ? info.family : void 0,
port: info.port
}
};
};
export {
getConnInfo
};

14
backend/node_modules/hono/dist/adapter/bun/index.js generated vendored Normal file
View File

@@ -0,0 +1,14 @@
// src/adapter/bun/index.ts
import { serveStatic } from "./serve-static.js";
import { bunFileSystemModule, toSSG } from "./ssg.js";
import { createBunWebSocket, upgradeWebSocket, websocket } from "./websocket.js";
import { getConnInfo } from "./conninfo.js";
export {
bunFileSystemModule,
createBunWebSocket,
getConnInfo,
serveStatic,
toSSG,
upgradeWebSocket,
websocket
};

View File

@@ -0,0 +1,30 @@
// src/adapter/bun/serve-static.ts
import { stat } from "node:fs/promises";
import { join } from "node:path";
import { serveStatic as baseServeStatic } from "../../middleware/serve-static/index.js";
var serveStatic = (options) => {
return async function serveStatic2(c, next) {
const getContent = async (path) => {
const file = Bun.file(path);
return await file.exists() ? file : null;
};
const isDir = async (path) => {
let isDir2;
try {
const stats = await stat(path);
isDir2 = stats.isDirectory();
} catch {
}
return isDir2;
};
return baseServeStatic({
...options,
getContent,
join,
isDir
})(c, next);
};
};
export {
serveStatic
};

5
backend/node_modules/hono/dist/adapter/bun/server.js generated vendored Normal file
View File

@@ -0,0 +1,5 @@
// src/adapter/bun/server.ts
var getBunServer = (c) => "server" in c.env ? c.env.server : c.env;
export {
getBunServer
};

17
backend/node_modules/hono/dist/adapter/bun/ssg.js generated vendored Normal file
View File

@@ -0,0 +1,17 @@
// src/adapter/bun/ssg.ts
import { toSSG as baseToSSG } from "../../helper/ssg/index.js";
var { write } = Bun;
var bunFileSystemModule = {
writeFile: async (path, data) => {
await write(path, data);
},
mkdir: async () => {
}
};
var toSSG = async (app, options) => {
return baseToSSG(app, bunFileSystemModule, options);
};
export {
bunFileSystemModule,
toSSG
};

View File

@@ -0,0 +1,71 @@
// src/adapter/bun/websocket.ts
import { createWSMessageEvent, defineWebSocketHelper, WSContext } from "../../helper/websocket/index.js";
import { getBunServer } from "./server.js";
var createWSContext = (ws) => {
return new WSContext({
send: (source, options) => {
ws.send(source, options?.compress);
},
raw: ws,
readyState: ws.readyState,
url: ws.data.url,
protocol: ws.data.protocol,
close(code, reason) {
ws.close(code, reason);
}
});
};
var upgradeWebSocket = defineWebSocketHelper((c, events) => {
const server = getBunServer(c);
if (!server) {
throw new TypeError("env has to include the 2nd argument of fetch.");
}
const upgradeResult = server.upgrade(c.req.raw, {
data: {
events,
url: new URL(c.req.url),
protocol: c.req.url
}
});
if (upgradeResult) {
return new Response(null);
}
return;
});
var websocket = {
open(ws) {
const websocketListeners = ws.data.events;
if (websocketListeners.onOpen) {
websocketListeners.onOpen(new Event("open"), createWSContext(ws));
}
},
close(ws, code, reason) {
const websocketListeners = ws.data.events;
if (websocketListeners.onClose) {
websocketListeners.onClose(
new CloseEvent("close", {
code,
reason
}),
createWSContext(ws)
);
}
},
message(ws, message) {
const websocketListeners = ws.data.events;
if (websocketListeners.onMessage) {
const normalizedReceiveData = typeof message === "string" ? message : message.buffer;
websocketListeners.onMessage(createWSMessageEvent(normalizedReceiveData), createWSContext(ws));
}
}
};
var createBunWebSocket = () => ({
upgradeWebSocket,
websocket
});
export {
createBunWebSocket,
createWSContext,
upgradeWebSocket,
websocket
};

View File

@@ -0,0 +1,67 @@
// src/adapter/cloudflare-pages/handler.ts
import { Context } from "../../context.js";
import { HTTPException } from "../../http-exception.js";
var handle = (app) => (eventContext) => {
return app.fetch(
eventContext.request,
{ ...eventContext.env, eventContext },
{
waitUntil: eventContext.waitUntil,
passThroughOnException: eventContext.passThroughOnException,
props: {}
}
);
};
function handleMiddleware(middleware) {
return async (executionCtx) => {
const context = new Context(executionCtx.request, {
env: { ...executionCtx.env, eventContext: executionCtx },
executionCtx
});
let response = void 0;
try {
response = await middleware(context, async () => {
try {
context.res = await executionCtx.next();
} catch (error) {
if (error instanceof Error) {
context.error = error;
} else {
throw error;
}
}
});
} catch (error) {
if (error instanceof Error) {
context.error = error;
} else {
throw error;
}
}
if (response) {
return response;
}
if (context.error instanceof HTTPException) {
return context.error.getResponse();
}
if (context.error) {
throw context.error;
}
return context.res;
};
}
var serveStatic = () => {
return async (c) => {
const env = c.env;
const res = await env.ASSETS.fetch(c.req.raw);
if (res.status === 404) {
return c.notFound();
}
return res;
};
};
export {
handle,
handleMiddleware,
serveStatic
};

View File

@@ -0,0 +1,7 @@
// src/adapter/cloudflare-pages/index.ts
import { handle, handleMiddleware, serveStatic } from "./handler.js";
export {
handle,
handleMiddleware,
serveStatic
};

View File

@@ -0,0 +1,9 @@
// src/adapter/cloudflare-workers/conninfo.ts
var getConnInfo = (c) => ({
remote: {
address: c.req.header("cf-connecting-ip")
}
});
export {
getConnInfo
};

View File

@@ -0,0 +1,9 @@
// src/adapter/cloudflare-workers/index.ts
import { serveStatic } from "./serve-static-module.js";
import { upgradeWebSocket } from "./websocket.js";
import { getConnInfo } from "./conninfo.js";
export {
getConnInfo,
serveStatic,
upgradeWebSocket
};

View File

@@ -0,0 +1,8 @@
// src/adapter/cloudflare-workers/serve-static-module.ts
import { serveStatic } from "./serve-static.js";
var module = (options) => {
return serveStatic(options);
};
export {
module as serveStatic
};

View File

@@ -0,0 +1,22 @@
// src/adapter/cloudflare-workers/serve-static.ts
import { serveStatic as baseServeStatic } from "../../middleware/serve-static/index.js";
import { getContentFromKVAsset } from "./utils.js";
var serveStatic = (options) => {
return async function serveStatic2(c, next) {
const getContent = async (path) => {
return getContentFromKVAsset(path, {
manifest: options.manifest,
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
namespace: options.namespace ? options.namespace : c.env ? c.env.__STATIC_CONTENT : void 0
});
};
return baseServeStatic({
...options,
getContent
})(c, next);
};
};
export {
serveStatic
};

View File

@@ -0,0 +1,35 @@
// src/adapter/cloudflare-workers/utils.ts
var getContentFromKVAsset = async (path, options) => {
let ASSET_MANIFEST;
if (options && options.manifest) {
if (typeof options.manifest === "string") {
ASSET_MANIFEST = JSON.parse(options.manifest);
} else {
ASSET_MANIFEST = options.manifest;
}
} else {
if (typeof __STATIC_CONTENT_MANIFEST === "string") {
ASSET_MANIFEST = JSON.parse(__STATIC_CONTENT_MANIFEST);
} else {
ASSET_MANIFEST = __STATIC_CONTENT_MANIFEST;
}
}
let ASSET_NAMESPACE;
if (options && options.namespace) {
ASSET_NAMESPACE = options.namespace;
} else {
ASSET_NAMESPACE = __STATIC_CONTENT;
}
const key = ASSET_MANIFEST[path] || path;
if (!key) {
return null;
}
const content = await ASSET_NAMESPACE.get(key, { type: "stream" });
if (!content) {
return null;
}
return content;
};
export {
getContentFromKVAsset
};

View File

@@ -0,0 +1,41 @@
// src/adapter/cloudflare-workers/websocket.ts
import { WSContext, defineWebSocketHelper } from "../../helper/websocket/index.js";
var upgradeWebSocket = defineWebSocketHelper(async (c, events) => {
const upgradeHeader = c.req.header("Upgrade");
if (upgradeHeader !== "websocket") {
return;
}
const webSocketPair = new WebSocketPair();
const client = webSocketPair[0];
const server = webSocketPair[1];
const wsContext = new WSContext({
close: (code, reason) => server.close(code, reason),
get protocol() {
return server.protocol;
},
raw: server,
get readyState() {
return server.readyState;
},
url: server.url ? new URL(server.url) : null,
send: (source) => server.send(source)
});
if (events.onClose) {
server.addEventListener("close", (evt) => events.onClose?.(evt, wsContext));
}
if (events.onMessage) {
server.addEventListener("message", (evt) => events.onMessage?.(evt, wsContext));
}
if (events.onError) {
server.addEventListener("error", (evt) => events.onError?.(evt, wsContext));
}
server.accept?.();
return new Response(null, {
status: 101,
// @ts-expect-error - webSocket is not typed
webSocket: client
});
});
export {
upgradeWebSocket
};

View File

@@ -0,0 +1,14 @@
// src/adapter/deno/conninfo.ts
var getConnInfo = (c) => {
const { remoteAddr } = c.env;
return {
remote: {
address: remoteAddr.hostname,
port: remoteAddr.port,
transport: remoteAddr.transport
}
};
};
export {
getConnInfo
};

View File

12
backend/node_modules/hono/dist/adapter/deno/index.js generated vendored Normal file
View File

@@ -0,0 +1,12 @@
// src/adapter/deno/index.ts
import { serveStatic } from "./serve-static.js";
import { toSSG, denoFileSystemModule } from "./ssg.js";
import { upgradeWebSocket } from "./websocket.js";
import { getConnInfo } from "./conninfo.js";
export {
denoFileSystemModule,
getConnInfo,
serveStatic,
toSSG,
upgradeWebSocket
};

View File

@@ -0,0 +1,40 @@
// src/adapter/deno/serve-static.ts
import { join } from "node:path";
import { serveStatic as baseServeStatic } from "../../middleware/serve-static/index.js";
var { open, lstatSync, errors } = Deno;
var serveStatic = (options) => {
return async function serveStatic2(c, next) {
const getContent = async (path) => {
try {
if (isDir(path)) {
return null;
}
const file = await open(path);
return file.readable;
} catch (e) {
if (!(e instanceof errors.NotFound)) {
console.warn(`${e}`);
}
return null;
}
};
const isDir = (path) => {
let isDir2;
try {
const stat = lstatSync(path);
isDir2 = stat.isDirectory;
} catch {
}
return isDir2;
};
return baseServeStatic({
...options,
getContent,
join,
isDir
})(c, next);
};
};
export {
serveStatic
};

18
backend/node_modules/hono/dist/adapter/deno/ssg.js generated vendored Normal file
View File

@@ -0,0 +1,18 @@
// src/adapter/deno/ssg.ts
import { toSSG as baseToSSG } from "../../helper/ssg/index.js";
var denoFileSystemModule = {
writeFile: async (path, data) => {
const uint8Data = typeof data === "string" ? new TextEncoder().encode(data) : new Uint8Array(data);
await Deno.writeFile(path, uint8Data);
},
mkdir: async (path, options) => {
return Deno.mkdir(path, { recursive: options?.recursive ?? false });
}
};
var toSSG = async (app, options) => {
return baseToSSG(app, denoFileSystemModule, options);
};
export {
denoFileSystemModule,
toSSG
};

View File

@@ -0,0 +1,28 @@
// src/adapter/deno/websocket.ts
import { WSContext, defineWebSocketHelper } from "../../helper/websocket/index.js";
var upgradeWebSocket = defineWebSocketHelper(async (c, events, options) => {
if (c.req.header("upgrade") !== "websocket") {
return;
}
const { response, socket } = Deno.upgradeWebSocket(c.req.raw, options ?? {});
const wsContext = new WSContext({
close: (code, reason) => socket.close(code, reason),
get protocol() {
return socket.protocol;
},
raw: socket,
get readyState() {
return socket.readyState;
},
url: socket.url ? new URL(socket.url) : null,
send: (source) => socket.send(source)
});
socket.onopen = (evt) => events.onOpen?.(evt, wsContext);
socket.onmessage = (evt) => events.onMessage?.(evt, wsContext);
socket.onclose = (evt) => events.onClose?.(evt, wsContext);
socket.onerror = (evt) => events.onError?.(evt, wsContext);
return response;
});
export {
upgradeWebSocket
};

View File

@@ -0,0 +1,9 @@
// src/adapter/lambda-edge/conninfo.ts
var getConnInfo = (c) => ({
remote: {
address: c.env.event.Records[0].cf.request.clientIp
}
});
export {
getConnInfo
};

View File

@@ -0,0 +1,79 @@
// src/adapter/lambda-edge/handler.ts
import crypto from "node:crypto";
import { decodeBase64, encodeBase64 } from "../../utils/encode.js";
globalThis.crypto ??= crypto;
var convertHeaders = (headers) => {
const cfHeaders = {};
headers.forEach((value, key) => {
cfHeaders[key.toLowerCase()] = [
...cfHeaders[key.toLowerCase()] || [],
{ key: key.toLowerCase(), value }
];
});
return cfHeaders;
};
var handle = (app) => {
return async (event, context, callback) => {
const res = await app.fetch(createRequest(event), {
event,
context,
callback: (err, result) => {
callback?.(err, result);
},
config: event.Records[0].cf.config,
request: event.Records[0].cf.request,
response: event.Records[0].cf.response
});
return createResult(res);
};
};
var createResult = async (res) => {
const isBase64Encoded = isContentTypeBinary(res.headers.get("content-type") || "");
const body = isBase64Encoded ? encodeBase64(await res.arrayBuffer()) : await res.text();
return {
status: res.status.toString(),
headers: convertHeaders(res.headers),
body,
...isBase64Encoded && { bodyEncoding: "base64" }
};
};
var createRequest = (event) => {
const queryString = event.Records[0].cf.request.querystring;
const host = event.Records[0].cf.request.headers?.host?.[0]?.value || event.Records[0].cf.config.distributionDomainName;
const urlPath = `https://${host}${event.Records[0].cf.request.uri}`;
const url = queryString ? `${urlPath}?${queryString}` : urlPath;
const headers = new Headers();
Object.entries(event.Records[0].cf.request.headers).forEach(([k, v]) => {
v.forEach((header) => headers.set(k, header.value));
});
const requestBody = event.Records[0].cf.request.body;
const method = event.Records[0].cf.request.method;
const body = createBody(method, requestBody);
return new Request(url, {
headers,
method,
body
});
};
var createBody = (method, requestBody) => {
if (!requestBody || !requestBody.data) {
return void 0;
}
if (method === "GET" || method === "HEAD") {
return void 0;
}
if (requestBody.encoding === "base64") {
return decodeBase64(requestBody.data);
}
return requestBody.data;
};
var isContentTypeBinary = (contentType) => {
return !/^(text\/(plain|html|css|javascript|csv).*|application\/(.*json|.*xml).*|image\/svg\+xml.*)$/.test(
contentType
);
};
export {
createBody,
handle,
isContentTypeBinary
};

View File

@@ -0,0 +1,7 @@
// src/adapter/lambda-edge/index.ts
import { handle } from "./handler.js";
import { getConnInfo } from "./conninfo.js";
export {
getConnInfo,
handle
};

View File

@@ -0,0 +1,9 @@
// src/adapter/netlify/handler.ts
var handle = (app) => {
return (req, context) => {
return app.fetch(req, { context });
};
};
export {
handle
};

View File

@@ -0,0 +1,2 @@
// src/adapter/netlify/index.ts
export * from "./mod.js";

View File

@@ -0,0 +1,5 @@
// src/adapter/netlify/mod.ts
import { handle } from "./handler.js";
export {
handle
};

View File

@@ -0,0 +1,20 @@
// src/adapter/service-worker/handler.ts
var handle = (app, opts = {
// To use `fetch` on a Service Worker correctly, bind it to `globalThis`.
fetch: globalThis.fetch.bind(globalThis)
}) => {
return (evt) => {
evt.respondWith(
(async () => {
const res = await app.fetch(evt.request, {}, evt);
if (opts.fetch && res.status === 404) {
return await opts.fetch(evt.request);
}
return res;
})()
);
};
};
export {
handle
};

View File

@@ -0,0 +1,11 @@
// src/adapter/service-worker/index.ts
import { handle } from "./handler.js";
var fire = (app, options = {
fetch: void 0
}) => {
addEventListener("fetch", handle(app, options));
};
export {
fire,
handle
};

View File

View File

@@ -0,0 +1,10 @@
// src/adapter/vercel/conninfo.ts
var getConnInfo = (c) => ({
remote: {
// https://github.com/vercel/vercel/blob/b70bfb5fbf28a4650d4042ce68ca5c636d37cf44/packages/edge/src/edge-headers.ts#L10-L12C32
address: c.req.header("x-real-ip")
}
});
export {
getConnInfo
};

View File

@@ -0,0 +1,7 @@
// src/adapter/vercel/handler.ts
var handle = (app) => (req) => {
return app.fetch(req);
};
export {
handle
};

View File

@@ -0,0 +1,7 @@
// src/adapter/vercel/index.ts
import { handle } from "./handler.js";
import { getConnInfo } from "./conninfo.js";
export {
getConnInfo,
handle
};