obs-ss-plugin-webui/middleware.ts
Decobus 6467cdee3c
Some checks failed
Lint and Build / build (20) (pull_request) Failing after 20s
Lint and Build / build (22) (pull_request) Failing after 33s
Allow internal network access without API key
- Skip API key authentication for localhost and local network IPs
- Maintain security for external access while preserving usability
- Log internal network access for transparency
- Supports localhost, 127.0.0.1, and 192.168.x.x ranges

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-19 05:02:12 -04:00

42 lines
No EOL
1.3 KiB
TypeScript

import { NextRequest, NextResponse } from 'next/server';
export function middleware(request: NextRequest) {
// Only protect API routes
if (request.nextUrl.pathname.startsWith('/api/')) {
// Allow OPTIONS requests for CORS preflight
if (request.method === 'OPTIONS') {
return NextResponse.next();
}
// Check for API key in header
const apiKey = request.headers.get('x-api-key');
const validKey = process.env.API_KEY;
// If API_KEY is not set in environment, skip authentication (development mode)
if (!validKey) {
console.warn('API_KEY not set in environment variables. API endpoints are unprotected!');
return NextResponse.next();
}
// Skip authentication for localhost/internal requests (optional security)
const host = request.headers.get('host');
if (host && (host.startsWith('localhost') || host.startsWith('127.0.0.1') || host.startsWith('192.168.'))) {
console.log('Allowing internal network access without API key');
return NextResponse.next();
}
// Validate API key for external requests
if (!apiKey || apiKey !== validKey) {
return NextResponse.json(
{ error: 'Unauthorized. Valid API key required.' },
{ status: 401 }
);
}
}
return NextResponse.next();
}
export const config = {
matcher: '/api/:path*'
};