X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/c0b733ed434c3a89ea3fdfb840dc1d8d6c302d8c..5e11adf6c0acffbd9e78f6a0a1fe39bcecf75047:/src/services/services.ts diff --git a/src/services/services.ts b/src/services/services.ts index 7ad2ff7d..d3e82f93 100644 --- a/src/services/services.ts +++ b/src/services/services.ts @@ -2,13 +2,63 @@ // // SPDX-License-Identifier: AGPL-3.0 -import AuthService from "./auth-service/auth-service"; -import ProjectService from "./project-service/project-service"; -import CollectionService from "./collection-service/collection-service"; -import GroupsService from "./groups-service/groups-service"; -import { serverApi } from "../common/api/server-api"; - -export const authService = new AuthService(); -export const projectService = new ProjectService(); -export const collectionService = new CollectionService(); -export const groupsService = new GroupsService(serverApi); +import Axios, { AxiosInstance } from "axios"; +import { AuthService } from "./auth-service/auth-service"; +import { GroupsService } from "./groups-service/groups-service"; +import { ProjectService } from "./project-service/project-service"; +import { LinkService } from "./link-service/link-service"; +import { FavoriteService } from "./favorite-service/favorite-service"; +import { CollectionService } from "./collection-service/collection-service"; +import { TagService } from "./tag-service/tag-service"; +import { CollectionFilesService } from "./collection-files-service/collection-files-service"; +import { KeepService } from "./keep-service/keep-service"; +import { WebDAV } from "../common/webdav"; +import { Config } from "../common/config"; +import { ResourceKind, Resource } from '~/models/resource'; +import { CommonResourceService } from '../common/api/common-resource-service'; + +export type ServiceRepository = ReturnType; + +export const createServices = (config: Config) => { + const apiClient = Axios.create(); + apiClient.defaults.baseURL = `${config.apiHost}/arvados/v1`; + + const webdavClient = new WebDAV(); + webdavClient.defaults.baseURL = config.keepWebHost; + + const authService = new AuthService(apiClient, config.apiHost); + const keepService = new KeepService(apiClient); + const groupsService = new GroupsService(apiClient); + const projectService = new ProjectService(apiClient); + const linkService = new LinkService(apiClient); + const favoriteService = new FavoriteService(linkService, groupsService); + const collectionService = new CollectionService(apiClient, webdavClient, authService); + const tagService = new TagService(linkService); + const collectionFilesService = new CollectionFilesService(collectionService); + + return { + apiClient, + webdavClient, + authService, + keepService, + groupsService, + projectService, + linkService, + favoriteService, + collectionService, + tagService, + collectionFilesService + }; +}; + +export const getResourceService = (resourceKind: ResourceKind, serviceRepository: ServiceRepository): undefined | CommonResourceService => { + switch (resourceKind) { + case ResourceKind.PROJECT: + return serviceRepository.projectService; + case ResourceKind.COLLECTION: + return serviceRepository.collectionService; + default: + return undefined; + } +}; +