diff --git a/editor.planx.uk/src/lib/graphql.ts b/editor.planx.uk/src/lib/graphql.ts index fde65bbd03..88220960f5 100644 --- a/editor.planx.uk/src/lib/graphql.ts +++ b/editor.planx.uk/src/lib/graphql.ts @@ -4,12 +4,15 @@ import { DefaultContext, from, InMemoryCache, + Operation, } from "@apollo/client"; import { onError } from "@apollo/client/link/error"; import { RetryLink } from "@apollo/client/link/retry"; +import { logger } from "airbrake"; import { toast } from "react-toastify"; import { getCookie } from "./cookie"; +import { useStore } from "pages/FlowEditor/lib/store"; const toastId = "error_toast"; @@ -45,14 +48,38 @@ const publicHttpLink = createHttpLink({ headers: { "x-hasura-role": "public" }, }); -const errorLink = onError(({ graphQLErrors }) => { +const handlePermissionErrors = (message: string, operation: Operation) => { + const permissionErrors = [ + // Constraints error - user does not have access to this resource + /permission has failed/gi, + // Query or mutation error - user does not have access to this query + /not found in type/gi, + ]; + + const isPermissionError = permissionErrors.some((re) => re.test(message)); + + if (isPermissionError) { + const user = useStore.getState().getUser(); + const team = useStore.getState().teamName; + logger.notify(`[Permission error]: User ${user?.id} cannot execute ${operation.operationName} for ${team}`); + + toast.error("Permission error", { + toastId: "permission_error", + hideProgressBar: true, + progress: undefined, + }); + } +} + +const errorLink = onError(({ graphQLErrors, operation }) => { if (graphQLErrors) { // GraphQL errors are not retried - graphQLErrors.map(({ message, locations, path }) => + graphQLErrors.forEach(({ message, locations, path }) => { console.error( `[GraphQL error]: Message: ${message}, Location: ${locations}, Path: ${path}`, - ), - ); + ) + handlePermissionErrors(message, operation) + }); } else { toast.error("Network error, attempting to reconnect…", { toastId, diff --git a/editor.planx.uk/src/pages/Team.tsx b/editor.planx.uk/src/pages/Team.tsx index c5fbbe7e47..8fc82b04cc 100644 --- a/editor.planx.uk/src/pages/Team.tsx +++ b/editor.planx.uk/src/pages/Team.tsx @@ -330,7 +330,7 @@ const Team: React.FC = () => { }} /> ))} - {useStore.getState().canUserEditTeam(slug) && ( + {/* {useStore.getState().canUserEditTeam(slug) && ( */} { const newFlowName = prompt("Service name"); @@ -347,7 +347,7 @@ const Team: React.FC = () => { > Add a new service - )} + {/* )} */} )}