A package to autoload your hono routes and middleware easier 🔥✨
MIT License
An auto-loader for hono to simplify the routing process, and to void boilerplate code.
for npm:
npm i hono-autoload
for bun:
bun i hono-autoload
// index.ts
import { Hono } from "hono";
import { createAutoloader, createAutoloaderMiddleware } from "hono-autoload";
import { join } from "path";
const app = new Hono();
async function runLoader() {
// NOTE: put your middleware loader before the route loader
await createAutoloaderMiddleware(app, join(__dirname, "middleware"));
await createAutoloader(app, join(__dirname, "routes"));
}
runLoader().then(() => {
console.log("Loaded all routes and middleware");
});
// ... listen for your server here
create a routes
directory inside your project and put your route modules in there.
A route module should export a path
and handler
property like this:
import type { AutoLoadRoute } from "hono-autoload/types/autoloader";
const routeModule: AutoLoadRoute = {
path: "/api",
handler: app,
};
export default routeModule; // don't forget to export default the route module
create a middleware
directory inside your project and put your middleware modules in there.
A middleware module should export a handler
and matcher
property like this:
import type { AutoLoadMiddleware } from "hono-autoload/types/autoloader";
const middlewareModule: AutoLoadMiddleware = {
handler: app,
matcher: "/api", // NOTE: not defining a matcher means the middleware works on all routes
};
export default middlewareModule; // don't forget to export default the middleware module
MIT
You can contribute to this project on GitHub. Contact me if you have any questions or suggestions. E-mail: [email protected]