A Next.js middleware for proxying requests to external services with advanced configuration options.
npm install @foomo/next-proxy-middleware
Import the middleware and configuration type in your Next.js middleware file:
import {
createProxyMiddleware,
DevProxyConfig,
} from "@foomo/next-proxy-middleware";
The DevProxyConfig
type defines the following options:
export type DevProxyConfig = {
debug?: boolean; // Enable debug logging
disable?: boolean; // Disable the proxy entirely
remoteUrl: string | ((request: NextRequest) => string); // Remote URL or function to generate it
allowResponseCompression?: boolean; // Allow response compression (default: false)
overrideHostHeader?: boolean; // Override host header (default: true)
overrideCookieDomain?: false | string; // Domain to use for cookies or false to disable
basicAuth?: {
authHeader: string; // Authorization header value
};
cfTokenAuth?: {
clientId: string;
clientSecret: string;
};
};
Here's an example of how to use the middleware in your middleware.ts
file:
import {
createProxyMiddleware,
DevProxyConfig,
} from "@foomo/next-proxy-middleware";
const proxyConfig: DevProxyConfig = {
remoteUrl: "https://api.example.com",
basicAuth: {
authHeader: "Basic abc123==",
},
overrideCookieDomain: "example.com",
};
export function middleware(request: NextRequest) {
if (request.nextUrl.pathname.match("^/(api|webhooks)/")) {
return proxyMiddleware(request);
}
return request;
}
export const config = {
matcher: ["/api/:path*"],
};
const proxyMiddleware = createProxyMiddleware(proxyConfig);
Contributions are welcome! Please fork the repository and submit a pull request.
Distributed under MIT License, please see license file within the code for more details.