Aktueller Stand
This commit is contained in:
366
backend/node_modules/hono/dist/adapter/aws-lambda/handler.js
generated
vendored
Normal file
366
backend/node_modules/hono/dist/adapter/aws-lambda/handler.js
generated
vendored
Normal 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
|
||||
};
|
||||
7
backend/node_modules/hono/dist/adapter/aws-lambda/index.js
generated
vendored
Normal file
7
backend/node_modules/hono/dist/adapter/aws-lambda/index.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
// src/adapter/aws-lambda/index.ts
|
||||
import { handle, streamHandle, defaultIsContentTypeBinary } from "./handler.js";
|
||||
export {
|
||||
defaultIsContentTypeBinary,
|
||||
handle,
|
||||
streamHandle
|
||||
};
|
||||
0
backend/node_modules/hono/dist/adapter/aws-lambda/types.js
generated
vendored
Normal file
0
backend/node_modules/hono/dist/adapter/aws-lambda/types.js
generated
vendored
Normal file
27
backend/node_modules/hono/dist/adapter/bun/conninfo.js
generated
vendored
Normal file
27
backend/node_modules/hono/dist/adapter/bun/conninfo.js
generated
vendored
Normal 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
14
backend/node_modules/hono/dist/adapter/bun/index.js
generated
vendored
Normal 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
|
||||
};
|
||||
30
backend/node_modules/hono/dist/adapter/bun/serve-static.js
generated
vendored
Normal file
30
backend/node_modules/hono/dist/adapter/bun/serve-static.js
generated
vendored
Normal 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
5
backend/node_modules/hono/dist/adapter/bun/server.js
generated
vendored
Normal 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
17
backend/node_modules/hono/dist/adapter/bun/ssg.js
generated
vendored
Normal 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
|
||||
};
|
||||
71
backend/node_modules/hono/dist/adapter/bun/websocket.js
generated
vendored
Normal file
71
backend/node_modules/hono/dist/adapter/bun/websocket.js
generated
vendored
Normal 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
|
||||
};
|
||||
67
backend/node_modules/hono/dist/adapter/cloudflare-pages/handler.js
generated
vendored
Normal file
67
backend/node_modules/hono/dist/adapter/cloudflare-pages/handler.js
generated
vendored
Normal 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
|
||||
};
|
||||
7
backend/node_modules/hono/dist/adapter/cloudflare-pages/index.js
generated
vendored
Normal file
7
backend/node_modules/hono/dist/adapter/cloudflare-pages/index.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
// src/adapter/cloudflare-pages/index.ts
|
||||
import { handle, handleMiddleware, serveStatic } from "./handler.js";
|
||||
export {
|
||||
handle,
|
||||
handleMiddleware,
|
||||
serveStatic
|
||||
};
|
||||
9
backend/node_modules/hono/dist/adapter/cloudflare-workers/conninfo.js
generated
vendored
Normal file
9
backend/node_modules/hono/dist/adapter/cloudflare-workers/conninfo.js
generated
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
// src/adapter/cloudflare-workers/conninfo.ts
|
||||
var getConnInfo = (c) => ({
|
||||
remote: {
|
||||
address: c.req.header("cf-connecting-ip")
|
||||
}
|
||||
});
|
||||
export {
|
||||
getConnInfo
|
||||
};
|
||||
9
backend/node_modules/hono/dist/adapter/cloudflare-workers/index.js
generated
vendored
Normal file
9
backend/node_modules/hono/dist/adapter/cloudflare-workers/index.js
generated
vendored
Normal 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
|
||||
};
|
||||
8
backend/node_modules/hono/dist/adapter/cloudflare-workers/serve-static-module.js
generated
vendored
Normal file
8
backend/node_modules/hono/dist/adapter/cloudflare-workers/serve-static-module.js
generated
vendored
Normal 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
|
||||
};
|
||||
22
backend/node_modules/hono/dist/adapter/cloudflare-workers/serve-static.js
generated
vendored
Normal file
22
backend/node_modules/hono/dist/adapter/cloudflare-workers/serve-static.js
generated
vendored
Normal 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
|
||||
};
|
||||
35
backend/node_modules/hono/dist/adapter/cloudflare-workers/utils.js
generated
vendored
Normal file
35
backend/node_modules/hono/dist/adapter/cloudflare-workers/utils.js
generated
vendored
Normal 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
|
||||
};
|
||||
41
backend/node_modules/hono/dist/adapter/cloudflare-workers/websocket.js
generated
vendored
Normal file
41
backend/node_modules/hono/dist/adapter/cloudflare-workers/websocket.js
generated
vendored
Normal 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
|
||||
};
|
||||
14
backend/node_modules/hono/dist/adapter/deno/conninfo.js
generated
vendored
Normal file
14
backend/node_modules/hono/dist/adapter/deno/conninfo.js
generated
vendored
Normal 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
|
||||
};
|
||||
0
backend/node_modules/hono/dist/adapter/deno/deno.d.js
generated
vendored
Normal file
0
backend/node_modules/hono/dist/adapter/deno/deno.d.js
generated
vendored
Normal file
12
backend/node_modules/hono/dist/adapter/deno/index.js
generated
vendored
Normal file
12
backend/node_modules/hono/dist/adapter/deno/index.js
generated
vendored
Normal 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
|
||||
};
|
||||
40
backend/node_modules/hono/dist/adapter/deno/serve-static.js
generated
vendored
Normal file
40
backend/node_modules/hono/dist/adapter/deno/serve-static.js
generated
vendored
Normal 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
18
backend/node_modules/hono/dist/adapter/deno/ssg.js
generated
vendored
Normal 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
|
||||
};
|
||||
28
backend/node_modules/hono/dist/adapter/deno/websocket.js
generated
vendored
Normal file
28
backend/node_modules/hono/dist/adapter/deno/websocket.js
generated
vendored
Normal 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
|
||||
};
|
||||
9
backend/node_modules/hono/dist/adapter/lambda-edge/conninfo.js
generated
vendored
Normal file
9
backend/node_modules/hono/dist/adapter/lambda-edge/conninfo.js
generated
vendored
Normal 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
|
||||
};
|
||||
79
backend/node_modules/hono/dist/adapter/lambda-edge/handler.js
generated
vendored
Normal file
79
backend/node_modules/hono/dist/adapter/lambda-edge/handler.js
generated
vendored
Normal 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
|
||||
};
|
||||
7
backend/node_modules/hono/dist/adapter/lambda-edge/index.js
generated
vendored
Normal file
7
backend/node_modules/hono/dist/adapter/lambda-edge/index.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
// src/adapter/lambda-edge/index.ts
|
||||
import { handle } from "./handler.js";
|
||||
import { getConnInfo } from "./conninfo.js";
|
||||
export {
|
||||
getConnInfo,
|
||||
handle
|
||||
};
|
||||
9
backend/node_modules/hono/dist/adapter/netlify/handler.js
generated
vendored
Normal file
9
backend/node_modules/hono/dist/adapter/netlify/handler.js
generated
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
// src/adapter/netlify/handler.ts
|
||||
var handle = (app) => {
|
||||
return (req, context) => {
|
||||
return app.fetch(req, { context });
|
||||
};
|
||||
};
|
||||
export {
|
||||
handle
|
||||
};
|
||||
2
backend/node_modules/hono/dist/adapter/netlify/index.js
generated
vendored
Normal file
2
backend/node_modules/hono/dist/adapter/netlify/index.js
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
// src/adapter/netlify/index.ts
|
||||
export * from "./mod.js";
|
||||
5
backend/node_modules/hono/dist/adapter/netlify/mod.js
generated
vendored
Normal file
5
backend/node_modules/hono/dist/adapter/netlify/mod.js
generated
vendored
Normal file
@@ -0,0 +1,5 @@
|
||||
// src/adapter/netlify/mod.ts
|
||||
import { handle } from "./handler.js";
|
||||
export {
|
||||
handle
|
||||
};
|
||||
20
backend/node_modules/hono/dist/adapter/service-worker/handler.js
generated
vendored
Normal file
20
backend/node_modules/hono/dist/adapter/service-worker/handler.js
generated
vendored
Normal 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
|
||||
};
|
||||
11
backend/node_modules/hono/dist/adapter/service-worker/index.js
generated
vendored
Normal file
11
backend/node_modules/hono/dist/adapter/service-worker/index.js
generated
vendored
Normal 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
|
||||
};
|
||||
0
backend/node_modules/hono/dist/adapter/service-worker/types.js
generated
vendored
Normal file
0
backend/node_modules/hono/dist/adapter/service-worker/types.js
generated
vendored
Normal file
10
backend/node_modules/hono/dist/adapter/vercel/conninfo.js
generated
vendored
Normal file
10
backend/node_modules/hono/dist/adapter/vercel/conninfo.js
generated
vendored
Normal 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
|
||||
};
|
||||
7
backend/node_modules/hono/dist/adapter/vercel/handler.js
generated
vendored
Normal file
7
backend/node_modules/hono/dist/adapter/vercel/handler.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
// src/adapter/vercel/handler.ts
|
||||
var handle = (app) => (req) => {
|
||||
return app.fetch(req);
|
||||
};
|
||||
export {
|
||||
handle
|
||||
};
|
||||
7
backend/node_modules/hono/dist/adapter/vercel/index.js
generated
vendored
Normal file
7
backend/node_modules/hono/dist/adapter/vercel/index.js
generated
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
// src/adapter/vercel/index.ts
|
||||
import { handle } from "./handler.js";
|
||||
import { getConnInfo } from "./conninfo.js";
|
||||
export {
|
||||
getConnInfo,
|
||||
handle
|
||||
};
|
||||
Reference in New Issue
Block a user