mirror of
https://github.com/ajnart/homarr.git
synced 2026-02-27 08:50:56 +01:00
36 lines
1.2 KiB
TypeScript
36 lines
1.2 KiB
TypeScript
import type { NextRequest } from "next/server";
|
|
import { createTRPCClient, httpLink } from "@trpc/client";
|
|
import SuperJSON from "superjson";
|
|
|
|
import type { AppRouter } from "@homarr/api";
|
|
import { createI18nMiddleware } from "@homarr/translation/middleware";
|
|
|
|
export async function middleware(request: NextRequest) {
|
|
// fetch api does not work because window is not defined and we need to construct the url from the headers
|
|
// In next 15 we will be able to use node apis and such the db directly
|
|
const culture = await serverFetchApi.serverSettings.getCulture.query();
|
|
|
|
// We don't want to fallback to accept-language header so we clear it
|
|
request.headers.set("accept-language", "");
|
|
const next = createI18nMiddleware(culture.defaultLocale);
|
|
return next(request);
|
|
}
|
|
|
|
export const config = {
|
|
matcher: ["/((?!api|static|.*\\..*|_next|favicon.ico|robots.txt).*)"],
|
|
};
|
|
|
|
export const serverFetchApi = createTRPCClient<AppRouter>({
|
|
links: [
|
|
httpLink({
|
|
url: `http://${process.env.HOSTNAME ?? "localhost"}:3000/api/trpc`,
|
|
transformer: SuperJSON,
|
|
headers() {
|
|
const headers = new Headers();
|
|
headers.set("x-trpc-source", "server-fetch");
|
|
return headers;
|
|
},
|
|
}),
|
|
],
|
|
});
|