Files
bun.sh/examples/bun/http-file.ts
2022-04-01 19:53:02 -07:00

26 lines
885 B
TypeScript

// Start a fast HTTP server from a function
Bun.serve({
fetch(req) {
const url = new URL(req.url.substring(1), "file://" + import.meta.path);
const path = Bun.resolveSync(url.pathname, import.meta.path);
return new Response(Bun.file(path));
},
// this is called when fetch() throws or rejects
error(err: Error) {
return new Response("uh oh! :(" + String(err.toString()), { status: 500 });
},
// this boolean enables the bun's default error handler
// sometime after the initial release, it will auto reload as well
development: process.env.NODE_ENV !== "production",
// note: this isn't node, but for compatibility bun supports process.env + more stuff in process
// SSL is enabled if these two are set
// certFile: './cert.pem',
// keyFile: './key.pem',
port: 8080, // number or string
hostname: "localhost", // defaults to 0.0.0.0
});