🚀 Launch Week Day 5:Introducing Immutable Scans.Learn More
Socket
Book a DemoInstallSign in
Socket

@rezamirzapour/nextjs-middleware-runner

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@rezamirzapour/nextjs-middleware-runner

A flexible and powerful middleware runner for Next.js with priority support, pattern matching, and error handling

latest
Source
npmnpm
Version
1.0.0
Version published
Maintainers
1
Created
Source

# 🚀 Next.js Middleware Runner

A flexible and powerful middleware runner for Next.js with priority support, advanced pattern matching, and comprehensive error handling.

## ✨ Features

- 🎯 **Priority-based execution** - Control middleware execution order

- 🔍 **Advanced pattern matching** - Support for wildcards, dynamic routes, and negative patterns

- ⚡ **Type-safe** - Full TypeScript support

- 🛡️ **Error handling** - Built-in error handling with skip options

- 🐛 **Debug mode** - Detailed logging for development

- 🎨 **Fluent API** - Chain-able methods for easy configuration

- 📦 **Zero dependencies** - Only requires Next.js as peer dependency

## 📦 Installation


npm install @remirzapour/nextjs-middleware-runner

\# or

yarn add @remirzapour/nextjs-middleware-runner

\# or

pnpm add @remirzapour/nextjs-middleware-runner

## 🚀 Quick Start


// middleware.ts or proxy.ts

import { MiddlewareRunner, createMiddleware } from '@remirzapour/nextjs-middleware-runner';

import type { NextRequest } from 'next/server';



// Create your middlewares

const loggingMiddleware = createMiddleware(

  async ({ request, response }) => {

    console.log(`${request.method} ${request.nextUrl.pathname}`);

    return { shouldContinue: true, response };

  },

  { name: 'logger', priority: 100 }

);



const authMiddleware = createMiddleware(

  async ({ request, response }) => {

    const token = request.cookies.get('auth-token');

    

    if (!token) {

      return {

        shouldContinue: false,

        response: NextResponse.redirect(new URL('/login', request.url)),

      };

    }

    

    return { shouldContinue: true, response };

  },

  {

    name: 'auth',

    matcher: \['/dashboard/\*', '/api/protected/\*'],

    priority: 90,

  }

);



// Setup runner

const runner = new MiddlewareRunner(loggingMiddleware, authMiddleware)

  .setDebugMode(process.env.NODE\_ENV === 'development');



export async function middleware(request: NextRequest) {

  return runner.run(request);

}



export const config = {

  matcher: \['/((?!\_next/static|\_next/image|favicon.ico).\*)'],

};

## 📖 API Documentation

### MiddlewareRunner

#### Constructor


new MiddlewareRunner(...middlewares: Middleware\[])

#### Methods

- **addMiddleware(...middlewares: Middleware\[])** - Add middlewares

- **setDebugMode(enabled: boolean)** - Enable/disable debug logging

- **removeMiddleware(name: string)** - Remove middleware by name

- **clear()** - Remove all middlewares

- **getMiddlewares()** - Get list of middlewares

- **run(request: NextRequest)** - Execute middleware chain

### createMiddleware


createMiddleware(

&nbsp; execute: (context: MiddlewareContext) => Promise<MiddlewareResult> | MiddlewareResult,

&nbsp; config?: MiddlewareConfig

): Middleware

### Pattern Matching

Supports various pattern types:

- **Exact match**: /api/users

- **Prefix match**: /api/\*

- **Dynamic routes**: /api/:id or /user/\[id]

- **Negative patterns**: !\\/api/public/\*

- **Function matcher**: (path) => path.startsWith('/api')

## 📚 Examples

See the [examples](./examples) directory for more use cases:

- Authentication

- Rate Limiting

- CORS

- Logging

- Request/Response modification

## 🤝 Contributing

Contributions are welcome! Please read our [Contributing Guide](CONTRIBUTING.md).

## 📄 License

MIT © [Your Name]

## 🔗 Links

- [GitHub Repository](https://github.com/remirzapour/nextjs-middleware-runner)

- [NPM Package](https://www.npmjs.com/package/@remirzapour/nextjs-middleware-runner)

- [Documentation](https://github.com/remirzapour/nextjs-middleware-runner/wiki)

Keywords

nextjs

FAQs

Package last updated on 09 Dec 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts