express-file-router
Installation
npm install express-file-router
How to Use
You can integrate the file router by using it as a middleware like this:
app.use(
"/api",
await FileRouter(
{
ROUTES_DIR: "/routes",
debug: true,
},
__dirname
)
);
Example Express Setup
import express from "express";
import cors from "cors";
import bodyParser from "body-parser";
import { createServer } from "http";
import FileRouter from "@ij/express-file-router";
async function init(): Promise<void> {
process.on("uncaughtException", (err) => {
console.log(err);
});
const app = express();
app.use(cors());
app.use(
bodyParser.json({
limit: "50mb",
})
);
app.use(bodyParser.urlencoded({ extended: true, limit: "50mb" }));
app.use(
"/api",
await FileRouter(
{
ROUTES_DIR: "/routes",
debug: true,
},
__dirname
)
);
const server = createServer(app);
const port = 3080;
server.listen(port, () => console.log(`Server listening on port ${port}`));
}
init();
Route Setup
Example Structure
Structure Setup
├── index.ts
├── routes
├── get.ts
├── dynamic
├── param
├── [example].ts
└── [...slug].ts
└── post.ts
Middleware
You are able to add route specific middlewares by exporting an array like this:
Post Example
import { RequestHandler } from "express";
import UserSession from "@/middleware/session/user";
export const post = [
async (req, res, next) => {
console.log("headers", req.headers);
return next();
},
UserSession,
async (req, res) => {
const { userID } = req.params;
console.log("req.params", req.params);
return res.status(200).json({
message: "Success",
userID,
});
},
] as RequestHandler[];
Get Example
import { RequestHandler } from "express";
import UserSession from "@/middleware/session/user";
export const get = [
async (req, res, next) => {
console.log("headers", req.headers);
return next();
},
UserSession,
async (req, res) => {
const { userID } = req.params;
console.log("req.params", req.params);
return res.status(200).json({
message: "Success",
userID,
});
},
] as RequestHandler[];