-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmiddleware.ts
39 lines (32 loc) · 1.15 KB
/
middleware.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import { singleParam } from "lib/misc";
import type { NextRequest } from "next/server";
import { NextResponse } from "next/server";
const HARDCODED_USERNAME = "admin";
// Very simple HTTP Basic auth with a hardcoded username.
export function middleware(req: NextRequest) {
const secret = process.env.PASSWORD;
if (!secret) return NextResponse.next();
const ip =
singleParam(req.headers.get("x-forwarded-for")).split(",").pop()?.trim() ||
req.ip;
try {
const auth = req.headers.get("authorization") || "";
// Buffer is not available in the Next Edge environment, so use atob
// https://edge-runtime.vercel.app/features/available-apis
const [username, password] = atob(auth.substring(5)).split(":");
if (username !== HARDCODED_USERNAME || password !== secret)
throw new Error("Invalid credentials");
return NextResponse.next();
} catch (err) {
console.log(`Authentication error: ${err} from ${ip}`);
return new NextResponse(null, {
status: 401,
headers: {
"WWW-Authenticate": 'Basic realm="Dashboard"',
},
});
}
}
export const config = {
matcher: ["/", "/api/stats/:path*"],
};