X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/5a7f3f56fc39ab231982435d29b8f15e819748fe..e2ea20e09a5e5a629eee78145f35a9ed443a5867:/src/services/services.ts diff --git a/src/services/services.ts b/src/services/services.ts index d2a8ce434d..6295527bfb 100644 --- a/src/services/services.ts +++ b/src/services/services.ts @@ -2,6 +2,7 @@ // // SPDX-License-Identifier: AGPL-3.0 +import Axios from "axios"; import { AuthService } from "./auth-service/auth-service"; import { GroupsService } from "./groups-service/groups-service"; import { ProjectService } from "./project-service/project-service"; @@ -9,30 +10,34 @@ 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 Axios from "axios"; 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 { UserService } from './user-service/user-service'; +import { AncestorService } from "~/services/ancestors-service/ancestors-service"; +import { ResourceKind } from "~/models/resource"; export type ServiceRepository = ReturnType; export const createServices = (config: Config) => { const apiClient = Axios.create(); - apiClient.defaults.baseURL = `${config.API_HOST}/arvados/v1`; + apiClient.defaults.baseURL = config.baseUrl; - const webdavClient = WebDAV.create(); - webdavClient.defaults.baseUrl = config.KEEP_WEB_HOST; + const webdavClient = new WebDAV(); + webdavClient.defaults.baseURL = config.keepWebServiceUrl; - const authService = new AuthService(apiClient, config.API_HOST); + const authService = new AuthService(apiClient, config.rootUrl); 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, keepService); + const collectionService = new CollectionService(apiClient, webdavClient, authService); const tagService = new TagService(linkService); const collectionFilesService = new CollectionFilesService(collectionService); + const userService = new UserService(apiClient); + const ancestorsService = new AncestorService(groupsService, userService); return { apiClient, @@ -45,7 +50,21 @@ export const createServices = (config: Config) => { favoriteService, collectionService, tagService, - collectionFilesService + collectionFilesService, + userService, + ancestorsService, }; }; +export const getResourceService = (kind?: ResourceKind) => (serviceRepository: ServiceRepository) => { + switch (kind) { + case ResourceKind.USER: + return serviceRepository.userService; + case ResourceKind.GROUP: + return serviceRepository.groupsService; + case ResourceKind.COLLECTION: + return serviceRepository.collectionService; + default: + return undefined; + } +}; \ No newline at end of file