X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/f17cabd0672f80de53186d42855aacba482b4ccf..795e98eac92b86652d3fe9de6657ffffc009d90e:/src/routes/routes.ts diff --git a/src/routes/routes.ts b/src/routes/routes.ts index 37c7a81673..191fe11b0c 100644 --- a/src/routes/routes.ts +++ b/src/routes/routes.ts @@ -19,6 +19,7 @@ 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})`, @@ -36,6 +37,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', @@ -45,6 +47,7 @@ export const Routes = { LINKS: '/links', PUBLIC_FAVORITES: '/public-favorites', COLLECTIONS_CONTENT_ADDRESS: '/collections/:id', + ALL_PROCESSES: '/all_processes', }; export const getResourceUrl = (uuid: string) => { @@ -71,7 +74,13 @@ export const getNavUrl = (uuid: string, config: FederationConfig) => { } 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; @@ -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 }); @@ -148,9 +160,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 });