X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/c57c9f8553e59144b4adeafc90ce2fa2ac946962..41f6f1e495c82fcfa79b87cf718fa2e9cd91c726:/src/routes/routes.ts diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 37c7a816..50689ec3 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -3,11 +3,11 @@ // SPDX-License-Identifier: AGPL-3.0 import { matchPath } from 'react-router'; -import { ResourceKind, RESOURCE_UUID_PATTERN, extractUuidKind, COLLECTION_PDH_REGEX } from '~/models/resource'; -import { getProjectUrl } from '~/models/project'; -import { getCollectionUrl } from '~/models/collection'; -import { Config } from '~/common/config'; -import { Session } from "~/models/session"; +import { ResourceKind, RESOURCE_UUID_PATTERN, extractUuidKind, COLLECTION_PDH_REGEX, PORTABLE_DATA_HASH_PATTERN } from 'models/resource'; +import { getProjectUrl } from 'models/project'; +import { getCollectionUrl } from 'models/collection'; +import { Config } from 'common/config'; +import { Session } from "models/session"; export interface FederationConfig { localCluster: string; @@ -19,12 +19,12 @@ export const Routes = { ROOT: '/', TOKEN: '/token', FED_LOGIN: '/fedtoken', + ADD_SESSION: '/add-session', PROJECTS: `/projects/:id(${RESOURCE_UUID_PATTERN})`, COLLECTIONS: `/collections/:id(${RESOURCE_UUID_PATTERN})`, PROCESSES: `/processes/:id(${RESOURCE_UUID_PATTERN})`, FAVORITES: '/favorites', TRASH: '/trash', - PROCESS_LOGS: `/process-logs/:id(${RESOURCE_UUID_PATTERN})`, REPOSITORIES: '/repositories', SHARED_WITH_ME: '/shared-with-me', RUN_PROCESS: '/run-process', @@ -36,15 +36,18 @@ export const Routes = { SSH_KEYS_USER: `/ssh-keys-user`, SITE_MANAGER: `/site-manager`, MY_ACCOUNT: '/my-account', + LINK_ACCOUNT: '/link_account', KEEP_SERVICES: `/keep-services`, - COMPUTE_NODES: `/nodes`, USERS: '/users', + USER_PROFILE: `/user/:id(${RESOURCE_UUID_PATTERN})`, API_CLIENT_AUTHORIZATIONS: `/api_client_authorizations`, GROUPS: '/groups', GROUP_DETAILS: `/group/:id(${RESOURCE_UUID_PATTERN})`, LINKS: '/links', PUBLIC_FAVORITES: '/public-favorites', - COLLECTIONS_CONTENT_ADDRESS: '/collections/:id', + COLLECTIONS_CONTENT_ADDRESS: `/collections/:id(${PORTABLE_DATA_HASH_PATTERN})`, + ALL_PROCESSES: '/all_processes', + NO_MATCH: '*', }; export const getResourceUrl = (uuid: string) => { @@ -65,13 +68,19 @@ export const getResourceUrl = (uuid: string) => { export const getNavUrl = (uuid: string, config: FederationConfig) => { const path = getResourceUrl(uuid) || ""; - const cls = uuid.substr(0, 5); + const cls = uuid.substring(0, 5); if (cls === config.localCluster || extractUuidKind(uuid) === ResourceKind.USER || COLLECTION_PDH_REGEX.exec(uuid)) { return path; } else if (config.remoteHostsConfig[cls]) { let u: URL; if (config.remoteHostsConfig[cls].workbench2Url) { - u = new URL(config.remoteHostsConfig[cls].workbench2Url || ""); + /* NOTE: wb2 presently doesn't support passing api_token + to arbitrary page to set credentials, only through + api-token route. So for navigation to work, user needs + to already be logged in. In the future we want to just + request the records and display in the current + workbench instance making this redirect unnecessary. */ + u = new URL(config.remoteHostsConfig[cls].workbench2Url); } else { u = new URL(config.remoteHostsConfig[cls].workbenchUrl); u.search = "api_token=" + config.sessions.filter((s) => s.clusterId === cls)[0].token; @@ -86,10 +95,10 @@ export const getNavUrl = (uuid: string, config: FederationConfig) => { export const getProcessUrl = (uuid: string) => `/processes/${uuid}`; -export const getProcessLogUrl = (uuid: string) => `/process-logs/${uuid}`; - export const getGroupUrl = (uuid: string) => `/group/${uuid}`; +export const getUserProfileUrl = (uuid: string) => `/user/${uuid}`; + export interface ResourceRouteParams { id: string; } @@ -103,6 +112,9 @@ export const matchFavoritesRoute = (route: string) => export const matchTrashRoute = (route: string) => matchPath(route, { path: Routes.TRASH }); +export const matchAllProcessesRoute = (route: string) => + matchPath(route, { path: Routes.ALL_PROCESSES }); + export const matchProjectRoute = (route: string) => matchPath(route, { path: Routes.PROJECTS }); @@ -112,9 +124,6 @@ export const matchCollectionRoute = (route: string) => export const matchProcessRoute = (route: string) => matchPath(route, { path: Routes.PROCESSES }); -export const matchProcessLogRoute = (route: string) => - matchPath(route, { path: Routes.PROCESS_LOGS }); - export const matchSharedWithMeRoute = (route: string) => matchPath(route, { path: Routes.SHARED_WITH_ME }); @@ -148,14 +157,23 @@ export const matchSiteManagerRoute = (route: string) => export const matchMyAccountRoute = (route: string) => matchPath(route, { path: Routes.MY_ACCOUNT }); +export const matchLinkAccountRoute = (route: string) => + matchPath(route, { path: Routes.LINK_ACCOUNT }); + export const matchKeepServicesRoute = (route: string) => matchPath(route, { path: Routes.KEEP_SERVICES }); +export const matchTokenRoute = (route: string) => + matchPath(route, { path: Routes.TOKEN }); + +export const matchFedTokenRoute = (route: string) => + matchPath(route, { path: Routes.FED_LOGIN }); + export const matchUsersRoute = (route: string) => matchPath(route, { path: Routes.USERS }); -export const matchComputeNodesRoute = (route: string) => - matchPath(route, { path: Routes.COMPUTE_NODES }); +export const matchUserProfileRoute = (route: string) => + matchPath(route, { path: Routes.USER_PROFILE }); export const matchApiClientAuthorizationsRoute = (route: string) => matchPath(route, { path: Routes.API_CLIENT_AUTHORIZATIONS });