X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fd470d8f7838b57777492289e6e4195b6c39bd2e..badcb86fb7d0e2ab87c7dcef230072db2e2ae95e:/src/routes/routes.ts diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 831c69e58c..08e0a03d05 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -3,9 +3,17 @@ // SPDX-License-Identifier: AGPL-3.0 import { matchPath } from 'react-router'; -import { ResourceKind, RESOURCE_UUID_PATTERN, extractUuidKind } from '~/models/resource'; +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"; + +export interface FederationConfig { + localCluster: string; + remoteHostsConfig: { [key: string]: Config }; + sessions: Session[]; +} export const Routes = { ROOT: '/', @@ -28,6 +36,7 @@ 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', @@ -44,6 +53,8 @@ export const getResourceUrl = (uuid: string) => { switch (kind) { case ResourceKind.PROJECT: return getProjectUrl(uuid); + case ResourceKind.USER: + return getProjectUrl(uuid); case ResourceKind.COLLECTION: return getCollectionUrl(uuid); case ResourceKind.PROCESS: @@ -53,6 +64,27 @@ export const getResourceUrl = (uuid: string) => { } }; +export const getNavUrl = (uuid: string, config: FederationConfig) => { + const path = getResourceUrl(uuid) || ""; + const cls = uuid.substr(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 || ""); + } else { + u = new URL(config.remoteHostsConfig[cls].workbenchUrl); + u.search = "api_token=" + config.sessions.filter((s) => s.clusterId === cls)[0].token; + } + u.pathname = path; + return u.toString(); + } else { + return ""; + } +}; + + export const getProcessUrl = (uuid: string) => `/processes/${uuid}`; export const getProcessLogUrl = (uuid: string) => `/process-logs/${uuid}`; @@ -117,9 +149,18 @@ 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 });