d3931f1855
* Readd work from old branch * Improved Login.vue * Replace watch with onResult * Server: Error improvement * FE Middleware * Update style * Delete Sso. Mixpanel events * Updates * Improved loading state * Invites. Register sso page * Middleware improvements. Session error no logout * Changes from deisgns * Swap button to LayoutMenu * Improve middleware * Remove typo * Fix errormessage * Remove edit functionality * New composable file for sso * Improved names for composables. Tidyups * Reactive errors * Reorder Login.vue * Improved Typeguard * Enum * Comments from Mike * Add error toast * Remove FormButton from LoginButtonBase * Use linkComponent prop * Move workspace select to new component * Fragmentation * Fix loading useFetch * use WorkspaceAvatar * Feature flag sso button * Update fragment name * Skip middleware during auth flow * Add rules to Workspace Selector * Reactive useWorkspacePublicSsoCheck * AuthRegisterNewsletter types * v-bind on Select * Fragment WrapperSecurity * Remove useForm from Form.vue * Reactive values in composables * Prevent infinite loading when no invite found * useWorkspaceSsoValidation maybeRef * Added comment to requireSsoEnabled * Bugfix * Update Button.vue * Fix form * Update valid model middleware * Update LoginButtonBase.vue * NewsletterConset ref * use setFieldValue * Update Login.vue * Swap mayberef to ref * Comments from PR * Changes from call with Fabs * Fix session-error bug * Fix circleci * Small fix to index
88 lines
2.5 KiB
TypeScript
88 lines
2.5 KiB
TypeScript
import { ProjectVisibility } from '~/lib/common/generated/gql/graphql'
|
|
import { WorkspaceSsoErrorCodes } from '~/lib/workspaces/helpers/types'
|
|
import { useApolloClientFromNuxt } from '~~/lib/common/composables/graphql'
|
|
import {
|
|
convertThrowIntoFetchResult,
|
|
getFirstErrorMessage
|
|
} from '~~/lib/common/helpers/graphql'
|
|
import { projectModelCheckQuery } from '~~/lib/projects/graphql/queries'
|
|
|
|
/**
|
|
* Used in project page to validate that project ID refers to a valid project and redirects to 404 if not
|
|
*/
|
|
export default defineNuxtRouteMiddleware(async (to) => {
|
|
const projectId = to.params.id as string
|
|
const modelId = to.params.modelId as string
|
|
|
|
const client = useApolloClientFromNuxt()
|
|
|
|
const { data, errors } = await client
|
|
.query({
|
|
query: projectModelCheckQuery,
|
|
variables: { projectId, modelId }
|
|
})
|
|
.catch(convertThrowIntoFetchResult)
|
|
|
|
// If project succesfully resolved, move on
|
|
if (data?.project?.model?.id) return
|
|
|
|
const isForbidden = (errors || []).find((e) => e.extensions['code'] === 'FORBIDDEN')
|
|
const isProjectNotFound = (errors || []).find(
|
|
(e) => e.extensions['code'] === 'STREAM_NOT_FOUND'
|
|
)
|
|
const isModelNotFound = (errors || []).find(
|
|
(e) => e.extensions['code'] === 'BRANCH_NOT_FOUND'
|
|
)
|
|
|
|
// Check if project exists and model is valid
|
|
if (!data?.project?.model?.id) {
|
|
if (errors?.length) {
|
|
const errMsg = getFirstErrorMessage(errors)
|
|
return abortNavigation(errMsg)
|
|
}
|
|
return
|
|
}
|
|
|
|
// If project is public or link shareable, allow access
|
|
if (
|
|
data.project.visibility === ProjectVisibility.Public ||
|
|
data.project.visibility === ProjectVisibility.Unlisted
|
|
) {
|
|
return
|
|
}
|
|
|
|
// Check for SSO session error
|
|
const ssoSessionError = (errors || []).find(
|
|
(e) => e.extensions?.['code'] === WorkspaceSsoErrorCodes.SESSION_MISSING_OR_EXPIRED
|
|
)
|
|
|
|
if (ssoSessionError) {
|
|
const workspaceSlug = ssoSessionError.message
|
|
return navigateTo(`/workspaces/${workspaceSlug}/sso/session-error`)
|
|
}
|
|
|
|
if (isForbidden) {
|
|
return abortNavigation(
|
|
createError({
|
|
statusCode: 403,
|
|
message: 'You do not have access to this project'
|
|
})
|
|
)
|
|
}
|
|
|
|
if (isProjectNotFound) {
|
|
return abortNavigation(
|
|
createError({ statusCode: 404, message: 'Project not found' })
|
|
)
|
|
}
|
|
|
|
if (isModelNotFound) {
|
|
return abortNavigation(createError({ statusCode: 404, message: 'Model not found' }))
|
|
}
|
|
|
|
if (errors?.length) {
|
|
const errMsg = getFirstErrorMessage(errors)
|
|
return abortNavigation(errMsg)
|
|
}
|
|
})
|