forked from github/plane
dev: route validation on non authenticated pages (#1238)
This commit is contained in:
parent
f9cd1b1352
commit
3d5fcbd4ce
@ -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;
|
||||||
|
@ -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 {
|
||||||
|
@ -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 = () => {
|
@ -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);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
Loading…
Reference in New Issue
Block a user