1.1.0 • Published 3 months ago

next-middleware-chain v1.1.0

Weekly downloads
-
License
SEE LICENSE IN LI...
Repository
github
Last release
3 months ago

Next Middleware

npm version

A versatile middleware package for enhancing and extending the capabilities of Next.js applications. Simplify common tasks, implement authentication, handle routing intricacies, and more with this easy-to-use middleware package.

Middleware Chain:

export default nextMiddleware([
  Starter,
  Auth,
  AnotherMiddleware
]);

Table of Contents

Installation

You can install next-middleware-chain using npm:

npm install next-middleware-chain

Usage

nextMiddleware

nextMiddleware allows you to compose an array of middleware functions, creating a versatile middleware handler.

// middleware.js
import { nextMiddleware, Starter } from "next-middleware-chain";

export default nextMiddleware([Starter, AnotherMiddleware]);

Starter

Starter is a demo middleware included in this package to showcase its usage. It demonstrates how to execute additional functions based on the current path.

Starter must have the following function signature with middleware argument and at the last return middleware to continue the middleware chain. The async function gets request and event for this middleware.

import { NextResponse } from "next/server";

function Starter(middleware) {
  return async (request, event) => {
    
    // add all functions which is required for start app
    
    return middleware(request, event); //return require for next middleware
  };
}

module.exports = Starter;

I have added a condition to redirect to home if path is /.

Here is some example usage of Starter middleware:

function Starter(middleware) {
  return async (request, event) => {
    
    // here i add a condition to redirect to home
    if (path === "/") {
      return NextResponse.redirect(new URL("/home", request.url));
    }

    return middleware(request, event);
  };
}

export default Starter;

Custom Middleware

You can create custom middleware as per your requirement. Manage you path:

- /app
- /profile
- ...
- Middleware
  - CustomMiddleware/index.js
- middleware.js
- ...
// middleware.js
import { nextMiddleware } from "next-middleware-chain";
import CustomMiddleware from "./Middleware/CustomMiddleware";

export default nextMiddleware([CustomMiddleware]);
// CustomMiddleware/index.js
export default function CustomMiddleware(middleware) {
  return async (request, event) => {
    
    // add your logic as per your requirement

    return middleware(request, event);
  };
  
}

Contribution

Feel free to contribute by opening issues or submitting pull requests. Your contributions are highly appreciated!

License

This project use self signed License by Jishan Hoshen.

SEE LICENSE IN LICENSE

Contact

Changelog

  • v1.1.0 (January 22, 2024):

    • Updated installation instructions in README.md
    • Improved changelog formatting
  • v1.0.0 (January 21, 2024):

    • Added basic and core features of middleware chain
1.1.0

3 months ago

1.0.0

3 months ago