mirror of
https://github.com/nicotsx/zerobyte.git
synced 2026-06-02 21:16:14 -04:00
* feat(auth): allow skipping forced recovery key download * refactor: move from session storage to cookie
41 lines
1.3 KiB
TypeScript
41 lines
1.3 KiB
TypeScript
import { createMiddleware } from "@tanstack/react-start";
|
|
import { redirect } from "@tanstack/react-router";
|
|
import { auth } from "~/server/lib/auth";
|
|
import { getCookie, getRequestHeaders } from "@tanstack/react-start/server";
|
|
import { authService } from "~/server/modules/auth/auth.service";
|
|
import { isAuthRoute } from "~/lib/auth-routes";
|
|
import { RECOVERY_KEY_DOWNLOAD_SKIPPED_COOKIE_NAME } from "~/lib/recovery-key-skip";
|
|
|
|
export const authMiddleware = createMiddleware().server(async ({ next, request }) => {
|
|
const headers = getRequestHeaders();
|
|
const session = await auth.api.getSession({ headers });
|
|
const pathname = new URL(request.url).pathname;
|
|
|
|
if (!session?.user?.id && !isAuthRoute(pathname)) {
|
|
const hasUsers = await authService.hasUsers();
|
|
if (!hasUsers) {
|
|
throw redirect({ to: "/onboarding" });
|
|
}
|
|
|
|
throw redirect({ to: "/login" });
|
|
}
|
|
|
|
if (session?.user?.id) {
|
|
const hasSkippedRecoveryKeyDownload = getCookie(RECOVERY_KEY_DOWNLOAD_SKIPPED_COOKIE_NAME) === session.user.id;
|
|
|
|
if (
|
|
!session.user.hasDownloadedResticPassword &&
|
|
!hasSkippedRecoveryKeyDownload &&
|
|
pathname !== "/download-recovery-key"
|
|
) {
|
|
throw redirect({ to: "/download-recovery-key" });
|
|
}
|
|
|
|
if (isAuthRoute(pathname)) {
|
|
throw redirect({ to: "/volumes" });
|
|
}
|
|
}
|
|
|
|
return next();
|
|
});
|