dev: route validation on non authenticated pages (#1238)

This commit is contained in:
guru_sainath 2023-06-07 13:47:56 +05:30 committed by GitHub
parent f9cd1b1352
commit 3d5fcbd4ce
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 38 additions and 21 deletions

View File

@ -5,7 +5,7 @@ import useSWR from "swr";
// components // components
import ToastAlert from "components/toast-alert"; import ToastAlert from "components/toast-alert";
// hooks // hooks
import useUser from "hooks/use-user"; import useUserAuth from "hooks/use-user-auth";
// services // services
import projectService from "services/project.service"; import projectService from "services/project.service";
// fetch-keys // fetch-keys
@ -65,7 +65,7 @@ export const reducer: ReducerFunctionType = (state, action) => {
export const ThemeContextProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => { export const ThemeContextProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {
const [state, dispatch] = useReducer(reducer, initialState); const [state, dispatch] = useReducer(reducer, initialState);
const { user } = useUser(); const { user } = useUserAuth(null);
const router = useRouter(); const router = useRouter();
const { workspaceSlug, projectId } = router.query; const { workspaceSlug, projectId } = router.query;

View File

@ -22,7 +22,9 @@ const useUserAuth = (routeAuth: "sign-in" | "onboarding" | "admin" | null = "adm
isLoading, isLoading,
error, error,
mutate, mutate,
} = useSWR<ICurrentUserResponse>(CURRENT_USER, () => userService.currentUser()); } = useSWR<ICurrentUserResponse>(CURRENT_USER, () => userService.currentUser(), {
refreshInterval: 0,
});
useEffect(() => { useEffect(() => {
const handleWorkSpaceRedirection = async () => { const handleWorkSpaceRedirection = async () => {
@ -80,6 +82,10 @@ const useUserAuth = (routeAuth: "sign-in" | "onboarding" | "admin" | null = "adm
} }
}; };
if (routeAuth === null) {
setIsRouteAccess(() => false);
return;
} else {
if (!isLoading) { if (!isLoading) {
setIsRouteAccess(() => true); setIsRouteAccess(() => true);
if (user) { if (user) {
@ -95,6 +101,7 @@ const useUserAuth = (routeAuth: "sign-in" | "onboarding" | "admin" | null = "adm
} }
} }
} }
}
}, [user, isLoading, routeAuth, router, next_url]); }, [user, isLoading, routeAuth, router, next_url]);
return { return {

View File

@ -30,12 +30,12 @@ import { WORKSPACE_INVITATION } from "constants/fetch-keys";
const WorkspaceInvitation: NextPage = () => { const WorkspaceInvitation: NextPage = () => {
const router = useRouter(); const router = useRouter();
const { invitationId, email } = router.query; const { invitation_id, email } = router.query;
const { user } = useUser(); const { user } = useUser();
const { data: invitationDetail, error } = useSWR(invitationId && WORKSPACE_INVITATION, () => const { data: invitationDetail, error } = useSWR(invitation_id && WORKSPACE_INVITATION, () =>
invitationId ? workspaceService.getWorkspaceInvitation(invitationId as string) : null invitation_id ? workspaceService.getWorkspaceInvitation(invitation_id as string) : null
); );
const handleAccept = () => { const handleAccept = () => {

View File

@ -2,16 +2,26 @@ import axios from "axios";
import Cookies from "js-cookie"; import Cookies from "js-cookie";
const unAuthorizedStatus = [401]; const unAuthorizedStatus = [401];
const nonValidatedRoutes = ["/", "/reset-password", "/workspace-member-invitation"];
const validateRouteCheck = (route: string): boolean => {
let validationToggle = false;
const routeCheck = nonValidatedRoutes.find((_route: string) => _route === route);
if (routeCheck) validationToggle = true;
return validationToggle;
};
axios.interceptors.response.use( axios.interceptors.response.use(
(response) => response, (response) => response,
(error) => { (error) => {
const { status }: any = error.response; const { status }: any = error.response;
if (!validateRouteCheck(window.location.pathname)) {
if (unAuthorizedStatus.includes(status)) { if (unAuthorizedStatus.includes(status)) {
Cookies.remove("refreshToken", { path: "/" }); Cookies.remove("refreshToken", { path: "/" });
Cookies.remove("accessToken", { path: "/" }); Cookies.remove("accessToken", { path: "/" });
if (window.location.pathname != "/")
window.location.href = `/?next_url=${window.location.pathname}`; window.location.href = `/?next_url=${window.location.pathname}`;
} }
}
return Promise.reject(error); return Promise.reject(error);
} }
); );