Files
discord.js/apps/website/src/middleware.ts
Jiralite 91f59cf183 fix(fetchVersions): Sort package versions (#10695)
* fix(fetchVersions): sort package versions

* fix(middleware): fix stable redirect
2025-01-12 19:09:46 +01:00

42 lines
1.4 KiB
TypeScript

import { sql } from '@vercel/postgres';
import { NextResponse, type NextRequest } from 'next/server';
import { PACKAGES } from './util/constants';
import { ENV } from './util/env';
async function fetchLatestVersion(packageName: string): Promise<string> {
if (ENV.IS_LOCAL_DEV) {
return 'main';
}
try {
const { rows } = await sql<{ version: string }>`with ordered_versions as (
select version from documentation where name = ${packageName} and version != 'main' order by string_to_array(version, '.')::int[] desc
)
select version from ordered_versions limit 1`;
return rows[0]?.version ?? 'main';
} catch {
return '';
}
}
export default async function middleware(request: NextRequest) {
if (request.nextUrl.pathname === '/docs') {
const latestVersion = await fetchLatestVersion('discord.js');
return NextResponse.redirect(new URL(`/docs/packages/discord.js/${latestVersion}`, request.url));
}
if (PACKAGES.some((pkg) => request.nextUrl.pathname.includes(pkg.name))) {
// eslint-disable-next-line prefer-named-capture-group
const packageName = /\/docs\/packages\/([^/]+)\/.*/.exec(request.nextUrl.pathname)?.[1] ?? 'discord.js';
const latestVersion = await fetchLatestVersion(packageName);
return NextResponse.redirect(new URL(request.nextUrl.pathname.replace('stable', latestVersion), request.url));
}
return NextResponse.next();
}
export const config = {
matcher: ['/docs', '/docs/packages/:package/stable/:member*'],
};